/**
 * Amair EG — mobile-first, cyan theme, dark mode, RTL-ready.
 */

:root {
	--font-sans: "DM Sans", system-ui, sans-serif;
	--font-ar: "Noto Sans Arabic", "DM Sans", system-ui, sans-serif;
	--color-primary: #00bcd4;
	--color-primary-dark: #0097a7;
	--color-primary-soft: rgba(0, 188, 212, 0.14);
	--color-bg: #f6fafb;
	--color-surface: #ffffff;
	--color-text: #0f1720;
	--color-muted: #4a5c68;
	--color-border: rgba(15, 23, 32, 0.1);
	--shadow-sm: 0 4px 20px rgba(6, 22, 32, 0.06);
	--shadow-md: 0 12px 40px rgba(6, 22, 32, 0.1);
	--radius: 14px;
	--radius-sm: 10px;
	--header-h: 72px;
	--transition: 0.25s ease;
}

html[data-theme="dark"] {
	--color-bg: #0b1216;
	--color-surface: #121b21;
	--color-text: #e8f1f4;
	--color-muted: #9fb0ba;
	--color-border: rgba(232, 241, 244, 0.1);
	--shadow-sm: 0 4px 24px rgba(0, 0, 0, 0.35);
	--shadow-md: 0 16px 48px rgba(0, 0, 0, 0.45);
}

html[dir="rtl"] body {
	font-family: var(--font-ar);
}

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

body {
	margin: 0;
	font-family: var(--font-sans);
	font-size: 1rem;
	line-height: 1.6;
	color: var(--color-text);
	background: var(--color-bg);
	transition: background-color var(--transition), color var(--transition);
}

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

a {
	color: var(--color-primary-dark);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.15em;
}

a:hover {
	color: var(--color-primary);
}

.container {
	width: min(100% - 2rem, 1200px);
	margin-inline: auto;
}

.container--narrow {
	width: min(100% - 2rem, 640px);
}

/* Skip link */
.skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 100000;
	padding: 0.75rem 1rem;
	background: var(--color-primary);
	color: #061016;
	font-weight: 600;
}

.skip-link:focus {
	left: 1rem;
}

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

/* Header */
.site-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: color-mix(in srgb, var(--color-surface) 88%, transparent);
	backdrop-filter: blur(12px);
	border-bottom: 1px solid var(--color-border);
	transition: box-shadow var(--transition), background var(--transition);
}

.site-header.is-stuck {
	box-shadow: var(--shadow-sm);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	min-height: var(--header-h);
	width: min(100% - 2rem, 1200px);
	margin-inline: auto;
}

.site-branding .custom-logo-link,
.site-branding .site-title {
	display: inline-flex;
	align-items: center;
}

.site-title {
	font-weight: 700;
	font-size: 1.25rem;
	color: var(--color-text);
	text-decoration: none;
}

.nav-toggle {
	display: none;
	flex-direction: column;
	gap: 5px;
	padding: 0.5rem;
	background: transparent;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	cursor: pointer;
}

.nav-toggle__bar {
	width: 22px;
	height: 2px;
	background: var(--color-text);
	border-radius: 2px;
}

.site-nav {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	flex: 1;
	justify-content: flex-end;
}

.primary-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem 1.25rem;
	align-items: center;
}

.primary-menu a {
	color: var(--color-text);
	text-decoration: none;
	font-weight: 500;
	padding: 0.35rem 0;
	border-bottom: 2px solid transparent;
	transition: border-color var(--transition), color var(--transition);
}

.primary-menu a:hover,
.primary-menu .current-menu-item > a {
	border-color: var(--color-primary);
	color: var(--color-primary-dark);
}

.site-header__actions {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-inline-start: 1rem;
}

.lang-switcher {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-weight: 600;
	font-size: 0.875rem;
}

.lang-switcher__btn {
	color: var(--color-muted);
	text-decoration: none;
	padding: 0.25rem 0.35rem;
	border-radius: 6px;
}

.lang-switcher__btn.is-active {
	color: var(--color-primary-dark);
	background: var(--color-primary-soft);
}

html[data-theme="dark"] .lang-switcher__btn.is-active {
	color: var(--color-primary);
}

