/**
 * Ahalyna Group — Main Stylesheet
 *
 * Structure:
 * 1. Font Faces
 * 2. CSS Custom Properties
 * 3. Reset / Normalize
 * 4. Base Typography
 * 5. Layout Primitives
 * 6. Buttons
 * 7. Forms
 * 8. Section Label Pattern
 * 9. WordPress Core
 * 10. Utilities
 *
 * All properties use logical directions (RTL-ready).
 * Brand reference: docs/governance/brand_identity.md
 */

/* ==========================================================================
   1. Font Faces
   ========================================================================== */

@font-face {
	font-family: 'Inter';
	src: url('../fonts/Inter/Inter-Regular.woff2') format('woff2');
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: 'Inter';
	src: url('../fonts/Inter/Inter-Medium.woff2') format('woff2');
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: 'Inter';
	src: url('../fonts/Inter/Inter-SemiBold.woff2') format('woff2');
	font-weight: 600;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: 'Inter';
	src: url('../fonts/Inter/Inter-Bold.woff2') format('woff2');
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}

/* ==========================================================================
   2. CSS Custom Properties
   ========================================================================== */

:root {
	/* --- Brand Colors --- */
	--color-deep-blue: #253758;
	--color-red: #9E252B;
	--color-gold: #A28C5C;

	/* --- Neutral Palette --- */
	--color-black: #1E1E1E;
	--color-graphite: #4A4A4A;
	--color-gray: #7A7A7A;
	--color-light-gray: #D8D6D2;
	--color-soft-gray: #ECEBE8;
	--color-off-white: #F5F4F2;
	--color-white: #FFFFFF;

	/* --- Semantic Aliases --- */
	--color-primary: var(--color-deep-blue);
	--color-accent: var(--color-red);
	--color-highlight: var(--color-gold);
	--color-highlight-text: #7A6B3F;       /* WCAG AA — gold for text on white (4.68:1) */
	--color-text: var(--color-black);
	--color-text-secondary: var(--color-graphite);
	--color-text-muted: #6B6B6B;            /* WCAG AA — 4.72:1 on white */
	--color-border: var(--color-light-gray);
	--color-bg: var(--color-white);
	--color-bg-alt: var(--color-off-white);
	--color-bg-section: var(--color-soft-gray);

	/* --- Focus --- */
	--focus-ring: 0 0 0 3px rgba(37, 55, 88, 0.35);
	--focus-ring-light: 0 0 0 3px rgba(255, 255, 255, 0.5);

	/* --- Typography --- */
	--font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--font-weight-regular: 400;
	--font-weight-medium: 500;
	--font-weight-semibold: 600;
	--font-weight-bold: 700;

	--text-xs: 0.75rem;     /* 12px */
	--text-sm: 0.875rem;    /* 14px */
	--text-base: 1rem;      /* 16px */
	--text-lg: 1.125rem;    /* 18px */
	--text-xl: 1.25rem;     /* 20px */
	--text-2xl: 1.5rem;     /* 24px */
	--text-3xl: 1.875rem;   /* 30px */
	--text-4xl: 2.25rem;    /* 36px */
	--text-5xl: 3rem;       /* 48px */
	--text-6xl: 3.75rem;    /* 60px */

	--leading-tight: 1.2;
	--leading-normal: 1.6;
	--leading-relaxed: 1.8;

	--tracking-tight: -0.01em;
	--tracking-normal: 0;
	--tracking-wide: 0.05em;
	--tracking-wider: 0.1em;

	/* --- Spacing Scale --- */
	--space-1: 0.25rem;     /* 4px */
	--space-2: 0.5rem;      /* 8px */
	--space-3: 0.75rem;     /* 12px */
	--space-4: 1rem;        /* 16px */
	--space-5: 1.25rem;     /* 20px */
	--space-6: 1.5rem;      /* 24px */
	--space-8: 2rem;        /* 32px */
	--space-10: 2.5rem;     /* 40px */
	--space-12: 3rem;       /* 48px */
	--space-16: 4rem;       /* 64px */
	--space-20: 5rem;       /* 80px */
	--space-24: 6rem;       /* 96px */

	/* --- Layout --- */
	--container-max: 1200px;
	--container-wide: 1400px;
	--container-padding: var(--space-6);
	--section-spacing: var(--space-20);

	/* --- Borders & Radius --- */
	--radius: 4px;
	--radius-md: 6px;

	/* --- Transitions --- */
	--transition-fast: 150ms ease;
	--transition-base: 250ms ease;
	--transition-slow: 400ms ease;

	/* --- Z-Index Scale --- */
	--z-header: 1000;
	--z-overlay: 1100;
	--z-modal: 1200;
}

/* ==========================================================================
   3. Reset / Normalize
   ========================================================================== */

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

html {
	-webkit-text-size-adjust: 100%;
	-moz-tab-size: 4;
	tab-size: 4;
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: var(--font-family);
	font-size: var(--text-base);
	font-weight: var(--font-weight-regular);
	line-height: var(--leading-normal);
	color: var(--color-text);
	background-color: var(--color-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

main {
	display: block;
}

h1, h2, h3, h4, h5, h6 {
	margin-block-start: 0;
	margin-block-end: 0;
}

p {
	margin-block-start: 0;
	margin-block-end: var(--space-4);
}

p:last-child {
	margin-block-end: 0;
}

a {
	color: var(--color-primary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

a:hover,
a:focus {
	color: var(--color-accent);
}

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

figure {
	margin: 0;
}

ul, ol {
	margin-block-start: 0;
	margin-block-end: 0;
	padding-inline-start: 0;
}

button {
	cursor: pointer;
	font-family: inherit;
	border: none;
	background: none;
	padding: 0;
}

input,
textarea,
select {
	font-family: inherit;
	font-size: inherit;
}

table {
	border-collapse: collapse;
	width: 100%;
}

hr {
	border: none;
	border-block-start: 1px solid var(--color-border);
	margin-block: var(--space-8);
}

[hidden] {
	display: none;
}

/* --- Global focus-visible ring (fallback for elements without custom focus) --- */
:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

:focus:not(:focus-visible) {
	outline: none;
}

/* --- Screen-reader only utility --- */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	clip-path: inset(50%);
	white-space: nowrap;
	border: 0;
}

/* ==========================================================================
   4. Base Typography
   ========================================================================== */

h1, .h1 {
	font-size: var(--text-4xl);
	font-weight: var(--font-weight-bold);
	line-height: var(--leading-tight);
	letter-spacing: var(--tracking-tight);
	color: var(--color-primary);
}

h2, .h2 {
	font-size: var(--text-3xl);
	font-weight: var(--font-weight-bold);
	line-height: var(--leading-tight);
	letter-spacing: var(--tracking-tight);
	color: var(--color-primary);
}

h3, .h3 {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-semibold);
	line-height: var(--leading-tight);
	color: var(--color-primary);
}

h4, .h4 {
	font-size: var(--text-xl);
	font-weight: var(--font-weight-semibold);
	line-height: var(--leading-tight);
	color: var(--color-primary);
}

h5, .h5 {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-medium);
	line-height: var(--leading-tight);
	color: var(--color-primary);
}

h6, .h6 {
	font-size: var(--text-base);
	font-weight: var(--font-weight-medium);
	line-height: var(--leading-tight);
	color: var(--color-primary);
}

/* Responsive headings */
@media (min-width: 768px) {
	h1, .h1 { font-size: var(--text-5xl); }
	h2, .h2 { font-size: var(--text-4xl); }
	h3, .h3 { font-size: var(--text-3xl); }
}

@media (min-width: 1024px) {
	h1, .h1 { font-size: var(--text-6xl); }
	h2, .h2 { font-size: var(--text-5xl); }
}

/* Body text variants */
.text-lg {
	font-size: var(--text-lg);
	line-height: var(--leading-relaxed);
}

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

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

.text-muted {
	color: var(--color-text-muted);
}

/* Uppercase label style (HassConsult section label pattern) */
.label-text {
	font-size: var(--text-xs);
	font-weight: var(--font-weight-medium);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wider);
	color: var(--color-text-muted);
}

/* ==========================================================================
   5. Layout Primitives
   ========================================================================== */

.container {
	width: 100%;
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--container-padding);
}

.container--wide {
	max-width: var(--container-wide);
}

.section {
	padding-block: var(--section-spacing);
}

.section--alt {
	background-color: var(--color-bg-alt);
}

.section--dark {
	background-color: var(--color-primary);
	color: var(--color-white);
}

.section--dark h1,
.section--dark h2,
.section--dark h3,
.section--dark h4,
.section--dark h5,
.section--dark h6,
.section--dark .h1,
.section--dark .h2,
.section--dark .h3 {
	color: var(--color-white);
}

/* Grid helpers */
.grid {
	display: grid;
	gap: var(--space-8);
}

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

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

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

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

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

/* Flex helpers */
.flex {
	display: flex;
}

.flex--between {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.flex--center {
	display: flex;
	justify-content: center;
	align-items: center;
}

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

/* ==========================================================================
   6. Buttons
   ========================================================================== */

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-3) var(--space-8);
	font-family: var(--font-family);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	text-decoration: none;
	border: 2px solid transparent;
	border-radius: var(--radius);
	cursor: pointer;
	transition: background-color var(--transition-base),
	            color var(--transition-base),
	            border-color var(--transition-base);
	min-height: 48px;
}

.btn--primary {
	background-color: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}

.btn--primary:hover,
.btn--primary:focus {
	background-color: #1a2940;
	border-color: #1a2940;
	color: var(--color-white);
}

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

.btn--secondary:hover,
.btn--secondary:focus {
	background-color: var(--color-primary);
	color: var(--color-white);
}

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

.btn--accent:hover,
.btn--accent:focus {
	background-color: #7d1d23;
	border-color: #7d1d23;
	color: var(--color-white);
}

.btn--white {
	background-color: var(--color-white);
	color: var(--color-primary);
	border-color: var(--color-white);
}

.btn--white:hover,
.btn--white:focus {
	background-color: var(--color-off-white);
	border-color: var(--color-off-white);
	color: var(--color-primary);
}

/* ==========================================================================
   7. Forms
   ========================================================================== */

.form-group {
	margin-block-end: var(--space-6);
}

.form-label {
	display: block;
	margin-block-end: var(--space-2);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text);
}

.form-input,
.form-textarea,
.form-select {
	width: 100%;
	padding: var(--space-3) var(--space-4);
	font-size: var(--text-base);
	color: var(--color-text);
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	transition: border-color var(--transition-fast);
}

.form-input:focus-visible,
.form-textarea:focus-visible,
.form-select:focus-visible {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: var(--focus-ring);
}

.form-textarea {
	min-height: 120px;
	resize: vertical;
}

/* ==========================================================================
   8. Section Label Pattern
   HassConsult-style: "SECTION NAME ───"
   ========================================================================== */

.section-label {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	margin-block-end: var(--space-10);
}

.section-label__text {
	font-size: var(--text-xs);
	font-weight: var(--font-weight-medium);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wider);
	color: var(--color-text-muted);
	white-space: nowrap;
}

.section-label__line {
	flex: 0 0 80px;
	height: 1px;
	background-color: var(--color-border);
}

/* ==========================================================================
   9. WordPress Core Styles
   ========================================================================== */

/* Sticky post indicator */
.sticky {
	display: block;
}

/* Updated/published visibility */
.updated:not(.published) {
	display: none;
}

/* Post navigation */
.post-navigation .nav-links,
.posts-navigation .nav-links {
	display: flex;
	justify-content: space-between;
	gap: var(--space-4);
}

/* WordPress alignments — logical properties */
.alignleft {
	/*rtl:ignore*/
	float: left;
	/*rtl:ignore*/
	margin-inline-end: var(--space-6);
	margin-block-end: var(--space-4);
}

.alignright {
	/*rtl:ignore*/
	float: right;
	/*rtl:ignore*/
	margin-inline-start: var(--space-6);
	margin-block-end: var(--space-4);
}

