/**
 * OPS Group Theme Main Stylesheet
 * Custom SaaS Modern Design, Mobile-First, Flexbox and Grid-based Layout.
 */

/* ==========================================================================
   1. CSS Variables & Design Tokens
   ========================================================================== */
:root {
	/* Color System */
	--primary-color: #4f46e5;       /* Indigo 600 */
	--primary-hover: #4338ca;       /* Indigo 700 */
	--primary-light: #e0e7ff;       /* Indigo 100 */
	--text-primary: #0f172a;        /* Slate 900 */
	--text-secondary: #334155;      /* Slate 700 */
	--text-muted: #64748b;          /* Slate 500 */
	--bg-body: #f8fafc;             /* Slate 50 */
	--bg-card: #ffffff;
	--bg-header: rgba(255, 255, 255, 0.85);
	--bg-footer: #0f172a;           /* Dark Slate 900 */
	--footer-text: #94a3b8;         /* Slate 400 */
	--footer-title: #f8fafc;
	--border-color: #e2e8f0;        /* Slate 200 */
	--border-focus: #a5b4fc;        /* Indigo 300 */
	--success-color: #10b981;       /* Emerald 500 */
	--error-color: #ef4444;         /* Red 500 */

	/* Typography */
	--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
	--font-heading: system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
	--font-mono: SFMono-Regular, Consolas, "Liberation Mono", Menlo, Courier, monospace;

	/* Spacing Scale (Rem-based) */
	--space-1: 0.25rem;  /* 4px */
	--space-2: 0.5rem;   /* 8px */
	--space-3: 0.75rem;  /* 12px */
	--space-4: 1rem;     /* 16px */
	--space-6: 1.5rem;   /* 24px */
	--space-8: 2rem;     /* 32px */
	--space-12: 3rem;    /* 48px */
	--space-16: 4rem;    /* 64px */

	/* Borders & Shadows */
	--radius-sm: 6px;
	--radius-md: 12px;
	--radius-lg: 16px;
	--radius-full: 9999px;
	
	--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
	--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
	--shadow-lg: 0 10px 15px -3px rgba(15, 23, 42, 0.08), 0 4px 6px -4px rgba(15, 23, 42, 0.08);
	--shadow-sticky: 0 10px 15px -3px rgba(15, 23, 42, 0.04);

	/* Animation */
	--transition-fast: 0.15s cubic-bezier(0.4, 0, 0.2, 1);
	--transition-normal: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
	
	/* Layout widths */
	--max-width: 1400px;
}

/* ==========================================================================
   2. Reset & Baseline Styles
   ========================================================================== */
*, *::before, *::after {
	box-sizing: border-box;
}

html {
	font-family: var(--font-sans);
	line-height: 1.6;
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
	background-color: var(--bg-body);
}

body {
	margin: 0;
	padding: 0;
	color: var(--text-secondary);
	font-size: 1rem;
	background-color: var(--bg-body);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	font-weight: 600;
	color: var(--text-primary);
	line-height: 1.25;
	margin-top: 0;
	margin-bottom: var(--space-4);
}

h1 { font-size: 2.25rem; letter-spacing: -0.025em; }
h2 { font-size: 1.75rem; letter-spacing: -0.02em; }
h3 { font-size: 1.35rem; letter-spacing: -0.01em; }
h4 { font-size: 1.15rem; }

p {
	margin-top: 0;
	margin-bottom: var(--space-6);
}

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

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

img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
	border-style: none;
}

/* Accessibility Skip Link */
.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 !important;
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: var(--radius-sm);
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	clip-path: none;
	color: #21759b;
	display: block;
	font-size: 0.875rem;
	font-weight: 600;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* Utility Containers */
.container {
	width: 100%;
	max-width: var(--max-width);
	margin-right: auto;
	margin-left: auto;
	padding-right: var(--space-6);
	padding-left: var(--space-6);
}

.text-center { text-align: center; }
.text-muted { color: var(--text-muted); }
.font-heading { font-family: var(--font-heading); }

/* Buttons */
.btn, .button, input[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-heading);
	font-size: 0.95rem;
	font-weight: 600;
	line-height: 1;
	padding: var(--space-3) var(--space-6);
	border-radius: var(--radius-sm);
	border: 1px solid transparent;
	cursor: pointer;
	transition: all var(--transition-fast);
}

.btn-primary, input[type="submit"] {
	background-color: var(--primary-color);
	color: white;
}

.btn-primary:hover, input[type="submit"]:hover {
	background-color: var(--primary-hover);
	color: white;
}

.btn-secondary {
	background-color: var(--bg-body);
	border-color: var(--border-color);
	color: var(--text-primary);
}

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

.btn-text {
	display: inline-flex;
	align-items: center;
	font-weight: 600;
	color: var(--primary-color);
}

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

/* Forms & Inputs */
input[type="text"],
input[type="email"],
input[type="search"],
input[type="url"],
textarea {
	width: 100%;
	padding: var(--space-3) var(--space-4);
	font-size: 0.95rem;
	font-family: var(--font-sans);
	color: var(--text-primary);
	background-color: #fff;
	border: 1px solid var(--border-color);
	border-radius: var(--radius-sm);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="search"]:focus,
input[type="url"]:focus,
textarea:focus {
	outline: none;
	border-color: var(--primary-color);
	box-shadow: 0 0 0 3px var(--primary-light);
}

/* Search Form */
.search-form {
	display: flex;
	gap: var(--space-2);
	max-width: 480px;
	margin: 0 auto;
}

.search-form label {
	flex-grow: 1;
}

/* Cards layout base */
.card {
	background-color: var(--bg-card);
	border: 1px solid var(--border-color);
	border-radius: var(--radius-md);
	padding: var(--space-6);
	box-shadow: var(--shadow-sm);
	transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

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

/* ==========================================================================
   3. Header & Navigation (Mobile-first)
   ========================================================================== */
.site-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background-color: var(--bg-header);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border-bottom: 1px solid var(--border-color);
	padding: var(--space-4) 0;
	transition: box-shadow var(--transition-fast);
}

.header-container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
}

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

.site-branding .custom-logo-link {
	display: inline-block;
}

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

.site-title {
	font-size: 1.25rem;
	font-weight: 600;
	margin: 0;
	letter-spacing: -0.02em;
}

.site-title a {
	color: var(--text-primary);
}

.site-description {
	font-size: 0.75rem;
	color: var(--text-muted);
	margin: 0;
}

/* Mobile Toggler */
.menu-toggle {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 32px;
	height: 24px;
	background: transparent;
	border: none;
	padding: 0;
	cursor: pointer;
	z-index: 1100;
	transition: all var(--transition-normal);
}

.menu-toggle:focus {
	outline: none;
}

.hamburger-bar {
	width: 100%;
	height: 3px;
	background-color: var(--text-primary);
	border-radius: var(--radius-full);
	transition: transform var(--transition-normal), opacity var(--transition-normal), background-color var(--transition-normal);
}

/* Base navigation link styles for desktop and fallback */
.nav-link {
	display: block;
	font-family: var(--font-heading);
	font-weight: 600;
	color: var(--text-secondary);
	font-size: 1rem;
	padding: var(--space-2) 0;
	border-bottom: 1px solid transparent;
	text-decoration: none;
	transition: color var(--transition-fast);
}

.nav-link:hover,
.nav-item.current-menu-item .nav-link,
.nav-item.current_page_item .nav-link {
	color: var(--primary-color);
}

/* Base navigation menu list styles */
.nav-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

/* Hide mobile-only elements on desktop by default */
.mobile-submenu-arrow-btn,
.submenu-back-item,
.mobile-menu-cta-container {
	display: none !important;
}

/* Base mobile overlay rules */
body.mobile-menu-active {
	overflow: hidden !important;
	position: fixed;
	width: 100%;
	height: 100%;
}

@media (max-width: 767px) {
	/* Header Container adjustment to keep header branding and action item visible above overlay */
	.site-header {
		z-index: 1200;
		background-color: #ffffff;
		border-bottom: 1px solid #f1f5f9;
	}

	/* Beautiful grey close button background on active */
	.main-navigation.toggled .menu-toggle {
		background-color: #6c6a69; /* matching image close button */
		width: 42px;
		height: 42px;
		border-radius: 8px;
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 0;
		position: relative;
	}

	.main-navigation.toggled .menu-toggle .hamburger-bar {
		background-color: #ffffff;
		position: absolute;
		width: 20px;
		height: 2.5px;
		margin: 0;
	}

	.main-navigation.toggled .menu-toggle .hamburger-bar:nth-child(1) {
		transform: rotate(45deg);
	}

	.main-navigation.toggled .menu-toggle .hamburger-bar:nth-child(2) {
		opacity: 0;
	}

	.main-navigation.toggled .menu-toggle .hamburger-bar:nth-child(3) {
		transform: rotate(-45deg);
	}

	/* Fullscreen Menu Wrapper */
	.menu-wrapper {
		display: none;
		position: fixed;
		top: 83px; /* Just below header */
		left: 0;
		right: 0;
		bottom: 0;
		height: calc(100vh - 83px);
		background-color: #ffffff;
		z-index: 1150;
		padding: 0;
		margin: 0;
		border: none;
		box-shadow: none;
		overflow: hidden;
		flex-direction: column;
	}

	.main-navigation.toggled .menu-wrapper {
		display: flex;
		animation: slideInMobileMenu 0.3s cubic-bezier(0.4, 0, 0.2, 1) forwards;
	}

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

	.nav-menu {
		list-style: none;
		margin: 0;
		padding: 0;
		display: flex;
		flex-direction: column;
		gap: 0;
		width: 100%;
		height: 100%;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 100px; /* Spacing for the sticky CTA */
		position: relative;
		transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease;
	}

	.main-navigation.submenu-active .nav-menu {
		transform: translateX(-15%); /* Subtle shift left for parallax depth */
		opacity: 0;
		pointer-events: none;
		overflow: hidden;
	}

	.nav-menu li {
		width: 100%;
		border-bottom: 1px solid #f1f5f9;
		display: flex;
		justify-content: space-between;
		align-items: stretch;
		/* No position:relative — allows .sub-menu position:absolute to escape to .menu-wrapper */
	}

	.nav-link,
	.nav-menu li > a {
		flex-grow: 1;
		display: block;
		font-family: var(--font-sans);
		font-weight: 600;
		color: #1e293b; /* Slate 800 */
		font-size: 1.15rem;
		padding: 20px 24px;
		border: none;
		text-decoration: none;
		transition: background-color var(--transition-fast), color var(--transition-fast);
	}

	.nav-link:hover,
	.nav-menu li > a:hover {
		background-color: #f8fafc;
		color: #0359db;
	}

	/* Chevron split-border button */
	.mobile-submenu-arrow-btn {
		display: flex !important;
		align-items: center;
		justify-content: center;
		width: 60px;
		background: transparent;
		border: none;
		border-left: 1px solid #f1f5f9;
		cursor: pointer;
		padding: 0;
		color: #52a7e7; /* Beautiful blue arrow matching image */
		transition: background-color var(--transition-fast), color var(--transition-fast);
	}

	.mobile-submenu-arrow-btn:hover {
		background-color: #f8fafc;
		color: #0359db;
	}

	/* Fullscreen Sub-menus Overlay */
	/* position:absolute relative to .menu-wrapper (position:fixed) — avoids iOS Safari
	   fixed-inside-scroll-container bug that caused a blank white panel.
	   Now placed as a direct sibling of .nav-menu inside .menu-wrapper via JS. */
	.main-navigation .sub-menu {
		position: absolute;
		top: 0;        /* Top of .menu-wrapper */
		left: 0;       /* Align left boundary with .menu-wrapper */
		width: 100%;
		height: 100%;
		background-color: #ffffff;
		z-index: 100;  /* Higher z-index to slide over .nav-menu */
		list-style: none;
		margin: 0;
		padding: 0;
		display: flex; /* Always display flex to allow transform transitions */
		flex-direction: column;
		transform: translateX(100%); /* Hidden off-screen right */
		visibility: hidden;          /* Hide from screen readers & click handlers when closed */
		transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.35s step-start;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 100px;
		border: none;
		box-shadow: none;
	}

	.main-navigation .sub-menu.open {
		visibility: visible;
		transform: translateX(0); /* Slides smoothly over main menu */
		transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.35s step-end;
	}

	.main-navigation .sub-menu li {
		width: 100%;
		border-bottom: 1px solid #f1f5f9;
	}

	.main-navigation .sub-menu li a {
		display: block;
		padding: 20px 24px;
		font-family: var(--font-sans);
		font-size: 1.1rem;
		font-weight: 500;
		color: #334155;
		text-decoration: none;
		transition: background-color var(--transition-fast), color var(--transition-fast);
	}

	.main-navigation .sub-menu li a:hover {
		background-color: #f8fafc;
		color: #0359db;
	}

	/* Submenu back item & header row */
	.submenu-back-item {
		display: block !important;
		width: 100%;
		border-bottom: 1px solid #f1f5f9;
		background-color: #ffffff;
	}

	.submenu-back-btn {
		display: flex;
		align-items: center;
		gap: 12px;
		width: 100%;
		padding: 20px 24px;
		background: transparent;
		border: none;
		cursor: pointer;
		text-align: left;
		font-family: var(--font-sans);
		font-size: 1.15rem;
		font-weight: 600;
		color: #1e293b;
		transition: background-color var(--transition-fast);
	}

	.submenu-back-btn:hover {
		background-color: #f8fafc;
	}

	.submenu-back-icon {
		color: #52a7e7;
		flex-shrink: 0;
	}

	/* Dynamic Sticky Bottom Button Container */
	.mobile-menu-cta-container {
		display: block !important;
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		padding: 16px 24px 24px 24px;
		background: #ffffff;
		border-top: 1px solid #f1f5f9;
		z-index: 1180;
	}

	.mobile-menu-cta-container .btn-cta {
		width: 100%;
		justify-content: center;
		height: 52px;
		font-size: 1.1rem;
	}

	.mobile-menu-cta-container .btn-cta:hover {
		padding-right: 56px;
	}
}

