/* ==========================================================================
   CIVIDEVS — Section-Specific Styles
   Hero, Services, Why Us, Projects, Testimonials, Process, FAQ, Contact
   ========================================================================== */

/* --------------------------------------------------------------------------
   Hero Section — Asymmetric, Impact-First
   -------------------------------------------------------------------------- */
.hero {
	min-height: 100dvh;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	padding: var(--space-3xl) var(--gutter);
	overflow: hidden;
}

.hero__container {
	width: 100%;
	max-width: var(--container-max);
	margin-inline: auto;
	text-align: center;
}

.hero__content {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-md);
}

.hero__label {
	font-family: var(--font-heading);
	font-size: var(--text-small);
	font-weight: 500;
	letter-spacing: var(--tracking-widest);
	text-transform: uppercase;
	color: var(--color-text-muted);
	display: block;
	margin-bottom: var(--space-sm);
}

.hero__title {
	font-size: var(--text-hero);
	font-weight: 800;
	letter-spacing: var(--tracking-tight);
	line-height: 0.9;
	margin: 0;
	text-transform: uppercase;
	overflow-wrap: break-word;
	word-wrap: break-word;
	hyphens: auto;
}

.hero__title-line {
	display: block;
}

.hero__title-line--heavy {
	font-weight: 900;
	font-style: italic;
	letter-spacing: -0.04em;
}

.hero__divider {
	width: 80px;
	height: 1px;
	background: var(--color-border);
	margin: var(--space-lg) auto;
	opacity: 0;
}

.hero__expertise {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-xs);
}

.hero__expertise-statement {
	font-family: var(--font-heading);
	font-size: var(--text-h4);
	font-weight: 400;
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
	color: var(--color-text-muted);
}

.hero__expertise-qualifier {
	font-family: var(--font-body);
	font-size: var(--text-body);
	font-weight: 300;
	color: var(--color-text-subtle);
	font-style: italic;
}

.hero__cta {
	margin-top: var(--space-lg);
	padding: var(--cta-padding-y) var(--cta-padding-x);
	font-size: var(--text-body);
	gap: var(--space-sm);
	opacity: 0;
}

.hero__cta svg {
	transition: transform var(--duration-normal) var(--ease-out);
}

.hero__cta:hover svg {
	transform: translateX(4px);
}

.hero__scroll-indicator {
	position: absolute;
	bottom: var(--space-xl);
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-sm);
}

.hero__scroll-line {
	width: 1px;
	height: 60px;
	background: linear-gradient(to bottom, var(--color-text), transparent);
	animation: scrollPulse 2s ease-in-out infinite;
}

.hero__scroll-text {
	font-family: var(--font-heading);
	font-size: var(--text-micro);
	font-weight: 500;
	letter-spacing: var(--tracking-widest);
	text-transform: uppercase;
	color: var(--color-text-subtle);
}

@keyframes scrollPulse {
	0%,
	100% {
		opacity: 0.3;
		transform: scaleY(0.8);
	}
	50% {
		opacity: 1;
		transform: scaleY(1);
	}
}

/* Light theme animation override */
[data-theme='light'] .hero__scroll-line {
	animation: scrollPulseLight 2s ease-in-out infinite;
}

@keyframes scrollPulseLight {
	0%,
	100% {
		opacity: 0.25;
		transform: scaleY(0.8);
	}
	50% {
		opacity: 0.55;
		transform: scaleY(1);
	}
}

/* Hero mobile adjustments */
@media (max-width: 768px) {
	.hero {
		min-height: auto;
		padding-top: calc(var(--space-3xl) + 4rem);
		padding-bottom: calc(var(--space-3xl) + 80px); /* Clear mobile dock */
	}

	.hero__content {
		padding-bottom: 5rem;
	}

	.hero__title {
		font-size: clamp(2.6rem, 14vw, 5rem);
		line-height: 0.96;
		max-width: 7ch;
	}

	.hero__scroll-indicator {
		bottom: 90px; /* Above mobile dock */
	}
}

@media (max-width: 480px) {
	.hero__title {
		font-size: clamp(2.2rem, 12vw, 3.6rem);
		line-height: 1;
		max-width: 6.5ch;
	}

	.hero__expertise-statement {
		letter-spacing: var(--tracking-wide);
	}

	.hero__scroll-indicator {
		bottom: 84px;
	}
}