.aligncenter {
	clear: both;
	display: block;
	margin-inline: auto;
	margin-block-end: var(--space-4);
}

/* WordPress galleries */
.gallery {
	display: grid;
	gap: var(--space-4);
	margin-block-end: var(--space-6);
}

.gallery-columns-2 { grid-template-columns: repeat(2, 1fr); }
.gallery-columns-3 { grid-template-columns: repeat(3, 1fr); }
.gallery-columns-4 { grid-template-columns: repeat(4, 1fr); }

.wp-caption {
	max-width: 100%;
	margin-block-end: var(--space-4);
}

.wp-caption-text {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	text-align: center;
	margin-block-start: var(--space-2);
}

/* Custom logo */
.custom-logo-link {
	display: inline-block;
}

.custom-logo {
	height: auto;
	max-height: 50px;
	width: auto;
}

/* Widgets */
.widget {
	margin-block-end: var(--space-8);
}

/* Comment content */
.comment-content a {
	word-wrap: break-word;
}

.bypostauthor {
	display: block;
}

/* Entry content */
.entry-content {
	line-height: var(--leading-relaxed);
}

.entry-content p {
	margin-block-end: var(--space-6);
}

.entry-content h2 {
	margin-block-start: var(--space-12);
	margin-block-end: var(--space-4);
}

.entry-content h3 {
	margin-block-start: var(--space-8);
	margin-block-end: var(--space-3);
}

.entry-content ul,
.entry-content ol {
	padding-inline-start: var(--space-6);
	margin-block-end: var(--space-6);
}

.entry-content li {
	margin-block-end: var(--space-2);
}

.entry-content blockquote {
	margin-inline: 0;
	padding-inline-start: var(--space-6);
	border-inline-start: 3px solid var(--color-gold);
	color: var(--color-text-secondary);
	font-style: italic;
}

/* ==========================================================================
   10. Utilities
   ========================================================================== */

/* Screen reader only */
.sr-only {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal;
}

.sr-only:focus {
	background-color: var(--color-bg);
	border-radius: var(--radius);
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto;
	clip-path: none;
	color: var(--color-primary);
	display: block;
	font-size: var(--text-sm);
	font-weight: var(--font-weight-bold);
	height: auto;
	inset-inline-start: var(--space-2);
	inset-block-start: var(--space-2);
	line-height: normal;
	padding: var(--space-4) var(--space-6);
	text-decoration: none;
	width: auto;
	z-index: 100000;
}

/* Skip to content target */
#primary[tabindex="-1"]:focus {
	outline: 0;
}

/* Text alignment */
.text-center { text-align: center; }
.text-start { text-align: start; }
.text-end { text-align: end; }

/* Margin utilities */
.mb-0 { margin-block-end: 0; }
.mb-4 { margin-block-end: var(--space-4); }
.mb-8 { margin-block-end: var(--space-8); }
.mb-12 { margin-block-end: var(--space-12); }
.mt-0 { margin-block-start: 0; }
.mt-8 { margin-block-start: var(--space-8); }

/* Visually hidden but accessible */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal;
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: var(--radius);
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto;
	clip-path: none;
	color: var(--color-primary);
	display: block;
	font-size: var(--text-sm);
	font-weight: var(--font-weight-bold);
	height: auto;
	inset-inline-start: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* ==========================================================================
   11. Site Header
   HassConsult pattern: transparent over hero → solid Deep Blue on scroll
   ========================================================================== */

.site-header {
	position: fixed;
	inset-block-start: 0;
	inset-inline: 0;
	z-index: var(--z-header);
	isolation: isolate;
	transition: background-color var(--transition-base),
	            box-shadow var(--transition-base);
}

/* Offset header when WP admin bar is active */
.admin-bar .site-header {
	inset-block-start: 32px;
}

@media screen and (max-width: 782px) {
	.admin-bar .site-header {
		inset-block-start: 46px;
	}
}

/* Transparent state (over hero) */
.site-header[data-scroll="top"] {
	background-color: transparent;
}

/* Solid state (scrolled) */
.site-header[data-scroll="scrolled"] {
	background-color: var(--color-primary);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

/* Inner container — flex row */
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-block: var(--space-4);
	min-height: 72px;
	overflow: visible;
}

/* --- Site Branding --- */

.site-branding {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	flex-shrink: 0;
}

.site-branding__logo .custom-logo-link {
	display: flex;
	align-items: center;
}

.site-branding__logo .custom-logo {
	max-height: 44px;
	width: auto;
}

.site-title {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-bold);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	margin: 0;
	line-height: var(--leading-tight);
}

.site-title a {
	color: var(--color-white);
	text-decoration: none;
	transition: opacity var(--transition-fast);
	display: flex;
	flex-direction: column;
}

.site-title a:hover {
	opacity: 0.85;
	color: var(--color-white);
}

.site-title__line2 {
	font-size: var(--text-xs);
	font-weight: var(--font-weight-medium);
	letter-spacing: var(--tracking-widest);
	opacity: 0.8;
}

.site-description {
	display: none; /* Hidden in header — visible only in meta/footer */
}

/* Mobile: adjust site title size */
@media (max-width: 767px) {
	.site-title {
		font-size: var(--text-base);
	}
}

/* --- Primary Navigation --- */

.site-nav {
	display: flex;
	align-items: center;
	flex-shrink: 0;
	overflow: visible;
}

.site-nav__list,
.site-nav > .menu > ul {
	display: none; /* Hidden on mobile — shown via is-open or desktop MQ */
	list-style: none;
	margin: 0;
	padding: 0;
}

/* Desktop: horizontal nav */
@media (min-width: 1024px) {
	.site-nav__list,
	.site-nav > .menu > ul {
		display: flex;
		align-items: center;
		gap: var(--space-1);
	}
}

.site-nav__list > li > a,
.site-nav > .menu > ul > li > a {
	display: block;
	padding: var(--space-2) var(--space-4);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	color: var(--color-white);
	text-decoration: none;
	border-radius: var(--radius);
	transition: background-color var(--transition-fast),
	            color var(--transition-fast);
}

.site-nav__list > li > a:hover,
.site-nav__list > li > a:focus,
.site-nav__list > li.current-menu-item > a,
.site-nav__list > li.current_page_item > a,
.site-nav > .menu > ul > li > a:hover,
.site-nav > .menu > ul > li > a:focus,
.site-nav > .menu > ul > li.current_page_item > a {
	background-color: rgba(255, 255, 255, 0.12);
	color: var(--color-white);
}

/* Sub-menu (desktop dropdown) */
.site-nav__list .sub-menu {
	display: none;
	position: absolute;
	inset-block-start: 100%;
	inset-inline-start: 0;
	min-width: 220px;
	background-color: var(--color-white);
	border-radius: var(--radius-md);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
	padding-block: var(--space-2);
	list-style: none;
	z-index: 10;
}

.site-nav__list > li {
	position: relative;
}

.site-nav__list > li.focus > .sub-menu,
.site-nav__list > li:hover > .sub-menu {
	display: block;
}

.site-nav__list .sub-menu a {
	display: block;
	padding: var(--space-2) var(--space-5);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-regular);
	color: var(--color-text);
	text-transform: none;
	letter-spacing: 0;
	transition: background-color var(--transition-fast);
}

.site-nav__list .sub-menu a:hover,
.site-nav__list .sub-menu a:focus {
	background-color: var(--color-bg-alt);
	color: var(--color-primary);
}

/* --- Mobile Toggle (hamburger) --- */

.site-nav__toggle {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 44px;
	height: 44px;
	padding: 0;
	background: none;
	border: none;
	cursor: pointer;
	z-index: 10;
	pointer-events: auto;
	-webkit-tap-highlight-color: transparent;
	position: relative;
}

@media (min-width: 1024px) {
	.site-nav__toggle {
		display: none;
	}
}

.site-nav__toggle-icon {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 24px;
	height: 24px;
}

.site-nav__toggle-icon span {
	display: block;
	width: 100%;
	height: 2px;
	background-color: var(--color-white);
	border-radius: 1px;
	transition: transform var(--transition-base),
	            opacity var(--transition-fast);
	transform-origin: center;
}

/* Hamburger → X animation */
.site-nav.is-open .site-nav__toggle-icon span:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.site-nav.is-open .site-nav__toggle-icon span:nth-child(2) {
	opacity: 0;
}

.site-nav.is-open .site-nav__toggle-icon span:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/* --- Header CTA — Phone Button --- */

.site-nav__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: var(--space-2) var(--space-4);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	color: var(--color-white);
	background-color: var(--color-accent);
	border-radius: var(--radius-md);
	text-decoration: none;
	white-space: nowrap;
	letter-spacing: 0.02em;
	transition: background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);
	margin-inline-start: var(--space-4);
}

.site-nav__cta:hover,
.site-nav__cta:focus {
	background-color: var(--color-highlight);
	color: var(--color-white);
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(162, 140, 92, 0.35);
}

.site-nav__cta-icon {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

.site-nav__cta-text {
	display: none;
}

/* Desktop: show full text */
@media (min-width: 1024px) {
	.site-nav__cta-text {
		display: inline;
	}

	.site-nav__cta {
		padding: var(--space-2) var(--space-5);
	}
}

/* Mobile: icon-only button, positioned before hamburger */
@media (max-width: 1023px) {
	.site-nav__cta {
		width: 40px;
		height: 40px;
		padding: 0;
		justify-content: center;
		border-radius: var(--radius-full);
		margin-inline-start: auto;
		margin-inline-end: var(--space-2);
	}

	.site-nav__cta-icon {
		width: 18px;
		height: 18px;
	}
}

/* Pulse animation for attention */
@keyframes ctaPulse {
	0%, 100% { box-shadow: 0 0 0 0 rgba(162, 140, 92, 0.4); }
	50% { box-shadow: 0 0 0 8px rgba(162, 140, 92, 0); }
}

.site-nav__cta {
	animation: ctaPulse 3s ease-in-out infinite;
}

.site-nav__cta:hover {
	animation: none;
}

/* --- Mobile Menu (overlay / slide-down) --- */

@media (max-width: 1023px) {
	.site-nav.is-open .site-nav__list {
		display: flex;
		flex-direction: column;
		position: fixed;
		inset-block-start: 72px; /* below header */
		inset-inline: 0;
		inset-block-end: 0;
		background-color: var(--color-primary);
		padding: var(--space-8) var(--space-6);
		gap: var(--space-1);
		overflow-y: auto;
		animation: slideDown var(--transition-base);
	}

	.site-nav.is-open .site-nav__list > li > a {
		font-size: var(--text-lg);
		padding: var(--space-3) var(--space-4);
	}

	/* Mobile sub-menus */
	.site-nav.is-open .sub-menu {
		display: none;
		position: static;
		background: transparent;
		box-shadow: none;
		padding-inline-start: var(--space-6);
		min-width: auto;
	}

	.site-nav.is-open .sub-menu a {
		color: rgba(255, 255, 255, 0.75);
		padding: var(--space-2) var(--space-4);
	}

	.site-nav.is-open .sub-menu a:hover,
	.site-nav.is-open .sub-menu a:focus {
		color: var(--color-white);
		background-color: transparent;
	}

	.site-nav.is-open li.focus > .sub-menu {
		display: block;
	}

	/* Prevent body scroll when menu is open */
	body.menu-open {
		overflow: hidden;
	}
}

@keyframes slideDown {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* --- Offset content for fixed header --- */

.site {
	padding-block-start: 0; /* Hero sits under transparent header */
}

/* For non-hero pages, add offset so content doesn't hide under header */
body:not(.page-template-page-home):not(.page-template-page-about):not(.page-template-page-services):not(.page-template-page-contact):not(.single-ahalyna_service):not(.single-ahalyna_project):not(.blog):not(.archive):not(.single-post):not(.search):not(.error404) .site {
	padding-block-start: 72px;
}

/* ==========================================================================
   12. Home Page — Hero Slider
   HassConsult pattern: full viewport, dark overlay, large text, arrows + dots
   ========================================================================== */

.hero-slider {
	position: relative;
	width: 100%;
	height: 100vh;
	min-height: 500px;
	max-height: 1000px;
	overflow: hidden;
}

.hero-slider__track {
	position: relative;
	width: 100%;
	height: 100%;
}

/* --- Individual Slide --- */

.hero-slider__slide {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.8s ease, visibility 0.8s ease;
	z-index: 1;
}

.hero-slider__slide.is-active {
	opacity: 1;
	visibility: visible;
	z-index: 2;
}

@media (prefers-reduced-motion: reduce) {
	.hero-slider__slide {
		transition: none;
	}
}

/* Background image layer */
.hero-slider__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

/* Dark overlay — deep blue blend (ref: HassConsult) */
.hero-slider__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		160deg,
		rgba(15, 25, 50, 0.85) 0%,
		rgba(37, 55, 88, 0.70) 50%,
		rgba(20, 35, 65, 0.80) 100%
	);
	mix-blend-mode: multiply;
	z-index: 1;
}