/* ==========================================================================
   4. Typography Header Banner (Hero Section fallback)
   ========================================================================== */
.page-header-banner {
	background-color: #fff;
	border-bottom: 1px solid var(--border-color);
	padding: var(--space-12) 0;
	margin-bottom: var(--space-12);
}

.page-header-banner .page-title {
	margin: 0 0 var(--space-2) 0;
}

.page-header-banner .page-subtitle {
	font-size: 1.125rem;
	color: var(--text-muted);
	margin: 0;
}

/* ==========================================================================
   5. Content Layout (Mobile first - Single column stacked)
   ========================================================================== */
.main-content-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-12);
	margin-bottom: var(--space-16);
}

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

/* Post Cards */
.post-card {
	padding: 0;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.post-thumbnail-wrapper {
	position: relative;
	overflow: hidden;
	aspect-ratio: 16 / 9;
}

.post-thumbnail-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-normal);
}

.post-card:hover .post-thumbnail-img {
	transform: scale(1.03);
}

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

.post-card-header {
	margin-bottom: var(--space-4);
}

.post-card-meta {
	font-size: 0.85rem;
	color: var(--text-muted);
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin-bottom: var(--space-2);
}

.post-card-title {
	font-size: 1.35rem;
	margin: 0;
}

.post-card-title a {
	color: var(--text-primary);
}

.post-card-title a:hover {
	color: var(--primary-color);
}

.post-card-excerpt {
	font-size: 0.95rem;
	margin-bottom: var(--space-6);
	flex-grow: 1;
}

/* Pagination */
.posts-pagination {
	margin-top: var(--space-12);
}

.posts-pagination .nav-links {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--space-2);
}

.posts-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var(--radius-sm);
	font-weight: 600;
	border: 1px solid var(--border-color);
	background-color: #fff;
	color: var(--text-secondary);
}

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

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

/* ==========================================================================
   6. Sidebar styling (Stacked on mobile)
   ========================================================================== */
.sidebar {
	display: flex;
	flex-direction: column;
	gap: var(--space-8);
}

.widget {
	background-color: var(--bg-card);
	border: 1px solid var(--border-color);
	border-radius: var(--radius-md);
	padding: var(--space-6);
	box-shadow: var(--shadow-sm);
}

.widget-title {
	font-size: 1.125rem;
	font-weight: 600;
	border-bottom: 2px solid var(--primary-light);
	padding-bottom: var(--space-2);
	margin-bottom: var(--space-4);
}

.widget ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.widget ul li {
	font-size: 0.95rem;
}

.widget ul li a {
	color: var(--text-secondary);
	display: inline-block;
}

.widget ul li a:hover {
	color: var(--primary-color);
	padding-left: 2px;
}

/* ==========================================================================
   7. Single Post and Static Page Styling
   ========================================================================== */
.single-post-entry, .page-entry {
	padding: var(--space-8);
	box-shadow: var(--shadow-sm);
	background-color: #fff;
	margin-bottom: var(--space-8);
}

.entry-header {
	margin-bottom: var(--space-6);
}

.entry-meta {
	font-size: 0.875rem;
	color: var(--text-muted);
	margin-bottom: var(--space-2);
	display: flex;
	gap: var(--space-3);
}

.entry-meta a {
	color: var(--text-muted);
	font-weight: 600;
}

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

.entry-title {
	font-size: 2.25rem;
	margin-bottom: var(--space-3);
}

.entry-author-meta {
	font-size: 0.9rem;
	color: var(--text-secondary);
}

.entry-hero-image {
	margin: 0 calc(-1 * var(--space-8)) var(--space-8) calc(-1 * var(--space-8));
	aspect-ratio: 1.91 / 1;
	overflow: hidden;
}

.entry-hero-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.entry-content {
	font-size: 1.05rem;
	line-height: 1.8;
	color: var(--text-secondary);
}

.entry-content > * {
	margin-bottom: var(--space-6);
}

.entry-content blockquote {
	margin: var(--space-8) 0;
	padding: var(--space-4) var(--space-6);
	border-left: 4px solid var(--primary-color);
	background-color: var(--bg-body);
	font-style: italic;
	font-size: 1.15rem;
	color: var(--text-primary);
}

.entry-content code {
	font-family: var(--font-mono);
	background-color: var(--bg-body);
	padding: var(--space-1) var(--space-2);
	border-radius: var(--radius-sm);
	font-size: 0.9em;
}

.entry-content pre {
	font-family: var(--font-mono);
	background-color: var(--bg-body);
	border: 1px solid var(--border-color);
	padding: var(--space-4);
	border-radius: var(--radius-md);
	overflow-x: auto;
	font-size: 0.9rem;
}

.entry-footer {
	margin-top: var(--space-8);
	padding-top: var(--space-4);
	border-top: 1px solid var(--border-color);
	font-size: 0.9rem;
	color: var(--text-muted);
}

.tags-links .tags-label {
	font-weight: 600;
	color: var(--text-primary);
}

/* Post Navigation (Prev/Next) */
.post-navigation {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
	padding: var(--space-6);
	margin-bottom: var(--space-8);
}

.post-navigation .nav-links {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

.post-navigation .nav-subtitle {
	display: block;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--text-muted);
	margin-bottom: var(--space-1);
}

.post-navigation .nav-title {
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: 1.05rem;
	color: var(--text-primary);
}

.post-navigation .nav-links a {
	display: block;
	padding: var(--space-3);
	border-radius: var(--radius-sm);
	border: 1px solid var(--border-color);
	background-color: var(--bg-body);
}

.post-navigation .nav-links a:hover {
	border-color: var(--primary-color);
}

/* ==========================================================================
   8. Comments Area Styling
   ========================================================================== */
.comments-area {
	background-color: #fff;
	border: 1px solid var(--border-color);
	border-radius: var(--radius-md);
	padding: var(--space-8);
}

.comments-title {
	font-size: 1.35rem;
	margin-bottom: var(--space-6);
}

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

.comment-body {
	position: relative;
	padding-left: 60px;
}

.comment-meta {
	margin-bottom: var(--space-2);
}

.comment-author .avatar {
	position: absolute;
	left: 0;
	top: 0;
	border-radius: var(--radius-full);
}

.comment-author .fn {
	font-weight: 600;
	font-style: normal;
	color: var(--text-primary);
}

.comment-metadata {
	font-size: 0.8rem;
	color: var(--text-muted);
}

.comment-content {
	font-size: 0.95rem;
	line-height: 1.6;
}

.comment-reply-link {
	font-size: 0.85rem;
	font-weight: 600;
}

/* Comment Form */
.comment-respond {
	margin-top: var(--space-8);
	padding-top: var(--space-8);
	border-top: 1px solid var(--border-color);
}

.comment-reply-title {
	font-size: 1.25rem;
	margin-bottom: var(--space-4);
}

.comment-form {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

/* ==========================================================================
   9. 404 Error Screen Styling
   ========================================================================== */
.error-404-container {
	padding: var(--space-16) var(--space-6);
}

.error-404 {
	padding: var(--space-12) var(--space-8);
}

.error-404-badge {
	font-size: 6rem;
	font-weight: 900;
	line-height: 1;
	color: var(--primary-color);
	opacity: 0.15;
	margin-bottom: var(--space-4);
}

.error-message-text {
	font-size: 1.1rem;
	color: var(--text-secondary);
	max-width: 600px;
	margin: 0 auto var(--space-8) auto;
}

.error-search-form {
	margin-bottom: var(--space-8);
}

/* ==========================================================================
   10. Footer Section
   ========================================================================== */
.site-footer {
	background-color: var(--bg-card);
	color: var(--text-muted);
	padding: var(--space-16) 0 var(--space-8) 0;
	border-top: 1px solid var(--border-color);
}

.footer-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-12);
	margin-bottom: var(--space-12);
}

@media (max-width: 767px) {
	.footer-column {
		text-align: center;
	}
	.footer-logo-wrapper {
		display: flex;
		justify-content: center;
	}
	.footer-logo {
		margin: 0 auto;
	}
	.footer-contact-details {
		align-items: center;
	}
	.footer-detail-item {
		justify-content: center;
	}
	.footer-menu-list {
		align-items: center;
	}
	.footer-social-links {
		justify-content: center;
	}
}

.footer-column .footer-title {
	color: var(--text-primary);
	font-size: 1.15rem;
	font-weight: 600;
	margin-bottom: var(--space-6);
}

.footer-logo-wrapper {
	margin-bottom: var(--space-2);
}

.footer-logo {
	max-height: 40px;
	width: auto;
	display: block;
}

.footer-description {
	font-size: 0.95rem;
	line-height: 1.6;
}

