/*
Theme Name: CCN Systems
Description: Custom styles for CCN Systems theme
*/

/* ==================================================
   Inner Page Content — match header container padding
   ================================================== */

body:not(.home) .entry-content.is-layout-constrained {
	padding-left: var(--wp--preset--spacing--50, 1.5rem);
	padding-right: var(--wp--preset--spacing--50, 1.5rem);
	padding-top: 30px;
	padding-bottom: 30px;
}

/* ==================================================
   Gutenberg Button Block Overrides
   ================================================== */

/* Fill button (default) */
.wp-block-button:not(.is-style-outline) .wp-block-button__link {
	background-color: var(--color-accent) !important;
	color: var(--color-text-light) !important;
	border: 2px solid var(--color-accent) !important;
	border-radius: 0 !important;
	padding: 0.625rem 1.5rem;
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	text-decoration: none;
	line-height: 1;
	transition: all var(--transition-base);
}

.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover {
	background-color: #b91f21 !important;
	border-color: #b91f21 !important;
	transform: translateY(-1px);
	box-shadow: var(--shadow-md);
}

/* Outline button */
.wp-block-button.is-style-outline .wp-block-button__link {
	background-color: transparent !important;
	color: var(--color-accent) !important;
	border: 2px solid var(--color-accent) !important;
	border-radius: 0 !important;
	padding: 0.625rem 1.5rem;
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	text-decoration: none;
	line-height: 1;
	transition: all var(--transition-base);
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background-color: var(--color-accent) !important;
	color: var(--color-text-light) !important;
}