/* Secondary overlay for contrast + depth */
.hero-slider__slide::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to bottom,
		rgba(0, 0, 0, 0.15) 0%,
		transparent 30%,
		transparent 70%,
		rgba(0, 0, 0, 0.25) 100%
	);
	z-index: 1;
	pointer-events: none;
}

/* Content layer */
.hero-slider__content {
	position: relative;
	z-index: 2;
	text-align: center;
	max-width: 800px;
	padding-block-start: 72px; /* Account for fixed header */
}

.hero-slider__heading {
	font-size: var(--text-3xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	letter-spacing: var(--tracking-tight);
	line-height: var(--leading-tight);
	margin-block-end: var(--space-6);
	text-transform: uppercase;
}

/* Gold highlight for key words/years in hero heading (ref: HassConsult golden text) */
.hero-slider__highlight {
	color: var(--color-accent);
	font-weight: var(--font-weight-bold);
	position: relative;
	display: inline-block;
}

.hero-slider__highlight::after {
	content: '';
	position: absolute;
	bottom: 0.05em;
	inset-inline-start: 0;
	width: 100%;
	height: 2px;
	background: var(--color-accent);
	opacity: 0.6;
}

.hero-slider__subtitle {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-regular);
	color: rgba(255, 255, 255, 0.85);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-8);
	max-width: 600px;
	margin-inline: auto;
}

.hero-slider__cta {
	margin-block-start: var(--space-4);
}

@media (min-width: 768px) {
	.hero-slider__heading {
		font-size: var(--text-5xl);
	}

	.hero-slider__subtitle {
		font-size: var(--text-xl);
	}
}

@media (min-width: 1024px) {
	.hero-slider__heading {
		font-size: var(--text-6xl);
	}
}

/* --- Nav Arrows --- */

.hero-slider__arrow {
	position: absolute;
	inset-block-start: 50%;
	transform: translateY(-50%);
	z-index: 10;
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: rgba(255, 255, 255, 0.15);
	color: var(--color-white);
	border: 1px solid rgba(255, 255, 255, 0.3);
	border-radius: 50%;
	cursor: pointer;
	transition: background-color var(--transition-fast),
	            border-color var(--transition-fast);
}

.hero-slider__arrow:hover {
	background-color: rgba(255, 255, 255, 0.3);
	border-color: rgba(255, 255, 255, 0.5);
}

.hero-slider__arrow:focus-visible {
	background-color: rgba(255, 255, 255, 0.3);
	border-color: rgba(255, 255, 255, 0.5);
	outline: 2px solid var(--color-white);
	outline-offset: 2px;
}

.hero-slider__arrow--prev {
	inset-inline-start: var(--space-6);
}

.hero-slider__arrow--next {
	inset-inline-end: var(--space-6);
}

@media (max-width: 767px) {
	.hero-slider__arrow {
		width: 40px;
		height: 40px;
	}

	.hero-slider__arrow--prev {
		inset-inline-start: var(--space-3);
	}

	.hero-slider__arrow--next {
		inset-inline-end: var(--space-3);
	}

	.hero-slider__content {
		padding-inline: var(--space-12);
	}
}

/* --- Dot Pagination --- */

.hero-slider__dots {
	position: absolute;
	inset-block-end: var(--space-8);
	inset-inline: 0;
	z-index: 10;
	display: flex;
	justify-content: center;
	gap: var(--space-3);
}

.hero-slider__dot {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background-color: rgba(255, 255, 255, 0.4);
	border: 2px solid transparent;
	cursor: pointer;
	transition: background-color var(--transition-fast),
	            transform var(--transition-fast);
	padding: 0;
}

.hero-slider__dot:hover {
	background-color: rgba(255, 255, 255, 0.7);
}

.hero-slider__dot.is-active {
	background-color: var(--color-white);
	transform: scale(1.25);
}

.hero-slider__dot:focus {
	outline: 2px solid var(--color-white);
	outline-offset: 2px;
}

/* ==========================================================================
   13. Home Page — Services Grid
   3-column cards: image + title + desc + CTA
   ========================================================================== */

.services-section {
	padding-block: var(--space-20);
}

.service-card {
	background-color: transparent;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	text-align: center;
}

.service-card__image {
	position: relative;
	overflow: hidden;
	aspect-ratio: 4 / 3;
	margin-block-end: var(--space-8);
}

.service-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

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

@media (prefers-reduced-motion: reduce) {
	.service-card:hover .service-card__img {
		transform: none;
	}
}

/* Placeholder when no thumbnail */
.service-card__placeholder {
	width: 100%;
	height: 100%;
	background-color: var(--color-bg-alt);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-text-muted);
}

.service-card__placeholder svg {
	width: 64px;
	height: 64px;
	opacity: 0.4;
}

.service-card__body {
	padding-inline: var(--space-4);
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.service-card__title {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-bold);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wider);
	margin-block-end: var(--space-4);
	font-variant: small-caps;
}

.service-card__title a {
	color: var(--color-primary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.service-card__title a:hover {
	color: var(--color-accent);
}

.service-card__subtitle {
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-highlight-text);
	margin-block-end: var(--space-4);
}

.service-card__excerpt {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-8);
	flex: 1;
	max-width: 320px;
}

.service-card__cta {
	width: 100%;
	max-width: 320px;
	margin-block-start: auto;
	text-align: center;
	display: block;
	padding: var(--space-4) var(--space-8);
	background-color: var(--color-primary);
	color: var(--color-white);
	font-size: var(--text-xs);
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wider);
	text-decoration: none;
	transition: background-color var(--transition-fast);
	border: none;
}

.service-card__cta:hover {
	background-color: var(--color-primary-dark, #1a2a45);
	color: var(--color-white);
}

/* ==========================================================================
   14. Home Page — Projects Showcase
   Asymmetric layout: text | large image | 2 small images
   ========================================================================== */

.projects-section {
	padding-block: var(--space-20);
}

.projects-showcase {
	display: grid;
	gap: var(--space-6);
	grid-template-columns: 1fr;
	align-items: stretch;
}

@media (min-width: 1024px) {
	.projects-showcase {
		grid-template-columns: 1fr 1.5fr 1fr;
		min-height: 500px;
	}
}

/* Text block */
.projects-showcase__text {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-block: var(--space-6);
}

.projects-showcase__heading {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	line-height: var(--leading-tight);
	margin-block-end: var(--space-6);
}

@media (min-width: 768px) {
	.projects-showcase__heading {
		font-size: var(--text-3xl);
	}
}

.projects-showcase__desc {
	font-size: var(--text-base);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-8);
}

/* Project image cards (shared) */
.projects-showcase__featured,
.projects-showcase__thumb {
	position: relative;
	display: block;
	overflow: hidden;
	border-radius: var(--radius-md);
	text-decoration: none;
}

.projects-showcase__featured {
	min-height: 300px;
}

.projects-showcase__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.projects-showcase__featured:hover .projects-showcase__img,
.projects-showcase__thumb:hover .projects-showcase__img {
	transform: scale(1.05);
}

@media (prefers-reduced-motion: reduce) {
	.projects-showcase__featured:hover .projects-showcase__img,
	.projects-showcase__thumb:hover .projects-showcase__img {
		transform: none;
	}
}

/* Label overlay */
.projects-showcase__label {
	position: absolute;
	inset-block-end: 0;
	inset-inline: 0;
	padding: var(--space-4) var(--space-6);
	background: linear-gradient(to top, rgba(0, 0, 0, 0.7), transparent);
	display: flex;
	flex-direction: column;
	gap: var(--space-1);
}

.projects-showcase__name {
	font-size: var(--text-base);
	font-weight: var(--font-weight-semibold);
	color: var(--color-white);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
}

.projects-showcase__location {
	font-size: var(--text-xs);
	color: rgba(255, 255, 255, 0.75);
	letter-spacing: var(--tracking-wide);
}

/* Side column — 2 stacked thumbnails */
.projects-showcase__side {
	display: grid;
	gap: var(--space-6);
	grid-template-rows: 1fr 1fr;
}

@media (max-width: 1023px) {
	.projects-showcase__side {
		grid-template-columns: 1fr 1fr;
		grid-template-rows: auto;
	}

	.projects-showcase__thumb {
		min-height: 200px;
	}
}

/* ==========================================================================
   15. Home Page — Company Intro
   About snapshot: text + 4 stat cards
   ========================================================================== */

.company-intro {
	padding-block: var(--space-20);
}

.company-intro__grid {
	display: grid;
	gap: var(--space-12);
	grid-template-columns: 1fr;
	align-items: center;
}

@media (min-width: 768px) {
	.company-intro__grid {
		grid-template-columns: 1.2fr 1fr;
		gap: var(--space-16);
	}
}

.company-intro__heading {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	line-height: var(--leading-tight);
	margin-block-end: var(--space-6);
}

@media (min-width: 768px) {
	.company-intro__heading {
		font-size: var(--text-3xl);
	}
}

.company-intro__desc {
	font-size: var(--text-base);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-4);
}

.company-intro__cta {
	margin-block-start: var(--space-8);
}

/* Stats grid */
.company-intro__stats {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-6);
}

.stat-card {
	background-color: var(--color-bg-alt);
	border-radius: var(--radius-md);
	padding: var(--space-8) var(--space-6);
	text-align: center;
	border-block-start: 3px solid var(--color-highlight);
}

.stat-card__number {
	display: block;
	font-size: var(--text-4xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	line-height: 1;
	margin-block-end: var(--space-2);
}

.stat-card__label {
	display: block;
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-secondary);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
}

/* ==========================================================================
   16. Home Page — CTA Banner
   Full-width dark section with centered text + button
   ========================================================================== */