.theme-toggle {
	position: relative;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 1px solid var(--color-border);
	background: var(--color-surface);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: transform var(--transition), border-color var(--transition);
}

.theme-toggle:hover {
	transform: scale(1.04);
	border-color: var(--color-primary);
}

.theme-toggle__icon {
	position: absolute;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	transition: opacity var(--transition), transform var(--transition);
}

.theme-toggle__icon--sun {
	background: radial-gradient(circle at 35% 35%, #ffe082 0%, #ffb300 100%);
	opacity: 1;
}

.theme-toggle__icon--moon {
	background: radial-gradient(circle at 30% 30%, #e0e0e0 0%, #90a4ae 100%);
	opacity: 0;
}

html[data-theme="dark"] .theme-toggle__icon--sun {
	opacity: 0;
	transform: scale(0.5);
}

html[data-theme="dark"] .theme-toggle__icon--moon {
	opacity: 1;
	transform: scale(1);
}

@media (max-width: 900px) {
	.nav-toggle {
		display: flex;
	}

	.site-nav {
		position: fixed;
		inset: var(--header-h) 0 auto 0;
		background: var(--color-surface);
		border-bottom: 1px solid var(--color-border);
		flex-direction: column;
		align-items: stretch;
		padding: 1rem 1.5rem 1.5rem;
		gap: 1rem;
		transform: translateY(-120%);
		opacity: 0;
		pointer-events: none;
		transition: transform var(--transition), opacity var(--transition);
		max-height: calc(100vh - var(--header-h));
		overflow-y: auto;
	}

	.site-nav.is-open {
		transform: translateY(0);
		opacity: 1;
		pointer-events: auto;
	}

	.primary-menu {
		flex-direction: column;
		align-items: flex-start;
	}

	.site-header__actions {
		margin-inline-start: 0;
		justify-content: space-between;
		width: 100%;
	}
}

/* Buttons */
.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.75rem 1.35rem;
	font-weight: 600;
	font-size: 0.95rem;
	border-radius: 999px;
	border: none;
	cursor: pointer;
	text-decoration: none;
	transition: background var(--transition), color var(--transition), transform 0.15s ease;
}

.button:active {
	transform: translateY(1px);
}

.button--primary {
	background: linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));
	color: #061016;
	box-shadow: 0 8px 24px rgba(0, 188, 212, 0.35);
}

.button--primary:hover {
	filter: brightness(1.05);
	color: #061016;
}

.button--ghost {
	background: transparent;
	color: var(--color-text);
	border: 1px solid var(--color-border);
}

.button--ghost:hover {
	border-color: var(--color-primary);
	color: var(--color-primary-dark);
}

.button--small {
	padding: 0.45rem 0.9rem;
	font-size: 0.875rem;
}

/* Hero */
.hero {
	position: relative;
	min-height: min(78vh, 820px);
	display: flex;
	align-items: flex-end;
	overflow: hidden;
}

.hero__media {
	position: absolute;
	inset: 0;
}

.hero__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(6, 16, 22, 0.2) 0%, rgba(6, 16, 22, 0.75) 100%);
}

.hero__content {
	position: relative;
	z-index: 1;
	padding: 4rem 0 3.5rem;
	width: 100%;
	color: #f0fdff;
}

.hero__title {
	font-size: clamp(1.85rem, 4vw, 3rem);
	line-height: 1.15;
	margin: 0 0 1rem;
	max-width: 18ch;
	text-wrap: balance;
}

.hero__sub {
	font-size: 1.05rem;
	max-width: 52ch;
	margin: 0 0 1.75rem;
	opacity: 0.95;
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

/* Sections */
.section {
	padding: clamp(3rem, 6vw, 5rem) 0;
}

.section--alt {
	background: var(--color-surface);
	border-block: 1px solid var(--color-border);
}

.section__title {
	font-size: clamp(1.5rem, 3vw, 2rem);
	margin: 0 0 2rem;
	text-align: center;
}

.section__title--on-dark {
	color: #f0fdff;
}

[data-reveal] {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}

[data-reveal].is-visible {
	opacity: 1;
	transform: none;
}

/* Metrics */
.metrics__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
}