/* Editor-specific: ensure button is visible in Gutenberg backend */
.editor-styles-wrapper .wp-block-button:not(.is-style-outline) .wp-block-button__link,
.editor-styles-wrapper .wp-block-button:not(.is-style-outline) .wp-block-button__link:not(.has-background) {
	background-color: var(--color-accent, #DC2626) !important;
	color: var(--color-text-light, #ffffff) !important;
	border: 2px solid var(--color-accent, #DC2626) !important;
	border-radius: 0 !important;
	padding: 0.625rem 1.5rem;
	font-size: var(--font-size-xs, 0.75rem);
	font-weight: var(--font-weight-medium, 500);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	line-height: 1;
}

.editor-styles-wrapper .wp-block-button.is-style-outline .wp-block-button__link,
.editor-styles-wrapper .wp-block-button.is-style-outline .wp-block-button__link:not(.has-background) {
	background-color: transparent !important;
	color: var(--color-accent, #DC2626) !important;
	border: 2px solid var(--color-accent, #DC2626) !important;
	border-radius: 0 !important;
	padding: 0.625rem 1.5rem;
	font-size: var(--font-size-xs, 0.75rem);
	font-weight: var(--font-weight-medium, 500);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	line-height: 1;
}

/* ==================================================
   Global List Styles (ul/li)
   ================================================== */

.site-main ul:not([class]),
.site-main .entry-content ul:not([class]),
.is-layout-constrained ul:not([class]) {
	list-style: none;
	padding-left: 0;
	margin: 1.25rem 0;
}

.site-main ul:not([class]) li,
.site-main .entry-content ul:not([class]) li,
.is-layout-constrained ul:not([class]) li {
	position: relative;
	padding-left: 1.75rem;
	margin-bottom: 0.625rem;
	font-family: var(--font-body, 'Inter', sans-serif);
	font-size: var(--font-size-base, 1rem);
	line-height: 1.7;
	color: var(--color-text-dark, #1a1a1a);
}

.site-main ul:not([class]) li::before,
.site-main .entry-content ul:not([class]) li::before,
.is-layout-constrained ul:not([class]) li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.55em;
	width: 8px;
	height: 8px;
	border-right: 2px solid var(--color-primary, #2B6CB7);
	border-bottom: 2px solid var(--color-primary, #2B6CB7);
	transform: rotate(-45deg);
}

.site-main ul:not([class]) li a,
.site-main .entry-content ul:not([class]) li a,
.is-layout-constrained ul:not([class]) li a {
	color: var(--color-primary, #2B6CB7);
	text-decoration: underline;
	text-underline-offset: 2px;
	transition: color 0.2s ease;
}

.site-main ul:not([class]) li a:hover,
.site-main .entry-content ul:not([class]) li a:hover,
.is-layout-constrained ul:not([class]) li a:hover {
	color: var(--color-secondary, #2865A8);
}

/* ==================================================
   Global Table Styles
   ================================================== */

.site-main table,
.wp-block-table table,
table {
	width: 100% !important;
	border-collapse: collapse;
	margin: 1.5rem 0;
	font-family: var(--font-body, 'Inter', sans-serif);
	font-size: var(--font-size-sm, 0.875rem);
	line-height: 1.6;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
	overflow: hidden;
}

.site-main table th,
.site-main table td,
.wp-block-table th,
.wp-block-table td,
table th,
table td {
	text-align: left !important;
	padding: 0.875rem 1.25rem !important;
}

.site-main table th,
.wp-block-table th,
table th {
	background-color: var(--color-bg-dark, #001F3F);
	color: #ffffff;
	font-family: var(--font-heading, 'Poppins', sans-serif);
	font-weight: 600;
	font-size: 0.8125rem;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	border-bottom: 2px solid var(--color-primary, #2B6CB7);
}

.site-main table td,
.wp-block-table td,
table td {
	color: var(--color-text-dark, #1a1a1a);
	border-bottom: 1px solid #e2e8f0;
}

table td pre,
table th pre {
	margin: 0;
}

.site-main table tr:nth-child(even),
.wp-block-table table tr:nth-child(even),
table tr:nth-child(even) {
	background-color: #f7fafc;
}

.site-main table tr:not(:first-child):hover,
.wp-block-table table tr:not(:first-child):hover,
table tr:not(:first-child):hover {
	background-color: #edf2f7;
}

.site-main table tr:last-child td,
.wp-block-table table tr:last-child td,
table tr:last-child td {
	border-bottom: none;
}

/* Responsive table */
@media screen and (max-width: 768px) {
	.site-main table,
	.wp-block-table table,
	table {
		display: block;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	.site-main table th,
	.site-main table td,
	.wp-block-table th,
	.wp-block-table td,
	table th,
	table td {
		padding: 0.625rem 1rem !important;
		font-size: 0.8125rem;
		white-space: nowrap;
	}
}

/* ==================================================
   Global Fixes
   ================================================== */

/* Ensure no white space shows below footer */
body {
	background-color: #020E1B;
}

body .is-layout-flex {
	justify-content: space-between;
}

p {
	line-height: 1.75;
}

/* Remove Underscores default post/page bottom margin */
.post,
.page {
	margin: 0;
}

#page {
	background-color: var(--color-bg-white);
}

/* ==================================================
   Block Layout (constrained/wide/full for Gutenberg blocks)
   ================================================== */

.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
	max-width: var(--wp--style--global--content-size, 1280px);
	margin-left: auto !important;
	margin-right: auto !important;
}

.is-layout-constrained > .alignwide {
	max-width: var(--wp--style--global--wide-size, 1440px);
	margin-left: auto !important;
	margin-right: auto !important;
}

.is-layout-constrained > .alignfull {
	max-width: none;
}

/* ==================================================
   Top Bar
   ================================================== */

.top-bar {
	background-color: var(--color-secondary);
	color: var(--color-text-light);
	font-size: var(--font-size-xs);
	padding: 0.375rem 0;
}

.top-bar__container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 var(--space-xl);
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--space-sm);
}

.top-bar__welcome {
	color: var(--color-text-light);
}

.top-bar__contact {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	flex-wrap: wrap;
}

.top-bar__contact a {
	color: var(--color-text-light);
	text-decoration: none;
	transition: opacity var(--transition-fast);
}

.top-bar__contact a[href^="tel:"],
.top-bar__contact a[href^="mailto:"] {
	font-weight: var(--font-weight-bold);
}

.top-bar__contact a:hover {
	opacity: 0.8;
	text-decoration: underline;
}

.top-bar__emergency {
	font-weight: var(--font-weight-normal);
}

.top-bar__emergency a {
	font-weight: var(--font-weight-bold);
}

/* ==================================================
   Site Header
   ================================================== */

.site-header {
	background-color: var(--color-bg-white);
	border-bottom: 1px solid #e5e5e5;
	position: sticky;
	top: 0;
	z-index: 100;
	box-shadow: var(--shadow-sm);
}

.site-header__container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: var(--space-sm) var(--space-xl);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-xl);
}

/* Logo */
.site-branding {
	flex-shrink: 0;
}

.site-branding img {
	max-height: 50px;
	width: auto;
	display: block;
}

.site-name {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-text-dark);
}

/* Navigation */
.main-navigation {
	flex: 1;
	display: flex;
	justify-content: center;
}

.main-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: var(--space-xl);
	align-items: center;
}

.main-navigation li {
	position: relative;
}

.main-navigation a {
	color: var(--color-text-dark);
	text-decoration: none;
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-normal);
	padding: var(--space-sm) 0;
	display: block;
	transition: color var(--transition-fast);
}

.main-navigation a:hover,
.main-navigation a:focus {
	color: var(--color-primary);
}

/* Dropdown indicator */
.main-navigation .menu-item-has-children > a::after {
	content: '';
	display: inline-block;
	width: 0;
	height: 0;
	margin-left: var(--space-xs);
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
	border-top: 4px solid currentColor;
	vertical-align: middle;
}

/* Dropdown menu */
.main-navigation ul ul {
	position: absolute;
	top: 100%;
	left: 0;
	background-color: var(--color-bg-white);
	box-shadow: var(--shadow-lg);
	min-width: 220px;
	padding: var(--space-sm) 0;
	display: none;
	flex-direction: column;
	gap: 0;
}

.main-navigation ul li:hover > ul,
.main-navigation ul li:focus-within > ul {
	display: flex;
}

.main-navigation ul ul li {
	width: 100%;
}

.main-navigation ul ul a {
	padding: var(--space-sm) var(--space-lg);
}

.main-navigation ul ul a:hover {
	background-color: var(--color-bg-light);
}

/* 3rd-level dropdown (sub-sub-menu) */
.main-navigation ul ul ul {
	top: 0;
	left: 100%;
}

/* Mobile menu toggle */
.menu-toggle {
	display: none;
	flex-direction: column;
	gap: 4px;
	background: none;
	border: none;
	padding: var(--space-sm);
	cursor: pointer;
}

.menu-toggle span {
	display: block;
	width: 25px;
	height: 3px;
	background-color: var(--color-text-dark);
	transition: all var(--transition-fast);
}

/* CTA Button */
.header-cta {
	flex-shrink: 0;
}

.btn {
	display: inline-block;
	padding: 0.625rem 1.5rem;
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-medium);
	text-decoration: none;
	border-radius: 0;
	transition: all var(--transition-base);
	cursor: pointer;
	border: 2px solid transparent;
	text-align: center;
	line-height: 1;
	letter-spacing: 0.08em;
}

/* Header CTA - square, compact */
.header-cta .btn {
	border-radius: 0;
	padding: 0.625rem 1.25rem;
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.08em;
}

.btn--primary {
	background-color: var(--color-accent);
	color: var(--color-text-light);
	border-color: var(--color-accent);
}

.btn--primary:hover {
	background-color: #b91f21;
	border-color: #b91f21;
	transform: translateY(-1px);
	box-shadow: var(--shadow-md);
}

.btn--secondary {
	background-color: transparent;
	color: var(--color-accent);
	border-color: var(--color-accent);
}

.btn--secondary:hover {
	background-color: var(--color-accent);
	color: var(--color-text-light);
}

/* Hide "About Us" on narrow desktop to prevent nav wrapping */
@media screen and (min-width: 1025px) and (max-width: 1200px) {
	#menu-item-175 {
		display: none;
	}

	.main-navigation ul {
		gap: var(--space-md);
	}
}

/* Tablet/Mobile: hamburger menu at 1024px */
@media screen and (max-width: 1024px) {
	.site-header__container {
		padding: var(--space-sm) var(--space-lg);
		flex-wrap: nowrap;
	}

	.site-branding img {
		max-height: 40px;
	}

	/* Hamburger — always visible, right side */
	.menu-toggle {
		display: flex;
		order: 3;
		z-index: 1001;
		position: relative;
		width: 28px;
		height: 20px;
		padding: 0;
		align-items: center;
		justify-content: center;
	}

	.menu-toggle span {
		position: absolute;
		width: 24px;
		height: 2px;
		background-color: var(--color-text-dark);
		transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
		border-radius: 2px;
	}

	.menu-toggle span:nth-child(1) { top: 0; }
	.menu-toggle span:nth-child(2) { top: 9px; }
	.menu-toggle span:nth-child(3) { top: 18px; }

	/* Hamburger → X animation */
	.main-navigation.toggled ~ .menu-toggle span:nth-child(1),
	.menu-toggle[aria-expanded="true"] span:nth-child(1) {
		top: 9px;
		transform: rotate(45deg);
	}

	.main-navigation.toggled ~ .menu-toggle span:nth-child(2),
	.menu-toggle[aria-expanded="true"] span:nth-child(2) {
		opacity: 0;
		transform: translateX(-8px);
	}

	.main-navigation.toggled ~ .menu-toggle span:nth-child(3),
	.menu-toggle[aria-expanded="true"] span:nth-child(3) {
		top: 9px;
		transform: rotate(-45deg);
	}

	/* CTA in header */
	.header-cta {
		order: 2;
		margin-left: auto;
	}

	.header-cta .btn {
		padding: 0.5rem 1rem;
		font-size: 10px;
	}

	/* ── Full-screen slide-in drawer ── */
	.main-navigation {
		position: fixed;
		top: 0;
		right: -100%;
		width: 85%;
		max-width: 360px;
		height: 100vh;
		height: 100dvh;
		background-color: var(--color-bg-dark);
		z-index: 1000;
		padding: 0;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		transition: right 0.35s cubic-bezier(0.4, 0, 0.2, 1);
		box-shadow: none;
		display: block;
	}

	.main-navigation.toggled {
		right: 0;
		box-shadow: -10px 0 40px rgba(0, 0, 0, 0.3);
	}

	/* Overlay behind drawer */
	.main-navigation::before {
		content: '';
		position: fixed;
		top: 0;
		left: 0;
		width: 100vw;
		height: 100vh;
		height: 100dvh;
		background: rgba(0, 0, 0, 0.5);
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.35s ease, visibility 0.35s ease;
		z-index: -1;
		pointer-events: none;
	}

	.main-navigation.toggled::before {
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
	}

	/* Menu list */
	.main-navigation ul {
		display: flex;
		flex-direction: column;
		gap: 0;
		width: 100%;
		padding: 5rem 0 2rem;
	}

	.main-navigation.toggled > ul {
		display: flex;
	}

	.main-navigation li {
		width: 100%;
		border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	}

	.main-navigation li:last-child {
		border-bottom: none;
	}

	/* Menu links — light on dark */
	.main-navigation a {
		color: rgba(255, 255, 255, 0.9);
		padding: 0.9rem 1.5rem;
		font-size: 15px;
		font-weight: 400;
		letter-spacing: 0.01em;
		transition: all 0.2s ease;
		position: relative;
	}

	.main-navigation a:hover,
	.main-navigation a:focus {
		color: #fff;
		background-color: rgba(255, 255, 255, 0.06);
	}

	/* Parent items with children — dropdown arrow */
	.main-navigation .menu-item-has-children > a::after {
		border-top-color: rgba(255, 255, 255, 0.5);
		position: absolute;
		right: 1.5rem;
		top: 50%;
		transform: translateY(-50%);
		transition: transform 0.25s ease;
	}

	.main-navigation .menu-item-has-children.submenu-open > a::after {
		transform: translateY(-50%) rotate(180deg);
	}

	/* Sub-menus — accordion style */
	.main-navigation ul ul {
		position: static;
		box-shadow: none;
		min-width: 0;
		padding: 0;
		display: none;
		background-color: rgba(0, 0, 0, 0.15);
	}

	.main-navigation ul ul li {
		border-bottom-color: rgba(255, 255, 255, 0.04);
	}

	.main-navigation ul ul a {
		padding-left: 2.5rem;
		font-size: 14px;
		color: rgba(255, 255, 255, 0.7);
	}

	.main-navigation ul ul a:hover {
		color: #fff;
		background-color: rgba(255, 255, 255, 0.06);
	}

	/* 3rd-level items */
	.main-navigation ul ul ul {
		position: static;
		left: auto;
	}

	.main-navigation ul ul ul a {
		padding-left: 3.5rem;
		font-size: 13px;
		color: rgba(255, 255, 255, 0.6);
	}

	/* Accordion open state */
	.main-navigation .submenu-open > ul {
		display: flex !important;
	}

	/* Disable hover-based sub-menu on touch */
	.main-navigation ul li:hover > ul,
	.main-navigation ul li:focus-within > ul {
		display: none;
	}

	.main-navigation .submenu-open > ul {
		display: flex !important;
	}

	/* Body scroll lock when menu open */
	body.mobile-menu-open {
		overflow: hidden;
	}
}

@media screen and (max-width: 768px) {
	.top-bar__container {
		flex-direction: column;
		text-align: center;
		gap: var(--space-xs);
	}

	.top-bar__contact {
		flex-direction: column;
		gap: var(--space-xs);
	}

	.top-bar__email,
	.top-bar__emergency {
		display: none;
	}
}

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

.hero {
	position: relative;
	min-height: 580px;
	padding-right: var(--wp--style--root--padding-right);
	padding-left: var(--wp--style--root--padding-left);
	display: flex;
	align-items: center;
	background-color: var(--color-bg-dark);
	overflow: hidden;
}

.hero.hero--small {
	min-height: 300px;
}

.hero.hero--medium {
	min-height: 420px;
}

.hero.hero--large {
	min-height: 580px;
}

.hero.hero--full {
	min-height: 100vh;
}

.hero__background {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: 55%;
	background-size: cover;
	background-position: center right;
	background-repeat: no-repeat;
}

.hero__background::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(100deg, var(--color-bg-dark) 0%, var(--color-bg-dark) 30%, rgba(0, 31, 63, 0.7) 50%, rgba(0, 31, 63, 0.1) 70%, transparent 85%);
}

.hero__container {
	position: relative;
	width: 100%;
	max-width: var(--max-width);
	margin: 0 auto;
	padding: var(--space-3xl) 0;
	z-index: 1;
}

.hero__content {
	max-width: 550px;
}

.hero__tagline {
	color: rgba(255, 255, 255, 0.8);
	font-family: var(--font-heading);
	font-size: 14px;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin: 0 0 var(--space-lg);
}

.hero__title {
	color: var(--color-text-light);
	font-family: var(--font-heading);
	font-size: 3.25rem;
	font-weight: var(--font-weight-medium);
	line-height: 1.2;
	margin: 0 0 var(--space-xl);
}

.hero__description {
	color: rgba(255, 255, 255, 0.9);
	font-family: var(--font-body);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-medium);
	line-height: 1.7;
	margin: 0;
	max-width: 540px;
}