.cta-banner {
	padding-block: var(--space-20);
	background-color: var(--color-primary);
	background-image: linear-gradient(135deg, var(--color-primary) 0%, #1a2940 100%);
}

.cta-banner__heading {
	font-size: var(--text-3xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	margin-block-end: var(--space-6);
}

@media (min-width: 768px) {
	.cta-banner__heading {
		font-size: var(--text-4xl);
	}
}

@media (min-width: 1024px) {
	.cta-banner__heading {
		font-size: var(--text-5xl);
	}
}

.cta-banner__desc {
	font-size: var(--text-lg);
	color: rgba(255, 255, 255, 0.8);
	line-height: var(--leading-relaxed);
	max-width: 650px;
	margin-inline: auto;
	margin-block-end: var(--space-10);
}

.cta-banner__btn {
	font-size: var(--text-base);
}

/* ==========================================================================
   17. Site Footer
   HassConsult pattern: 4 columns, light gray bg, social row, copyright bar
   ========================================================================== */

.site-footer {
	background-color: var(--color-bg-alt);
	border-block-start: 1px solid var(--color-border);
}

.site-footer__main {
	padding-block: var(--space-16);
}

/* 4-column grid */
.site-footer__grid {
	display: grid;
	gap: var(--space-10);
	grid-template-columns: 1fr;
}

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

@media (min-width: 1024px) {
	.site-footer__grid {
		grid-template-columns: 1.4fr 1.2fr 0.8fr 0.8fr;
		gap: var(--space-8);
	}
}

/* --- Column Headings --- */

.footer-col__heading {
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wider);
	color: var(--color-primary);
	margin-block-end: var(--space-6);
}

/* --- Column 1: Company Info --- */

.footer-col__address {
	font-style: normal;
	font-size: var(--text-sm);
	line-height: var(--leading-relaxed);
	color: var(--color-text-secondary);
	margin-block-end: var(--space-4);
}

.footer-col__contact {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-col__contact li {
	margin-block-end: var(--space-2);
}

.footer-col__link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.footer-col__link:hover,
.footer-col__link:focus {
	color: var(--color-primary);
}

.footer-icon {
	flex-shrink: 0;
}

/* --- Column 2: Subscribe + Social --- */

.footer-col__desc {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	margin-block-end: var(--space-4);
}

.footer-subscribe__field {
	display: flex;
	gap: 0;
}

.footer-subscribe__input {
	flex: 1;
	padding: var(--space-3) var(--space-4);
	font-size: var(--text-sm);
	border: 1px solid var(--color-border);
	border-start-start-radius: var(--radius);
	border-end-start-radius: var(--radius);
	border-start-end-radius: 0;
	border-end-end-radius: 0;
	border-inline-end: none;
	background-color: var(--color-white);
	color: var(--color-text);
}

.footer-subscribe__input:focus-visible {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: var(--focus-ring);
}

.footer-subscribe__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	background-color: var(--color-primary);
	color: var(--color-white);
	border: 1px solid var(--color-primary);
	border-start-start-radius: 0;
	border-end-start-radius: 0;
	border-start-end-radius: var(--radius);
	border-end-end-radius: var(--radius);
	cursor: pointer;
	transition: background-color var(--transition-fast);
}

.footer-subscribe__btn:hover,
.footer-subscribe__btn:focus {
	background-color: #1a2940;
}

.footer-subscribe__success {
	font-size: var(--text-sm);
	color: #4ade80;
	margin-block-end: var(--space-3);
}

/* Social icons */
.footer-social {
	display: flex;
	gap: var(--space-3);
	margin-block-start: var(--space-6);
}

.footer-social__link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background-color: var(--color-bg-section);
	color: var(--color-text-secondary);
	transition: background-color var(--transition-fast),
	            color var(--transition-fast);
}

.footer-social__link:hover,
.footer-social__link:focus {
	background-color: var(--color-primary);
	color: var(--color-white);
}

/* --- Columns 3 & 4: Navigation --- */

.footer-col__list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-col__list li {
	margin-block-end: var(--space-3);
}

.footer-col__list a {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.footer-col__list a:hover,
.footer-col__list a:focus {
	color: var(--color-primary);
}

/* --- Footer Bottom Bar --- */

.site-footer__bottom {
	border-block-start: 1px solid var(--color-border);
	padding-block: var(--space-6);
}

.site-footer__copy {
	font-size: var(--text-xs);
	color: var(--color-text-muted);
	text-align: center;
	margin: 0;
}

/* ==========================================================================
   18. About Page — Page Hero Banner
   Inner page header with dark overlay, title, subtitle
   ========================================================================== */

.page-hero {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	min-height: 340px;
	padding-block: var(--space-20);
	background-color: var(--color-primary);
	background-image: linear-gradient(135deg, var(--color-primary) 0%, #1a2940 60%, #0f1a2a 100%);
	overflow: hidden;
}

.page-hero__overlay {
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 20% 80%, rgba(162, 140, 92, 0.08) 0%, transparent 50%),
		radial-gradient(circle at 80% 20%, rgba(255, 255, 255, 0.03) 0%, transparent 50%);
	pointer-events: none;
}

.page-hero__content {
	position: relative;
	z-index: 2;
	padding-block-start: var(--space-12);
}

.page-hero__heading {
	font-size: var(--text-3xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	letter-spacing: var(--tracking-tight);
	line-height: var(--leading-tight);
	margin-block-end: var(--space-4);
}

.page-hero__subtitle {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-regular);
	color: rgba(255, 255, 255, 0.75);
	line-height: var(--leading-relaxed);
	max-width: 600px;
	margin: 0;
}

/* Section label light variant (for dark backgrounds) */
.section-label--light .section-label__text {
	color: rgba(255, 255, 255, 0.7);
}

.section-label__line--light {
	background-color: rgba(255, 255, 255, 0.3);
}

@media (min-width: 768px) {
	.page-hero {
		min-height: 400px;
	}

	.page-hero__heading {
		font-size: var(--text-4xl);
	}

	.page-hero__subtitle {
		font-size: var(--text-xl);
	}
}

@media (min-width: 1024px) {
	.page-hero {
		min-height: 450px;
	}

	.page-hero__heading {
		font-size: var(--text-5xl);
	}
}

/* ==========================================================================
   19. About Page — Intro / Story Section
   Two-column layout: image with accent + text with mission/vision
   ========================================================================== */

.about-intro {
	padding-block: var(--space-20);
}

.about-intro__grid {
	display: grid;
	gap: var(--space-12);
	grid-template-columns: 1fr;
	align-items: start;
}

@media (min-width: 768px) {
	.about-intro__grid {
		grid-template-columns: 1fr 1.2fr;
		gap: var(--space-16);
		align-items: center;
	}
}

/* Image column with accent bar */
.about-intro__image-wrapper {
	position: relative;
}

.about-intro__img,
.about-intro__img-placeholder {
	width: 100%;
	border-radius: var(--radius-lg);
	object-fit: cover;
}

.about-intro__img {
	box-shadow: 0 12px 40px rgba(37, 55, 88, 0.12);
	transition: transform var(--transition-slow);
}

.about-intro__image-wrapper:hover .about-intro__img {
	transform: scale(1.02);
}

.about-intro__img-placeholder {
	aspect-ratio: 4 / 3;
	background-color: var(--color-primary);
	background-image:
		linear-gradient(135deg, var(--color-primary) 0%, #1a2940 60%, #0f1a2a 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.3);
}

.about-intro__image-accent {
	position: absolute;
	inset-block-start: var(--space-6);
	inset-inline-start: calc(-1 * var(--space-4));
	width: 4px;
	height: 60%;
	background: linear-gradient(to bottom, var(--color-accent), var(--color-highlight));
	border-radius: 2px;
}

@media (max-width: 767px) {
	.about-intro__image-accent {
		display: none;
	}
}

/* Text column */
.about-intro__heading {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	line-height: var(--leading-tight);
	margin-block-end: var(--space-6);
}

@media (min-width: 768px) {
	.about-intro__heading {
		font-size: var(--text-3xl);
	}
}

.about-intro__desc {
	font-size: var(--text-base);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-4);
}

/* Mission & Vision blocks */
.about-intro__mission,
.about-intro__vision {
	margin-block-start: var(--space-8);
	padding: var(--space-5) var(--space-6);
	border-inline-start: 3px solid var(--color-accent);
	background-color: var(--color-bg-alt);
	border-start-start-radius: 0;
	border-end-start-radius: 0;
	border-start-end-radius: var(--radius-md);
	border-end-end-radius: var(--radius-md);
}

.about-intro__mission-label,
.about-intro__vision-label {
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wider);
	color: var(--color-accent);
	margin-block-end: var(--space-2);
}

.about-intro__quote {
	margin: 0;
	padding: 0;
	font-size: var(--text-base);
	font-style: italic;
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
}

/* ==========================================================================
   20. About Page — Values Grid
   6-card grid of company differentiators
   ========================================================================== */

.about-values {
	padding-block: var(--space-20);
}

.about-values__heading {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	line-height: var(--leading-tight);
	margin-block-end: var(--space-4);
}

@media (min-width: 768px) {
	.about-values__heading {
		font-size: var(--text-3xl);
	}
}

@media (min-width: 1024px) {
	.about-values__heading {
		font-size: var(--text-4xl);
	}
}

.about-values__subtitle {
	font-size: var(--text-lg);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	max-width: 700px;
	margin-block-end: var(--space-12);
}

.about-values__grid {
	display: grid;
	gap: var(--space-8);
	grid-template-columns: 1fr;
}

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

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

/* Value card */
.value-card {
	background-color: var(--color-white);
	padding: var(--space-8);
	border-radius: var(--radius-lg);
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
	transition:
		box-shadow var(--transition-base),
		transform var(--transition-base),
		border-color var(--transition-base);
	border: 1px solid var(--color-border);
	border-block-start: 3px solid transparent;
}

.value-card:hover {
	box-shadow: 0 12px 36px rgba(37, 55, 88, 0.1);
	transform: translateY(-4px);
	border-block-start-color: var(--color-accent);
}

@media (prefers-reduced-motion: reduce) {
	.value-card:hover {
		transform: none;
	}
}

.value-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: var(--radius-md);
	background: linear-gradient(135deg, rgba(162, 140, 92, 0.1) 0%, rgba(37, 55, 88, 0.06) 100%);
	color: var(--color-accent);
	margin-block-end: var(--space-5);
	transition: background-color var(--transition-base);
}

.value-card:hover .value-card__icon {
	background: linear-gradient(135deg, rgba(162, 140, 92, 0.2) 0%, rgba(37, 55, 88, 0.1) 100%);
}

.value-card__icon svg {
	flex-shrink: 0;
}

.value-card__title {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
	margin-block-end: var(--space-3);
	line-height: var(--leading-tight);
}

.value-card__desc {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	margin: 0;
}

/* ==========================================================================
   21. About Page — Stats Counter
   Dark section with 6 key numbers in a responsive grid
   ========================================================================== */

.stats-counter {
	padding-block: var(--space-20);
}

.stats-counter__heading {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: var(--leading-tight);
	margin-block-end: var(--space-12);
}

@media (min-width: 768px) {
	.stats-counter__heading {
		font-size: var(--text-3xl);
	}
}

@media (min-width: 1024px) {
	.stats-counter__heading {
		font-size: var(--text-4xl);
	}
}

.stats-counter__grid {
	display: grid;
	gap: var(--space-8);
	grid-template-columns: repeat(2, 1fr);
}

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

@media (min-width: 1024px) {
	.stats-counter__grid {
		grid-template-columns: repeat(6, 1fr);
		gap: var(--space-6);
	}
}

/* Individual counter */
.counter-item {
	text-align: center;
	padding: var(--space-6);
	border-radius: var(--radius-lg);
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.03) 100%);
	border: 1px solid rgba(255, 255, 255, 0.1);
	transition:
		background-color var(--transition-base),
		transform var(--transition-base),
		border-color var(--transition-base);
}

.counter-item:hover {
	background-color: rgba(255, 255, 255, 0.12);
	transform: translateY(-3px);
	border-color: rgba(162, 140, 92, 0.4);
}

@media (prefers-reduced-motion: reduce) {
	.counter-item:hover {
		transform: none;
	}
}

.counter-item__number {
	display: block;
	font-size: var(--text-3xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
	line-height: 1;
	margin-block-end: var(--space-2);
}

@media (min-width: 768px) {
	.counter-item__number {
		font-size: var(--text-4xl);
	}
}

.counter-item__label {
	display: block;
	font-size: var(--text-xs);
	font-weight: var(--font-weight-medium);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wider);
	color: rgba(255, 255, 255, 0.65);
	line-height: var(--leading-normal);
}

/* ==========================================================================
   22. Services Page — Category Filter
   Horizontal pill-style filter navigation
   ========================================================================== */

.services-listing {
	padding-block: var(--space-16) var(--space-20);
	background-color: var(--color-bg-alt);
}

/* --- Services Intro Section --- */
.services-intro {
	padding-block: var(--space-16) var(--space-12);
}

.services-intro__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
	align-items: center;
}