.footer-contact-details {
	margin-top: var(--space-4);
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.footer-detail-item {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	font-size: 0.875rem;
	line-height: 1.5;
	color: var(--text-secondary);
	margin: 0;
}

.footer-detail-icon {
	flex-shrink: 0;
	margin-top: 2px;
	color: var(--text-muted);
}

.footer-detail-item a {
	color: var(--text-secondary);
	text-decoration: none;
	transition: color 0.2s ease;
}

.footer-detail-item a:hover {
	color: var(--primary-color);
}

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

.footer-menu-list a, .footer-menu-list li a {
	font-size: 0.95rem;
	color: var(--text-muted);
	transition: color var(--transition-fast);
}

.footer-menu-list a:hover, .footer-menu-list li a:hover {
	color: var(--text-primary);
}

.footer-contact-info {
	font-size: 0.95rem;
	margin-bottom: var(--space-4);
}

.footer-social-links {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: var(--space-4);
}

.social-link {
	display: inline-flex;
	color: var(--text-muted);
	font-weight: 600;
	font-size: 0.9rem;
	transition: color var(--transition-fast);
}

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

.footer-bottom {
	border-top: 1px solid var(--border-color);
	padding-top: var(--space-8);
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
	align-items: center;
	text-align: center;
	font-size: 0.85rem;
}

.footer-bottom .copyright a {
	color: var(--text-muted);
	font-weight: 600;
}

.footer-bottom .copyright a:hover {
	color: var(--text-primary);
}

.footer-bottom .theme-credits {
	margin: 0;
}

/* ==========================================================================
   11. Media Queries (Desktop-first or tablet breakpoints)
   ========================================================================== */

/* Tablet & Desktop Layouts (> 768px) */
@media (min-width: 768px) {
	/* Header Navigation */
	.menu-toggle {
		display: none; /* Hide hamburger */
	}

	.menu-wrapper {
		display: block; /* Show menu wrapper as standard flow */
		position: static;
		box-shadow: none;
		border: none;
		padding: 0;
		background: transparent;
		max-height: none;
		overflow: visible;
	}

	.nav-menu {
		flex-direction: row; /* Horizontal menu */
		gap: var(--space-6);
		transform: none !important;
		transition: none !important;
	}

	.nav-link {
		padding: 0;
		font-size: 0.95rem;
	}

	/* Main Page Content Grid with Sidebar */
	.main-content-layout {
		grid-template-columns: 2fr 1fr; /* 2/3 Content, 1/3 Sidebar */
		align-items: start;
	}

	/* Two column post list or larger grid */
	.posts-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--space-8);
	}

	.posts-grid .post-card:first-child {
		grid-column: span 2; /* Main featured card is full width */
	}

	.posts-grid .post-card:first-child .post-thumbnail-wrapper {
		aspect-ratio: 21 / 9; /* Wider for full width */
	}

	/* Page layouts */
	.page-layout-full {
		max-width: 800px;
		margin-left: auto;
		margin-right: auto;
	}

	/* Post Nav split */
	.post-navigation .nav-links {
		flex-direction: row;
		justify-content: space-between;
	}

	.post-navigation .nav-links a {
		flex: 1;
	}

	/* Footer 3 Column Layout */
	.footer-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--space-8);
	}

	.footer-bottom {
		flex-direction: row;
		justify-content: space-between;
		text-align: left;
	}
}

/* Desktop Grid Adjustments (> 1024px) */
@media (min-width: 1024px) {
	.main-content-layout {
		grid-template-columns: 3fr 1fr; /* 75% / 25% distribution on very wide screens */
		gap: var(--space-16);
	}

	.posts-grid {
		gap: var(--space-12);
	}
}

/* ==========================================================================
   12. Clean SaaS Solid White Header
   ========================================================================== */

/* Header Actions */
.header-actions {
	display: none; /* Hidden on mobile, flex on desktop */
	align-items: center;
	gap: var(--space-4);
}

/* Desktop Navigation Clean SaaS Style */
@media (min-width: 768px) {
	.header-solid .menu-wrapper {
		background: transparent;
		border: none;
		padding: 0;
		backdrop-filter: none;
		-webkit-backdrop-filter: none;
	}

	.header-solid .nav-menu {
		gap: var(--space-1);
		align-items: center;
		transform: none !important;
		transition: none !important;
	}

	.header-solid .nav-link {
		color: var(--text-secondary);
		font-weight: 500;
		font-size: 0.9rem;
		padding: 6px 14px;
		border-radius: var(--radius-sm);
		transition: all var(--transition-fast);
		display: flex;
		align-items: center;
		gap: var(--space-1);
	}

	.header-solid .nav-link:hover {
		color: var(--text-primary);
		background-color: rgba(0, 0, 0, 0.04);
	}

	/* Active item subtle underline feel */
	.header-solid .nav-item.current-menu-item .nav-link {
		color: var(--text-primary);
		background-color: rgba(0, 0, 0, 0.06);
	}

	/* Hide mobile-only elements on desktop */
	.mobile-submenu-arrow-btn,
	.submenu-back-item,
	.mobile-menu-cta-container {
		display: none !important;
	}

	/* Sub menus */
	.main-navigation .nav-item,
	.main-navigation .menu-item-has-children {
		position: relative;
	}

	.main-navigation .sub-menu {
		position: absolute;
		top: 100%;
		left: 0;
		transform: translateY(10px);
		background-color: #ffffff;
		border: 1px solid var(--border-color);
		border-radius: var(--radius-md);
		padding: var(--space-2) 0;
		min-width: 180px;
		box-shadow: var(--shadow-lg);
		list-style: none;
		margin: 0;
		opacity: 0;
		visibility: hidden;
		transition: all var(--transition-normal);
		z-index: 999;
	}

	.main-navigation .nav-item:hover > .sub-menu,
	.main-navigation .menu-item-has-children:hover > .sub-menu {
		opacity: 1;
		visibility: visible;
		transform: translateY(4px);
	}

	.main-navigation .sub-menu li a {
		display: block;
		padding: var(--space-2) var(--space-4);
		color: var(--text-secondary);
		font-size: 0.9rem;
		font-weight: 500;
		transition: all var(--transition-fast);
	}

	.main-navigation .sub-menu li a:hover {
		background-color: var(--bg-body);
		color: var(--primary-color);
	}

	.dropdown-arrow {
		display: inline-block;
		width: 0;
		height: 0;
		margin-left: 5px;
		vertical-align: middle;
		border-top: 4px solid;
		border-right: 4px solid transparent;
		border-left: 4px solid transparent;
		opacity: 0.7;
	}
}

/* ==========================================================================
   13. Hero Landing Grid Section Layout
   ========================================================================== */
.hero-section {
	position: relative;
	background-image: url('../images/ops-group-hero.jpeg');
	background-size: cover;
	background-position: center;
	padding: var(--space-24) 0 var(--space-16) 0; /* Huge padding top for transparent header */
	color: #ffffff;
	overflow: hidden;
	min-height: 550px;
	display: flex;
	align-items: center;
}

.hero-bg-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(15, 23, 42, 0.95) 0%, rgba(15, 23, 42, 0.85) 45%, rgba(15, 23, 42, 0.45) 100%);
	z-index: 1;
}

.hero-container-grid {
	position: relative;
	z-index: 2;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-12);
	align-items: center;
	width: 100%;
}

.hero-content {
	max-width: 620px;
}

.hero-heading {
	font-size: 2.5rem;
	font-weight: 600;
	color: #ffffff;
	line-height: 1.15;
	letter-spacing: -0.03em;
	margin-bottom: var(--space-6);
}

.hero-subheading {
	font-size: 1.05rem;
	line-height: 1.6;
	color: rgba(241, 245, 249, 0.9); /* Slate-100 */
	margin-bottom: var(--space-8);
}

/* Hero CTA Group & Button Aesthetics */
.hero-cta-group {
	display: flex;
	gap: var(--space-4);
	margin-top: var(--space-8);
}

.btn-cta {
	position: relative;
	display: inline-flex;
	align-items: center;
	background-color: #ffffff;
	color: #0f172a;
	border-radius: var(--radius-sm);
	padding: 10px 56px 10px var(--space-6);
	font-size: 0.95rem;
	font-weight: 600;
	font-family: var(--font-heading);
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.08);
	transition: all var(--transition-normal);
	border: 1px solid rgba(0, 0, 0, 0.06);
	text-decoration: none;
}

.btn-cta:hover {
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
	padding-right: 60px;
}

.btn-cta-text {
	padding-right: var(--space-2);
}

.btn-cta-icon {
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	background-color: #3b82f6; /* Blue-500 */
	color: #ffffff;
	border-radius: var(--radius-sm);
	width: 32px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: all var(--transition-normal);
}

.btn-cta:hover .btn-cta-icon {
	background-color: #2563eb; /* Blue-600 */
	transform: translateY(-50%) translateX(6px);
}

/* Contractor Image Cutout overlapping */
.hero-image-wrapper {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: flex-end;
	height: 320px;
	margin-top: var(--space-6);
}

.contractor-cutout-bg {
	position: absolute;
	bottom: 0;
	width: 260px;
	height: 260px;
	background: linear-gradient(180deg, rgba(79, 70, 229, 0.3) 0%, rgba(79, 70, 229, 0.1) 100%);
	border-radius: var(--radius-full);
	z-index: 1;
}

.contractor-img {
	position: relative;
	z-index: 2;
	height: 310px;
	width: auto;
	object-fit: contain;
	filter: drop-shadow(0 20px 25px rgba(0, 0, 0, 0.15));
}

/* ==========================================================================
   14. Services Section
   ========================================================================== */
.services-section {
	padding: var(--space-16) 0;
	background-color: var(--bg-body);
}

.section-header {
	max-width: 600px;
	margin: 0 auto var(--space-12) auto;
}

.section-title {
	font-size: 1.85rem;
	letter-spacing: -0.02em;
	margin-bottom: var(--space-2);
}

.section-subtitle {
	font-size: 1rem;
}

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

.service-card {
	position: relative;
	height: 380px;
	padding: var(--space-8);
	text-align: left;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	background-size: cover;
	background-position: center;
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: all var(--transition-normal);
	border: none;
	box-shadow: var(--shadow-md);
	text-decoration: none;
}

.service-card::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 65%;
	background: linear-gradient(to top, rgba(15, 23, 42, 0.95) 0%, rgba(15, 23, 42, 0.7) 50%, rgba(15, 23, 42, 0) 100%);
	z-index: 1;
	pointer-events: none;
	transition: opacity var(--transition-normal);
}

.service-card:hover {
	box-shadow: var(--shadow-xl);
}

/* Slightly darken the image on card hover */
.service-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: rgba(15, 23, 42, 0.35);
	z-index: 1;
	opacity: 0;
	transition: opacity var(--transition-normal);
}

.service-card:hover::before {
	opacity: 1;
}