/* Responsive Styles */
@media screen and (max-width: 1024px) {
	.hero__background {
		width: 60%;
	}

	.hero__title {
		font-size: var(--font-size-4xl);
	}

	.hero__container {
		padding: var(--space-4xl) 0;
	}
}

@media screen and (max-width: 768px) {
	.hero {
		min-height: 500px;
	}

	.hero.hero--small {
		min-height: 250px;
	}

	.hero.hero--medium {
		min-height: 350px;
	}

	.hero__background {
		width: 100%;
		opacity: 0.3;
	}

	.hero__background::before {
		background: rgba(0, 31, 63, 0.75);
	}

	.hero__container {
		padding: var(--space-3xl) 0;
	}

	.hero__content {
		max-width: 100%;
	}

	.hero__tagline {
		font-size: 0.6875rem;
	}

	.hero__title {
		font-size: var(--font-size-4xl);
	}

	.hero__description {
		font-size: var(--font-size-sm);
	}
}

@media screen and (max-width: 480px) {
	.hero {
		min-height: 450px;
	}

	.hero.hero--small {
		min-height: 200px;
	}

	.hero.hero--medium {
		min-height: 300px;
	}

	.hero__title {
		font-size: var(--font-size-4xl);
	}
}

/* ==================================================
   Services Intro Section
   ================================================== */

.services-intro {
	background-color: var(--color-bg-white);
	padding: var(--space-5xl) 0 var(--space-3xl);
}

.services-intro__container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 var(--space-xl);
	display: grid;
	grid-template-columns: 55% 1fr;
	gap: var(--space-4xl);
	align-items: start;
}

.services-intro__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.services-intro__tagline {
	color: var(--color-primary);
	font-family: var(--font-heading);
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-normal);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin: 0;
}

.services-intro__title {
	color: var(--color-primary);
	font-family: var(--font-heading);
	font-size: 46px;
	font-weight: var(--font-weight-medium);
	line-height: var(--line-height-tight);
	margin: 0;
}

.services-intro__description {
	color: var(--color-text-body);
	font-size: var(--font-size-base);
	line-height: var(--line-height-relaxed);
	margin: 0;
}

.services-intro__buttons {
	display: flex;
	gap: var(--space-lg);
	flex-wrap: wrap;
	margin-top: 15px;
}

.services-intro__image {
	position: relative;
}

.services-intro__image img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 0;
	box-shadow: none;
}

/* Responsive */
@media screen and (max-width: 1024px) {
	.services-intro {
		padding: var(--space-4xl) 0;
	}

	.services-intro__container {
		gap: var(--space-3xl);
	}

	.services-intro__title {
		font-size: var(--font-size-3xl);
	}
}

@media screen and (max-width: 768px) {
	.services-intro {
		padding: var(--space-3xl) 0;
	}

	.services-intro__container {
		grid-template-columns: 1fr;
		gap: var(--space-2xl);
		padding: 0 var(--space-lg);
	}

	.services-intro__title {
		font-size: var(--font-size-2xl);
	}

	.services-intro__buttons {
		flex-direction: column;
		gap: var(--space-md);
	}

	.services-intro__buttons .btn {
		width: 100%;
		text-align: center;
	}
}

/* ==================================================
   Clients Carousel Section
   ================================================== */

.clients-carousel {
	background-color: var(--color-bg-white);
	padding: 0;
	overflow: hidden;
}

.clients-carousel__container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0;
}

.clients-carousel__heading {
	color: var(--color-primary);
	font-family: var(--font-heading);
	font-size: 14px;
	font-weight: var(--font-weight-normal);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-align: left;
	margin: 0 0 var(--space-xl);
}

.clients-carousel__wrapper {
	overflow: hidden;
	position: relative;
}

.clients-carousel__track {
	display: flex;
	gap: 5rem;
	animation: scroll-logos 30s linear infinite;
	will-change: transform;
}

.clients-carousel__track:hover {
	animation-play-state: paused;
}

.clients-carousel__item {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 150px;
}

.clients-carousel__item img {
	min-height: 80px;
	max-height: 80px;
	width: auto;
	max-width: 200px;
	object-fit: contain;
	transition: all var(--transition-base);
}

.clients-carousel__item img:hover {
	transform: scale(1.05);
}

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

/* ========================================
   Our Services Section
   ======================================== */
.our-services {
	background-color: #F9F9F9;
}

.our-services__container {
	max-width: var(--max-width);
	margin: 0 auto;
}

@media screen and (min-width: 769px) {
	.our-services__container {
		padding: 70px 0;
	}
}

.our-services__heading {
	color: var(--color-primary);
	font-family: var(--font-heading);
	font-size: 46px;
	font-weight: var(--font-weight-medium);
	text-align: center;
	margin: 0 0 var(--space-xl);
	text-transform: capitalize;
}

.our-services__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-md);
}

/* Service Card */
.service-card {
	position: relative;
	display: block;
	overflow: hidden;
	cursor: pointer;
	text-decoration: none;
	min-height: 500px;
}

.service-card__image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	transition: transform var(--transition-base);
}

.service-card:hover .service-card__image {
	transform: scale(1.05);
}

.service-card__overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	min-height: 250px;
	background: linear-gradient(
		to top,
		rgba(0, 0, 0, 0.9) 0%,
		rgba(0, 0, 0, 0.7) 45%,
		transparent 65%
	);
	transition: background 0.4s ease;
	display: flex;
	align-items: flex-end;
	padding: var(--space-xl);
}

.service-card:hover .service-card__overlay {
	height: 100%;
	background: linear-gradient(
		to top,
		rgba(0, 0, 0, 0.95) 0%,
		rgba(0, 0, 0, 0.8) 50%,
		transparent 75%
	);
}