@media (min-width: 992px) {
	.services-intro__grid {
		grid-template-columns: 1.4fr 0.6fr;
		gap: var(--space-16);
	}
}

.services-intro__heading {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	line-height: var(--leading-tight);
	margin-block-end: var(--space-4);
}

@media (min-width: 768px) {
	.services-intro__heading {
		font-size: var(--text-3xl);
	}
}

.services-intro__desc {
	font-size: var(--text-base);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	max-width: 640px;
}

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

@media (min-width: 992px) {
	.services-intro__stats {
		grid-template-columns: 1fr;
		gap: var(--space-6);
	}
}

.services-intro__stat {
	text-align: center;
	padding: var(--space-6) var(--space-4);
	background: var(--color-white);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
}

@media (min-width: 992px) {
	.services-intro__stat {
		display: flex;
		align-items: center;
		gap: var(--space-4);
		text-align: start;
		padding: var(--space-5) var(--space-6);
	}
}

.services-intro__stat-number {
	display: block;
	font-size: var(--text-3xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
	line-height: 1;
}

.services-intro__stat-label {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
}

.services-filter {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin-block-end: var(--space-12);
}

.services-filter__item {
	display: inline-flex;
	align-items: center;
	padding: var(--space-2) var(--space-6);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	color: var(--color-text-secondary);
	text-decoration: none;
	border: 1px solid var(--color-border);
	border-radius: 100px;
	transition: background-color var(--transition-fast),
	            color var(--transition-fast),
	            border-color var(--transition-fast);
	min-height: 40px;
}

.services-filter__item:hover,
.services-filter__item:focus {
	color: var(--color-primary);
	border-color: var(--color-primary);
	background-color: transparent;
}

.services-filter__item.is-active {
	background-color: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}

/* Services listing grid spacing */
.services-listing__grid {
	gap: var(--space-10) var(--space-8);
}

/* On the services listing page, cards get a subtle bottom border */
.services-listing .service-card {
	padding-block-end: var(--space-8);
	border-block-end: 1px solid var(--color-border);
}

.services-listing .service-card:hover {
	border-color: var(--color-accent);
}

/* Service card empty state */
.services-listing__empty {
	padding-block: var(--space-16);
}

/* Service card category badge overlay */
.service-card__category {
	position: absolute;
	inset-block-start: var(--space-3);
	inset-inline-start: var(--space-3);
	padding: var(--space-1) var(--space-3);
	font-size: var(--text-xs);
	font-weight: var(--font-weight-medium);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	color: var(--color-white);
	background-color: var(--color-primary);
	border-radius: var(--radius);
	z-index: 2;
}

/* ==========================================================================
   22b. Project Card — Used by archive-ahalyna_project.php
   ========================================================================== */

.projects-listing__grid {
	gap: var(--space-8);
}

.projects-listing__empty {
	padding-block: var(--space-16);
}

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

.project-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.project-card__image {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background-color: var(--color-bg-alt);
}

.project-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.project-card:hover .project-card__img {
	transform: scale(1.05);
}

.project-card__placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	color: var(--color-light-gray);
}

.project-card__placeholder svg {
	width: 48px;
	height: 48px;
}

.project-card__status {
	position: absolute;
	inset-block-start: var(--space-3);
	inset-inline-end: var(--space-3);
	padding: var(--space-1) var(--space-3);
	font-size: var(--text-xs);
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	color: var(--color-white);
	border-radius: var(--radius);
	z-index: 2;
}

.project-card__status--completed {
	background-color: #2d7a4f;
}

.project-card__status--in_progress {
	background-color: var(--color-highlight-text);
}

.project-card__status--upcoming {
	background-color: var(--color-primary);
}

.project-card__status--planning {
	background-color: var(--color-text-secondary);
}

.project-card__body {
	padding: var(--space-5) var(--space-5) var(--space-6);
}

.project-card__type {
	display: inline-block;
	font-size: 11px;
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-highlight-text);
	margin-block-end: var(--space-2);
}

.project-card__title {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-bold);
	line-height: var(--leading-snug);
	margin-block-end: var(--space-2);
}

.project-card__title a {
	color: var(--color-primary);
	text-decoration: none;
}

.project-card__title a:hover {
	color: var(--color-accent);
}

.project-card__meta {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	margin-block-end: var(--space-3);
}

.project-card__location {
	display: flex;
	align-items: center;
	gap: var(--space-1);
}

.project-card__location svg {
	flex-shrink: 0;
}

.project-card__excerpt {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-4);
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.project-card__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--text-xs);
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wider);
	color: var(--color-primary);
	text-decoration: none;
	padding-block: var(--space-2);
	border-block-end: 2px solid transparent;
	transition: border-color var(--transition-fast),
	            color var(--transition-fast);
}

.project-card__cta:hover {
	border-color: var(--color-accent);
	color: var(--color-accent);
}

.project-card__cta svg {
	transition: transform var(--transition-fast);
}

.project-card__cta:hover svg {
	transform: translateX(4px);
}

/* ==========================================================================
   22c. Projects Intro — Mirror of services-intro
   ========================================================================== */

.projects-intro {
	padding-block: var(--space-16) var(--space-12);
}

.projects-intro__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
	align-items: center;
}

@media (min-width: 992px) {
	.projects-intro__grid {
		grid-template-columns: 1.4fr 0.6fr;
		gap: var(--space-16);
	}
}

.projects-intro__heading {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	line-height: var(--leading-tight);
	margin-block-end: var(--space-4);
}

@media (min-width: 768px) {
	.projects-intro__heading {
		font-size: var(--text-3xl);
	}
}

.projects-intro__desc {
	font-size: var(--text-base);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	max-width: 640px;
}

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

@media (min-width: 992px) {
	.projects-intro__stats {
		grid-template-columns: 1fr;
		gap: var(--space-6);
	}
}

.projects-intro__stat {
	text-align: center;
	padding: var(--space-6) var(--space-4);
	background: var(--color-white);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
}

@media (min-width: 992px) {
	.projects-intro__stat {
		display: flex;
		align-items: center;
		gap: var(--space-4);
		text-align: start;
		padding: var(--space-5) var(--space-6);
	}
}

.projects-intro__stat-number {
	display: block;
	font-size: var(--text-3xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
	line-height: 1;
}

.projects-intro__stat-label {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
}

/* ==========================================================================
   23. Single Service Page
   Two-column layout: content + sidebar
   ========================================================================== */

.single-service {
	padding-block: var(--space-20);
}

.single-service__grid {
	display: grid;
	gap: var(--space-12);
	grid-template-columns: 1fr;
}

@media (min-width: 768px) {
	.single-service__grid {
		grid-template-columns: 1fr 340px;
		gap: var(--space-16);
		align-items: start;
	}
}

/* Featured image */
.single-service__featured-image {
	margin-block-end: var(--space-8);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.single-service__img {
	width: 100%;
	height: auto;
	object-fit: cover;
	border-radius: var(--radius-md);
}

/* Sidebar cards */
.service-detail-card {
	background-color: var(--color-bg-alt);
	border-radius: var(--radius-md);
	padding: var(--space-8);
	margin-block-end: var(--space-6);
}

.service-detail-card__heading {
	font-size: var(--text-base);
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	color: var(--color-primary);
	margin-block-end: var(--space-6);
	padding-block-end: var(--space-4);
	border-block-end: 1px solid var(--color-border);
}

.service-detail-card__row {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: var(--space-4);
	padding-block: var(--space-3);
	border-block-end: 1px solid var(--color-border);
}

.service-detail-card__row:last-child {
	border-block-end: none;
}

.service-detail-card__label {
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-muted);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	flex-shrink: 0;
}

.service-detail-card__value {
	font-size: var(--text-sm);
	color: var(--color-text);
	text-align: end;
}

.service-detail-card__icon {
	font-size: 24px;
	color: var(--color-primary);
}

/* CTA sidebar card */
.service-cta-card {
	background-color: var(--color-primary);
	color: var(--color-white);
	border-radius: var(--radius-md);
	padding: var(--space-8);
	margin-block-end: var(--space-6);
}

.service-cta-card__heading {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	margin-block-end: var(--space-3);
}

.service-cta-card__desc {
	font-size: var(--text-sm);
	color: rgba(255, 255, 255, 0.8);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-6);
}

.service-cta-card__btn {
	width: 100%;
	text-align: center;
}

.service-cta-card__btn.btn--primary {
	background-color: var(--color-white);
	color: var(--color-primary);
	border-color: var(--color-white);
}

.service-cta-card__btn.btn--primary:hover,
.service-cta-card__btn.btn--primary:focus {
	background-color: var(--color-off-white);
	border-color: var(--color-off-white);
	color: var(--color-primary);
}

/* Back link */
.single-service__back {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-secondary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.single-service__back:hover,
.single-service__back:focus {
	color: var(--color-primary);
}

/* ==========================================================================
   24. Related Services Section
   ========================================================================== */

.related-services {
	padding-block: var(--space-20);
}

.related-services__heading {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	line-height: var(--leading-tight);
	margin-block-end: var(--space-10);
}

@media (min-width: 768px) {
	.related-services__heading {
		font-size: var(--text-3xl);
	}
}

/* ==========================================================================
   25. Contact Page — Info Cards
   Three card grid: Address · Phone · Email
   ========================================================================== */

.contact-info-section {
	padding-block: var(--space-16) var(--space-20);
	background-color: var(--color-white);
}

.contact-info__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--space-4);
}

@media (min-width: 768px) {
	.contact-info__grid {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--space-8);
		padding-inline: var(--space-8);
	}
}

.contact-card {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: var(--space-10) var(--space-6) var(--space-8);
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	transition: box-shadow 0.4s ease, transform 0.4s ease;
	overflow: hidden;
}

/* Gold accent top border */
.contact-card::before {
	content: '';
	position: absolute;
	top: 0;
	inset-inline-start: 50%;
	transform: translateX(-50%);
	width: 60px;
	height: 3px;
	background: var(--color-accent);
	border-radius: 0 0 3px 3px;
	transition: width 0.4s ease;
}

.contact-card:hover {
	box-shadow: 0 12px 40px rgba(37, 55, 88, 0.1);
	transform: translateY(-4px);
}

.contact-card:hover::before {
	width: 100%;
}

.contact-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 72px;
	height: 72px;
	border-radius: var(--radius-full);
	background: linear-gradient(135deg, var(--color-primary), #1a2a45);
	color: var(--color-white);
	margin-block-end: var(--space-6);
	flex-shrink: 0;
	box-shadow: 0 4px 15px rgba(37, 55, 88, 0.2);
}

.contact-card__icon svg {
	width: 28px;
	height: 28px;
	stroke: currentColor;
	fill: none;
}

.contact-card__title {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wider);
	margin-block-end: var(--space-4);
}

.contact-card__link {
	font-size: var(--text-sm);
	color: var(--color-primary);
	text-decoration: none;
	line-height: var(--leading-relaxed);
	transition: color var(--transition-fast);
	display: block;
	margin-block-end: var(--space-1);
}

.contact-card__link:hover {
	color: var(--color-accent);
}

.contact-card__text {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-1);
}

.contact-card__meta {
	font-size: var(--text-xs);
	color: var(--color-text-muted);
	margin-block-start: var(--space-3);
	padding-block-start: var(--space-3);
	border-block-start: 1px solid var(--color-border);
	width: 100%;
}

/* ==========================================================================
   26. Contact Page — Form & Map Section
   Two-column layout: form on inline-start, map + hours on inline-end
   ========================================================================== */

.contact-main {
	padding-block: var(--space-16) var(--space-20);
	background-color: var(--color-bg-alt);
}

.contact-main__inner {
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--space-4);
}

@media (min-width: 768px) {
	.contact-main__inner {
		padding-inline: var(--space-8);
	}
}

.contact-main__heading {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-block-end: var(--space-3);
}

.contact-main__desc {
	font-size: var(--text-base);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-8);
}