.service-card-content {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.service-card-title {
	font-size: 1.6rem;
	font-weight: 600;
	color: #ffffff;
	margin: 0 0 var(--space-2) 0;
	line-height: 1.3;
}

.service-card-desc {
	font-size: 1rem;
	color: rgba(255, 255, 255, 0.8);
	margin-bottom: var(--space-5);
	padding-bottom: 15px;
	line-height: 1.5;
}

/* Sleek Pill Button matching the pool image design */
.btn-learn-more {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	background-color: #bce6ec; /* Beautiful light minty/teal color */
	color: #0f172a;
	padding: 8px 18px;
	border-radius: var(--radius-full);
	font-size: 0.85rem;
	font-weight: 600;
	text-decoration: none;
	transition: all var(--transition-fast);
}

.btn-learn-more-icon {
	font-size: 1rem;
	transition: transform var(--transition-fast);
}

.btn-learn-more:hover {
	background-color: #a4d8df; /* Slightly richer teal on hover */
	color: #0f172a;
	box-shadow: 0 4px 12px rgba(188, 230, 236, 0.3);
}

.btn-learn-more:hover .btn-learn-more-icon {
	transform: translateX(4px);
}

/* ==========================================================================
   14d. FAQ Section
   ========================================================================== */
.faq-section {
	padding: var(--space-20) 0;
	background-color: var(--bg-body);
}

.faq-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
	align-items: stretch; /* Stretch left column image to match right column height */
}

/* Left Column: Image */
.faq-image-column {
	border-radius: var(--radius-lg);
	background-size: cover;
	background-position: center;
	min-height: 350px; /* Base height for mobile */
	box-shadow: var(--shadow-md);
	order: 2; /* Show below content column on mobile */
	margin-top: 30px;
}

/* Right Column: Content */
.faq-content-column {
	display: flex;
	flex-direction: column;
	justify-content: center;
	order: 1; /* Show above image column on mobile */
}

.faq-header-left {
	margin-bottom: var(--space-8);
}

.faq-header-left .faq-badge {
	display: block;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: #64748b; /* Slate-500 */
	margin-bottom: var(--space-2);
}

.faq-title {
	font-size: 1.85rem;
	font-weight: 600;
	color: #0a325c; /* Deep rich navy blue */
	margin: 0;
	line-height: 1.25;
}

/* Accordion */
.faq-accordion {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.faq-item {
	background-color: #f1f5f9; /* Slate-100 light grey background */
	border: 1px solid transparent;
	border-radius: var(--radius-md);
	overflow: hidden;
	transition: background-color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

.faq-item:hover {
	box-shadow: var(--shadow-sm);
	background-color: #e2e8f0; /* Slightly darker grey on hover when closed */
}

.faq-item.active {
	background-color: #ffffff;
	border-color: #e2e8f0; /* Light gray border around open item */
	box-shadow: var(--shadow-md);
}

.faq-item.active:hover {
	background-color: #ffffff; /* Do not darken when open */
}

.faq-toggle {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-4);
	padding: var(--space-4) var(--space-6);
	background: none;
	border: none;
	cursor: pointer;
	text-align: left;
	font-family: inherit;
	transition: background-color 0.25s ease;
}

.faq-item.active .faq-toggle {
	background-color: #0a325c; /* Solid rich navy blue when open */
	border-radius: 6px 6px 0 0;
}

.faq-question {
	font-size: 0.95rem;
	font-weight: 600;
	color: #0a325c; /* Deep rich navy blue */
	line-height: 1.4;
	transition: color 0.25s ease;
}

.faq-item.active .faq-question {
	color: #ffffff; /* White text when active */
}

.faq-chevron-wrapper {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #0a325c;
	transition: color 0.25s ease;
}

.faq-item.active .faq-chevron-wrapper {
	color: #ffffff;
}

.faq-chevron {
	transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.faq-item.active .faq-chevron {
	transform: rotate(180deg); /* Turn down chevron into up chevron */
}

/* Smooth accordion using CSS Grid template-rows */
.faq-answer {
	display: grid;
	grid-template-rows: 0fr;
	transition: grid-template-rows 0.25s cubic-bezier(0.16, 1, 0.3, 1),
				opacity 0.2s ease-out;
	opacity: 0;
	background-color: #ffffff;
	overflow: hidden; /* Crucial to hide overflow when rows is 0fr */
}

.faq-answer > p {
	overflow: hidden;
	min-height: 0;
	padding: 0 var(--space-6); /* Start with 0 top/bottom padding to let grid collapse completely */
	font-size: 0.875rem;
	color: #64748b;
	line-height: 1.6;
	margin: 0;
	transition: padding 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}

.faq-item.active .faq-answer {
	grid-template-rows: 1fr;
	opacity: 1;
}

.faq-item.active .faq-answer > p {
	padding: var(--space-6); /* Apply full padding when open */
}

@media (min-width: 768px) {
	.faq-grid {
		grid-template-columns: 1fr 1.25fr; /* Left image narrower than right content */
		gap: var(--space-12);
	}

	.faq-title {
		font-size: 2.25rem;
	}

	.faq-image-column {
		min-height: 480px; /* Stretch automatically with grid, but have a solid min-height */
		order: 1; /* Left on desktop */
	}

	.faq-content-column {
		order: 2; /* Right on desktop */
	}
}

/* Latest News Layout homepage override */
.latest-news-section {
	padding: var(--space-16) 0;
	background-color: var(--bg-body);
}

.section-header-split {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: var(--space-12);
}

.homepage-posts-grid .post-card:first-child {
	grid-column: auto; /* Clean standard layout on front-page queries */
}

.homepage-posts-grid .post-card:first-child .post-thumbnail-wrapper {
	aspect-ratio: 16 / 9;
}

/* ==========================================================================
   14b. Fixed Price Services Section
   ========================================================================== */
.fixed-price-section {
	padding: var(--space-16) 0;
	background-color: var(--bg-card);
}

.fixed-price-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
	align-items: center;
}

.fixed-price-content {
	min-width: 0;
	overflow: hidden;
}

.fixed-price-title {
	font-size: 2rem;
	font-weight: 600;
	color: var(--text-primary);
	margin-bottom: var(--space-4);
	line-height: 1.2;
}

.fixed-price-text {
	font-size: 1rem;
	line-height: 1.6;
	margin-bottom: var(--space-6);
}

.fixed-price-list {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-6) 0;
}

.fixed-price-list li {
	position: relative;
	padding-left: var(--space-6);
	margin-bottom: var(--space-3);
	font-size: 0.95rem;
	color: var(--text-secondary);
}

.fixed-price-list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 8px;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background-color: var(--primary-color);
}

.fixed-price-image-wrapper {
	display: flex;
	justify-content: center;
	align-items: center;
}

.fixed-price-image {
	max-width: 100%;
	height: auto;
	border-radius: var(--radius-lg);
	object-fit: cover;
}

/* Infinite Scrolling Tags Section */
.scrolling-tags-wrapper {
	margin-top: var(--space-8);
	overflow: hidden;
	position: relative;
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	padding: var(--space-2) 0;
}

/* Linear gradient fade out effect on left and right edges */
.scrolling-tags-wrapper::before,
.scrolling-tags-wrapper::after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	width: 80px;
	z-index: 2;
	pointer-events: none;
}

.scrolling-tags-wrapper::before {
	left: 0;
	background: linear-gradient(to right, #ffffff 0%, rgba(255, 255, 255, 0) 100%);
}

.scrolling-tags-wrapper::after {
	right: 0;
	background: linear-gradient(to left, #ffffff 0%, rgba(255, 255, 255, 0) 100%);
}

.scrolling-tags-row {
	display: flex;
	width: 100%;
	overflow: hidden;
}

.scrolling-tags-track {
	display: flex;
	width: max-content;
	gap: 0;
}

.scrolling-tags-group {
	display: flex;
	flex-shrink: 0;
	align-items: center;
	gap: var(--space-3);
	padding-right: var(--space-3);
}

.scrolling-tag {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	background-color: #f1f5f9; /* Light Slate 100 background matching the screenshot */
	border: 1px solid #e2e8f0; /* Light Slate 200 border */
	border-radius: 9999px;
	padding: 0.5rem 1rem;
	font-size: 0.85rem;
	font-weight: 600;
	color: #64748b; /* Slate 500 */
	white-space: nowrap;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.02);
	transition: background-color var(--transition-fast), border-color var(--transition-fast);
}

.scrolling-tag-icon {
	color: #94a3b8; /* Slate 400 */
	flex-shrink: 0;
}

/* CSS Keyframe Animations for Infinite Scrolling */
.row-left .scrolling-tags-track {
	animation: scrollLeft 35s linear infinite;
}

.row-right .scrolling-tags-track {
	animation: scrollRight 35s linear infinite;
}

/* Pause scroll on hover */
.scrolling-tags-wrapper:hover .scrolling-tags-track {
	animation-play-state: paused;
}

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

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

@media (min-width: 768px) {
	.fixed-price-grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-12);
	}
}

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

/* Call To Action Banner */
.cta-banner-section {
	padding: 0 0 var(--space-16) 0;
	background-color: var(--bg-body);
	margin-top: 50px;
}

.cta-box {
	background-color: #0a325c;
	border-radius: var(--radius-lg);
	padding: 30px;
	display: flex;
	flex-direction: column;
	gap: var(--space-8);
	align-items: flex-start;
	position: relative;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.15);
	box-shadow: var(--shadow-lg);
}

.cta-title {
	color: #ffffff;
	font-size: 1.5rem;
	margin-bottom: var(--space-2);
}

.cta-subtitle {
	color: rgba(255, 255, 255, 0.85);
	font-size: 1rem;
	margin: 0;
	max-width: 600px;
}

.cta-actions {
	margin-left: auto;
}

/* ==========================================================================
   15b. Locations Section (Infinite Scrolling Badges)
   ========================================================================== */
.locations-section {
	padding: var(--space-8) 0;
	background-color: var(--bg-card);
	border-top: 1px solid var(--border-color);
	overflow: hidden;
}

.locations-marquee-wrapper {
	overflow: hidden;
	width: 100%;
	position: relative;
}

.locations-marquee-wrapper + .locations-marquee-wrapper {
	margin-top: 12px;
}

.locations-marquee-wrapper::before,
.locations-marquee-wrapper::after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	width: 60px;
	z-index: 2;
	pointer-events: none;
}

.locations-marquee-wrapper::before {
	left: 0;
	background: linear-gradient(to right, var(--bg-card), transparent);
}

.locations-marquee-wrapper::after {
	right: 0;
	background: linear-gradient(to left, var(--bg-card), transparent);
}

.locations-marquee-track {
	display: flex;
	width: max-content;
	gap: 12px;
	animation: marquee 80s linear infinite;
	padding: 4px 0;
}

.locations-marquee-track-reverse {
	animation: marquee-reverse 80s linear infinite;
}

@keyframes marquee-reverse {
	from {
		transform: translateX(-50%);
	}
	to {
		transform: translateX(0);
	}
}

.scrolling-tag {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	white-space: nowrap;
	padding: 8px 16px;
	background-color: #f1f6fb;
	border: 1px solid #d1dae4;
	border-radius: 999px;
	color: #475569;
	font-size: 0.875rem;
	font-weight: 500;
	text-decoration: none;
	transition: border-color 0.2s ease, color 0.2s ease;
}

.scrolling-tag svg {
	flex-shrink: 0;
	color: #38bdf8;
}

.scrolling-tag:hover {
	border-color: #38bdf8;
	color: #0a325c;
}

@keyframes marquee {
	from {
		transform: translateX(0);
	}
	to {
		transform: translateX(-50%);
	}
}

/* ==========================================================================
   Scroll Reveal Animations
   ========================================================================== */
[data-animate] {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 0.6s cubic-bezier(0.16, 1, 0.3, 1),
	            transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
	will-change: opacity, transform;
}

[data-animate].is-visible {
	opacity: 1;
	transform: translateY(0);
}

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