.service-card__content {
	width: 100%;
	color: var(--color-text-light);
}

.service-card__title {
	font-family: var(--font-heading);
	font-size: var(--font-size-2xl);
	color: var(--color-text-light);
	margin: 0 0 var(--space-md);
	line-height: 1.3;
}

.service-card__description {
	font-family: var(--font-body);
	font-size: var(--font-size-base);
	color: var(--color-text-light);
	line-height: 1.6;
	margin: 0;
	max-height: 0;
	opacity: 0;
	overflow: hidden;
	transition: all 0.4s ease;
}

.service-card:hover .service-card__description {
	opacity: 1;
	max-height: 500px;
}

/* Responsive */
@media screen and (max-width: 768px) {
	.clients-carousel {
		padding: var(--space-3xl) 0;
		padding-right: var(--wp--style--root--padding-right);
		padding-left: var(--wp--style--root--padding-left);
	}

	.clients-carousel__heading {
		margin: 0 0 var(--space-2xl);
	}

	.clients-carousel__track {
		gap: var(--space-2xl);
	}

	.clients-carousel__item {
		min-width: 120px;
	}

	.clients-carousel__item img {
		max-height: 40px;
		max-width: 120px;
	}
}

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

.site-footer {
	background-color: #020E1B;
	color: var(--color-text-light);
	border-top: 10px solid var(--color-primary);
}

/* Footer Main */
.footer__main {
	padding: var(--space-4xl) 0 var(--space-3xl);
}

.footer__container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 var(--space-xl);
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: var(--space-2xl);
}

/* Company Info */
.footer__company {
	display: flex;
	flex-direction: column;
	gap: var(--space-xl);
}

.footer__logo {
	margin-bottom: var(--space-md);
}

.footer__logo img {
	max-height: 60px;
	width: auto;
	display: block;
}

.footer__info {
	color: rgba(255, 255, 255, 0.7);
	font-size: var(--font-size-xs);
	line-height: var(--line-height-relaxed);
	max-width: 280px;
}

.footer__info a {
	color: var(--color-text-light);
	text-decoration: none;
	transition: opacity var(--transition-fast);
}

.footer__info a:hover {
	opacity: 0.8;
	text-decoration: underline;
}

/* Footer Right (services + legal) */
.footer__right {
	padding-left: var(--space-2xl);
	align-self: stretch;
	position: relative;
}

.footer__right::before {
	content: '';
	position: absolute;
	left: 0;
	top: calc(-1 * var(--space-4xl));
	bottom: calc(-1 * var(--space-3xl));
	width: 1px;
	background-color: rgba(255, 255, 255, 0.15);
}

/* Service Columns */
.footer__services {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-xl);
}

.footer__column {
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
}

.footer__title {
	color: var(--color-link-footer);
	font-family: var(--font-heading);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-semibold);
	margin: 0;
}

.footer__menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.8rem;
}

.footer__menu li {
	margin: 0;
	padding: 0;
}

.footer__menu a {
	color: rgba(255, 255, 255, 0.75);
	text-decoration: none;
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-normal);
	transition: color var(--transition-fast);
	display: block;
}

.footer__menu a:hover {
	color: var(--color-link-footer);
}

/* Footer Bottom (legal links under service columns) */
.footer__bottom {
	padding-top: var(--space-2xl);
	margin-top: var(--space-2xl);
}

.footer__legal {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	gap: var(--space-xl);
	flex-wrap: wrap;
}

.footer__legal li {
	margin: 0;
	padding: 0;
}

.footer__legal a {
	color: rgba(255, 255, 255, 0.7);
	text-decoration: none;
	font-size: var(--font-size-xs);
	transition: color var(--transition-fast);
}

.footer__legal a:hover {
	color: var(--color-link-footer);
}

/* Hide nested sub-menus in legal links */
.footer__legal .sub-menu,
.footer__legal ul ul {
	display: none;
}

/* Footer Responsive */
@media screen and (max-width: 1024px) {
	.footer__services {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--space-xl);
	}
}

@media screen and (max-width: 768px) {
	.footer__container {
		grid-template-columns: 1fr;
		gap: var(--space-xl);
	}

	.footer__right {
		padding-left: 0;
	}

	.footer__right::before {
		display: none;
	}

	.footer__services {
		display: none;
	}

	.footer__company {
		align-items: center;
		text-align: center;
	}

	.footer__info {
		max-width: 100%;
	}

	.footer__bottom {
		padding-top: var(--space-lg);
		margin-top: var(--space-lg);
		border-top: 1px solid rgba(255, 255, 255, 0.1);
	}

	.footer__legal {
		flex-direction: column;
		gap: var(--space-sm);
		text-align: center;
	}
}

@media screen and (max-width: 480px) {
	.footer__main {
		padding: var(--space-3xl) 0 var(--space-2xl);
	}

	.footer__container {
		padding: 0 var(--space-lg);
	}
}

/* ========================================
   Infrastructure Partner Section
   ======================================== */
/* Remove constrained layout max-width from block wrapper — max-width lives on __container */
.wp-block-ccn-infra-partner.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
	max-width: none;
	margin-left: 0;
	margin-right: 0;
}

.infrastructure-partner {
	background-color: var(--color-bg-white);
	padding: var(--space-4xl) 0;
}

.infrastructure-partner__container {
	max-width: var(--max-width);
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-3xl);
	align-items: center;
}

/* Image Grid */
.infrastructure-partner__images {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.infrastructure-partner__image-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-md);
}

.infrastructure-partner__image {
	overflow: hidden;
}

.infrastructure-partner__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.infrastructure-partner__image--top img,
.infrastructure-partner__image--bottom img {
	height: 260px;
}

.infrastructure-partner__image--mid img {
	height: 200px;
}

/* Content */
.infrastructure-partner__content {
	padding: var(--space-xl) 0;
}

.infrastructure-partner__heading {
	color: var(--color-primary);
	font-family: var(--font-heading);
	font-size: 46px;
	font-weight: var(--font-weight-medium);
	line-height: 1.2;
	margin: 0 0 var(--space-xl);
}

.infrastructure-partner__description {
	font-family: var(--font-body);
	font-size: var(--font-size-base);
	color: var(--color-text);
	line-height: 1.7;
	margin: 0 0 var(--space-2xl);
}

.infrastructure-partner__description p {
	margin: 0 0 var(--space-lg);
}

.infrastructure-partner__description p:last-child {
	margin-bottom: 0;
}

/* Features Grid */
.infrastructure-partner__features {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	border: 1px solid #E5E7EB;
}

.infrastructure-partner__feature {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	padding: var(--space-lg);
	border-right: 1px solid #E5E7EB;
	border-bottom: 1px solid #E5E7EB;
}

.infrastructure-partner__feature:nth-child(2n) {
	border-right: none;
}

.infrastructure-partner__feature:nth-last-child(-n+2) {
	border-bottom: none;
}

.infrastructure-partner__feature-icon {
	width: 32px;
	height: 32px;
	object-fit: contain;
	flex-shrink: 0;
}

.infrastructure-partner__feature-text {
	font-family: var(--font-heading);
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-medium);
	color: var(--color-text);
}

/* Our Services Responsive */
@media screen and (max-width: 1024px) {
	.our-services__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.service-card {
		min-height: 350px;
	}
}

@media screen and (max-width: 768px) {
	.our-services__heading {
		font-size: var(--font-size-2xl);
		margin: 0 0 var(--space-2xl);
	}

	.our-services__grid {
		grid-template-columns: 1fr;
		gap: var(--space-sm);
	}

	.service-card {
		min-height: 300px;
		aspect-ratio: auto;
	}

	.service-card__overlay {
		padding: var(--space-lg);
	}

	.service-card__title {
		font-size: var(--font-size-md);
	}

	.service-card__description {
		font-size: var(--font-size-sm);
	}
}

/* ========================================
   FAQ Section
   ======================================== */
.faq {
	background-color: #EAF0FF;
	padding: var(--space-5xl) 0;
}

.faq__container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 var(--space-lg);
}

.faq__heading {
	color: #1F5C9F;
	font-family: var(--font-heading);
	font-size: 46px;
	font-weight: var(--font-weight-medium);
	margin: 0 0 var(--space-2xl);
}

/* Accordion */
.faq__accordion {
	display: flex;
	flex-direction: column;
}