/* --------------------------------------------------------------------------
   Marquee — Continuous Credibility Strip
   -------------------------------------------------------------------------- */
.marquee {
	padding: var(--space-lg) 0;
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
	overflow: hidden;
	position: relative;
}

.marquee__track {
	display: flex;
	width: max-content;
	animation: marqueeScroll 30s linear infinite;
}

.marquee:hover .marquee__track {
	animation-play-state: paused;
}

.marquee__content {
	display: flex;
	align-items: center;
	gap: var(--space-xl);
	padding-right: var(--space-xl);
	flex-shrink: 0;
}

.marquee__item {
	font-family: var(--font-heading);
	font-size: var(--text-small);
	font-weight: 500;
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
	color: var(--color-text-muted);
	white-space: nowrap;
}

.marquee__separator {
	color: var(--color-text-subtle);
	font-size: var(--text-micro);
}

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

@media (prefers-reduced-motion: reduce) {
	.marquee__track {
		animation: none;
	}
}

@media (max-width: 480px) {
	.marquee__content {
		gap: var(--space-lg);
		padding-right: var(--space-lg);
	}

	.marquee__item {
		font-size: 0.7rem;
	}
}

/* --------------------------------------------------------------------------
   Services Section — Interactive Value Pillars (Accordion)
   -------------------------------------------------------------------------- */
.services {
	padding: var(--space-3xl) var(--gutter);
}

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

.services__intro {
	font-family: var(--font-body);
	font-size: var(--text-body);
	color: var(--color-text-muted);
	line-height: var(--leading-relaxed);
	max-width: 55ch;
	margin-bottom: var(--space-2xl);
}

.services__list {
	display: flex;
	flex-direction: column;
}

.service-pillar {
	border-bottom: 1px solid var(--color-border);
	position: relative;
	overflow: hidden;
}

.service-pillar:first-child {
	border-top: 1px solid var(--color-border);
}

.service-pillar__header {
	display: grid;
	grid-template-columns: 40px 1fr auto 30px;
	align-items: center;
	gap: var(--space-md);
	padding: var(--space-lg) 0;
	cursor: pointer;
	transition: padding-left var(--duration-normal) var(--ease-out);
}

.service-pillar__header:hover {
	padding-left: var(--space-sm);
}

.service-pillar__num {
	font-family: var(--font-heading);
	font-size: var(--text-micro);
	font-weight: 500;
	letter-spacing: var(--tracking-widest);
	color: var(--color-text-subtle);
}

.service-pillar__title {
	font-size: var(--text-h3);
	font-weight: 600;
	line-height: var(--leading-snug);
	margin: 0;
}

@media (max-width: 480px) {
	.service-pillar__header {
		grid-template-columns: 30px 1fr 30px;
		gap: var(--space-sm);
	}

	.service-pillar__result {
		grid-column: 2;
		justify-self: start;
		font-size: 10px;
		margin-top: -4px;
	}
}

.service-pillar__result {
	font-family: var(--font-heading);
	font-size: var(--text-micro);
	font-weight: 500;
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
	color: var(--color-text-muted);
	padding: var(--space-xs) var(--space-sm);
	border: 1px solid var(--color-border);
	white-space: nowrap;
}

.service-pillar__toggle {
	font-family: var(--font-heading);
	font-size: var(--text-h4);
	font-weight: 300;
	color: var(--color-text-muted);
	transition: transform var(--duration-normal) var(--ease-out);
	text-align: center;
}

.service-pillar.is-open .service-pillar__toggle {
	transform: rotate(45deg);
}

.service-pillar__body {
	max-height: 0;
	overflow: hidden;
	transition:
		max-height var(--duration-slow) var(--ease-out),
		padding var(--duration-slow) var(--ease-out);
	padding: 0 0 0 40px;
}

.service-pillar.is-open .service-pillar__body {
	max-height: 300px;
	padding: 0 0 var(--space-xl) 40px;
}