@media (min-width: 768px) {
	.metrics__grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.metric-card {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	padding: 1.5rem;
	text-align: center;
	box-shadow: var(--shadow-sm);
	transition: transform var(--transition), box-shadow var(--transition);
}

.metric-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-md);
}

.metric-card__num {
	font-size: clamp(1.75rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--color-primary-dark);
	margin: 0 0 0.35rem;
}

html[data-theme="dark"] .metric-card__num {
	color: var(--color-primary);
}

.metric-card__label {
	margin: 0;
	color: var(--color-muted);
	font-weight: 500;
}

/* Problems */
.problems__grid {
	display: grid;
	gap: 1rem;
}

@media (min-width: 768px) {
	.problems__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.problem-card {
	padding: 1.5rem;
	border-radius: var(--radius);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
}

.problem-card__title {
	margin: 0 0 0.5rem;
	font-size: 1.15rem;
}

.problem-card__text {
	margin: 0;
	color: var(--color-muted);
}

/* Why */
.why__layout {
	display: grid;
	gap: 2rem;
	align-items: start;
}

@media (min-width: 900px) {
	.why__layout {
		grid-template-columns: 1fr 1.1fr;
	}
}

.why__img {
	width: 100%;
	border-radius: var(--radius);
	box-shadow: var(--shadow-md);
}

.why__features {
	display: grid;
	gap: 1rem;
}

@media (min-width: 600px) {
	.why__features {
		grid-template-columns: repeat(2, 1fr);
	}
}

.feature-card {
	padding: 1.25rem;
	border-radius: var(--radius-sm);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	position: relative;
	padding-inline-start: 3.25rem;
}

html[dir="rtl"] .feature-card {
	padding-inline-start: 1.25rem;
	padding-inline-end: 3.25rem;
}

.feature-card__icon {
	position: absolute;
	inset-block-start: 1.25rem;
	inset-inline-start: 1rem;
	width: 32px;
	height: 32px;
	border-radius: 10px;
	background: var(--color-primary-soft);
	border: 1px solid rgba(0, 188, 212, 0.35);
}

html[dir="rtl"] .feature-card__icon {
	inset-inline-start: auto;
	inset-inline-end: 1rem;
}

.feature-card__icon--pin::after,
.feature-card__icon--design::after,
.feature-card__icon--doc::after,
.feature-card__icon--care::after {
	content: "";
	position: absolute;
	inset: 8px;
	background: var(--color-primary-dark);
	mask: radial-gradient(circle, #000 60%, transparent 62%);
}

.feature-card__title {
	margin: 0 0 0.35rem;
	font-size: 1.05rem;
}

.feature-card__text {
	margin: 0;
	color: var(--color-muted);
	font-size: 0.95rem;
}

/* Cases */
.cases__grid {
	display: grid;
	gap: 1.25rem;
}

@media (min-width: 768px) {
	.cases__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.case-card {
	border-radius: var(--radius);
	overflow: hidden;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	box-shadow: var(--shadow-sm);
	transition: transform var(--transition), box-shadow var(--transition);
}

.case-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-md);
}

.case-card__link {
	display: block;
	color: inherit;
	text-decoration: none;
}

.case-card__media {
	aspect-ratio: 16 / 10;
	overflow: hidden;
}

.case-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
}

.case-card:hover .case-card__img {
	transform: scale(1.04);
}

.case-card__body {
	padding: 1.25rem;
}

.case-card__title {
	margin: 0 0 0.35rem;
	font-size: 1.15rem;
}

.case-card__meta {
	margin: 0 0 0.5rem;
	font-size: 0.875rem;
	color: var(--color-primary-dark);
}

.case-card__excerpt {
	margin: 0 0 0.75rem;
	color: var(--color-muted);
	font-size: 0.95rem;
}

.case-card__cta {
	font-weight: 600;
	color: var(--color-primary-dark);
}

/* Testimonials */
.testimonials {
	position: relative;
	overflow: hidden;
	color: #f0fdff;
}

.testimonials__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	opacity: 0.9;
}

.testimonials .container {
	position: relative;
	z-index: 1;
}

.testimonial {
	max-width: 720px;
	margin: 0 auto;
	text-align: center;
}