.faq__item {
	background-color: transparent;
	border-bottom: 1px solid rgba(0, 0, 0, 0.07);
}

.faq__item:first-child {
	border-top: 1px solid rgba(0, 0, 0, 0.07);
}

.faq__question {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-lg);
	padding: 20px 0;
	background: none;
	border: none;
	font-family: var(--font-body);
	font-size: 18px;
	font-weight: var(--font-weight-medium);
	color: #160042;
	text-align: left;
	cursor: pointer;
	transition: all var(--transition-base);
}

.faq__question:hover {
	color: var(--color-primary);
}

.faq__icon {
	flex-shrink: 0;
	transition: transform var(--transition-base);
}

.faq__question[aria-expanded="true"] .faq__icon {
	transform: rotate(180deg);
}

.faq__answer {
	overflow: hidden;
	max-height: 0;
	transition: max-height 0.3s ease;
}

.faq__answer:not([hidden]) {
	max-height: 500px;
	padding: 0 0 var(--space-lg);
}

.faq__answer p {
	font-family: var(--font-body);
	font-size: var(--font-size-base);
	color: var(--color-text);
	line-height: 1.7;
	margin: 0;
}

/* Image */
.faq__image {
	position: sticky;
	top: var(--space-2xl);
}

.faq__image img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
	border-radius: 8px;
}

/* Infrastructure Partner Responsive */
@media screen and (max-width: 1024px) {
	.infrastructure-partner__container {
		gap: var(--space-3xl);
	}

	.infrastructure-partner__heading {
		font-size: var(--font-size-2xl);
	}

	.infrastructure-partner__feature-text {
		font-size: var(--font-size-base);
	}
}

@media screen and (max-width: 768px) {
	.infrastructure-partner {
		padding: var(--space-3xl) 0;
	}

	.infrastructure-partner__container {
		grid-template-columns: 1fr;
		gap: var(--space-2xl);
	}

	.infrastructure-partner__content {
		padding: 0;
	}

	.infrastructure-partner__heading {
		font-size: var(--font-size-xl);
		margin-bottom: var(--space-lg);
	}

	.infrastructure-partner__description {
		font-size: var(--font-size-sm);
		margin-bottom: var(--space-xl);
	}

	.infrastructure-partner__description p {
		margin-bottom: var(--space-md);
	}

	.infrastructure-partner__features {
		grid-template-columns: 1fr;
	}

	.infrastructure-partner__feature {
		padding: var(--space-lg);
		border-right: none;
	}

	.infrastructure-partner__feature:not(:last-child) {
		border-bottom: 1px solid #E0E0E0;
	}

	.infrastructure-partner__feature:last-child {
		border-bottom: none;
	}

	.infrastructure-partner__feature-icon {
		width: 32px;
		height: 32px;
	}

	.infrastructure-partner__feature-text {
		font-size: var(--font-size-sm);
	}
}

/* FAQ Responsive */
@media screen and (max-width: 1200px) {
	.faq__image {
		display: none;
	}

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

	.faq--with-image {
		grid-template-columns: 1fr;
	}
}

@media screen and (max-width: 1024px) {
	.faq__container {
		gap: var(--space-3xl);
	}

	.faq__heading {
		font-size: var(--font-size-2xl);
	}
}

@media screen and (max-width: 768px) {
	.faq {
		padding: var(--space-3xl) 0;
	}

	.faq__container {
		grid-template-columns: 1fr;
		gap: var(--space-2xl);
	}

	.faq__heading {
		font-size: var(--font-size-xl);
		margin-bottom: var(--space-2xl);
	}

	.faq__question {
		padding: var(--space-lg) 0;
		font-size: var(--font-size-base);
	}

	.faq__answer:not([hidden]) {
		padding: 0 var(--space-lg) var(--space-lg);
	}

	.faq__answer p {
		font-size: var(--font-size-sm);
	}

	.faq__image {
		position: static;
		order: -1;
	}
}

/* ========================================
   Testimonials Section
   ======================================== */
.testimonials {
	background-color: var(--color-bg-white);
	padding: var(--space-3xl, 4rem) 0;
}

.testimonials__container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0;
}

.testimonials__header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: var(--space-3xl);
	margin-bottom: var(--space-3xl);
}

.testimonials__intro {
	flex: 1;
}

.testimonials__title {
	color: var(--color-primary);
	font-family: var(--font-heading);
	font-size: 46px;
	font-weight: var(--font-weight-medium);
	line-height: 1.2;
	margin: 0 0 var(--space-lg);
}

.testimonials__subtitle {
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: var(--font-size-base);
	line-height: 1.6;
	margin: 0;
	max-width: 800px;
}

.testimonials__nav {
	display: flex;
	gap: var(--space-md);
	flex-shrink: 0;
}

.testimonials__nav-btn {
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: transparent;
	border: 1px solid #D1D5DB;
	border-radius: 50%;
	cursor: pointer;
	transition: all var(--transition-base);
	color: var(--color-text);
}

.testimonials__nav-btn:hover:not(:disabled) {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-text-light);
}

.testimonials__nav-btn:disabled {
	opacity: 0.3;
	cursor: not-allowed;
}

/* Carousel Wrapper - outside container, full width */
.testimonials__wrapper {
	overflow: hidden;
	margin-bottom: var(--space-3xl);
	padding: 0;
}

@media screen and (min-width: 1600px) {
	.testimonials__wrapper {
		padding: 0 20%;
	}
}

.testimonials__track {
	display: flex;
	gap: var(--space-lg);
	transition: transform 0.5s ease;
}

/* Testimonial Card */
.testimonial-card {
	flex: 0 0 calc(33.333% - 12px);
	background-color: var(--color-bg-white);
	border: 1px solid #E5E7EB;
	border-radius: 0;
	padding: var(--space-2xl);
	display: flex;
	flex-direction: column;
	min-height: 320px;
}

.testimonial-card__quote {
	flex: 1;
	margin-bottom: var(--space-xl);
}

.testimonial-card__quote::after {
	content: '';
	display: block;
	width: 100%;
	height: 1px;
	background-color: #E5E7EB;
	margin-top: var(--space-2xl);
}

.testimonial-card__quote p {
	font-family: var(--font-body);
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-dark);
	line-height: 1.7;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 8;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.testimonial-card__footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-lg);
}

.testimonial-card__author {
	flex: 1;
}

.testimonial-card__name {
	font-family: var(--font-heading);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-dark);
	margin: 0 0 var(--space-xs);
}

.testimonial-card__company {
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	color: var(--color-text);
	margin: 0;
}

.testimonial-card__logo {
	flex-shrink: 0;
	max-width: 140px;
}

.testimonial-card__logo img {
	width: 100%;
	height: auto;
	max-height: 55px;
	object-fit: contain;
}

/* Dots Navigation */
.testimonials__dots {
	display: flex;
	justify-content: center;
	gap: var(--space-sm);
}

.testimonials__dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background-color: #D1D5DB;
	border: none;
	padding: 0;
	cursor: pointer;
	transition: all var(--transition-base);
}

.testimonials__dot:hover {
	background-color: #9CA3AF;
}

.testimonials__dot.active {
	background-color: var(--color-primary);
	width: 32px;
	border-radius: 5px;
}

/* Testimonials Responsive */
@media screen and (max-width: 1024px) {
	.testimonials {
		padding: var(--space-4xl) 0;
	}

	.testimonials__title {
		font-size: var(--font-size-3xl);
	}

	.testimonial-card {
		flex: 0 0 calc(50% - var(--space-lg) / 2);
	}
}