[data-animate="slide-left"] {
	transform: translateX(-40px);
}

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

[data-animate="slide-right"] {
	transform: translateX(40px);
}

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

/* Staggered children inside animated sections */
[data-animate] .service-card,
[data-animate] .faq-item,
[data-animate] .about-feature-card {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.5s cubic-bezier(0.16, 1, 0.3, 1),
	            transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

[data-animate].is-visible .service-card,
[data-animate].is-visible .faq-item,
[data-animate].is-visible .about-feature-card {
	opacity: 1;
	transform: translateY(0);
}

[data-animate].is-visible .service-card:nth-child(1),
[data-animate].is-visible .faq-item:nth-child(1),
[data-animate].is-visible .about-feature-card:nth-child(1) { transition-delay: 0.05s; }
[data-animate].is-visible .service-card:nth-child(2),
[data-animate].is-visible .faq-item:nth-child(2),
[data-animate].is-visible .about-feature-card:nth-child(2) { transition-delay: 0.12s; }
[data-animate].is-visible .service-card:nth-child(3),
[data-animate].is-visible .faq-item:nth-child(3),
[data-animate].is-visible .about-feature-card:nth-child(3) { transition-delay: 0.19s; }
[data-animate].is-visible .service-card:nth-child(4),
[data-animate].is-visible .faq-item:nth-child(4),
[data-animate].is-visible .about-feature-card:nth-child(4) { transition-delay: 0.26s; }
[data-animate].is-visible .service-card:nth-child(5),
[data-animate].is-visible .faq-item:nth-child(5),
[data-animate].is-visible .about-feature-card:nth-child(5) { transition-delay: 0.33s; }
[data-animate].is-visible .service-card:nth-child(6),
[data-animate].is-visible .faq-item:nth-child(6),
[data-animate].is-visible .about-feature-card:nth-child(6) { transition-delay: 0.40s; }

@media (prefers-reduced-motion: reduce) {
	[data-animate],
	[data-animate] .service-card,
	[data-animate] .faq-item,
	[data-animate] .about-feature-card {
		opacity: 1 !important;
		transform: none !important;
		transition: none !important;
	}
}

/* ==========================================================================
   15c. Standalone Pages (404 / Search – no header/footer)
   ========================================================================== */
html:has(body.page-standalone),
body.page-standalone {
	height: 100vh;
	overflow: hidden;
}

.page-standalone {
	background-color: var(--bg-default);
	color: var(--text-primary);
	display: flex;
	flex-direction: column;
	width: 100%;
}

.standalone-content {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: var(--space-4);
}

.standalone-main {
	width: 100%;
	max-width: 720px;
	margin: 0 auto;
}

.standalone-main.text-center {
	text-align: center;
}

.standalone-badge {
	font-size: 10rem;
	font-weight: 600;
	line-height: 1;
	color: #2563eb;
	margin-bottom: var(--space-4);
}

.standalone-title {
	font-size: 1.75rem;
	font-weight: 600;
	margin-bottom: var(--space-4);
	color: var(--text-primary);
}

.standalone-title .search-term {
	color: var(--color-primary);
}

.standalone-text {
	font-size: 1rem;
	line-height: 1.6;
	margin-bottom: var(--space-6);
}

.standalone-actions {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-4);
}

.standalone-actions .search-form {
	width: 100%;
	max-width: 400px;
}

.standalone-results {
	display: flex;
	flex-direction: column;
	gap: var(--space-6);
	margin-top: var(--space-8);
}

.standalone-result-item {
	background-color: var(--bg-card);
	border: 1px solid var(--border-color);
	border-radius: var(--radius-lg);
	padding: var(--space-5);
}

.standalone-result-title {
	font-size: 1.125rem;
	font-weight: 600;
	margin-bottom: var(--space-2);
}

.standalone-result-title a {
	color: var(--text-primary);
	text-decoration: none;
	transition: color 0.2s ease;
}

.standalone-result-title a:hover {
	color: var(--color-primary);
}

.standalone-pagination {
	display: flex;
	justify-content: center;
	gap: var(--space-3);
	margin-top: var(--space-8);
}

.standalone-pagination a,
.standalone-pagination span {
	padding: var(--space-2) var(--space-4);
	border-radius: var(--radius-md);
	border: 1px solid var(--border-color);
	color: var(--text-secondary);
	font-size: 0.9rem;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.standalone-pagination a:hover {
	background-color: var(--color-primary);
	color: #fff;
	border-color: var(--color-primary);
}

.standalone-pagination .current {
	background-color: var(--bg-muted);
	color: var(--text-primary);
}

/* ==========================================================================
   15. Advanced Breakpoints (Larger Screen adjustments)
   ========================================================================== */
@media (min-width: 768px) {
	/* Header Actions visibility on desktop */
	.header-actions {
		display: flex;
	}

	/* Hero Grid */
	.hero-container-grid {
		grid-template-columns: 1.2fr 0.8fr;
		gap: var(--space-8);
	}

	.hero-heading {
		font-size: 3.25rem;
		margin-bottom: var(--space-6);
	}

	.hero-image-wrapper {
		height: 460px;
		margin-top: 0;
	}

	.contractor-cutout-bg {
		width: 360px;
		height: 360px;
	}

	.contractor-img {
		height: 450px;
	}

	/* Services and Section headers on desktop */
	.services-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--space-6);
	}

	.section-header-split {
		flex-direction: row;
		align-items: flex-end;
	}

	.cta-box {
		padding: var(--space-12) var(--space-16);
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
	}
}

@media (min-width: 1024px) {
	.hero-heading {
		font-size: 3.75rem;
	}

	.hero-image-wrapper {
		height: 520px;
	}

	.contractor-cutout-bg {
		width: 420px;
		height: 420px;
	}

	.contractor-img {
		height: 510px;
	}
}

/* ==========================================================================
   Contact Page
   ========================================================================== */
.modern-contact-page-wrapper {
	padding: var(--space-12) 0;
	background: 
		radial-gradient(circle at 10% 35%, rgba(99, 102, 241, 0.12) 0%, rgba(99, 102, 241, 0) 50%),
		radial-gradient(circle at 15% 65%, rgba(14, 165, 233, 0.1) 0%, rgba(14, 165, 233, 0) 60%),
		linear-gradient(135deg, #fbfcfe 0%, #edf4f9 100%);
	min-height: 100vh;
	display: flex;
	align-items: center;
	position: relative;
	overflow: hidden;
}

.modern-contact-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
	align-items: flex-start;
}

/* Left Column Content */
.modern-contact-content {
	display: flex;
	flex-direction: column;
	gap: var(--space-6);
}

.modern-contact-title {
	font-size: 2.5rem;
	font-weight: 600;
	color: #0c1a30;
	line-height: 1.15;
	margin: 0;
	letter-spacing: -0.02em;
}

.modern-contact-subtitle {
	font-size: 1.05rem;
	color: #475569;
	line-height: 1.6;
	margin: 0;
	max-width: 540px;
}