.testimonial__quote {
	font-size: clamp(1.1rem, 2.5vw, 1.35rem);
	line-height: 1.65;
	margin: 0 0 1rem;
}

.testimonial__cite {
	color: rgba(240, 253, 255, 0.85);
	font-style: normal;
	font-weight: 600;
}

/* Final CTA form */
.section--cta {
	background: linear-gradient(180deg, var(--color-primary-soft), transparent);
}

.final-cta__sub {
	text-align: center;
	color: var(--color-muted);
	margin: -1rem 0 2rem;
}

.form-call__row {
	margin-bottom: 1rem;
}

.form-call__label {
	display: block;
	font-weight: 600;
	margin-bottom: 0.35rem;
}

.required {
	color: #c62828;
}

.form-call__input,
.form-call__select {
	width: 100%;
	padding: 0.65rem 0.85rem;
	border-radius: var(--radius-sm);
	border: 1px solid var(--color-border);
	background: var(--color-surface);
	color: var(--color-text);
	font: inherit;
}

.form-call__input:focus,
.form-call__select:focus {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

.form-call__phone {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
}

.form-call__phone .form-call__select {
	max-width: 220px;
	flex: 0 0 auto;
}

.form-call__phone .form-call__input {
	flex: 1 1 180px;
}

.form-call__honeypot {
	position: absolute;
	left: -9999px;
	height: 0;
	overflow: hidden;
}

.form-call__message {
	min-height: 1.5rem;
	font-weight: 600;
	color: var(--color-primary-dark);
}

.form-call__submit {
	margin-top: 0.5rem;
	width: 100%;
}

/* FAQ */
.faq__item {
	border-bottom: 1px solid var(--color-border);
}

.faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 1rem 0;
	background: none;
	border: none;
	font: inherit;
	font-weight: 600;
	text-align: start;
	cursor: pointer;
	color: var(--color-text);
}

.faq__icon {
	width: 12px;
	height: 12px;
	border-inline-end: 2px solid var(--color-text);
	border-block-end: 2px solid var(--color-text);
	transform: rotate(45deg);
	transition: transform var(--transition);
	flex-shrink: 0;
}

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

.faq__answer {
	padding: 0 0 1rem;
	color: var(--color-muted);
}

.faq__answer[hidden] {
	display: none;
}

/* Footer */
.site-footer {
	background: #050a0d;
	color: #c5d4dc;
	padding: 3rem 0 0;
	margin-top: 2rem;
}

.site-footer a {
	color: #e0f7fa;
}

.site-footer__inner {
	width: min(100% - 2rem, 1200px);
	margin-inline: auto;
	display: grid;
	gap: 2rem;
	padding-bottom: 2rem;
}

@media (min-width: 768px) {
	.site-footer__inner {
		grid-template-columns: 1.2fr 1fr 1fr;
		align-items: start;
	}
}

.site-footer__name {
	font-weight: 700;
	font-size: 1.25rem;
	color: #fff;
}

.site-footer__tagline {
	margin: 0.35rem 0 0;
	color: #8a9ba8;
	font-size: 0.95rem;
}

.footer-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.5rem;
}

.footer-menu a {
	text-decoration: none;
}

.footer-menu a:hover {
	text-decoration: underline;
}

.site-footer__social-title {
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin: 0 0 0.75rem;
}

.social-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 0.75rem;
}

.social-list a {
	display: inline-flex;
	width: 40px;
	height: 40px;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: rgba(0, 188, 212, 0.15);
	border: 1px solid rgba(0, 188, 212, 0.35);
}

.social-list__icon {
	width: 18px;
	height: 18px;
	background: var(--color-primary);
	mask: radial-gradient(circle, #000 55%, transparent 56%);
}

.site-footer__bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	padding: 1rem 0;
	text-align: center;
	font-size: 0.875rem;
}

.site-footer__copy {
	margin: 0;
}

/* Page header */
.page-header {
	padding: clamp(2.5rem, 5vw, 4rem) 0 1rem;
}

.page-header--archive,
.page-header--inner {
	background: var(--color-surface);
	border-bottom: 1px solid var(--color-border);
}