.service-pillar__outcome {
	font-size: var(--text-body);
	color: var(--color-text-muted);
	line-height: var(--leading-relaxed);
	max-width: 60ch;
	margin-bottom: var(--space-md);
}

.service-pillar__tags {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-xs);
}

.service-pillar__line {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 1px;
	background: var(--color-text);
	transition: width var(--duration-normal) var(--ease-out);
}

.service-pillar__header:hover ~ .service-pillar__line,
.service-pillar.is-open .service-pillar__line {
	width: 100%;
}

/* Metric Badges — for project success metrics */
.metric-badge {
	font-family: var(--font-heading);
	font-size: 0.65rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-text-muted);
	padding: 4px 8px;
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 2px;
	white-space: nowrap;
}

.project-item__metrics {
	display: flex;
	gap: var(--space-xs);
}

/* --------------------------------------------------------------------------
   Generic Slider Nav — Reusable overlay arrows for mobile swipe sections
   -------------------------------------------------------------------------- */
.slider-wrapper {
	position: relative;
}

.slider-nav {
	display: none;
}

@media (max-width: 768px) {
	.slider-nav {
		position: absolute;
		top: 50%;
		left: 0;
		right: 0;
		transform: translateY(-50%);
		display: flex;
		justify-content: space-between;
		pointer-events: none;
		padding: 0 var(--space-xs);
		z-index: 10;
	}
	.slider-nav__btn {
		pointer-events: auto;
		width: 44px;
		height: 44px;
		display: flex;
		align-items: center;
		justify-content: center;
		background: rgba(0, 0, 0, 0.4);
		backdrop-filter: blur(8px);
		-webkit-backdrop-filter: blur(8px);
		border: 1px solid rgba(255, 255, 255, 0.2);
		color: #ffffff;
		border-radius: 50%;
		cursor: pointer;
		transition: all var(--duration-fast) var(--ease-out);
	}
	.slider-nav__btn:active {
		background: rgba(0, 0, 0, 0.6);
		transform: scale(0.9);
	}
	[data-theme='light'] .slider-nav__btn {
		background: rgba(255, 255, 255, 0.7);
		border: 1px solid rgba(0, 0, 0, 0.15);
		color: #111111;
	}
	[data-theme='light'] .slider-nav__btn:active {
		background: rgba(255, 255, 255, 0.9);
	}
}

/* Testimonials slider nav needs to show at 1024px since grid switches at that breakpoint */
@media (max-width: 1024px) {
	.testimonials .slider-nav {
		position: absolute;
		top: 50%;
		left: 0;
		right: 0;
		transform: translateY(-50%);
		display: flex;
		justify-content: space-between;
		pointer-events: none;
		padding: 0 var(--space-xs);
		z-index: 10;
	}
	.testimonials .slider-nav .slider-nav__btn {
		pointer-events: auto;
		width: 44px;
		height: 44px;
		display: flex;
		align-items: center;
		justify-content: center;
		background: rgba(0, 0, 0, 0.4);
		backdrop-filter: blur(8px);
		-webkit-backdrop-filter: blur(8px);
		border: 1px solid rgba(255, 255, 255, 0.2);
		color: #ffffff;
		border-radius: 50%;
		cursor: pointer;
		transition: all var(--duration-fast) var(--ease-out);
	}
	.testimonials .slider-nav .slider-nav__btn:active {
		background: rgba(0, 0, 0, 0.6);
		transform: scale(0.9);
	}
	[data-theme='light'] .testimonials .slider-nav .slider-nav__btn {
		background: rgba(255, 255, 255, 0.7);
		border: 1px solid rgba(0, 0, 0, 0.15);
		color: #111111;
	}
}

/* Nudge Links — subtle CTA toward contact */
.nudge-link {
	font-family: var(--font-heading);
	font-size: var(--text-small);
	font-weight: 500;
	letter-spacing: var(--tracking-wide);
	color: var(--color-text-muted);
	transition: color var(--duration-normal) var(--ease-out);
}

.nudge-link:hover {
	color: var(--color-text);
}

.services__nudge,
.why__nudge {
	margin-top: var(--space-xl);
	padding-top: var(--space-lg);
	border-top: 1px solid var(--color-border);
}