.contact-main__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
}

@media (min-width: 992px) {
	.contact-main__grid {
		grid-template-columns: 1.2fr 0.8fr;
		gap: var(--space-12);
		align-items: start;
	}
}

/* --- Form Status Alerts --- */

.contact-alert {
	padding: var(--space-4) var(--space-5);
	border-radius: var(--radius-md);
	margin-block-end: var(--space-6);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	line-height: var(--leading-relaxed);
}

.contact-alert--success {
	background-color: #d1fae5;
	color: #065f46;
	border: 1px solid #6ee7b7;
}

.contact-alert--error {
	background-color: #fee2e2;
	color: #991b1b;
	border: 1px solid #fca5a5;
}

.contact-alert--validation {
	background-color: #fef3c7;
	color: #92400e;
	border: 1px solid #fcd34d;
}

/* --- Contact Form --- */

.contact-form {
	position: relative;
	background-color: var(--color-white);
	padding: var(--space-10) var(--space-8);
	border-radius: var(--radius-lg);
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
	overflow: hidden;
}

.contact-form::after {
	content: '';
	position: absolute;
	bottom: 0;
	inset-inline: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
}

@media (min-width: 768px) {
	.contact-form {
		padding: var(--space-12) var(--space-10);
	}
}

.contact-form__title {
	font-size: var(--text-xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-block-end: var(--space-2);
}

.contact-form__subtitle {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	margin-block-end: var(--space-6);
}

.contact-form__row {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
	margin-block-end: var(--space-4);
}

@media (min-width: 600px) {
	.contact-form__row {
		grid-template-columns: 1fr 1fr;
	}
}

.contact-form__group {
	display: flex;
	flex-direction: column;
	margin-block-end: var(--space-4);
}

.contact-form__row .contact-form__group {
	margin-block-end: 0;
}

.contact-form__label {
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-primary);
	margin-block-end: var(--space-1);
}

.form-required {
	color: var(--color-accent);
	margin-inline-start: 2px;
}

.contact-form__input,
.contact-form__select,
.contact-form__textarea {
	width: 100%;
	padding: var(--space-3) var(--space-4);
	font-family: var(--font-family-primary);
	font-size: var(--text-base);
	color: var(--color-text-primary);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.contact-form__input:focus-visible,
.contact-form__select:focus-visible,
.contact-form__textarea:focus-visible {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: var(--focus-ring);
}

.contact-form__select {
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23666'%3E%3Cpath d='M5.293 7.293a1 1 0 0 1 1.414 0L10 10.586l3.293-3.293a1 1 0 1 1 1.414 1.414l-4 4a1 1 0 0 1-1.414 0l-4-4a1 1 0 0 1 0-1.414z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right var(--space-3) center;
	background-size: 16px;
	padding-inline-end: var(--space-10);
	cursor: pointer;
}

[dir="rtl"] .contact-form__select {
	background-position: left var(--space-3) center;
	padding-inline-start: var(--space-10);
	padding-inline-end: var(--space-4);
}

.contact-form__textarea {
	resize: vertical;
	min-height: 140px;
}

.contact-form__honeypot {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.contact-form__submit {
	margin-block-start: var(--space-6);
}

.contact-form__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-3);
	width: 100%;
	padding: var(--space-4) var(--space-8);
	font-family: var(--font-family-primary);
	font-size: var(--text-base);
	font-weight: var(--font-weight-semibold);
	color: var(--color-white);
	background: linear-gradient(135deg, var(--color-primary), #1a2a45);
	border: none;
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
	text-transform: uppercase;
	letter-spacing: var(--tracking-wider);
}

@media (min-width: 600px) {
	.contact-form__btn {
		width: auto;
	}
}

.contact-form__btn:hover,
.contact-form__btn:focus-visible {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(37, 55, 88, 0.3);
}

.contact-form__btn svg {
	width: 18px;
	height: 18px;
	transition: transform 0.3s ease;
}

.contact-form__btn:hover svg {
	transform: translateX(3px) translateY(-3px);
}

.contact-form__privacy {
	margin-block-start: var(--space-3);
	font-size: var(--text-xs);
	color: var(--color-text-muted);
}

/* --- Map & Sidebar --- */

.contact-sidebar {
	display: flex;
	flex-direction: column;
	gap: var(--space-8);
}

.contact-map {
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
}

.contact-map iframe,
.contact-map__iframe {
	display: block;
	width: 100%;
	height: 320px;
	border: 0;
}

@media (min-width: 992px) {
	.contact-map iframe,
	.contact-map__iframe {
		height: 380px;
	}
}

.contact-hours {
	background: linear-gradient(135deg, var(--color-primary), #1a2a45);
	color: var(--color-white);
	padding: var(--space-8) var(--space-6);
	border-radius: var(--radius-lg);
}

.contact-hours__title {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	margin-block-end: var(--space-4);
	display: flex;
	align-items: center;
	gap: var(--space-2);
}

.contact-hours__title svg {
	width: 20px;
	height: 20px;
	fill: currentcolor;
}

.contact-hours__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.contact-hours__item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: var(--text-sm);
	padding-block-end: var(--space-3);
	border-block-end: 1px solid rgba(255, 255, 255, 0.15);
}

.contact-hours__item:last-child {
	border-block-end: none;
	padding-block-end: 0;
}

.contact-hours__day {
	font-weight: var(--font-weight-medium);
	color: rgba(255, 255, 255, 0.9);
}

.contact-hours__time {
	color: rgba(255, 255, 255, 0.7);
}

.contact-hours__time--closed {
	color: var(--color-accent);
	font-weight: var(--font-weight-semibold);
}

/* ==========================================================================
   27. Blog Listing — Post Cards Grid
   3-column responsive grid with image-top cards, pagination.
   ========================================================================== */

.blog-listing {
	padding-block: var(--space-16) var(--space-20);
}

.blog-listing__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
}

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

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

/* --- Post Card --- */

.post-card {
	display: flex;
	flex-direction: column;
	background-color: var(--color-surface);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	overflow: hidden;
	transition: box-shadow var(--transition-base), transform var(--transition-base);
}

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

.post-card__image-link {
	display: block;
	text-decoration: none;
}

.post-card__image {
	position: relative;
	overflow: hidden;
	aspect-ratio: 16 / 10;
	background-color: var(--color-bg-alt);
}

.post-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-base);
}

.post-card:hover .post-card__img {
	transform: scale(1.05);
}

.post-card__image--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-text-muted, #c0c0c0);
}

.post-card__placeholder-icon {
	width: 48px;
	height: 48px;
}

.post-card__body {
	display: flex;
	flex-direction: column;
	flex-grow: 1;
	padding: var(--space-5) var(--space-6) var(--space-6);
}

.post-card__category {
	display: inline-block;
	align-self: flex-start;
	font-size: 11px;
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-highlight-text);
	background-color: rgba(162, 140, 92, 0.1);
	padding: var(--space-1) var(--space-2);
	border-radius: var(--radius-sm);
	text-decoration: none;
	margin-block-end: var(--space-3);
	transition: background-color var(--transition-fast);
}

.post-card__category:hover,
.post-card__category:focus {
	background-color: rgba(162, 140, 92, 0.2);
	color: var(--color-highlight-text);
}

.post-card__title {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-bold);
	line-height: var(--leading-snug);
	color: var(--color-primary);
	margin-block-end: var(--space-2);
}

.post-card__title a {
	color: inherit;
	text-decoration: none;
	transition: color var(--transition-fast);
}

.post-card__title a:hover,
.post-card__title a:focus {
	color: var(--color-accent);
}

.post-card__excerpt {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-4);
	flex-grow: 1;
}

.post-card__meta {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	font-size: 12px;
	color: var(--color-text-muted, #999);
	margin-block-start: auto;
	padding-block-start: var(--space-4);
	border-block-start: 1px solid var(--color-border);
}

.post-card__date,
.post-card__read-time {
	display: inline-flex;
	align-items: center;
	gap: var(--space-1);
}

.post-card__date svg,
.post-card__read-time svg {
	width: 14px;
	height: 14px;
	flex-shrink: 0;
}

/* --- Blog Empty State --- */

.blog-listing__empty {
	text-align: center;
	padding: var(--space-20) var(--space-4);
}

.blog-listing__empty-title {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-block-end: var(--space-4);
}

.blog-listing__empty-text {
	font-size: var(--text-base);
	color: var(--color-text-secondary);
	max-width: 480px;
	margin-inline: auto;
}

/* ==========================================================================
   28. Pagination
   Numbered page links with prev/next arrows.
   ========================================================================== */

.pagination {
	padding-block-start: var(--space-12);
}

.pagination .page-numbers {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	list-style: none;
	padding: 0;
	margin: 0;
	flex-wrap: wrap;
}

.pagination .page-numbers li {
	display: inline-flex;
}

.pagination .page-numbers a,
.pagination .page-numbers span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding-inline: var(--space-3);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-primary);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	text-decoration: none;
	transition: background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}

.pagination .page-numbers a:hover,
.pagination .page-numbers a:focus {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}

.pagination .page-numbers .current {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
	font-weight: var(--font-weight-semibold);
}

.pagination .page-numbers .dots {
	border: none;
	background: none;
	color: var(--color-text-secondary);
	min-width: auto;
	padding: 0 var(--space-1);
}

.pagination .prev,
.pagination .next {
	display: inline-flex;
	align-items: center;
}

.pagination .prev svg,
.pagination .next svg {
	width: 18px;
	height: 18px;
}

/* ==========================================================================
   29. Single Post — Hero & Article Layout
   Featured image hero with dark overlay, 2-column content + sidebar.
   ========================================================================== */

.single-post-hero {
	position: relative;
	display: flex;
	align-items: flex-end;
	min-height: 50vh;
	padding-block: var(--space-20) var(--space-12);
	background-color: var(--color-primary);
	overflow: hidden;
}

.single-post-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.15) 100%);
	z-index: 1;
}

.single-post-hero__image {
	position: absolute;
	inset: 0;
}

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

.single-post-hero__content {
	position: relative;
	z-index: 2;
	max-width: 800px;
}

.single-post-hero__cats {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
	margin-block-end: var(--space-4);
}

.single-post-hero__cat {
	display: inline-block;
	font-size: 11px;
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-highlight-text);
	background-color: rgba(162, 140, 92, 0.25);
	padding: var(--space-1) var(--space-3);
	border-radius: var(--radius-sm);
	text-decoration: none;
	transition: background-color var(--transition-fast);
}

.single-post-hero__cat:hover {
	background-color: rgba(162, 140, 92, 0.45);
	color: var(--color-highlight-text);
}

.single-post-hero__title {
	font-size: var(--text-3xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: var(--leading-tight);
	margin-block-end: var(--space-4);
}

@media (min-width: 768px) {
	.single-post-hero__title {
		font-size: var(--text-4xl);
	}
}

@media (min-width: 1024px) {
	.single-post-hero__title {
		font-size: var(--text-5xl);
	}
}

.single-post-hero__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-4);
	font-size: var(--text-sm);
	color: rgba(255, 255, 255, 0.8);
}

.single-post-hero__date,
.single-post-hero__author,
.single-post-hero__comments {
	display: inline-flex;
	align-items: center;
	gap: var(--space-1);
}

.single-post-hero__date svg,
.single-post-hero__author svg,
.single-post-hero__comments svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	opacity: 0.7;
}

/* --- Single Post Content Grid --- */

.single-post-content {
	padding-block: var(--space-16) var(--space-20);
}

.single-post__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
}

@media (min-width: 1024px) {
	.single-post__grid {
		grid-template-columns: 1fr 320px;
		gap: var(--space-12);
	}
}

/* --- Article Body --- */

.single-post__body {
	font-size: var(--text-base);
	line-height: var(--leading-relaxed);
	color: var(--color-text-primary);
}

.single-post__body h2 {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-block-start: var(--space-10);
	margin-block-end: var(--space-4);
}