.page-header--inner {
	padding-bottom: clamp(1.5rem, 3vw, 2.5rem);
}

.page-section {
	padding-top: clamp(1.5rem, 4vw, 2.5rem);
	padding-bottom: clamp(3rem, 6vw, 5rem);
}

.page-surface {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow-sm);
	padding: clamp(1.5rem, 4vw, 2.5rem);
	max-width: 900px;
	margin-inline: auto;
}

.page-title {
	margin: 0 0 0.5rem;
	font-size: clamp(1.75rem, 3vw, 2.25rem);
}

.page-intro {
	margin: 0;
	color: var(--color-muted);
	max-width: 60ch;
}

/* Project grid */
.project-grid {
	display: grid;
	gap: 1.5rem;
}

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

@media (min-width: 1000px) {
	.project-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.project-card {
	border-radius: var(--radius);
	overflow: hidden;
	border: 1px solid var(--color-border);
	background: var(--color-surface);
	box-shadow: var(--shadow-sm);
	transition: transform var(--transition), box-shadow var(--transition);
}

.project-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-md);
}

.project-card__link {
	display: block;
	color: inherit;
	text-decoration: none;
}

.project-card__media {
	aspect-ratio: 16 / 10;
	overflow: hidden;
}

.project-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.project-card__body {
	padding: 1.25rem;
}

.project-card__title {
	margin: 0 0 0.35rem;
	font-size: 1.2rem;
}

.project-card__location {
	margin: 0 0 0.5rem;
	font-size: 0.9rem;
	color: var(--color-primary-dark);
}

.project-card__excerpt {
	margin: 0 0 1rem;
	color: var(--color-muted);
	font-size: 0.95rem;
}

/* Single project */
.single-project__hero {
	position: relative;
	min-height: 320px;
}

.single-project__hero-media {
	position: absolute;
	inset: 0;
}

.single-project__hero-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.single-project__hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(6, 16, 22, 0.35), rgba(6, 16, 22, 0.85));
}

.single-project__hero-text {
	position: relative;
	z-index: 1;
	padding: 4rem 0 2.5rem;
	color: #f0fdff;
}

.single-project__location {
	margin: 0.5rem 0 0;
	opacity: 0.9;
}

.prose {
	max-width: 72ch;
}

.prose--page {
	max-width: none;
}

.prose p {
	margin-top: 0;
}

.prose--page > *:first-child {
	margin-top: 0;
}

.prose h2,
.prose h3,
.prose h4 {
	color: var(--color-text);
	line-height: 1.25;
	margin-top: 1.75em;
	margin-bottom: 0.5em;
}

.prose h2 {
	font-size: clamp(1.35rem, 2.5vw, 1.6rem);
	border-bottom: 1px solid var(--color-border);
	padding-bottom: 0.35rem;
}

.prose h3 {
	font-size: 1.15rem;
}

.prose ul,
.prose ol {
	margin: 0.75em 0 1em;
	padding-inline-start: 1.25em;
	color: var(--color-muted);
}

.prose li + li {
	margin-top: 0.35em;
}

.prose blockquote {
	margin: 1.25em 0;
	padding: 1rem 1.25rem;
	border-inline-start: 4px solid var(--color-primary);
	background: var(--color-primary-soft);
	border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
	color: var(--color-text);
}

html[dir="rtl"] .prose blockquote {
	border-inline-start: none;
	border-inline-end: 4px solid var(--color-primary);
	border-radius: var(--radius-sm) 0 0 var(--radius-sm);
}

.prose .wp-block-image,
.prose figure {
	margin: 1.5em 0;
}

.prose .wp-block-image img,
.prose figure img {
	border-radius: var(--radius-sm);
	box-shadow: var(--shadow-sm);
}

.prose a {
	font-weight: 500;
}

/* Gutenberg alignwide inside page */
.page-surface .alignwide {
	max-width: none;
	margin-inline: 0;
}

.project-gallery__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 0.75rem;
}

.project-gallery__item {
	padding: 0;
	border: none;
	background: none;
	cursor: zoom-in;
	border-radius: var(--radius-sm);
	overflow: hidden;
}

.project-gallery__item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.units-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 1rem;
}