@media (max-width: 1024px) {
	.service-pillar__header {
		grid-template-columns: 30px 1fr 30px;
	}
	.service-pillar__result {
		display: none;
	}
}

@media (max-width: 768px) {
	.services__intro {
		max-width: none;
	}

	.service-pillar__header {
		align-items: start;
		padding: var(--space-md) 0;
	}

	.service-pillar__title {
		font-size: clamp(1.1rem, 4vw, 1.5rem);
	}

	.service-pillar__body {
		padding-left: 0;
	}

	.service-pillar.is-open .service-pillar__body {
		max-height: 420px;
		padding: 0 0 var(--space-lg);
	}
}

@media (max-width: 480px) {
	.service-pillar__header:hover {
		padding-left: 0;
	}

	.service-pillar__outcome {
		max-width: none;
	}
}

@media (max-width: 768px) {
	.project-item__metrics {
		grid-column: 1 / -1;
	}
}

@media (max-width: 768px) {
	.section-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
		margin-bottom: var(--space-lg);
	}

	.header__utility-menu {
		right: 0;
		min-width: 160px;
	}

	.section-header__title {
		font-size: var(--text-h3);
	}

	.section-header__label {
		font-size: 10px;
	}
}

/* --------------------------------------------------------------------------
   Why Us Section
   -------------------------------------------------------------------------- */
.why {
	padding: var(--space-3xl) var(--gutter) var(--space-2xl);
}

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

.why__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xl);
}

.why__lead {
	font-family: var(--font-heading);
	font-size: var(--text-h2);
	font-weight: 300;
	line-height: var(--leading-snug);
	max-width: 25ch;
}

@media (max-width: 768px) {
	.why__lead {
		max-width: none;
	}
}

.why__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-xl);
}

.why__card {
	padding: var(--space-lg) var(--space-md);
	border-top: 1px solid var(--color-border);
	transition: border-color var(--duration-normal) var(--ease-out);
}

.why__card:hover {
	border-color: var(--color-border-hover);
}

.why__card-num {
	font-family: var(--font-heading);
	font-size: var(--text-micro);
	font-weight: 500;
	letter-spacing: var(--tracking-widest);
	color: var(--color-text-subtle);
	display: block;
	margin-bottom: var(--space-md);
}

.why__card-title {
	font-size: var(--text-h4);
	font-weight: 600;
	margin-bottom: var(--space-sm);
}

.why__card-desc {
	font-size: var(--text-small);
	color: var(--color-text-muted);
	line-height: var(--leading-relaxed);
}

@media (max-width: 640px) {
	.stats__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--space-xl) 0;
	}

	.stat-item {
		padding: 0 var(--space-md);
	}

	.stat__divider {
		display: none;
	}
}

@media (max-width: 768px) {
	.why__grid {
		display: flex;
		overflow-x: auto;
		overflow-y: hidden;
		scroll-snap-type: x mandatory;
		scroll-behavior: smooth;
		-webkit-overflow-scrolling: touch;
		gap: 0;
		padding-bottom: var(--space-md);
		scrollbar-width: none;
	}
	.why__grid::-webkit-scrollbar {
		display: none;
	}
	.why__card {
		scroll-snap-align: center;
		flex: 0 0 100%;
		min-width: 100%;
		transform: scale(1);
		opacity: 0.72;
		transition: opacity 0.5s ease;
	}
	.why__card.is-active {
		opacity: 1;
	}
}

/* --------------------------------------------------------------------------
   Projects Section
   -------------------------------------------------------------------------- */
.projects {
	padding: var(--space-3xl) var(--gutter);
	position: relative;
}

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

.projects__list {
	display: flex;
	flex-direction: column;
}

.projects__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: var(--space-lg);
	margin-top: var(--space-2xl);
}

.impact-card {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	padding: var(--space-lg);
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	transition:
		transform var(--duration-normal) var(--ease-out),
		border-color var(--duration-normal) var(--ease-out),
		box-shadow var(--duration-normal) var(--ease-out);
	position: relative;
	min-height: 380px;
}

@media (max-width: 1024px) {
	.projects__grid {
		grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	}

	.impact-card {
		min-height: 340px;
	}
}