.single-post__body h3 {
	font-size: var(--text-xl);
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
	margin-block-start: var(--space-8);
	margin-block-end: var(--space-3);
}

.single-post__body p {
	margin-block-end: var(--space-4);
}

.single-post__body ul,
.single-post__body ol {
	margin-block-end: var(--space-4);
	padding-inline-start: var(--space-6);
}

.single-post__body li {
	margin-block-end: var(--space-2);
}

.single-post__body blockquote {
	border-inline-start: 4px solid var(--color-highlight);
	padding: var(--space-4) var(--space-6);
	margin-block: var(--space-6);
	margin-inline: 0;
	background-color: var(--color-bg-alt);
	border-start-start-radius: 0;
	border-end-start-radius: 0;
	border-start-end-radius: var(--radius-md);
	border-end-end-radius: var(--radius-md);
	font-style: italic;
	color: var(--color-text-secondary);
}

.single-post__body img {
	max-width: 100%;
	height: auto;
	border-radius: var(--radius-md);
	margin-block: var(--space-4);
}

.single-post__body pre {
	background-color: var(--color-primary);
	color: var(--color-white);
	padding: var(--space-5);
	border-radius: var(--radius-md);
	overflow-x: auto;
	font-size: var(--text-sm);
	margin-block: var(--space-4);
}

.single-post__body a {
	color: var(--color-primary);
	text-decoration: underline;
	text-underline-offset: 2px;
	transition: color var(--transition-fast);
}

.single-post__body a:hover {
	color: var(--color-accent);
}

/* --- Tags --- */

.single-post__tags {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-2);
	margin-block-start: var(--space-8);
	padding-block-start: var(--space-6);
	border-block-start: 1px solid var(--color-border);
}

.single-post__tags-label {
	display: inline-flex;
	align-items: center;
	gap: var(--space-1);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-primary);
}

.single-post__tags-label svg {
	width: 16px;
	height: 16px;
}

.single-post__tags a {
	display: inline-block;
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	background-color: var(--color-bg-alt);
	padding: var(--space-1) var(--space-3);
	border-radius: var(--radius-sm);
	text-decoration: none;
	transition: background-color var(--transition-fast), color var(--transition-fast);
}

.single-post__tags a:hover {
	background-color: var(--color-primary);
	color: var(--color-white);
}

/* --- Divider --- */

.single-post__divider {
	border: none;
	border-block-start: 1px solid var(--color-border);
	margin-block: var(--space-8);
}

/* --- Author Box --- */

.single-post__author-box {
	display: flex;
	gap: var(--space-5);
	align-items: flex-start;
	padding: var(--space-6);
	background-color: var(--color-bg-alt);
	border-radius: var(--radius-lg);
}

.single-post__author-avatar img {
	width: 80px;
	height: 80px;
	border-radius: var(--radius-full);
	object-fit: cover;
}

.single-post__author-label {
	display: block;
	font-size: 11px;
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-muted, #999);
	margin-block-end: var(--space-1);
}

.single-post__author-name {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-block-end: var(--space-2);
}

.single-post__author-name a {
	color: inherit;
	text-decoration: none;
}

.single-post__author-name a:hover {
	color: var(--color-accent);
}

.single-post__author-bio {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
}

/* ==========================================================================
   30. Single Post — Sidebar
   Share links, recent articles.
   ========================================================================== */

.single-post__sidebar {
	display: flex;
	flex-direction: column;
	gap: var(--space-8);
}

@media (min-width: 1024px) {
	.single-post__sidebar {
		position: sticky;
		top: calc(72px + var(--space-8));
		align-self: flex-start;
	}
}

/* --- Share Widget --- */

.single-post__share {
	padding: var(--space-6);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
}

.single-post__share-title {
	font-size: var(--text-base);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-block-end: var(--space-4);
}

.single-post__share-links {
	display: flex;
	gap: var(--space-3);
}

.single-post__share-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border);
	background-color: var(--color-surface);
	color: var(--color-text-secondary);
	text-decoration: none;
	cursor: pointer;
	transition: background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}

.single-post__share-link svg {
	width: 18px;
	height: 18px;
}

.single-post__share-link:hover {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}

.single-post__share-link--linkedin:hover {
	background-color: #0077b5;
	border-color: #0077b5;
}

.single-post__share-link--whatsapp:hover {
	background-color: #25d366;
	border-color: #25d366;
}

/* --- Recent Articles Widget --- */

.single-post__recent {
	padding: var(--space-6);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
}

.single-post__recent-title {
	font-size: var(--text-base);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-block-end: var(--space-4);
}

.single-post__recent-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

.single-post__recent-item {
	display: flex;
	gap: var(--space-3);
	align-items: flex-start;
}

.single-post__recent-thumb {
	flex-shrink: 0;
	width: 64px;
	height: 64px;
	border-radius: var(--radius-md);
	overflow: hidden;
}

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

.single-post__recent-info {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.single-post__recent-link {
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-primary);
	text-decoration: none;
	line-height: var(--leading-snug);
	transition: color var(--transition-fast);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.single-post__recent-link:hover {
	color: var(--color-primary);
}

.single-post__recent-date {
	font-size: 11px;
	color: var(--color-text-muted, #999);
}

/* ==========================================================================
   31. Single Post — Navigation (Prev / Next)
   ========================================================================== */

.single-post-nav {
	background-color: var(--color-bg-alt);
	padding-block: var(--space-10);
}

.single-post-nav__inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}

@media (min-width: 768px) {
	.single-post-nav__inner {
		grid-template-columns: 1fr 1fr;
	}
}

.single-post-nav__link {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	padding: var(--space-5) var(--space-6);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	text-decoration: none;
	transition: box-shadow var(--transition-base), border-color var(--transition-fast);
}

.single-post-nav__link:hover {
	box-shadow: var(--shadow-md);
	border-color: var(--color-primary);
}

.single-post-nav__link--next {
	text-align: end;
}

.single-post-nav__label {
	display: inline-flex;
	align-items: center;
	gap: var(--space-1);
	font-size: 12px;
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--color-text-muted, #999);
}

.single-post-nav__link--next .single-post-nav__label {
	justify-content: flex-end;
}

.single-post-nav__label svg {
	width: 16px;
	height: 16px;
}

.single-post-nav__title {
	font-size: var(--text-base);
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
	line-height: var(--leading-snug);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ==========================================================================
   32. Comments Section
   ========================================================================== */

.single-post-comments {
	padding-block: var(--space-12) var(--space-20);
}

.comments-area {
	max-width: 720px;
}

.comments-title {
	font-size: var(--text-xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-block-end: var(--space-8);
}

.comment-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.comment-list .comment {
	padding-block: var(--space-6);
	border-block-start: 1px solid var(--color-border);
}

.comment-list .comment:first-child {
	border-block-start: none;
	padding-block-start: 0;
}

.comment-list .comment-body {
	display: flex;
	gap: var(--space-4);
}

.comment-list .comment-author img {
	border-radius: var(--radius-full);
	width: 48px;
	height: 48px;
}

.comment-list .comment-author .fn {
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
}

.comment-list .comment-metadata a {
	font-size: 12px;
	color: var(--color-text-muted, #999);
	text-decoration: none;
}

.comment-list .comment-content {
	font-size: var(--text-sm);
	line-height: var(--leading-relaxed);
	color: var(--color-text-secondary);
	margin-block-start: var(--space-2);
}

.comment-list .reply a {
	font-size: 12px;
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
	text-decoration: none;
}

.comment-list .reply a:hover {
	color: var(--color-accent);
}

.comment-list .children {
	list-style: none;
	padding-inline-start: var(--space-10);
}

/* Comment Form */

.comment-respond {
	margin-block-start: var(--space-10);
	padding-block-start: var(--space-8);
	border-block-start: 1px solid var(--color-border);
}

.comment-reply-title {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-block-end: var(--space-4);
}

.comment-form label {
	display: block;
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-primary);
	margin-block-end: var(--space-1);
}

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	padding: var(--space-3) var(--space-4);
	font-family: var(--font-family-primary);
	font-size: var(--text-base);
	color: var(--color-text-primary);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	margin-block-end: var(--space-4);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.comment-form input:focus-visible,
.comment-form textarea:focus-visible {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: var(--focus-ring);
}

.comment-form .form-submit input[type="submit"] {
	display: inline-flex;
	padding: var(--space-3) var(--space-8);
	font-family: var(--font-family-primary);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--color-white);
	background-color: var(--color-primary);
	border: 2px solid var(--color-primary);
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: background-color var(--transition-base);
}

.comment-form .form-submit input[type="submit"]:hover {
	background-color: var(--color-accent);
	border-color: var(--color-accent);
}

.no-comments {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	font-style: italic;
}

/* ==========================================================================
   32b. Search Inline Form — Reusable search bar
   Used on search results and 404 pages.
   ========================================================================== */

.search-inline {
	margin-block-end: var(--space-10);
}

.search-inline__form {
	max-width: 640px;
	margin-inline: auto;
}

.search-inline__wrapper {
	display: flex;
	align-items: center;
	gap: 0;
	background-color: var(--color-surface);
	border: 2px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-1);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.search-inline__wrapper:focus-within {
	border-color: var(--color-primary);
	box-shadow: var(--focus-ring);
}

.search-inline__icon {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
	margin-inline-start: var(--space-4);
	color: var(--color-text-muted, #999);
}

.search-inline__input {
	flex-grow: 1;
	border: none;
	background: transparent;
	padding: var(--space-3) var(--space-3);
	font-family: var(--font-family-primary);
	font-size: var(--text-base);
	color: var(--color-text-primary);
	outline: none;
	min-width: 0;
}

.search-inline__input::placeholder {
	color: var(--color-text-muted, #999);
}

.search-inline__btn {
	flex-shrink: 0;
	border-radius: var(--radius-md);
	padding: var(--space-3) var(--space-6);
	font-size: var(--text-sm);
}

@media (max-width: 480px) {
	.search-inline__btn {
		padding: var(--space-3) var(--space-4);
		font-size: 12px;
	}
}

/* ==========================================================================
   32c. Search Empty State — No results found
   ========================================================================== */

.search-empty {
	text-align: center;
	padding: var(--space-16) var(--space-4) var(--space-20);
	max-width: 520px;
	margin-inline: auto;
}

.search-empty__icon {
	margin-block-end: var(--space-6);
	color: var(--color-text-muted, #c0c0c0);
}

.search-empty__icon svg {
	width: 80px;
	height: 80px;
	margin-inline: auto;
}

.search-empty__title {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-block-end: var(--space-3);
}

.search-empty__text {
	font-size: var(--text-base);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-8);
}

.search-empty__links {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-4);
	flex-wrap: wrap;
}

/* ==========================================================================
   32d. 404 Error Page — Professional not-found page
   ========================================================================== */

.error-page {
	padding-block: var(--space-12) var(--space-20);
}

.error-page__content {
	text-align: center;
	max-width: 580px;
	margin-inline: auto;
	margin-block-end: var(--space-16);
}

.error-page__illustration {
	margin-block-end: var(--space-8);
	color: var(--color-accent);
}

.error-page__svg {
	width: 200px;
	height: 160px;
	margin-inline: auto;
}

.error-page__title {
	font-size: var(--text-xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-block-end: var(--space-3);
}

.error-page__text {
	font-size: var(--text-base);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-8);
}

.error-page__content .search-inline__form {
	max-width: 480px;
}

/* --- Quick Nav Grid --- */

.error-page__nav {
	max-width: 700px;
	margin-inline: auto;
}

.error-page__nav-title {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	text-align: center;
	margin-block-end: var(--space-6);
}

.error-page__nav-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-4);
}

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

.error-page__nav-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-3);
	padding: var(--space-6) var(--space-4);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	text-decoration: none;
	transition: box-shadow var(--transition-base), transform var(--transition-base), border-color var(--transition-fast);
}

.error-page__nav-card:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-3px);
	border-color: var(--color-accent);
}