/* Checklist Styling */
.modern-contact-checklist {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.modern-contact-checklist .checklist-item {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	font-size: 1.05rem;
	font-weight: 600;
	color: #1e293b;
}

.modern-contact-checklist .checklist-icon {
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background-color: #fee2e2; /* Red badge backdrop */
	color: #ef4444; /* Red badge icon */
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

/* Check icon from image needs to match our blue theme requirement */
.modern-contact-page-wrapper .checklist-icon {
	background-color: #dbeafe; /* Soft blue */
	color: #2563eb; /* Blue checkmark */
}

/* Left Column Bottom Cards */
.modern-contact-cards-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
	margin-top: var(--space-6);
}

.modern-info-card {
	background-color: rgba(255, 255, 255, 0.7);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border: 1px solid rgba(255, 255, 255, 0.5);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	box-shadow: 0 4px 12px rgba(15, 23, 42, 0.02);
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.modern-info-card .info-card-title {
	font-size: 1.1rem;
	font-weight: 600;
	color: #0f172a;
	margin: 0;
}

.modern-info-card .info-card-text {
	font-size: 0.9rem;
	color: #64748b;
	line-height: 1.5;
	margin: 0;
}

.modern-info-card .info-card-link,
.modern-info-card .info-card-link-action {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	color: #0c1a30;
	font-size: 0.95rem;
	font-weight: 600;
	text-decoration: none;
	margin-top: var(--space-2);
	transition: color 0.15s ease;
}

.modern-info-card .info-card-link:hover,
.modern-info-card .info-card-link-action:hover {
	color: #2563eb;
}

.modern-info-card .info-card-icon-arrow {
	transition: transform 0.15s ease;
}

.modern-info-card .info-card-link-action:hover .info-card-icon-arrow {
	transform: translate(2px, -2px);
}

/* Right Column Contact Form Panel */
.modern-contact-form-panel {
	background-color: #ffffff;
	border-radius: 24px;
	padding: 30px;
	box-shadow: 0 20px 40px -15px rgba(15, 23, 42, 0.06), 0 15px 15px -15px rgba(15, 23, 42, 0.04);
	border: 1px solid #f1f5f9;
}

.modern-form-title {
	font-size: 1.35rem;
	font-weight: 600;
	color: #0f172a;
	margin: 0 0 var(--space-8) 0;
}

/* Notched Floating label form elements inside the panel */
.modern-contact-form-panel form {
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: var(--space-4);
	row-gap: var(--space-6);
}

/* By default, all form wrappers span full width */
.modern-contact-form-panel .wpcf7-form > p {
	grid-column: span 2;
	margin: 0;
	position: relative;
}

/* Paragraphs that contain first name or last name span 1 column */
.modern-contact-form-panel .wpcf7-form p:has(input[name*="first"]),
.modern-contact-form-panel .wpcf7-form p:has(input[name*="last"]),
.modern-contact-form-panel .wpcf7-form p:has(input[name*="fname"]),
.modern-contact-form-panel .wpcf7-form p:has(input[name*="lname"]),
.modern-contact-form-panel .wpcf7-form p:has(.first-name),
.modern-contact-form-panel .wpcf7-form p:has(.last-name),
.modern-contact-form-panel .wpcf7-form > p:nth-of-type(1):not(:has(input[type="submit"])),
.modern-contact-form-panel .wpcf7-form > p:nth-of-type(2):not(:has(input[type="submit"])),
.modern-contact-form-panel .wpcf7-form > p:nth-of-type(3):not(:has(input[type="submit"])),
.modern-contact-form-panel .wpcf7-form > p:nth-of-type(4):not(:has(input[type="submit"])) {
	grid-column: span 1;
}

/* Label styling - beautiful custom notched floating label on top of input border */
.modern-contact-form-panel label {
	display: block;
	position: relative;
	margin: 0;
	width: 100%;
}

.modern-contact-form-panel .wpcf7-form-control-wrap {
	display: block;
	margin: 0;
	width: 100%;
}

.modern-contact-form-panel .custom-form-label {
	position: absolute;
	top: -9px;
	left: 12px;
	background-color: #ffffff;
	padding: 0 6px;
	font-size: 0.75rem;
	font-weight: 600;
	color: #94a3b8; /* Slate 400 */
	z-index: 10;
	pointer-events: none;
	text-transform: capitalize;
	transition: color 0.15s ease;
}

.modern-contact-form-panel label:focus-within .custom-form-label {
	color: #0a325c;
}

/* Fields styling - clean white inputs with solid border */
.modern-contact-form-panel .wpcf7-form-control:not(.wpcf7-submit):not(.wpcf7-checkbox):not(.wpcf7-radio):not(.wpcf7-accept-checkbox) {
	width: 100%;
	padding: 0.8rem 1.125rem;
	border: 1px solid #cbd5e1;
	border-radius: 8px;
	font-size: 0.95rem;
	font-family: var(--font-sans);
	color: var(--text-primary);
	background-color: #ffffff;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.modern-contact-form-panel .wpcf7-form-control:not(.wpcf7-submit):not(.wpcf7-checkbox):not(.wpcf7-radio):not(.wpcf7-accept-checkbox):focus {
	outline: none;
	border-color: #0a325c;
	box-shadow: 0 0 0 3px rgba(10, 50, 92, 0.08);
}

.modern-contact-form-panel textarea.wpcf7-form-control,
.modern-contact-form-panel .wpcf7-textarea {
	min-height: 100px;
	height: 100px;
	resize: none;
}

/* Beautiful custom-styled native Select dropdown (completely bulletproof fallback) */
.modern-contact-form-panel select.wpcf7-form-control {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%230a325c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='18 9 12 15 6 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1.125rem center;
	background-size: 16px;
	padding-right: 3rem !important;
	cursor: pointer;
}

.modern-contact-form-panel select.wpcf7-form-control option {
	background-color: #ffffff;
	color: var(--text-primary);
}

/* Custom Select Dropdown Replacement Styling */
.custom-select-wrapper {
	position: relative;
	width: 100%;
}

/* Force-hide original native select element when custom dropdown is enqueued */
.custom-select-wrapper select,
.custom-select-wrapper select.wpcf7-form-control {
	position: absolute !important;
	top: 0 !important;
	left: 0 !important;
	opacity: 0 !important;
	pointer-events: none !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
	clip: rect(1px, 1px, 1px, 1px) !important;
	white-space: nowrap !important;
	z-index: -999 !important;
	display: inline-block !important; /* Keep display inline so it can receive focus for validation, but opacity 0 and position absolute hides it 100% */
	background: none !important;
	border: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

.custom-select-trigger {
	width: 100%;
	padding: 0.8rem 3rem 0.8rem 1.125rem;
	border: 1px solid #cbd5e1;
	border-radius: 8px;
	font-size: 0.95rem;
	font-family: var(--font-sans);
	color: var(--text-primary);
	background-color: #ffffff;
	text-align: left;
	cursor: pointer;
	display: block;
	position: relative;
	outline: none;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
	
	/* Chevron icon matching your image exactly */
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%230a325c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='18 9 12 15 6 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1.125rem center;
	background-size: 16px;
}

.custom-select-trigger:focus,
.custom-select-trigger.focused,
.custom-select-wrapper.open .custom-select-trigger {
	border-color: #0a325c;
	box-shadow: 0 0 0 3px rgba(10, 50, 92, 0.08);
	background-color: #ffffff;
}

/* Floating custom options dropdown card matching your style image */
.custom-options-container {
	position: absolute;
	top: calc(100% + 6px);
	left: 0;
	right: 0;
	background-color: #ffffff;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
	box-shadow: 0 10px 25px -5px rgba(15, 23, 42, 0.08), 0 8px 16px -6px rgba(15, 23, 42, 0.08);
	z-index: 1000;
	max-height: 240px;
	overflow-y: auto;
	scrollbar-width: thin;
	scrollbar-color: #cbd5e1 transparent;
	
	/* Animation transition */
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px);
	transition: opacity 0.2s cubic-bezier(0.4, 0, 0.2, 1), transform 0.2s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.2s;
}

.custom-select-wrapper.open .custom-options-container {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

/* Beautiful custom scrollbar matching your screenshot */
.custom-options-container::-webkit-scrollbar {
	width: 8px;
}

.custom-options-container::-webkit-scrollbar-track {
	background: transparent;
}

.custom-options-container::-webkit-scrollbar-thumb {
	background-color: #cbd5e1;
	border-radius: 9999px;
	border: 2px solid #ffffff;
}

.custom-options-container::-webkit-scrollbar-thumb:hover {
	background-color: #94a3b8;
}

/* Option List item */
.custom-option {
	padding: 0.8rem 1.125rem;
	font-size: 0.95rem;
	font-family: var(--font-sans);
	color: var(--text-secondary);
	cursor: pointer;
	transition: background-color var(--transition-fast), color var(--transition-fast);
}

.custom-option:first-child {
	border-top-left-radius: 8px;
	border-top-right-radius: 8px;
}

.custom-option:last-child {
	border-bottom-left-radius: 8px;
	border-bottom-right-radius: 8px;
}

.custom-option:hover,
.custom-option.selected {
	background-color: #f8fafc;
	color: #0a325c;
}

.custom-option.selected {
	font-weight: 600;
}

/* Submit Button */
.modern-contact-form-panel .wpcf7-submit {
	grid-column: span 2;
	width: 100%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.95rem 1.5rem;
	background: linear-gradient(95deg, #0a325c 0%, #1e293b 100%);
	color: #ffffff;
	border: none;
	border-radius: 8px;
	font-size: 1rem;
	font-weight: 600;
	font-family: var(--font-sans);
	cursor: pointer;
	box-shadow: 0 4px 10px rgba(10, 50, 92, 0.15);
	transition: opacity 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
	margin-top: var(--space-4);
}

.modern-contact-form-panel .wpcf7-submit:hover {
	opacity: 0.95;
	transform: translateY(-1px);
	box-shadow: 0 6px 15px rgba(10, 50, 92, 0.22);
}

.modern-contact-form-panel .wpcf7-submit:active {
	transform: translateY(0);
}

/* CF7 Response Messages */
.modern-contact-form-panel .wpcf7-response-output {
	grid-column: span 2;
	margin: var(--space-4) 0 0;
	padding: 0.75rem 1rem;
	border-radius: 8px;
	font-size: 0.9rem;
	font-weight: 500;
	text-align: center;
}

.modern-contact-form-panel .wpcf7-mail-sent-ok {
	border: 1px solid var(--success-color) !important;
	background-color: rgba(16, 185, 129, 0.08);
	color: #047857;
}

.modern-contact-form-panel .wpcf7-validation-errors,
.modern-contact-form-panel .wpcf7-mail-sent-ng {
	border: 1px solid var(--error-color) !important;
	background-color: rgba(239, 68, 68, 0.08);
	color: #b91c1c;
}

.modern-contact-form-panel .wpcf7-not-valid-tip {
	color: var(--error-color);
	font-size: 0.8rem;
	margin-top: 4px;
}

/* Spinner */
.modern-contact-form-panel .wpcf7 .ajax-loader {
	display: none;
}

/* Desktop Responsive Layout overrides */
@media (min-width: 640px) {
	.modern-contact-cards-grid {
		grid-template-columns: 1fr 1fr;
	}
}

@media (min-width: 1024px) {
	.modern-contact-page-wrapper {
		padding: var(--space-16) 0;
	}

	.modern-contact-title {
		font-size: 3.5rem;
	}

	.modern-contact-grid {
		grid-template-columns: 1.25fr 1fr;
		gap: var(--space-16);
	}

	.modern-contact-form-panel {
		padding: 30px;
	}
}

/* ==========================================================================
   15d. About Us Page Section
   ========================================================================== */
.about-page-wrapper {
	background-color: var(--bg-body);
	overflow-x: hidden;
}

/* Hero Section */
.about-hero-section {
	background-color: #09213d;
	color: #ffffff;
	padding: var(--space-12) 0 var(--space-16);
	position: relative;
}

.about-hero-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
	align-items: center;
	padding-bottom: 60px;
}

@media (min-width: 992px) {
	.about-hero-grid {
		grid-template-columns: 1.1fr 0.9fr;
		gap: var(--space-12);
	}
}

.about-hero-content {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

.about-hero-subtitle {
	font-size: 0.9rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #38bdf8; /* Cyan */
}

.about-hero-title {
	font-size: 2.5rem;
	font-weight: 600;
	line-height: 1.15;
	margin: 0;
	color: #ffffff;
}

@media (min-width: 768px) {
	.about-hero-title {
		font-size: 3.5rem;
	}
}

.about-hero-desc {
	font-size: 1.05rem;
	line-height: 1.65;
	color: #94a3b8; /* Muted Slate */
	max-width: 600px;
	margin: 0;
}

.about-hero-actions {
	margin-top: var(--space-2);
}

.btn-about-pill {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	background-color: #38bdf8; /* Cyan */
	color: #0f172a;
	padding: 0.85rem 1.75rem;
	border-radius: var(--radius-full);
	font-weight: 600;
	text-decoration: none;
	transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
	box-shadow: 0 4px 14px rgba(56, 189, 248, 0.25);
}

.btn-about-pill:hover {
	background-color: #7dd3fc;
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(56, 189, 248, 0.4);
}

.about-hero-checklist {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	margin-top: var(--space-4);
}

@media (min-width: 576px) {
	.about-hero-checklist {
		flex-direction: row;
		flex-wrap: wrap;
		gap: var(--space-6);
	}
}

.checklist-item-pill {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	font-size: 0.95rem;
	color: #cbd5e1;
}

.checklist-item-pill .check-icon {
	color: #38bdf8;
	flex-shrink: 0;
}

.about-hero-image-wrapper {
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
	aspect-ratio: 4 / 3;
}

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

/* Features Section (Overlay cards) */
.about-features-section {
	margin-top: -50px;
	position: relative;
	z-index: 10;
	padding-bottom: var(--space-12);
}

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

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

.about-feature-card {
	background-color: var(--bg-card);
	border: 1px solid var(--border-color);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	box-shadow: var(--shadow-lg);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.about-feature-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
}

.feature-icon-wrapper {
	width: 44px;
	height: 44px;
	border-radius: var(--radius-md);
	background-color: #f1f6fb;
	color: #0a325c;
	display: flex;
	align-items: center;
	justify-content: center;
}

.feature-card-title {
	font-size: 1.15rem;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0;
}

.feature-card-desc {
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--text-muted);
	margin: 0;
}

/* Why Choose Us Section */
.about-why-choose-section {
	padding: var(--space-12) 0 var(--space-16);
	background-color: #ffffff;
	border-top: 1px solid var(--border-color);
}

.why-choose-title {
	font-size: 2rem;
	font-weight: 600;
	color: var(--text-primary);
	margin-top: var(--space-2);
}

@media (min-width: 768px) {
	.why-choose-title {
		font-size: 2.5rem;
	}
}

.why-choose-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
	margin-top: var(--space-8);
}

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

.why-box {
	border-radius: var(--radius-lg);
	overflow: hidden;
	padding: var(--space-8);
	display: flex;
	flex-direction: column;
	min-height: 280px;
}

/* Box 1: Experienced Professionals (Large Block) */
.experienced-box {
	background-size: cover;
	background-position: center;
	position: relative;
	justify-content: flex-end;
	color: #ffffff;
}

.experienced-box .why-box-content {
	position: relative;
	z-index: 2;
}

.experienced-box .why-box-title {
	font-size: 1.5rem;
	font-weight: 600;
	margin: 0 0 var(--space-2);
	color: #ffffff;
}

.experienced-box .why-box-desc {
	font-size: 0.95rem;
	line-height: 1.55;
	color: #e2e8f0;
	margin: 0;
}

/* Right Area Group */
.why-right-group {
	display: flex;
	flex-direction: column;
	gap: var(--space-6);
}

.why-right-top-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}

@media (min-width: 576px) {
	.why-right-top-grid {
		grid-template-columns: 1fr 1fr;
	}
}

/* Box 2: Light Quality Card */
.quality-box {
	background-color: #f1f6fb; /* Light cool grey/ice blue */
	border: 1px solid var(--border-color);
	color: var(--text-primary);
	justify-content: flex-start;
	gap: var(--space-3);
}

.why-box-icon {
	width: 48px;
	height: 48px;
	border-radius: var(--radius-md);
	background-color: #e0e7ff;
	color: #4f46e5;
	display: flex;
	align-items: center;
	justify-content: center;
}

.quality-box .why-box-title {
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0;
}

.quality-box .why-box-desc {
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--text-secondary);
	margin: 0;
}