@media screen and (max-width: 768px) {
	.testimonials {
		padding: var(--space-3xl) 0;
		display: flex;
		flex-direction: column;
	}

	.testimonials__header {
		flex-direction: column;
		gap: var(--space-sm);
		margin-bottom: var(--space-lg);
	}

	.testimonials__title {
		font-size: var(--font-size-2xl);
	}

	.testimonials__subtitle {
		font-size: var(--font-size-sm);
	}

	.testimonials__dots {
		display: none;
	}

	.testimonials__dots {
		display: none;
	}

	.testimonials {
		position: relative;
		padding-bottom: calc(var(--space-xl) + 20px);
	}

	.testimonials__nav {
		position: absolute;
		bottom: var(--space-xl);
		left: 50%;
		transform: translateX(-50%);
	}

	.testimonials__nav-btn {
		width: 36px;
		height: 36px;
		color: var(--color-text-dark, #333);
		border-color: #D1D5DB;
		background-color: var(--color-bg-white, #fff);
		padding: 10px;
	}

	.testimonial-card {
		flex: 0 0 100%;
		min-height: 240px;
		padding: var(--space-xl);
	}

	.testimonial-card__quote {
		margin-bottom: 0;
	}

	.testimonial-card__quote::after {
		margin-top: var(--space-xl);
	}

	.testimonial-card__quote p {
		font-size: var(--font-size-sm);
		-webkit-line-clamp: 8;
	}

	.testimonial-card__name {
		font-size: var(--font-size-sm);
	}

	.testimonial-card__company {
		font-size: var(--font-size-xs);
	}

	.testimonial-card__logo {
		max-width: 60px;
	}

	.testimonial-card__logo img {
		max-height: 30px;
	}
}

/* ==================================================
   Projects Archive
   ================================================== */

/* Grid Section */
.projects-archive .hero--small {
	min-height: 200px;
}

.projects-archive__grid-section {
	padding: 60px 0 80px;
	background: #fff;
}

.projects-archive__container {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 var(--space-xl);
}

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

/* Card */
.projects-archive__card {
	list-style: none;
}

.projects-archive__card-link {
	position: relative;
	display: block;
	overflow: hidden;
	border-radius: 0;
	min-height: 350px;
	background: #e0e0e0;
	text-decoration: none;
}

.projects-archive__card-image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.projects-archive__card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.projects-archive__card-link:hover .projects-archive__card-image img {
	transform: scale(1.05);
}

.projects-archive__card-image--placeholder {
	background: linear-gradient(135deg, var(--color-primary) 0%, #001F3F 100%);
}

.projects-archive__card-overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	min-height: 140px;
	background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.5) 50%, transparent 100%);
	display: flex;
	align-items: flex-end;
	padding: var(--space-xl);
	transition: min-height 0.4s ease;
}

.projects-archive__card-link:hover .projects-archive__card-overlay {
	min-height: 200px;
}

.projects-archive__card-content {
	width: 100%;
	color: #fff;
}

.projects-archive__card-cat {
	display: inline-block;
	font-family: var(--font-body);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #fff;
	background: var(--color-primary);
	padding: 0.2em 0.6em;
	border-radius: 3px;
	margin-bottom: var(--space-xs);
}

.projects-archive__card-title {
	font-family: var(--font-heading);
	font-size: 1.35rem;
	color: #fff;
	margin: 0;
	line-height: 1.3;
}

.projects-archive__card-excerpt {
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	color: rgba(255,255,255,0.85);
	line-height: 1.5;
	margin: var(--space-xs) 0 0;
	max-height: 0;
	opacity: 0;
	overflow: hidden;
	transition: all 0.4s ease;
}

.projects-archive__card-link:hover .projects-archive__card-excerpt {
	opacity: 1;
	max-height: 200px;
}

.projects-archive__card-arrow {
	display: inline-block;
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-primary);
	margin-top: var(--space-sm);
	opacity: 0;
	transform: translateY(5px);
	transition: all 0.3s ease;
}

.projects-archive__card-link:hover .projects-archive__card-arrow {
	opacity: 1;
	transform: translateY(0);
}

/* Pagination */
.projects-archive .nav-links {
	display: flex;
	justify-content: center;
	gap: var(--space-sm);
	padding: var(--space-xl) 0 0;
	max-width: 1280px;
	margin: 0 auto;
}

.projects-archive .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 6px;
	background: #fff;
	color: var(--color-text-dark);
	text-decoration: none;
	font-weight: 500;
	transition: all 0.2s ease;
}

.projects-archive .page-numbers.current,
.projects-archive .page-numbers:hover {
	background: var(--color-primary);
	color: #fff;
}

/* Responsive */
@media (max-width: 1024px) {
	.projects-archive__grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.projects-archive__card-link {
		min-height: 300px;
	}
}

@media (max-width: 768px) {
	.projects-archive__grid {
		grid-template-columns: 1fr;
	}
	.projects-archive__card-link {
		min-height: 280px;
	}
}

/* ==================================================
   Single Project
   ================================================== */

/* Single Project — Article */
.project-single__article {
	background: #fff;
}

.project-single__body {
	max-width: 900px;
	margin: 0 auto;
	padding: 50px var(--space-xl) 40px;
}

.project-single__skills {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: var(--space-xl);
}

.project-single__skill-tag {
	display: inline-block;
	font-family: var(--font-body);
	font-size: 0.8rem;
	font-weight: 500;
	color: var(--color-primary);
	background: rgba(43, 108, 183, 0.1);
	padding: 4px 14px;
	border-radius: 20px;
}

.project-single__content {
	font-family: var(--font-body);
	font-size: var(--font-size-base);
	line-height: 1.8;
	color: var(--color-text-body);
}

.project-single__content h2,
.project-single__content h3,
.project-single__content h4 {
	font-family: var(--font-heading);
	color: var(--color-text-dark);
	margin-top: var(--space-xl);
	margin-bottom: var(--space-md);
}

.project-single__content h2 {
	font-size: 1.5rem;
}

.project-single__content h3 {
	font-size: 1.25rem;
}

.project-single__content img {
	max-width: 100%;
	height: auto;
	border-radius: 0;
	margin: var(--space-lg) 0;
}

.project-single__content ul,
.project-single__content ol {
	padding-left: var(--space-xl);
	margin-bottom: var(--space-lg);
}

.project-single__content li {
	margin-bottom: var(--space-xs);
}

.project-single__content p {
	margin-bottom: var(--space-lg);
}

.project-single__footer {
	max-width: 900px;
	margin: 0 auto;
	padding: 0 var(--space-xl) 60px;
	border-top: 1px solid #e5e5e5;
	padding-top: var(--space-xl);
}

@media (max-width: 768px) {
	.project-single__body {
		padding: 30px var(--space-lg) 20px;
	}

	.project-single__footer {
		padding: var(--space-lg) var(--space-lg) 40px;
	}
}

/* ==================================================
   Customers Archive
   ================================================== */

.customers-archive .page-header {
	background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%);
	color: var(--color-text-light);
	padding: var(--space-xxl) 0;
	text-align: center;
	margin-bottom: var(--space-xxl);
}

.customers-archive .page-title {
	color: var(--color-text-light);
	margin-bottom: var(--space-sm);
}

.customers-archive .page-description {
	font-size: var(--font-size-lg);
	opacity: 0.95;
	max-width: 600px;
	margin: 0 auto;
}

.customers-grid {
	padding: var(--space-xxl) 0;
}

.customer-logo {
	background: var(--color-bg-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 1;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.customer-logo:hover {
	border-color: var(--color-primary);
	box-shadow: var(--shadow-sm);
}

.customer-logo__image {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
}

.customer-logo__image img {
	max-width: 100%;
	max-height: 80%;
	width: auto;
	height: auto;
	object-fit: contain;
	filter: grayscale(100%);
	opacity: 0.7;
	transition: filter var(--transition-normal), opacity var(--transition-normal);
}

.customer-logo:hover .customer-logo__image img {
	filter: grayscale(0%);
	opacity: 1;
}

.customer-logo__name {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	text-align: center;
}

.customer-logo__placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-bg-light);
	border-radius: var(--radius-sm);
}

.customer-logo__placeholder .customer-logo__name {
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-body);
}

/* ==================================================
   Grid Utilities
   ================================================== */

.grid {
	display: grid;
	gap: var(--space-xl);
}

.grid--3-col {
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}

.grid--5-col {
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}