.error-page__nav-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: var(--radius-md);
	background: linear-gradient(135deg, rgba(162, 140, 92, 0.12) 0%, rgba(37, 55, 88, 0.08) 100%);
	color: var(--color-accent);
}

.error-page__nav-icon svg {
	width: 24px;
	height: 24px;
}

.error-page__nav-label {
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
}

.error-page__nav-card:hover .error-page__nav-label {
	color: var(--color-accent);
}

/* ==========================================================================
   33. Section Heading — Reusable component
   Wrapper for section-label + title + subtitle.
   ========================================================================== */

.section-heading {
	margin-block-end: var(--space-10);
}

.section-heading .section-label {
	margin-block-end: var(--space-4);
}

.section-heading__title {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	line-height: var(--leading-tight);
	margin-block-end: var(--space-3);
}

@media (min-width: 768px) {
	.section-heading__title {
		font-size: var(--text-3xl);
	}
}

.section-heading__subtitle {
	font-size: var(--text-base);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	max-width: 640px;
}

/* Center variant */

.section-heading--center {
	text-align: center;
}

.section-heading--center .section-label {
	justify-content: center;
}

.section-heading--center .section-heading__subtitle {
	margin-inline: auto;
}

/* Light variant (for dark backgrounds) */

.section-heading--light .section-heading__title {
	color: var(--color-white);
}

.section-heading--light .section-heading__subtitle {
	color: rgba(255, 255, 255, 0.8);
}

/* ==========================================================================
   34. Breadcrumbs — Structured navigation trail
   Schema.org BreadcrumbList, chevron separators.
   ========================================================================== */

.breadcrumbs {
	padding-block: var(--space-4);
	background-color: var(--color-bg-alt);
	border-block-end: 1px solid var(--color-border);
}

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

.breadcrumbs__item {
	display: inline-flex;
	align-items: center;
	gap: var(--space-1);
	font-size: var(--text-sm);
	line-height: 1;
}

.breadcrumbs__link {
	color: var(--color-text-secondary);
	text-decoration: none;
	transition: color var(--transition-fast);
	white-space: nowrap;
}

.breadcrumbs__link:hover,
.breadcrumbs__link:focus {
	color: var(--color-primary);
}

.breadcrumbs__current {
	color: var(--color-primary);
	font-weight: var(--font-weight-medium);
	white-space: nowrap;
	max-width: 200px;
	overflow: hidden;
	text-overflow: ellipsis;
}

.breadcrumbs__separator {
	color: var(--color-text-muted, #999);
	flex-shrink: 0;
}

/* ==========================================================================
   24a. Single Project Page
   Hero + two-column layout + gallery + related
   ========================================================================== */

/* --- Project Featured Image (inside content) --- */
.project-content__featured-image {
	margin-block-end: var(--space-8);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.project-content__img {
	width: 100%;
	height: auto;
	object-fit: cover;
	border-radius: var(--radius-md);
	display: block;
}

/* --- Project Content Grid --- */
.project-content {
	padding-block: var(--space-16) var(--space-20);
}

.project-content__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-12);
}

@media (min-width: 992px) {
	.project-content__grid {
		grid-template-columns: 1fr 360px;
		gap: var(--space-16);
		align-items: start;
	}
}

.project-content__lead {
	font-size: var(--text-lg);
	color: var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-8);
	padding-block-end: var(--space-8);
	border-block-end: 1px solid var(--color-border);
}

.project-content__body {
	font-size: var(--text-base);
	line-height: var(--leading-relaxed);
}

/* --- Project Sidebar --- */
.project-sidebar {
	position: sticky;
	inset-block-start: calc(var(--header-height, 80px) + var(--space-6));
}

.project-sidebar__card {
	background-color: var(--color-bg-alt);
	border-radius: var(--radius-md);
	padding: var(--space-8);
	margin-block-end: var(--space-6);
}

.project-sidebar__heading {
	font-size: var(--text-base);
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	color: var(--color-primary);
	margin-block-end: var(--space-6);
	padding-block-end: var(--space-4);
	border-block-end: 2px solid var(--color-accent);
}

.project-sidebar__facts {
	margin: 0;
	padding: 0;
}

.project-sidebar__fact {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-2);
	padding-block: var(--space-3);
	border-block-end: 1px solid var(--color-border);
}

.project-sidebar__fact:last-child {
	border-block-end: none;
}

.project-sidebar__fact dt {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-secondary);
}

.project-sidebar__fact dt svg {
	flex-shrink: 0;
	color: var(--color-accent);
}

.project-sidebar__fact dd {
	margin: 0;
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
	text-align: end;
}

/* Status badges in sidebar */
.project-sidebar__status {
	display: inline-block;
	padding: var(--space-1) var(--space-2);
	font-size: 11px;
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-white);
	border-radius: var(--radius);
}

.project-sidebar__status--completed {
	background-color: #2d7a4f;
}

.project-sidebar__status--in_progress {
	background-color: var(--color-highlight-text);
}

.project-sidebar__status--upcoming {
	background-color: var(--color-primary);
}

.project-sidebar__status--planning {
	background-color: var(--color-text-secondary);
}

/* CTA Card in sidebar */
.project-sidebar__cta-card {
	background: linear-gradient(135deg, var(--color-primary) 0%, #1a2a45 100%);
	border-radius: var(--radius-md);
	padding: var(--space-8);
	color: var(--color-white);
}

.project-sidebar__cta-heading {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-bold);
	margin-block-end: var(--space-3);
	color: var(--color-white);
}

.project-sidebar__cta-text {
	font-size: var(--text-sm);
	color: rgba(255, 255, 255, 0.75);
	line-height: var(--leading-relaxed);
	margin-block-end: var(--space-6);
}

.project-sidebar__cta-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	width: 100%;
	justify-content: center;
	padding: var(--space-3) var(--space-6);
	background-color: var(--color-accent);
	color: var(--color-white);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	text-decoration: none;
	border-radius: var(--radius);
	transition: background-color var(--transition-fast),
	            transform var(--transition-fast);
}

.project-sidebar__cta-btn:hover {
	background-color: var(--color-accent-dark, #8a7a50);
	transform: translateY(-2px);
	color: var(--color-white);
}

.project-sidebar__cta-btn svg {
	transition: transform var(--transition-fast);
}

.project-sidebar__cta-btn:hover svg {
	transform: translateX(4px);
}

/* --- Project Gallery (Slider) --- */
.project-gallery {
	padding-block: var(--space-12) var(--space-20);
	background-color: var(--color-bg-alt);
}

.gallery-slider {
	--slides-visible: 4;
	--slide-gap: var(--space-4);
	position: relative;
	margin-block-start: var(--space-8);
}

.gallery-slider__viewport {
	overflow: hidden;
	border-radius: var(--radius-lg);
}

.gallery-slider__track {
	display: flex;
	gap: var(--slide-gap);
	will-change: transform;
}

.gallery-slider__slide {
	flex: 0 0 calc((100% - (var(--slides-visible) - 1) * var(--slide-gap)) / var(--slides-visible));
	aspect-ratio: 4 / 3;
	position: relative;
	border-radius: var(--radius-md);
	overflow: hidden;
}

.gallery-slider__slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform var(--transition-slow);
}

.gallery-slider__slide:hover img {
	transform: scale(1.05);
}

/* --- Dots / Indicators --- */
.gallery-slider__dots {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	margin-block-start: var(--space-5);
}

.gallery-slider__dot {
	width: 10px;
	height: 10px;
	border-radius: var(--radius-full);
	border: 2px solid var(--color-border);
	background-color: transparent;
	cursor: pointer;
	padding: 0;
	transition:
		background-color var(--transition-normal),
		border-color var(--transition-normal),
		transform var(--transition-normal);
}

.gallery-slider__dot:hover {
	border-color: var(--color-accent);
}

.gallery-slider__dot.is-active {
	background-color: var(--color-accent);
	border-color: var(--color-accent);
	transform: scale(1.3);
}

/* --- Navigation Arrows --- */
.gallery-slider__arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 3;
	width: 44px;
	height: 44px;
	border-radius: var(--radius-full);
	border: 2px solid rgba(255, 255, 255, 0.35);
	background-color: rgba(37, 55, 88, 0.6);
	color: #fff;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition:
		background-color var(--transition-normal),
		border-color var(--transition-normal),
		transform var(--transition-normal),
		opacity var(--transition-normal);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
}

.gallery-slider__arrow:hover {
	background-color: var(--color-accent);
	border-color: var(--color-accent);
	transform: translateY(-50%) scale(1.1);
}

.gallery-slider__arrow:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}

.gallery-slider__arrow--prev {
	inset-inline-start: calc(var(--space-3) * -1);
}

.gallery-slider__arrow--next {
	inset-inline-end: calc(var(--space-3) * -1);
}

.gallery-slider__arrow svg {
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	pointer-events: none;
}

/* --- Reduced Motion --- */
@media (prefers-reduced-motion: reduce) {
	.gallery-slider__track {
		transition: none !important;
	}
}

/* --- Tablet: 3 visible --- */
@media (max-width: 991px) {
	.gallery-slider {
		--slides-visible: 3;
	}
}

/* --- Mobile: 2 visible --- */
@media (max-width: 639px) {
	.gallery-slider {
		--slides-visible: 2;
		--slide-gap: var(--space-3);
	}

	.gallery-slider__arrow {
		width: 36px;
		height: 36px;
	}

	.gallery-slider__arrow svg {
		width: 14px;
		height: 14px;
	}

	.gallery-slider__arrow--prev {
		inset-inline-start: calc(var(--space-2) * -1);
	}

	.gallery-slider__arrow--next {
		inset-inline-end: calc(var(--space-2) * -1);
	}
}

/* --- Related Projects --- */
.project-related {
	padding-block: var(--space-16) var(--space-20);
}

.project-related__heading {
	font-size: var(--text-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-block-end: var(--space-10);
}

@media (min-width: 768px) {
	.project-related__heading {
		font-size: var(--text-3xl);
	}
}

/* ==========================================================================
   24. Scroll-Triggered Animations
   IntersectionObserver-driven reveal animations.
   Elements start hidden/offset, gain .is-visible when in viewport.
   ========================================================================== */

/* --- Base: hide before animation --- */
[data-animate] {
	opacity: 0;
	will-change: opacity, transform;
}

[data-animate].is-visible {
	opacity: 1;
}

/* --- fade-up: fade in + slide up 30px --- */
[data-animate="fade-up"] {
	transform: translateY(40px);
	transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
	            transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

[data-animate="fade-up"].is-visible {
	transform: translateY(0);
}

/* --- fade-in: simple opacity fade --- */
[data-animate="fade-in"] {
	transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

/* --- slide-left: slide in from the left --- */
[data-animate="slide-left"] {
	transform: translateX(-50px);
	transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
	            transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

[data-animate="slide-left"].is-visible {
	transform: translateX(0);
}

/* --- slide-right: slide in from the right --- */
[data-animate="slide-right"] {
	transform: translateX(50px);
	transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
	            transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

[data-animate="slide-right"].is-visible {
	transform: translateX(0);
}

/* --- scale-in: scale from small to full --- */
[data-animate="scale-in"] {
	transform: scale(0.85);
	transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
	            transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

[data-animate="scale-in"].is-visible {
	transform: scale(1);
}

/* --- line-grow: decorative line width grows from 0 --- */
[data-animate="line-grow"] {
	max-width: 0;
	overflow: hidden;
	transition: max-width 0.6s cubic-bezier(0.22, 1, 0.36, 1) 0.3s,
	            opacity 0.4s ease;
}

[data-animate="line-grow"].is-visible {
	max-width: 120px;
}

/* --- Reduced-motion: instant reveal --- */
@media (prefers-reduced-motion: reduce) {
	[data-animate] {
		opacity: 1 !important;
		transform: none !important;
		transition: none !important;
		max-width: none !important;
	}
}