/* Box 3: Dark Blue Satisfaction Card */
.satisfaction-box {
	background-color: #0a325c; /* Deep dark blue */
	color: #ffffff;
	justify-content: space-between;
	gap: var(--space-4);
}

.satisfaction-box .why-box-title {
	font-size: 1.25rem;
	font-weight: 600;
	color: #ffffff;
	margin: 0;
	line-height: 1.35;
}

.team-avatars {
	display: flex;
	align-items: center;
	margin-left: 8px;
}

.avatar-img {
	width: 36px;
	height: 36px;
	border-radius: var(--radius-full);
	border: 2px solid #0a325c;
	object-fit: cover;
	margin-left: -8px;
	display: block;
}

.why-box-link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	color: #38bdf8;
	font-size: 0.9rem;
	font-weight: 600;
	text-decoration: none;
	transition: color 0.2s ease, transform 0.2s ease;
}

.why-box-link:hover {
	color: #7dd3fc;
}

.why-box-link:hover svg {
	transform: translateX(3px);
}

.why-box-link svg {
	transition: transform 0.2s ease;
}

/* Box 4: Emergency Box (Horizontal Wide Banner) */
.emergency-box {
	background-size: cover;
	background-position: center;
	position: relative;
	color: #ffffff;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: var(--space-6);
	min-height: 200px;
}

@media (min-width: 576px) {
	.emergency-box {
		flex-direction: row;
		align-items: center;
		text-align: left;
	}
}

.emergency-content {
	position: relative;
	z-index: 2;
}

.emergency-box .why-box-title {
	font-size: 1.5rem;
	font-weight: 600;
	color: #ffffff;
	margin: 0 0 var(--space-1);
}

.emergency-box .why-box-desc {
	font-size: 0.95rem;
	color: #cbd5e1;
	margin: 0;
}

.emergency-contact-info {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	gap: 4px;
	background-color: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(8px);
	padding: var(--space-4) var(--space-6);
	border-radius: var(--radius-md);
	border: 1px solid rgba(255, 255, 255, 0.15);
	align-self: flex-start;
}

@media (min-width: 576px) {
	.emergency-contact-info {
		align-self: auto;
		text-align: right;
	}
}

.emergency-contact-info .phone-link {
	font-size: 1.35rem;
	font-weight: 600;
	color: #ffffff;
	text-decoration: none;
	transition: color 0.2s ease;
}

.emergency-contact-info .phone-link:hover {
	color: #38bdf8;
}

.emergency-contact-info .tag-label {
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	color: #38bdf8;
}

/* ==========================================================================
   16. Custom Single Service Page Templates
   ========================================================================== */

/* Hero Section */
.single-service-hero {
	padding: 50px 0;
	background-size: cover;
	background-position: center;
	position: relative;
	color: #ffffff;
}

.single-service-hero::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(135deg, rgba(10, 50, 92, 0.9) 0%, rgba(15, 23, 42, 0.7) 100%);
	z-index: 1;
}

.single-service-hero-grid {
	position: relative;
	z-index: 2;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
	align-items: center;
}

@media (min-width: 992px) {
	.single-service-hero-grid {
		grid-template-columns: 1.2fr 0.8fr;
		gap: var(--space-16);
	}
}

.hero-left-content .service-badge {
	display: inline-block;
	background-color: rgba(56, 189, 248, 0.15);
	color: #38bdf8;
	padding: 0.35rem 0.85rem;
	border-radius: 9999px;
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin-bottom: var(--space-4);
}

.hero-left-content .hero-title {
	font-size: 2.5rem;
	font-weight: 600;
	color: #ffffff;
	line-height: 1.15;
	margin: 0 0 var(--space-4) 0;
	letter-spacing: -0.01em;
}

@media (min-width: 768px) {
	.hero-left-content .hero-title {
		font-size: 3.25rem;
	}
}

.hero-left-content .hero-desc {
	font-size: 1.1rem;
	color: rgba(255, 255, 255, 0.85);
	line-height: 1.6;
	margin: 0;
	max-width: 600px;
}

/* Page Hero (centered text, no form) */
.page-hero {
	padding: 60px 0;
	background-size: cover;
	background-position: center;
	position: relative;
	color: #ffffff;
}

.page-hero::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(135deg, rgba(10, 50, 92, 0.9) 0%, rgba(15, 23, 42, 0.7) 100%);
	z-index: 1;
}

.page-hero .container {
	position: relative;
	z-index: 2;
}

.page-hero-title {
	font-size: 2.5rem;
	font-weight: 600;
	color: #ffffff;
	line-height: 1.15;
	margin: 0 0 var(--space-4) 0;
	letter-spacing: -0.01em;
}

.page-hero-desc {
	font-size: 1.1rem;
	color: rgba(255, 255, 255, 0.85);
	line-height: 1.6;
	margin: 0 auto;
	max-width: 600px;
}

@media (min-width: 768px) {
	.page-hero-title {
		font-size: 3.25rem;
	}
}

/* Quick Contact floating panel */
.hero-right-cta {
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 20px;
	padding: var(--space-8);
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
}

.hero-right-cta.modern-contact-form-panel {
	background: #ffffff;
	border: 1px solid #e2e8f0;
	color: var(--text-primary);
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
	box-shadow: 0 20px 40px rgba(10, 50, 92, 0.15);
}

.cta-inner-panel .cta-panel-title {
	color: #ffffff;
	font-size: 1.25rem;
	font-weight: 600;
	margin: 0 0 var(--space-2) 0;
}

.cta-inner-panel .cta-panel-text {
	color: rgba(255, 255, 255, 0.8);
	font-size: 0.95rem;
	line-height: 1.5;
	margin: 0 0 var(--space-6) 0;
}

.cta-inner-panel .cta-phone-number {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	font-size: 1.35rem;
	font-weight: 600;
	color: #ffffff;
	margin-bottom: var(--space-6);
	background: rgba(10, 50, 92, 0.4);
	padding: 0.75rem 1rem;
	border-radius: 12px;
	border: 1px solid rgba(255, 255, 255, 0.1);
}

.cta-inner-panel .cta-phone-number svg {
	color: #38bdf8;
}

.cta-inner-panel .btn-panel-action {
	width: 100%;
	justify-content: center;
	background: #38bdf8;
	color: #0a325c;
	border-color: #38bdf8;
}

.cta-inner-panel .btn-panel-action:hover {
	background: #ffffff;
	color: #0a325c;
	border-color: #ffffff;
}

/* Section 2: Split Description with image */
.service-details-section {
	padding: var(--space-16) 0;
	background-color: #ffffff;
}

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

@media (min-width: 992px) {
	.service-details-grid {
		grid-template-columns: 1.1fr 0.9fr;
		gap: var(--space-16);
	}
}

.details-text-column .details-title {
	font-size: 1.85rem;
	font-weight: 600;
	color: #0c1a30;
	margin: 0 0 var(--space-4) 0;
}

.details-text-column .details-subtitle {
	font-size: 1.25rem;
	font-weight: 600;
	color: #0c1a30;
	margin: var(--space-6) 0 var(--space-3) 0;
}

.details-text-column .details-p {
	font-size: 1rem;
	color: #475569;
	line-height: 1.65;
	margin: 0 0 var(--space-4) 0;
}

.details-text-column .details-p:last-child {
	margin-bottom: 0;
}

.details-image-column .details-img {
	width: 100%;
	height: auto;
	border-radius: 16px;
	box-shadow: var(--shadow-md);
}

@media (max-width: 991px) {
	.details-image-column {
		margin-top: 30px;
	}
}

/* Section 3: Technical Blueprint Checklists Section */
.service-blueprint-section {
	padding: var(--space-16) 0;
	background-size: cover;
	background-position: center;
	position: relative;
	color: #ffffff;
}

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

@media (min-width: 992px) {
	.blueprint-grid {
		grid-template-columns: 0.9fr 1.1fr;
		gap: var(--space-16);
	}
}

.blueprint-text .blueprint-title {
	font-size: 1.85rem;
	font-weight: 600;
	color: #ffffff;
	margin: 0 0 var(--space-4) 0;
}

.blueprint-text .blueprint-p {
	font-size: 1rem;
	color: rgba(255, 255, 255, 0.85);
	line-height: 1.65;
	margin: 0;
}

@media (max-width: 991px) {
	.blueprint-text .blueprint-p {
		padding-bottom: 20px;
	}
}

.blueprint-lists-wrapper {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
}

@media (min-width: 576px) {
	.blueprint-lists-wrapper {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-8);
	}
}

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

.blueprint-list li {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	font-size: 1rem;
	color: rgba(255, 255, 255, 0.9);
}

.blueprint-list .blueprint-bullet {
	color: #38bdf8;
	flex-shrink: 0;
}

/* Section 4: Brand colored intermediate divider ribbon */
.service-colored-divider {
	background: linear-gradient(95deg, #0a325c 0%, #1e293b 100%);
	padding: var(--space-8) 0;
	color: #ffffff;
}

.service-colored-divider .divider-ribbon-text {
	font-size: 1.15rem;
	font-weight: 600;
	margin: 0;
	line-height: 1.5;
}

/* Section 5: Complete Cleaning Service & Accordions */
.service-accordion-section {
	padding: var(--space-16) 0;
	background-color: #f8fafc;
}

.service-accordion-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
	align-items: flex-start;
}

@media (min-width: 992px) {
	.service-accordion-grid {
		grid-template-columns: 0.9fr 1.1fr;
		gap: var(--space-16);
	}
}

.accordion-left-desc .accordion-section-title {
	font-size: 1.85rem;
	font-weight: 600;
	color: #0c1a30;
	margin: 0 0 var(--space-4) 0;
}

.accordion-left-desc .accordion-section-p {
	font-size: 1rem;
	color: #475569;
	line-height: 1.65;
	margin: 0 0 var(--space-4) 0;
}

.accordion-left-desc .accordion-section-p:last-child {
	margin-bottom: 0;
}

.accordion-right-items {
	width: 100%;
}

@media (max-width: 991px) {
	.accordion-right-items {
		margin-top: 30px;
	}
}