.impact-card:hover {
	transform: translate(-4px, -4px);
	border-color: var(--color-text);
	box-shadow: 8px 8px 0px 0px var(--color-border);
}

.impact-card__header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: var(--space-lg);
}

.impact-card__num {
	font-family: var(--font-heading);
	font-size: var(--text-micro);
	color: var(--color-text-subtle);
	letter-spacing: var(--tracking-widest);
}

.impact-card__cat {
	font-family: var(--font-heading);
	font-size: var(--text-micro);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	color: var(--color-text-muted);
	padding: var(--space-xs) var(--space-sm);
	border: 1px solid var(--color-border);
}

.impact-card__content {
	flex-grow: 1;
	display: flex;
	flex-direction: column;
}

.impact-card__title {
	font-size: var(--text-h3);
	font-weight: 700;
	text-transform: uppercase;
	margin: 0 0 var(--space-xs) 0;
	line-height: 1.1;
}

.impact-card__client {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	margin-bottom: var(--space-md);
	font-family: var(--font-heading);
	font-size: var(--text-micro);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
}

.impact-card__client-label {
	color: var(--color-text-subtle);
}

.impact-card__client-name {
	color: var(--color-text);
	font-weight: 600;
}

.impact-card__desc {
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--color-text-muted);
	margin-bottom: var(--space-lg);
}

.impact-card__footer {
	display: flex;
	flex-direction: column;
	margin-top: var(--space-md);
}

.impact-card__actions {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	width: 100%;
}

.impact-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-sm) var(--space-md);
	text-decoration: none;
	font-family: var(--font-heading);
	font-size: var(--text-micro);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	transition: all var(--duration-fast) var(--ease-out);
	border: 1px solid var(--color-text);
	text-align: center;
}

.impact-btn span {
	position: relative;
	z-index: 1;
}

.impact-btn--primary {
	background: var(--color-text);
	color: var(--color-bg);
}

.impact-btn--primary:hover {
	background: transparent;
	color: var(--color-text);
}

.impact-btn--secondary {
	background: transparent;
	color: var(--color-text);
}

.impact-btn--secondary:hover {
	background: var(--color-text);
	color: var(--color-bg);
}

.projects__nav {
	display: none;
}

@media (max-width: 768px) {
	.projects__grid {
		display: flex;
		overflow-x: auto;
		overflow-y: hidden;
		scroll-snap-type: x mandatory;
		scroll-behavior: smooth;
		-webkit-overflow-scrolling: touch;
		gap: 0;
		padding-bottom: var(--space-md);
		scrollbar-width: none;
	}
	.projects__grid::-webkit-scrollbar {
		display: none;
	}
	.impact-card {
		scroll-snap-align: center;
		flex: 0 0 100%;
		min-width: 100%;
		transform: scale(1);
		opacity: 0.72;
		transition: opacity 0.5s ease;
	}
	.impact-card.is-active {
		opacity: 1;
	}
}

@media (max-width: 480px) {
	.impact-card {
		padding: var(--space-md);
		min-height: 320px;
	}

	.impact-card__header {
		align-items: start;
		gap: var(--space-sm);
		flex-wrap: wrap;
	}

	.impact-card__title {
		font-size: clamp(1.15rem, 5vw, 1.5rem);
	}
}

/* --------------------------------------------------------------------------
   Testimonials Section
   -------------------------------------------------------------------------- */
.testimonials {
	padding: var(--space-3xl) var(--gutter);
}

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

.testimonials__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1px;
	background: var(--color-border);
	border: 1px solid var(--color-border);
}

.testimonial {
	background: var(--color-bg);
	padding: var(--space-xl);
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	min-height: 280px;
	transition: background-color var(--duration-normal) var(--ease-out);
}

.testimonial:hover {
	background: var(--color-bg-elevated);
}

.testimonial__text {
	font-family: var(--font-body);
	font-size: var(--text-body);
	font-weight: 300;
	line-height: var(--leading-relaxed);
	color: var(--color-text);
	font-style: italic;
	max-width: none;
}

.testimonial__footer {
	display: flex;
	flex-direction: column;
	gap: 2px;
	margin-top: var(--space-lg);
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-border);
}