.unit-row {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 1rem;
	padding: 1.25rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	background: var(--color-surface);
	align-items: center;
}

.unit-row__meta {
	list-style: none;
	margin: 0.5rem 0 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1.25rem;
	color: var(--color-muted);
	font-size: 0.9rem;
}

.unit-row__title {
	margin: 0;
	font-size: 1.15rem;
}

.unit-row__total {
	margin: 0 0 0.5rem;
	font-weight: 700;
}

/* Units archive */
.units-archive {
	display: grid;
	gap: 1.25rem;
}

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

@media (min-width: 1000px) {
	.units-archive {
		grid-template-columns: repeat(3, 1fr);
	}
}

.unit-card {
	border-radius: var(--radius);
	overflow: hidden;
	border: 1px solid var(--color-border);
	background: var(--color-surface);
	transition: transform var(--transition), box-shadow var(--transition);
}

.unit-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-md);
}

.unit-card__link {
	display: block;
	color: inherit;
	text-decoration: none;
}

.unit-card__media {
	aspect-ratio: 16 / 10;
	overflow: hidden;
}

.unit-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.unit-card__body {
	padding: 1.15rem;
}

.unit-card__title {
	margin: 0 0 0.25rem;
	font-size: 1.1rem;
}

.unit-card__project {
	margin: 0 0 0.5rem;
	color: var(--color-primary-dark);
	font-size: 0.9rem;
}

.unit-card__meta {
	list-style: none;
	margin: 0 0 0.5rem;
	padding: 0;
	font-size: 0.9rem;
	color: var(--color-muted);
}

.unit-card__price {
	font-weight: 700;
	margin: 0 0 0.75rem;
}

/* Single unit */
.single-unit__header {
	padding: 2rem 0 0;
}

.single-unit__breadcrumb {
	margin: 0 0 0.5rem;
	font-size: 0.95rem;
}

.single-unit__breadcrumb a {
	color: var(--color-primary-dark);
	text-decoration: none;
}

.single-unit__grid {
	display: grid;
	gap: 2rem;
}

@media (min-width: 900px) {
	.single-unit__grid {
		grid-template-columns: 1fr 1fr;
		align-items: start;
	}
}

.single-unit__fig {
	margin: 0 0 1.25rem;
}

.single-unit__fig figcaption {
	font-weight: 600;
	margin-bottom: 0.5rem;
}

.unit-specs {
	list-style: none;
	margin: 0 0 1.5rem;
	padding: 0;
	display: grid;
	gap: 0.5rem;
}

.unit-specs li {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.5rem 0;
	border-bottom: 1px solid var(--color-border);
}

.pricing-box {
	padding: 1.25rem;
	border-radius: var(--radius);
	background: var(--color-primary-soft);
	border: 1px solid rgba(0, 188, 212, 0.35);
	margin-bottom: 1.5rem;
}

.pricing-box__title {
	margin: 0 0 1rem;
	font-size: 1.15rem;
}

.pricing-box__list {
	margin: 0;
}

.pricing-box__row {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.4rem 0;
}

.pricing-box__row--total {
	margin-top: 0.75rem;
	padding-top: 0.75rem;
	border-top: 1px dashed rgba(0, 188, 212, 0.45);
	font-weight: 700;
	font-size: 1.05rem;
}

.pricing-box__note {
	margin: 1rem 0 0;
	font-size: 0.9rem;
	color: var(--color-muted);
}

.single-unit__cta-wrap {
	margin-top: 1.5rem;
}

/* Pagination */
.pagination,
.nav-links {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	flex-wrap: wrap;
	margin-top: 2rem;
}

.pagination a,
.nav-links a,
.page-numbers {
	padding: 0.4rem 0.75rem;
	border-radius: 8px;
	border: 1px solid var(--color-border);
	text-decoration: none;
	color: var(--color-text);
}

.pagination .current,
.page-numbers.current {
	background: var(--color-primary-soft);
	border-color: var(--color-primary);
	font-weight: 700;
}

.not-found {
	text-align: center;
	padding: 4rem 0;
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}

	[data-reveal] {
		opacity: 1 !important;
		transform: none !important;
	}
}