@media (max-width: 768px) {
	.grid--3-col {
		grid-template-columns: 1fr;
	}

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

/* ==================================================
   Pagination
   ================================================== */

.pagination {
	display: flex;
	justify-content: center;
	gap: var(--space-sm);
	margin-top: var(--space-xxl);
	padding: var(--space-xl) 0;
}

.pagination .page-numbers {
	display: inline-block;
	padding: var(--space-sm) var(--space-md);
	background: var(--color-bg-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	color: var(--color-text-body);
	text-decoration: none;
	transition: background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}

.pagination .page-numbers:hover {
	background: var(--color-primary);
	color: var(--color-text-light);
	border-color: var(--color-primary);
}

.pagination .page-numbers.current {
	background: var(--color-primary);
	color: var(--color-text-light);
	border-color: var(--color-primary);
}

.pagination .page-numbers.dots {
	border: none;
	background: transparent;
}

/* ==================================================
   Search Form
   ================================================== */

.search-form__wrapper {
	display: flex;
	max-width: 500px;
}

.search-form__input {
	flex: 1;
	padding: 0.75rem 1rem;
	font-family: var(--font-body);
	font-size: var(--font-size-base);
	border: 2px solid #e5e7eb;
	border-right: none;
	outline: none;
	transition: border-color 0.2s ease;
}

.search-form__input:focus {
	border-color: var(--color-primary);
}

.search-form__submit {
	padding: 0.75rem 1.25rem;
	background-color: var(--color-primary);
	color: #fff;
	border: 2px solid var(--color-primary);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background-color 0.2s ease;
}

.search-form__submit:hover {
	background-color: var(--color-secondary);
	border-color: var(--color-secondary);
}

/* ==================================================
   404 Page
   ================================================== */

.error-404 {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 60vh;
	padding: var(--space-4xl) var(--space-xl);
	text-align: center;
	background-color: var(--color-bg-white);
}

.error-404__container {
	max-width: 600px;
}

.error-404__code {
	display: block;
	font-family: var(--font-heading);
	font-size: 8rem;
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1;
	margin-bottom: var(--space-md);
	opacity: 0.15;
}

.error-404__title {
	font-family: var(--font-heading);
	font-size: var(--font-size-3xl);
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-dark);
	margin: 0 0 var(--space-lg);
}

.error-404__description {
	font-family: var(--font-body);
	font-size: var(--font-size-base);
	color: var(--color-text-muted);
	line-height: 1.7;
	margin: 0 0 var(--space-2xl);
}

.error-404__search {
	margin-bottom: var(--space-xl);
}

.error-404__search .search-form__wrapper {
	max-width: 100%;
}

/* ==================================================
   Blog Archive
   ================================================== */

.blog-archive__header {
	background: linear-gradient(135deg, var(--color-bg-dark) 0%, var(--color-primary) 100%);
	padding: var(--space-4xl) 0;
	text-align: center;
}

.blog-archive__header-container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 var(--space-xl);
}

.blog-archive__title {
	font-family: var(--font-heading);
	font-size: var(--font-size-4xl);
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-light);
	margin: 0 0 var(--space-md);
}

.blog-archive__description {
	font-family: var(--font-body);
	font-size: var(--font-size-lg);
	color: rgba(255, 255, 255, 0.85);
	margin: 0;
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
}

.blog-archive__content {
	padding: var(--space-4xl) 0;
	background-color: var(--color-bg-white);
}

.blog-archive__container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 var(--space-xl);
}

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

/* Blog Card */
.blog-card__link {
	display: block;
	text-decoration: none;
	color: inherit;
	border: 1px solid #e5e7eb;
	overflow: hidden;
	transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.blog-card__link:hover {
	box-shadow: var(--shadow-lg);
	transform: translateY(-4px);
}

.blog-card__image {
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background-color: #f3f4f6;
}

.blog-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.blog-card__link:hover .blog-card__image img {
	transform: scale(1.05);
}

.blog-card__image-placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-bg-dark) 100%);
}

.blog-card__body {
	padding: var(--space-xl);
}

.blog-card__cat {
	display: inline-block;
	font-family: var(--font-body);
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-primary);
	background: rgba(43, 108, 183, 0.1);
	padding: 0.2em 0.6em;
	border-radius: 3px;
	margin-bottom: var(--space-sm);
}

.blog-card__title {
	font-family: var(--font-heading);
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-dark);
	line-height: 1.3;
	margin: 0 0 var(--space-sm);
}

.blog-card__excerpt {
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	line-height: 1.6;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.blog-card__excerpt p {
	margin: 0;
}

.blog-card__meta {
	margin-top: var(--space-md);
	font-family: var(--font-body);
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
}

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

@media screen and (max-width: 768px) {
	.blog-archive__header {
		padding: var(--space-3xl) 0;
	}

	.blog-archive__title {
		font-size: var(--font-size-2xl);
	}

	.blog-archive__grid {
		grid-template-columns: 1fr;
	}

	.blog-archive__content {
		padding: var(--space-3xl) 0;
	}
}

/* ==================================================
   Blog Single Post
   ================================================== */

.blog-single__hero {
	width: 100%;
	max-height: 500px;
	overflow: hidden;
}

.blog-single__hero-image {
	width: 100%;
	height: 500px;
	object-fit: cover;
	display: block;
}

.blog-single__container {
	max-width: 800px;
	margin: 0 auto;
	padding: var(--space-3xl) var(--space-xl) var(--space-4xl);
}

.blog-single__header {
	margin-bottom: var(--space-2xl);
}

.blog-single__meta {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	margin-bottom: var(--space-lg);
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
}

.blog-single__cat {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-primary);
	background: rgba(43, 108, 183, 0.1);
	padding: 0.2em 0.6em;
	border-radius: 3px;
}

.blog-single__title {
	font-family: var(--font-heading);
	font-size: var(--font-size-4xl);
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-dark);
	line-height: 1.2;
	margin: 0;
}

/* Blog single content */
.blog-single__content {
	font-family: var(--font-body);
	font-size: var(--font-size-base);
	line-height: 1.8;
	color: var(--color-text-body);
}

.blog-single__content h2,
.blog-single__content h3,
.blog-single__content h4 {
	font-family: var(--font-heading);
	color: var(--color-text-dark);
	margin-top: var(--space-2xl);
	margin-bottom: var(--space-md);
}

.blog-single__content h2 { font-size: 1.75rem; }
.blog-single__content h3 { font-size: 1.35rem; }

.blog-single__content p {
	margin-bottom: var(--space-lg);
}

.blog-single__content img {
	max-width: 100%;
	height: auto;
	margin: var(--space-xl) 0;
}

.blog-single__content blockquote {
	border-left: 4px solid var(--color-primary);
	padding: var(--space-md) var(--space-xl);
	margin: var(--space-xl) 0;
	background-color: #f8fafc;
	font-style: italic;
	color: var(--color-text-body);
}

.blog-single__content blockquote p:last-child {
	margin-bottom: 0;
}

/* Tags */
.blog-single__footer {
	border-top: 1px solid #e5e7eb;
	padding-top: var(--space-xl);
	margin-top: var(--space-2xl);
}

.blog-single__tags {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
}

.blog-single__tag {
	display: inline-block;
	font-family: var(--font-body);
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
	background: #f3f4f6;
	padding: 0.3em 0.8em;
	border-radius: 3px;
	text-decoration: none;
	transition: color 0.2s ease, background 0.2s ease;
}

.blog-single__tag:hover {
	color: var(--color-primary);
	background: rgba(43, 108, 183, 0.1);
}

/* Post navigation */
.blog-single__nav {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-xl);
	margin-top: var(--space-2xl);
	padding-top: var(--space-2xl);
	border-top: 1px solid #e5e7eb;
}

.blog-single__nav-link {
	text-decoration: none;
	display: block;
	padding: var(--space-lg);
	border: 1px solid #e5e7eb;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.blog-single__nav-link:hover {
	border-color: var(--color-primary);
	box-shadow: var(--shadow-sm);
}

.blog-single__nav-link--next {
	text-align: right;
}

.blog-single__nav-label {
	display: block;
	font-family: var(--font-body);
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
	margin-bottom: var(--space-xs);
}

.blog-single__nav-title {
	display: block;
	font-family: var(--font-heading);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-dark);
	line-height: 1.4;
}

@media screen and (max-width: 768px) {
	.blog-single__hero-image {
		height: 300px;
	}

	.blog-single__container {
		padding: var(--space-2xl) var(--space-lg) var(--space-3xl);
	}

	.blog-single__title {
		font-size: var(--font-size-2xl);
	}

	.blog-single__meta {
		flex-wrap: wrap;
		gap: var(--space-sm);
	}

	.blog-single__nav {
		grid-template-columns: 1fr;
	}

	.blog-single__nav-link--next {
		text-align: left;
	}
}

/* ==================================================
   Search Results
   ================================================== */