.testimonial__author {
	font-family: var(--font-heading);
	font-size: var(--text-small);
	font-weight: 600;
	font-style: normal;
	letter-spacing: var(--tracking-wide);
}

.testimonial__role {
	font-family: var(--font-heading);
	font-size: var(--text-micro);
	font-weight: 400;
	letter-spacing: var(--tracking-wide);
	color: var(--color-text-muted);
}

@media (max-width: 1024px) {
	.testimonials__grid {
		display: flex;
		overflow-x: auto;
		overflow-y: hidden;
		scroll-snap-type: x mandatory;
		scroll-behavior: smooth;
		-webkit-overflow-scrolling: touch;
		gap: 0;
		scrollbar-width: none;
		border: none;
		background: transparent;
	}
	.testimonials__grid::-webkit-scrollbar {
		display: none;
	}
	.testimonial {
		scroll-snap-align: center;
		flex: 0 0 100%;
		min-width: 100%;
		border: 1px solid var(--color-border);
		min-height: auto;
		transform: scale(1);
		opacity: 0.72;
		transition: opacity 0.5s ease;
	}
	.testimonial.is-active {
		opacity: 1;
	}
}

@media (max-width: 480px) {
	.testimonial {
		padding: var(--space-lg);
	}
}

/* --------------------------------------------------------------------------
   Process Section
   -------------------------------------------------------------------------- */
.process {
	padding: var(--space-3xl) var(--gutter);
}

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

.process__steps {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1px;
	background: var(--color-border);
	border: 1px solid var(--color-border);
}

.process-step {
	background: var(--color-bg);
	padding: var(--space-xl);
	display: flex;
	flex-direction: column;
	position: relative;
	transition: background-color var(--duration-normal) var(--ease-out);
}

.process-step:hover {
	background: var(--color-bg-elevated);
}

.process-step__header {
	margin-bottom: var(--space-lg);
}

.process-step__num {
	font-family: var(--font-heading);
	font-size: var(--text-micro);
	font-weight: 500;
	letter-spacing: var(--tracking-widest);
	color: var(--color-text-subtle);
	display: block;
	margin-bottom: var(--space-sm);
}

.process-step__title {
	font-size: var(--text-h4);
	font-weight: 600;
	line-height: var(--leading-snug);
}

.process-step__desc {
	font-size: var(--text-small);
	color: var(--color-text-muted);
	line-height: var(--leading-relaxed);
	flex-grow: 1;
}

.process-step__duration {
	font-family: var(--font-heading);
	font-size: var(--text-micro);
	font-weight: 500;
	letter-spacing: var(--tracking-widest);
	text-transform: uppercase;
	color: var(--color-text-subtle);
	margin-top: var(--space-lg);
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-border);
}

@media (max-width: 1024px) {
	.process__steps {
		grid-template-columns: repeat(2, 1fr);
	}
}

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

	.process-step {
		padding: var(--space-lg);
	}
}

/* --------------------------------------------------------------------------
   FAQ Section
   -------------------------------------------------------------------------- */
.faq {
	padding: var(--space-3xl) var(--gutter);
}

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

.faq__list {
	display: flex;
	flex-direction: column;
}

.faq-item {
	border-bottom: 1px solid var(--color-border);
}

.faq-item:first-child {
	border-top: 1px solid var(--color-border);
}

.faq-item__question {
	font-family: var(--font-heading);
	font-size: var(--text-h4);
	font-weight: 500;
	letter-spacing: var(--tracking-normal);
	padding: var(--space-lg) 0;
	cursor: pointer;
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	transition: color var(--duration-normal) var(--ease-out);
	position: relative;
}

@media (max-width: 480px) {
	.faq-item__question {
		font-size: 1rem;
	}
}

.faq-item__question::-webkit-details-marker {
	display: none;
}

.faq-item__question::after {
	content: '+';
	font-family: var(--font-heading);
	font-size: var(--text-h4);
	font-weight: 300;
	color: var(--color-text-muted);
	transition: transform var(--duration-normal) var(--ease-out);
	flex-shrink: 0;
}

.faq-item[open] .faq-item__question::after {
	transform: rotate(45deg);
}

.faq-item__question:hover {
	color: var(--color-text);
}