[data-animate] .accordion-right-items {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.6s cubic-bezier(0.16, 1, 0.3, 1),
	            transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

[data-animate].is-visible .accordion-right-items {
	opacity: 1;
	transform: translateY(0);
}

/* Section 6: Footer Call to Action Bar (Indigo Gradient) */
.service-footer-cta {
	background: linear-gradient(135deg, #0a325c 0%, #0c1a30 100%);
	padding: var(--space-12) 0;
	color: #ffffff;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.service-footer-cta-flex {
	display: flex;
	flex-direction: column;
	gap: var(--space-6);
	align-items: center;
	text-align: center;
}

@media (min-width: 992px) {
	.service-footer-cta-flex {
		flex-direction: row;
		justify-content: space-between;
		text-align: left;
		gap: var(--space-12);
	}
}

.service-footer-cta .footer-cta-title {
	font-size: 1.25rem;
	font-weight: 600;
	color: #ffffff;
	margin: 0;
	line-height: 1.5;
	max-width: 800px;
}

.service-footer-cta .btn-light {
	background-color: #ffffff;
	border-color: #ffffff;
}

.service-footer-cta .btn-light:hover {
	background-color: #38bdf8;
	border-color: #38bdf8;
}

/* ==========================================================================
   17. Custom Location Page (Huntingdon) Templates
   ========================================================================== */

/* Location Hero Section */
.location-hero {
	padding: 80px 0;
	background-size: cover;
	background-position: center;
	position: relative;
	color: #ffffff;
}

.location-hero::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(135deg, rgba(10, 50, 92, 0.85) 0%, rgba(15, 23, 42, 0.8) 100%);
	z-index: 1;
}

.location-hero-content {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.location-hero-icon-wrapper {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	background-color: #38bdf8;
	color: #0a325c;
	border-radius: 14px;
	margin-bottom: var(--space-5);
	box-shadow: 0 10px 25px rgba(56, 189, 248, 0.3);
}

.location-hero-title {
	font-size: 2.75rem;
	font-weight: 600;
	color: #ffffff;
	line-height: 1.15;
	margin: 0 0 var(--space-4) 0;
	letter-spacing: -0.01em;
}

@media (min-width: 768px) {
	.location-hero-title {
		font-size: 3.5rem;
	}
}

.location-hero-desc {
	font-size: 1.15rem;
	color: rgba(255, 255, 255, 0.9);
	line-height: 1.6;
	margin: 0;
	max-width: 680px;
}

/* Location Hero Split Grid (Form Left, Text Right) */
.location-hero-grid {
	position: relative;
	z-index: 2;
	display: grid;
	grid-template-columns: 1fr;
	gap: 40px;
	align-items: center;
}

@media (min-width: 992px) {
	.location-hero-grid {
		grid-template-columns: 1fr 1fr;
		gap: 60px;
	}
}

.location-hero-text {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	text-align: left;
}

.location-hero-text .location-hero-icon-wrapper {
	margin-bottom: var(--space-5);
}

.location-hero-text .location-hero-title {
	margin: 0 0 var(--space-4) 0;
}

/* Location Mission / Trust Section (Overlapping images + checklist) */
.location-mission-section {
	padding: 80px 0;
	background-color: #f8fafc;
}

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

@media (min-width: 768px) {
	.location-mission-grid {
		grid-template-columns: 1fr 1fr;
		gap: 60px;
	}
}

/* Overlapping Images */
.location-mission-images {
	position: relative;
	min-height: 360px;
}

.mission-img-wrapper {
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 20px 40px rgba(10, 50, 92, 0.1);
}

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

.mission-img-primary {
	width: 85%;
	height: 320px;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}

.mission-img-secondary {
	width: 55%;
	height: 220px;
	position: absolute;
	bottom: 0;
	right: 0;
	z-index: 2;
	border: 4px solid #f8fafc;
}

/* Mission Text Content */
.location-mission-text {
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
}

.mission-title {
	font-size: 2.25rem;
	font-weight: 600;
	color: #0a325c;
	line-height: 1.15;
	margin: 0;
	letter-spacing: -0.01em;
}

.mission-desc {
	font-size: 1.05rem;
	color: #475569;
	line-height: 1.65;
	margin: 20px 0;
	max-width: 520px;
}

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

.mission-checklist li {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	font-size: 1rem;
	font-weight: 500;
	color: #0a325c;
}

.mission-check-icon {
	color: #38bdf8;
	flex-shrink: 0;
}

/* Location Split Layout */
.location-split-section {
	padding: 80px 0;
	background-color: #ffffff;
}

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

@media (min-width: 992px) {
	.location-split-grid {
		grid-template-columns: 300px 1fr;
		gap: 60px;
	}
}

/* Sidebar Styling (Matches reference images exactly) */
.location-sidebar {
	width: 100%;
}

@media (min-width: 992px) {
	.location-sidebar {
		position: sticky;
		top: 110px;
		align-self: start;
	}
}

.location-sidebar-title {
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--text-muted);
	margin: 0 0 20px 0;
}

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

.sidebar-menu-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.75rem 1rem;
	background-color: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 14px;
	color: var(--text-primary);
	font-weight: 600;
	font-size: 0.95rem;
	text-decoration: none;
	transition: all var(--transition-fast) ease;
}

.sidebar-link-icon-wrapper {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background-color: #f1f5f9;
	color: #0a325c;
	border-radius: 8px;
	margin-right: var(--space-3);
	transition: all var(--transition-fast) ease;
}

.sidebar-link-text {
	flex-grow: 1;
}

.sidebar-link-chevron {
	color: #94a3b8;
	transition: transform var(--transition-fast) ease, color var(--transition-fast) ease;
}

/* Sidebar States */
.sidebar-menu-link:hover {
	background-color: #ffffff;
	border-color: #cbd5e1;
	box-shadow: 0 8px 16px rgba(10, 50, 92, 0.05);
	transform: translateY(-1px);
}

.sidebar-menu-link:hover .sidebar-link-chevron {
	transform: translateX(2px);
	color: #475569;
}

.sidebar-menu-link.active {
	background-color: #0a325c;
	border-color: #0a325c;
	color: #ffffff;
	box-shadow: 0 8px 20px rgba(10, 50, 92, 0.15);
}

.sidebar-menu-link.active .sidebar-link-icon-wrapper {
	background-color: rgba(255, 255, 255, 0.15);
	color: #38bdf8;
}

.sidebar-menu-link.active .sidebar-link-chevron {
	color: #ffffff;
}

/* Service Content Blocks */
.location-main-content {
	display: flex;
	flex-direction: column;
	gap: 60px;
}

.location-service-block {
	scroll-margin-top: 110px;
	padding-bottom: 50px;
	border-bottom: 1px solid #f1f5f9;
}

.location-service-block:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.service-block-title {
	font-size: 1.75rem;
	font-weight: 600;
	color: #0a325c;
	margin: 0 0 var(--space-4) 0;
	letter-spacing: -0.01em;
}

.service-block-p {
	font-size: 1.05rem;
	color: #475569;
	line-height: 1.65;
	margin: 0 0 var(--space-4) 0;
}

.service-block-p:last-child {
	margin-bottom: 0;
}

/* Location Footer Call to Action Bar */
.location-footer-cta {
	background: linear-gradient(135deg, #0a325c 0%, #0c1a30 100%);
	padding: var(--space-12) 0;
	color: #ffffff;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.location-footer-cta-flex {
	display: flex;
	flex-direction: column;
	gap: var(--space-6);
	align-items: center;
	text-align: center;
}

@media (min-width: 992px) {
	.location-footer-cta-flex {
		flex-direction: row;
		justify-content: space-between;
		text-align: left;
		gap: var(--space-12);
	}
}

.location-footer-cta .location-footer-cta-title {
	font-size: 1.25rem;
	font-weight: 600;
	color: #ffffff;
	margin: 0;
	line-height: 1.5;
	max-width: 800px;
}

.location-footer-cta .btn-light {
	background-color: #ffffff;
	border-color: #ffffff;
}

.location-footer-cta .btn-light:hover {
	background-color: #38bdf8;
	border-color: #38bdf8;
}

/* ==========================================================================
   18. Custom Locations Archive Hub Page Templates
   ========================================================================== */

/* Locations Hero */
.locations-hero {
	padding: 80px 0;
	background-size: cover;
	background-position: center;
	position: relative;
	color: #ffffff;
}

.locations-hero::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(135deg, rgba(10, 50, 92, 0.85) 0%, rgba(15, 23, 42, 0.8) 100%);
	z-index: 1;
}

.locations-hero-content {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.locations-badge {
	display: inline-block;
	background-color: rgba(56, 189, 248, 0.15);
	color: #38bdf8;
	padding: 0.35rem 0.85rem;
	border-radius: 9999px;
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin-bottom: var(--space-4);
}

.locations-title {
	font-size: 2.75rem;
	font-weight: 600;
	color: #ffffff;
	line-height: 1.15;
	margin: 0 0 var(--space-4) 0;
	letter-spacing: -0.01em;
}

@media (min-width: 768px) {
	.locations-title {
		font-size: 3.5rem;
	}
}

.locations-desc {
	font-size: 1.15rem;
	color: rgba(255, 255, 255, 0.9);
	line-height: 1.6;
	margin: 0;
	max-width: 680px;
}

/* Locations Grid Section */
.locations-grid-section {
	padding: 80px 0;
	background-color: #f8fafc;
}

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

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

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

@media (min-width: 992px) {
	.locations-grid {
		grid-template-columns: repeat(4, 1fr);
		gap: 24px;
	}
}

/* Locations Card Design (Matches reference image perfectly) */
.location-card {
	background-color: #ffffff;
	border: 1px solid #e2e8f0;
	border-radius: 20px;
	padding: 30px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.location-card-title {
	font-size: 1.35rem;
	font-weight: 600;
	color: #0c1a30;
	margin: 0 0 0.75rem 0;
	letter-spacing: -0.01em;
}

.location-card-desc {
	font-size: 0.95rem;
	color: #475569;
	line-height: 1.55;
	margin: 0 0 1.5rem 0;
}

.location-explore-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: #1e3a8a; /* Clean indigo link matching reference */
	font-weight: 600;
	font-size: 0.9rem;
	text-decoration: none;
	transition: color var(--transition-fast) ease;
}

.location-explore-link .link-arrow {
	color: #2563eb;
	transition: transform var(--transition-fast) ease;
}

/* Location Card Hover Interactions */
.location-card:hover {
	transform: translateY(-4px);
	border-color: #cbd5e1;
	box-shadow: 0 12px 30px rgba(10, 50, 92, 0.05);
}

.location-card:hover .location-explore-link {
	color: #2563eb;
}

.location-card:hover .link-arrow {
	transform: translateX(4px);
}

/* Fallback Locations CTA Section */
.locations-fallback-cta {
	background: linear-gradient(135deg, #0a325c 0%, #0c1a30 100%);
	padding: var(--space-16) 0;
	color: #ffffff;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.locations-fallback-flex {
	display: flex;
	flex-direction: column;
	gap: var(--space-8);
	align-items: center;
	text-align: center;
}

@media (min-width: 992px) {
	.locations-fallback-flex {
		flex-direction: row;
		justify-content: space-between;
		text-align: left;
		gap: var(--space-12);
	}
}

.locations-fallback-cta .fallback-title {
	font-size: 1.75rem;
	font-weight: 600;
	color: #ffffff;
	margin: 0 0 var(--space-3) 0;
	letter-spacing: -0.01em;
}

.locations-fallback-cta .fallback-desc {
	font-size: 1.05rem;
	color: rgba(255, 255, 255, 0.85);
	margin: 0;
	line-height: 1.6;
	max-width: 720px;
}

.locations-fallback-cta .btn-light {
	background-color: #ffffff;
	border-color: #ffffff;
	white-space: nowrap;
}

.locations-fallback-cta .btn-light:hover {
	background-color: #38bdf8;
	border-color: #38bdf8;
}