.search-results__header {
	background: linear-gradient(135deg, var(--color-bg-dark) 0%, var(--color-primary) 100%);
	padding: var(--space-4xl) 0;
	text-align: center;
}

.search-results__header-container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 var(--space-xl);
}

.search-results__title {
	font-family: var(--font-heading);
	font-size: var(--font-size-3xl);
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-light);
	margin: 0 0 var(--space-xl);
}

.search-results__title span {
	color: rgba(255, 255, 255, 0.7);
}

.search-results__form {
	display: flex;
	justify-content: center;
}

.search-results__form .search-form__wrapper {
	max-width: 500px;
	width: 100%;
}

.search-results__form .search-form__input {
	border-color: rgba(255, 255, 255, 0.3);
	background: rgba(255, 255, 255, 0.1);
	color: #fff;
}

.search-results__form .search-form__input::placeholder {
	color: rgba(255, 255, 255, 0.5);
}

.search-results__form .search-form__input:focus {
	border-color: #fff;
	background: rgba(255, 255, 255, 0.15);
}

.search-results__content {
	padding: var(--space-4xl) 0;
	background-color: var(--color-bg-white);
}

.search-results__container {
	max-width: 800px;
	margin: 0 auto;
	padding: 0 var(--space-xl);
}

.search-results__count {
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	margin: 0 0 var(--space-2xl);
}

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

.search-results__item {
	display: flex;
	gap: var(--space-xl);
	padding-bottom: var(--space-xl);
	border-bottom: 1px solid #e5e7eb;
}

.search-results__thumb {
	flex-shrink: 0;
	width: 180px;
	height: 130px;
	overflow: hidden;
}

.search-results__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.search-results__item-content {
	flex: 1;
}

.search-results__type {
	display: inline-block;
	font-family: var(--font-body);
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-primary);
	margin-bottom: var(--space-xs);
}

.search-results__item-title {
	font-family: var(--font-heading);
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-semibold);
	line-height: 1.3;
	margin: 0 0 var(--space-sm);
}

.search-results__item-title a {
	color: var(--color-text-dark);
	text-decoration: none;
}

.search-results__item-title a:hover {
	color: var(--color-primary);
}

.search-results__excerpt {
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	line-height: 1.6;
}

.search-results__excerpt p {
	margin: 0;
}

.search-results__none {
	text-align: center;
	padding: var(--space-4xl) 0;
}

.search-results__none h2 {
	font-family: var(--font-heading);
	font-size: var(--font-size-2xl);
	color: var(--color-text-dark);
	margin: 0 0 var(--space-md);
}

.search-results__none p {
	color: var(--color-text-muted);
	margin: 0 0 var(--space-2xl);
}

@media screen and (max-width: 768px) {
	.search-results__header {
		padding: var(--space-3xl) 0;
	}

	.search-results__title {
		font-size: var(--font-size-2xl);
	}

	.search-results__item {
		flex-direction: column;
		gap: var(--space-md);
	}

	.search-results__thumb {
		width: 100%;
		height: 200px;
	}

	.search-results__content {
		padding: var(--space-3xl) 0;
	}
}

/* ==================================================
   Comments
   ================================================== */

.comments-area {
	margin-top: var(--space-2xl);
	padding-top: var(--space-2xl);
	border-top: 1px solid #e5e7eb;
}

.comments-title {
	font-family: var(--font-heading);
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-dark);
	margin: 0 0 var(--space-xl);
}

.comment-list {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-2xl);
}

.comment-list .comment {
	padding: var(--space-lg) 0;
	border-bottom: 1px solid #f3f4f6;
}

.comment-list .comment-body {
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	line-height: 1.7;
	color: var(--color-text-body);
}

.comment-author {
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-dark);
	margin-bottom: var(--space-xs);
}

.comment-metadata {
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
	margin-bottom: var(--space-sm);
}

.comment-metadata a {
	color: var(--color-text-muted);
	text-decoration: none;
}

.comment-respond {
	margin-top: var(--space-xl);
}

.comment-reply-title {
	font-family: var(--font-heading);
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-dark);
	margin: 0 0 var(--space-lg);
}

.comment-form label {
	display: block;
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-dark);
	margin-bottom: var(--space-xs);
}

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	padding: 0.75rem 1rem;
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	border: 2px solid #e5e7eb;
	outline: none;
	transition: border-color 0.2s ease;
	margin-bottom: var(--space-md);
}

.comment-form input:focus,
.comment-form textarea:focus {
	border-color: var(--color-primary);
}

.comment-form .form-submit .submit {
	display: inline-block;
	padding: 0.75rem 2rem;
	background-color: var(--color-primary);
	color: #fff;
	border: none;
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-semibold);
	cursor: pointer;
	transition: background-color 0.2s ease;
}

.comment-form .form-submit .submit:hover {
	background-color: var(--color-secondary);
}

/* ==================================================
   WP Pagination (the_posts_pagination)
   ================================================== */

.nav-links {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--space-sm);
	margin-top: var(--space-3xl);
}

.nav-links .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 var(--space-sm);
	background: var(--color-bg-white);
	border: 1px solid #e5e7eb;
	color: var(--color-text-body);
	text-decoration: none;
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-medium);
	transition: all 0.2s ease;
}

.nav-links .page-numbers:hover {
	background: var(--color-primary);
	color: #fff;
	border-color: var(--color-primary);
}

.nav-links .page-numbers.current {
	background: var(--color-primary);
	color: #fff;
	border-color: var(--color-primary);
}

.nav-links .page-numbers.dots {
	border: none;
	background: transparent;
}

/* ==================================================
   Contact Form 7
   ================================================== */

.q-title {
	margin-bottom: 30px;
	max-width: 740px;
}

.wpcf7 {
	max-width: 740px;
}

.wpcf7-form p {
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-dark);
	margin: 0;
	line-height: 1.4;
}

.wpcf7-form-control.wpcf7-text,
.wpcf7-form-control.wpcf7-email,
.wpcf7-form-control.wpcf7-tel,
.wpcf7-form-control.wpcf7-textarea,
.wpcf7-form-control.wpcf7-select {
	display: block;
	width: 100%;
	margin-top: var(--space-xs);
	padding: 0.75rem 1rem;
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	color: var(--color-text-dark);
	background: var(--color-bg-white);
	border: 1px solid #d1d5db;
	border-radius: 0;
	outline: none;
	transition: border-color 0.2s ease;
	-webkit-appearance: none;
	appearance: none;
	margin-bottom: 20px;
}

.wpcf7-form-control.wpcf7-text:focus,
.wpcf7-form-control.wpcf7-email:focus,
.wpcf7-form-control.wpcf7-tel:focus,
.wpcf7-form-control.wpcf7-textarea:focus,
.wpcf7-form-control.wpcf7-select:focus {
	border-color: var(--color-primary);
}

.wpcf7-form-control.wpcf7-textarea {
	min-height: 150px;
	resize: vertical;
}

.wpcf7-form-control.wpcf7-select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236B7280' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	padding-right: 2.5rem;
}

.wpcf7-form-control.wpcf7-submit {
	display: block;
	width: 100%;
	padding: 0.875rem 2rem;
	font-family: var(--font-body);
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--color-text-light);
	background-color: var(--color-accent);
	border: 2px solid var(--color-accent);
	border-radius: 0;
	cursor: pointer;
	transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.wpcf7-form-control.wpcf7-submit:hover {
	background-color: #b91f21;
	border-color: #b91f21;
	transform: translateY(-1px);
	box-shadow: var(--shadow-md);
}

.wpcf7-not-valid {
	border-color: var(--color-accent) !important;
}

.wpcf7-not-valid-tip {
	font-family: var(--font-body);
	font-size: var(--font-size-xs);
	color: var(--color-accent);
	margin-top: var(--space-xs);
}

.wpcf7-response-output {
	font-family: var(--font-body);
	font-size: var(--font-size-sm);
	padding: var(--space-md) var(--space-lg) !important;
	margin: var(--space-lg) 0 0 !important;
	border-radius: 0;
}

.wpcf7-mail-sent-ok {
	border-color: #10b981 !important;
	color: #065f46;
	background: #ecfdf5;
}

.wpcf7-validation-errors,
.wpcf7-acceptance-missing {
	border-color: var(--color-accent) !important;
	color: #991b1b;
	background: #fef2f2;
}

.wpcf7-spinner {
	margin: var(--space-sm) auto 0;
}