.faq-item__answer {
	padding-bottom: var(--space-lg);
}

.faq-item__answer p {
	font-size: var(--text-body);
	color: var(--color-text-muted);
	line-height: var(--leading-relaxed);
	max-width: 65ch;
}

/* --------------------------------------------------------------------------
   Contact Section
   -------------------------------------------------------------------------- */
.contact {
	padding: var(--space-3xl) var(--gutter);
	min-height: 80vh;
	display: flex;
	align-items: center;
}

.contact__container {
	max-width: var(--container-max);
	margin-inline: auto;
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: var(--space-2xl);
}

.contact__content {
	text-align: center;
}

.contact__label {
	display: block;
	font-family: var(--font-heading);
	font-size: var(--text-micro);
	font-weight: 500;
	letter-spacing: var(--tracking-widest);
	color: var(--color-text-muted);
	margin-bottom: var(--space-lg);
}

.contact__title {
	font-size: clamp(3rem, 8vw, 6rem);
	font-weight: 300;
	line-height: var(--leading-tight);
	letter-spacing: var(--tracking-tight);
	margin-bottom: var(--space-md);
}

.contact__subheadline {
	font-family: var(--font-body);
	font-size: var(--text-body);
	color: var(--color-text-muted);
	max-width: 45ch;
	margin-inline: auto;
	margin-bottom: var(--space-2xl);
	line-height: var(--leading-relaxed);
}

.contact__hub {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 1px;
	background: var(--color-border);
	border: 1px solid var(--color-border);
}

.contact__node {
	position: relative;
	background: var(--color-bg);
	padding: var(--space-xl) var(--space-md);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--space-md);
	text-decoration: none;
	color: var(--color-text);
	transition: all var(--duration-normal) var(--ease-out-expo);
	cursor: pointer;
	border: none;
	outline: none;
}

.contact__node-icon {
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	border: 1px solid var(--color-border);
	transition: all var(--duration-normal) var(--ease-out-expo);
}

.contact__node-content {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.contact__node-label {
	font-family: var(--font-heading);
	font-size: var(--text-micro);
	color: var(--color-text-subtle);
	letter-spacing: var(--tracking-widest);
	text-transform: uppercase;
}

.contact__node-value {
	font-family: var(--font-heading);
	font-size: var(--text-h4);
	font-weight: 500;
}

/* Hover States & Brand Colors */
.contact__node:hover {
	background: var(--color-bg-elevated);
	transform: translateY(-5px);
	z-index: 2;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
}

.contact__node--whatsapp:hover .contact__node-icon {
	background: #25d366;
	border-color: #25d366;
	color: #fff;
}

.contact__node--telegram:hover .contact__node-icon {
	background: #229ed9;
	border-color: #229ed9;
	color: #fff;
}

.contact__node--github:hover .contact__node-icon {
	background: #fff;
	border-color: #fff;
	color: #000;
}

.contact__node--email:hover .contact__node-icon {
	background: var(--color-text);
	border-color: var(--color-text);
	color: var(--color-bg);
}

.contact__node--phone:hover .contact__node-icon {
	background: var(--color-text);
	border-color: var(--color-text);
	color: var(--color-bg);
}

.contact__tooltip {
	position: absolute;
	bottom: var(--space-sm);
	left: 50%;
	transform: translateX(-50%) translateY(10px);
	background: var(--color-text);
	color: var(--color-bg);
	font-size: var(--text-micro);
	padding: 4px 8px;
	border-radius: 4px;
	opacity: 0;
	visibility: hidden;
	transition: all var(--duration-fast) var(--ease-out);
}

.contact__tooltip.is-active {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(0);
}

@media (max-width: 1024px) {
	.contact__hub {
		grid-template-columns: repeat(3, 1fr);
	}

	.contact__node {
		padding: var(--space-lg) var(--space-sm);
	}
}

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

@media (max-width: 480px) {
	.contact {
		min-height: auto;
	}

	.contact__title {
		font-size: clamp(2.2rem, 11vw, 3rem);
	}

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

	.contact__node-value {
		font-size: 1rem;
	}
}

/* ==========================================================================
   Light Theme Adjustments
   ========================================================================== */

/* Services */
[data-theme='light'] .service-pillar {
	border-bottom-color: rgba(0, 0, 0, 0.15);
}

[data-theme='light'] .service-pillar:first-child {
	border-top-color: rgba(0, 0, 0, 0.15);
}

[data-theme='light'] .service-pillar__result {
	border-color: rgba(0, 0, 0, 0.15);
}

[data-theme='light'] .service-pillar__line {
	background: rgba(0, 0, 0, 0.6);
}

[data-theme='light'] .metric-badge {
	border-color: rgba(0, 0, 0, 0.2);
	color: #111;
}

[data-theme='light'] .nudge-link {
	color: rgba(0, 0, 0, 0.5);
}

[data-theme='light'] .nudge-link:hover {
	color: #111;
}

[data-theme='light'] .projects__nav-btn {
	background: rgba(255, 255, 255, 0.6);
	border: 1px solid rgba(0, 0, 0, 0.1);
	color: #111111;
}

[data-theme='light'] .projects__nav-btn:active {
	background: rgba(255, 255, 255, 0.9);
}

[data-theme='light'] .services__nudge,
[data-theme='light'] .why__nudge {
	border-top-color: rgba(0, 0, 0, 0.12);
}

/* Why Us */
[data-theme='light'] .why__card {
	border-top-color: rgba(0, 0, 0, 0.15);
}

[data-theme='light'] .why__card:hover {
	border-top-color: rgba(0, 0, 0, 0.6);
}

/* Projects */
[data-theme='light'] .project-item {
	border-bottom-color: rgba(0, 0, 0, 0.12);
	transition:
		padding 0.4s var(--ease-out),
		background-color 0.4s var(--ease-out),
		border-color 0.4s var(--ease-out);
}

[data-theme='light'] .project-item:first-child {
	border-top-color: rgba(0, 0, 0, 0.12);
}

[data-theme='light'] .project-item:hover {
	padding-left: var(--space-lg);
	background: rgba(0, 0, 0, 0.02);
	border-bottom-color: rgba(0, 0, 0, 0.5);
}

[data-theme='light'] .project-item__cat {
	border-color: rgba(0, 0, 0, 0.15);
	background: rgba(0, 0, 0, 0.02);
}

[data-theme='light'] .project-item:hover .project-item__cat {
	border-color: rgba(0, 0, 0, 0.4);
}

[data-theme='light'] .project-item__line {
	background: rgba(0, 0, 0, 0.6);
	height: 2px;
}

[data-theme='light'] .project-item:hover .project-item__title {
	transform: translateX(15px);
}

/* Testimonials */
[data-theme='light'] .testimonials__grid {
	background: rgba(0, 0, 0, 0.1);
	border-color: rgba(0, 0, 0, 0.1);
}

[data-theme='light'] .testimonial {
	background: var(--color-bg);
}

[data-theme='light'] .testimonial:hover {
	background: #ffffff;
}

[data-theme='light'] .testimonial__footer {
	border-top-color: rgba(0, 0, 0, 0.1);
}

/* Process */
[data-theme='light'] .process__steps {
	background: rgba(0, 0, 0, 0.1);
	border-color: rgba(0, 0, 0, 0.1);
}

[data-theme='light'] .process-step {
	background: var(--color-bg);
}

[data-theme='light'] .process-step:hover {
	background: #ffffff;
}

[data-theme='light'] .process-step__duration {
	border-top-color: rgba(0, 0, 0, 0.1);
}

/* FAQ */
[data-theme='light'] .faq-item {
	border-color: rgba(0, 0, 0, 0.15);
}

[data-theme='light'] .faq-item:first-child {
	border-top-color: rgba(0, 0, 0, 0.15);
}

/* Contact */
[data-theme='light'] .contact__email-line {
	background: rgba(0, 0, 0, 0.6);
	height: 2px;
}

/* Marquee */
[data-theme='light'] .marquee {
	border-color: rgba(0, 0, 0, 0.1);
}

/* Hero divider */
[data-theme='light'] .hero__divider {
	background: rgba(0, 0, 0, 0.2);
}

[data-theme='light'] .hero__scroll-line {
	background: linear-gradient(to bottom, var(--color-text), transparent);
}
