/**
 * CleanOut Junkers — Main Stylesheet
 *
 * Global layout, header, footer, utility bar, mobile menu,
 * section scaffolding, and page-level patterns.
 * All values reference CSS custom properties defined in style.css.
 *
 * @package CleanOut_Junkers
 */

/* =============================================================================
   UTILITY BAR
   Thin strip above the header. Desktop only (hidden < 768px).
   ============================================================================= */

.utility-bar {
	background-color: var(--color-black);
	border-bottom:    1px solid rgba(255, 255, 255, 0.06);
	padding-block:    var(--space-2);
	font-size:        var(--text-xs);
	color:            var(--color-text-secondary);
}

.utility-bar__inner {
	display:         flex;
	align-items:     center;
	justify-content: space-between;
	gap:             var(--space-4);
}

.utility-bar__left,
.utility-bar__right {
	display:     flex;
	align-items: center;
	gap:         var(--space-4);
	flex-wrap:   wrap;
}

.utility-bar__item {
	display:     flex;
	align-items: center;
	gap:         var(--space-2);
}

.utility-bar__link {
	color:      var(--color-text-secondary);
	transition: var(--transition-color);
}

.utility-bar__link:hover {
	color: var(--color-accent);
}

.utility-bar__divider {
	color:   var(--color-charcoal);
	opacity: 0.6;
}

.utility-bar__badge {
	display:          inline-flex;
	align-items:      center;
	gap:              var(--space-1);
	background-color: var(--color-accent-muted);
	color:            var(--color-accent-light);
	padding:          2px var(--space-3);
	border-radius:    var(--radius-full);
	font-weight:      var(--weight-semibold);
	letter-spacing:   var(--tracking-wide);
	font-size:        10px;
	text-transform:   uppercase;
}

@media (max-width: 767px) {
	.utility-bar {
		display: none;
	}
}

/* =============================================================================
   SITE HEADER
   Sticky dark navigation bar. Transitions to .is-scrolled on scroll.
   ============================================================================= */

.site-header {
	position:         sticky;
	top:              0;
	left:             0;
	right:            0;
	z-index:          var(--z-sticky);
	height:           var(--header-height);
	background-color: var(--color-black);
	border-bottom:    1px solid rgba(255, 255, 255, 0.06);
	transition:       box-shadow var(--duration-base) var(--ease-out),
	                  background-color var(--duration-base) var(--ease-out);
}

/* Scrolled state — stronger shadow */
.site-header.is-scrolled {
	background-color: rgba(10, 10, 10, 0.97);
	backdrop-filter:  saturate(180%) blur(12px);
	-webkit-backdrop-filter: saturate(180%) blur(12px);
	box-shadow:       0 4px 30px rgba(0, 0, 0, 0.50);
}

.site-header__inner {
	display:         flex;
	align-items:     center;
	justify-content: space-between;
	height:          100%;
	gap:             var(--space-6);
}

/* ---- Logo ---- */

.site-header__logo {
	flex-shrink: 0;
	display:     flex;
	align-items: center;
}

.site-header__logo .custom-logo {
	height:     48px;
	width:      auto;
	max-width:  180px;
	object-fit: contain;
}

.site-header__logo-text {
	font-family:    var(--font-display);
	font-size:      var(--text-2xl);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	color:          var(--color-text-primary);
	line-height:    1;
	transition:     var(--transition-color);
}

.site-header__logo-text:hover {
	color: var(--color-accent);
}

.logo-text__main {
	display: block;
}

/* ---- Primary Nav ---- */

.site-header__nav {
	display:     flex;
	align-items: center;
	flex:        1;
}

.nav-menu {
	display:     flex;
	align-items: center;
	gap:         var(--space-1);
	list-style:  none;
	margin:      0;
	padding:     0;
}

.nav-menu__item {
	position: relative;
}

.nav-menu__link {
	display:        block;
	padding:        var(--space-2) var(--space-4);
	font-family:    var(--font-body);
	font-size:      var(--text-sm);
	font-weight:    var(--weight-medium);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	color:          var(--color-text-secondary);
	transition:     var(--transition-color);
	white-space:    nowrap;
	border-radius:  var(--radius-sm);
}

.nav-menu__link:hover,
.nav-menu__item.is-active .nav-menu__link,
.nav-menu__item.current-menu-item .nav-menu__link {
	color: var(--color-text-primary);
}

/* Active underline indicator */
.nav-menu__item.is-active .nav-menu__link::after,
.nav-menu__item.current-menu-item .nav-menu__link::after {
	content:          '';
	display:          block;
	position:         absolute;
	bottom:           -2px;
	left:             var(--space-4);
	right:            var(--space-4);
	height:           2px;
	background:       var(--gradient-accent);
	border-radius:    var(--radius-full);
}

/* ---- Header Actions ---- */

.site-header__actions {
	display:     flex;
	align-items: center;
	gap:         var(--space-4);
	flex-shrink: 0;
}

.site-header__cta {
	/* Slight glow on header CTA */
	box-shadow: var(--shadow-accent-sm);
}

/* Hide nav + CTA on mobile — shown via mobile menu */
@media (max-width: 1023px) {
	.site-header__nav {
		display: none;
	}

	.site-header__cta {
		display: none;
	}
}

/* =============================================================================
   HAMBURGER BUTTON
   Three-line icon that animates to an X when .is-active.
   ============================================================================= */

.mobile-menu-toggle {
	display:          flex;
	align-items:      center;
	justify-content:  center;
	width:            44px;
	height:           44px;
	background:       transparent;
	border:           1px solid rgba(255, 255, 255, 0.15);
	border-radius:    var(--radius-sm);
	cursor:           pointer;
	padding:          0;
	transition:       border-color var(--duration-base) var(--ease-out),
	                  background-color var(--duration-base) var(--ease-out);
}

.mobile-menu-toggle:hover {
	border-color:     var(--color-accent);
	background-color: var(--color-accent-muted);
}

/* Hide hamburger on desktop */
@media (min-width: 1024px) {
	.mobile-menu-toggle {
		display: none;
	}
}

.hamburger {
	display:        flex;
	flex-direction: column;
	justify-content:center;
	gap:            5px;
	width:          22px;
}

.hamburger__line {
	display:          block;
	height:           2px;
	background-color: var(--color-text-primary);
	border-radius:    var(--radius-full);
	transition:       transform var(--duration-base) var(--ease-out),
	                  opacity   var(--duration-base) var(--ease-out),
	                  width     var(--duration-base) var(--ease-out);
	transform-origin: center;
}

.hamburger__line--mid {
	width: 75%;
}

/* Animate to X when .is-active on the toggle */
.mobile-menu-toggle.is-active .hamburger__line--top {
	transform: translateY(7px) rotate(45deg);
}

.mobile-menu-toggle.is-active .hamburger__line--mid {
	opacity: 0;
	transform: scaleX(0);
}

.mobile-menu-toggle.is-active .hamburger__line--bot {
	transform: translateY(-7px) rotate(-45deg);
}

/* =============================================================================
   MOBILE MENU DRAWER
   Slides in from the right. Backdrop covers the rest of the screen.
   ============================================================================= */

.mobile-menu {
	position:   fixed;
	inset:      0;
	z-index:    var(--z-modal);
	display:    grid;
	/* Hidden via opacity + pointer-events rather than display:none
	   so CSS transitions work properly. */
}

/* When hidden prop is present the menu is completely invisible */
.mobile-menu[hidden] {
	display: none !important;
}

.mobile-menu__backdrop {
	position:         absolute;
	inset:            0;
	background-color: rgba(0, 0, 0, 0.75);
	backdrop-filter:  blur(4px);
	opacity:          0;
	transition:       opacity var(--duration-slow) var(--ease-out);
}

.mobile-menu.is-open .mobile-menu__backdrop {
	opacity: 1;
}

.mobile-menu__panel {
	position:         absolute;
	top:              0;
	right:            0;
	bottom:           0;
	width:            min(380px, 90vw);
	background-color: var(--color-dark-mid);
	border-left:      1px solid rgba(255, 255, 255, 0.08);
	display:          flex;
	flex-direction:   column;
	overflow-y:       auto;
	transform:        translateX(100%);
	transition:       transform var(--duration-slow) var(--ease-out);
}

.mobile-menu.is-open .mobile-menu__panel {
	transform: translateX(0);
}

.mobile-menu__header {
	display:         flex;
	align-items:     center;
	justify-content: space-between;
	padding:         var(--space-6);
	border-bottom:   1px solid rgba(255, 255, 255, 0.08);
	flex-shrink:     0;
}

.mobile-menu__logo {
	font-family:    var(--font-display);
	font-size:      var(--text-xl);
	color:          var(--color-text-primary);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
}

.mobile-menu__logo:hover {
	color: var(--color-accent);
}

.mobile-menu__close {
	display:          flex;
	align-items:      center;
	justify-content:  center;
	width:            40px;
	height:           40px;
	background:       transparent;
	border:           1px solid rgba(255, 255, 255, 0.12);
	border-radius:    var(--radius-sm);
	color:            var(--color-text-secondary);
	cursor:           pointer;
	transition:       var(--transition-base);
	flex-shrink:      0;
}

.mobile-menu__close:hover {
	border-color: var(--color-accent);
	color:        var(--color-accent);
}

/* Mobile nav list */
.mobile-nav-menu {
	list-style:     none;
	padding:        var(--space-4) 0;
	margin:         0;
	flex:           1;
}

.mobile-nav-menu li {
	border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.mobile-nav-menu li:last-child {
	border-bottom: none;
}

.mobile-nav-menu a {
	display:        block;
	padding:        var(--space-4) var(--space-6);
	font-size:      var(--text-md);
	font-weight:    var(--weight-medium);
	color:          var(--color-text-secondary);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	transition:     var(--transition-color);
}

.mobile-nav-menu a:hover,
.mobile-nav-menu .is-active a,
.mobile-nav-menu .current-menu-item a {
	color:            var(--color-text-primary);
	background-color: rgba(255, 255, 255, 0.04);
}

.mobile-nav-menu .is-active a {
	color:            var(--color-accent);
	border-left:      3px solid var(--color-accent);
	padding-left:     calc(var(--space-6) - 3px);
}

.mobile-menu__footer {
	padding:       var(--space-6);
	border-top:    1px solid rgba(255, 255, 255, 0.08);
	flex-shrink:   0;
	display:       flex;
	flex-direction:column;
	gap:           var(--space-4);
}

.mobile-menu__contact {
	text-align:  center;
	font-size:   var(--text-sm);
	color:       var(--color-text-secondary);
}

.mobile-menu__phone {
	display:     block;
	font-family: var(--font-display);
	font-size:   var(--text-2xl);
	color:       var(--color-accent);
	letter-spacing: var(--tracking-wide);
	margin-top:  var(--space-1);
	transition:  var(--transition-color);
}

.mobile-menu__phone:hover {
	color: var(--color-accent-hover);
}

/* =============================================================================
   SITE MAIN
   Offset from sticky header so content starts below it.
   ============================================================================= */

.site-main {
	min-height: 60vh;
}

/* Offset anchor targets so they don't hide behind sticky header */
:target {
	scroll-margin-top: calc(var(--header-height) + var(--space-4));
}

/* =============================================================================
   SITE FOOTER
   ============================================================================= */

.site-footer {
	background-color: var(--color-black);
	color:            var(--color-text-secondary);
}

/* Orange accent stripe at top of footer */
.footer-accent-bar {
	height:     4px;
	background: var(--gradient-accent-h);
}

/* ---- Footer Main (4 columns) ---- */

.footer-main {
	padding-block: var(--space-16) var(--space-12);
}

.footer-main__inner {
	display:               grid;
	grid-template-columns: 2fr 1fr 1fr 1.5fr;
	gap:                   var(--gap-lg);
}

@media (max-width: 1199px) {
	.footer-main__inner {
		grid-template-columns: 1fr 1fr;
		gap:                   var(--gap-md);
	}

	.footer-col--brand {
		grid-column: 1 / -1;
	}
}

@media (max-width: 599px) {
	.footer-main__inner {
		grid-template-columns: 1fr;
	}

	.footer-col--brand {
		grid-column: auto;
	}
}

/* ---- Footer Col Shared ---- */

.footer-col__title {
	font-family:    var(--font-body);
	font-size:      var(--text-xs);
	font-weight:    var(--weight-semibold);
	letter-spacing: var(--tracking-widest);
	text-transform: uppercase;
	color:          var(--color-text-primary);
	margin-bottom:  var(--space-6);
}

/* ---- Brand Column ---- */

.footer-col__logo .custom-logo {
	height:     50px;
	width:      auto;
	margin-bottom: var(--space-4);
}

.footer-col__logo-text {
	display:        block;
	font-family:    var(--font-display);
	font-size:      var(--text-3xl);
	color:          var(--color-text-primary);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	line-height:    1;
	margin-bottom:  var(--space-4);
	transition:     var(--transition-color);
}

.footer-col__logo-text:hover {
	color: var(--color-accent);
}

.footer-col__tagline {
	font-size:   var(--text-sm);
	line-height: var(--leading-relaxed);
	max-width:   34ch;
	margin-bottom: var(--space-6);
}

/* Trust list */
.footer-trust-list {
	list-style:    none;
	margin:        0 0 var(--space-6);
	padding:       0;
	display:       flex;
	flex-direction:column;
	gap:           var(--space-2);
}

.footer-trust-list__item {
	display:     flex;
	align-items: center;
	gap:         var(--space-2);
	font-size:   var(--text-sm);
	color:       var(--color-text-secondary);
}

/* Social icons */
.footer-social {
	display: flex;
	gap:     var(--space-3);
}

.footer-social__link {
	display:          flex;
	align-items:      center;
	justify-content:  center;
	width:            38px;
	height:           38px;
	background-color: var(--color-dark-surface);
	border:           1px solid rgba(255, 255, 255, 0.08);
	border-radius:    var(--radius-sm);
	color:            var(--color-text-secondary);
	transition:       var(--transition-base);
}

.footer-social__link:hover {
	background-color: var(--color-accent);
	border-color:     var(--color-accent);
	color:            var(--color-white);
	transform:        translateY(-3px);
	box-shadow:       var(--shadow-accent-sm);
}

/* ---- Nav / Services Lists ---- */

.footer-nav-list {
	list-style: none;
	margin:     0;
	padding:    0;
	display:    flex;
	flex-direction: column;
	gap:        var(--space-2);
}

.footer-nav-list__item {
	display: block;
}

.footer-nav-list__link {
	display:     inline-flex;
	align-items: center;
	gap:         var(--space-2);
	font-size:   var(--text-sm);
	color:       var(--color-text-secondary);
	transition:  var(--transition-color);
	padding-block: var(--space-1);
}

.footer-nav-list__link::before {
	content:     '—';
	color:       var(--color-accent);
	font-size:   10px;
	opacity:     0;
	transform:   translateX(-4px);
	transition:  opacity var(--duration-base) var(--ease-out),
	             transform var(--duration-base) var(--ease-out);
}

.footer-nav-list__link:hover {
	color:           var(--color-text-primary);
	padding-left:    var(--space-2);
}

.footer-nav-list__link:hover::before {
	opacity:   1;
	transform: translateX(0);
}

/* ---- Contact List ---- */

.footer-contact-list {
	list-style: none;
	margin:     0 0 var(--space-6);
	padding:    0;
	display:    flex;
	flex-direction: column;
	gap:        var(--space-5);
}

.footer-contact-list__item {
	display:     flex;
	align-items: flex-start;
	gap:         var(--space-3);
	font-size:   var(--text-sm);
	line-height: var(--leading-relaxed);
}

.footer-contact-list__item .icon--accent {
	color:      var(--color-accent);
	flex-shrink:0;
	margin-top: 3px;
}

.footer-contact-list__item strong {
	display:      block;
	font-weight:  var(--weight-semibold);
	color:        var(--color-text-primary);
	margin-bottom:var(--space-1);
	font-size:    var(--text-xs);
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
}

.footer-contact-list__link {
	color:      var(--color-text-secondary);
	transition: var(--transition-color);
}

.footer-contact-list__link:hover {
	color: var(--color-accent);
}

.footer-col__cta {
	margin-top: var(--space-4);
}

/* ---- Footer Bottom Bar ---- */

.footer-bottom {
	border-top:    1px solid rgba(255, 255, 255, 0.06);
	padding-block: var(--space-5);
}

.footer-bottom__inner {
	display:         flex;
	align-items:     center;
	justify-content: space-between;
	gap:             var(--space-4);
	flex-wrap:       wrap;
}

.footer-bottom__copy,
.footer-bottom__credit {
	font-size: var(--text-xs);
	color:     var(--color-text-tertiary);
}

.footer-bottom__copy a,
.footer-bottom__credit a {
	color:      var(--color-text-secondary);
	transition: var(--transition-color);
}

.footer-bottom__copy a:hover,
.footer-bottom__credit a:hover {
	color: var(--color-accent);
}

.footer-bottom__legal {
	display:     flex;
	align-items: center;
	gap:         var(--space-5);
	list-style:  none;
	flex-wrap:   wrap;
}

.footer-bottom__legal a {
	font-size:  var(--text-xs);
	color:      var(--color-text-tertiary);
	transition: var(--transition-color);
}

.footer-bottom__legal a:hover {
	color: var(--color-accent);
}

/* =============================================================================
   ICON UTILITY
   SVG icons used inline throughout templates.
   ============================================================================= */

.icon {
	display:        inline-block;
	vertical-align: middle;
	flex-shrink:    0;
}

.icon--accent {
	color: var(--color-accent);
}

/* =============================================================================
   PAGE HERO (inner pages — about, contact, etc.)
   ============================================================================= */

.page-hero {
	position:      relative;
	padding-block: clamp(4rem, 10vw, 7rem);
	background-color: var(--color-dark);
	overflow:      hidden;
}

/* Diagonal accent line decoration */
.page-hero::before {
	content:          '';
	position:         absolute;
	bottom:           0;
	left:             0;
	right:            0;
	height:           3px;
	background:       var(--gradient-accent-h);
}

.page-hero__inner {
	position:  relative;
	z-index:   var(--z-raised);
}

.page-hero__label {
	display:       inline-block;
	font-size:     var(--text-xs);
	font-weight:   var(--weight-semibold);
	letter-spacing:var(--tracking-widest);
	text-transform:uppercase;
	color:         var(--color-accent);
	margin-bottom: var(--space-3);
}

.page-hero__title {
	font-size:     var(--text-5xl);
	color:         var(--color-text-primary);
	letter-spacing:var(--tracking-wide);
	text-transform:uppercase;
	line-height:   var(--leading-tight);
	margin-bottom: var(--space-4);
}

.page-hero__subtitle {
	font-size:   var(--text-lg);
	color:       var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	max-width:   55ch;
}

/* Background image variant */
.page-hero--has-bg {
	background-size:     cover;
	background-position: center;
	background-repeat:   no-repeat;
}

.page-hero--has-bg::after {
	content:  '';
	position: absolute;
	inset:    0;
	background: var(--gradient-hero);
	z-index:  1;
}

.page-hero--has-bg .page-hero__inner {
	z-index: var(--z-raised);
}

/* =============================================================================
   BREADCRUMB
   ============================================================================= */

.breadcrumb {
	display:     flex;
	align-items: center;
	gap:         var(--space-2);
	font-size:   var(--text-xs);
	color:       var(--color-text-tertiary);
	margin-bottom: var(--space-4);
}

.breadcrumb a {
	color:      var(--color-text-tertiary);
	transition: var(--transition-color);
}

.breadcrumb a:hover {
	color: var(--color-accent);
}

.breadcrumb__sep {
	opacity: 0.4;
}

/* =============================================================================
   SECTION HEADING BLOCKS
   Generated by cleanout_section_heading() in functions.php.
   ============================================================================= */

.section-heading {
	margin-bottom: var(--space-12);
}

.section-heading.text-center {
	max-width:     700px;
	margin-inline: auto;
}

/* =============================================================================
   STATS / NUMBERS BAR
   Used in home trust-bar section.
   ============================================================================= */

.stats-bar {
	background-color: var(--color-dark-mid);
	border-top:    1px solid rgba(255, 255, 255, 0.06);
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
	padding-block: var(--space-10) var(--space-8);
}

.stats-bar__inner {
	display:               grid;
	grid-template-columns: repeat(4, 1fr);
	gap:                   var(--gap-md);
}

@media (max-width: 899px) {
	.stats-bar__inner {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 479px) {
	.stats-bar__inner {
		grid-template-columns: 1fr;
		text-align: center;
	}
}

.stat-item {
	display:        flex;
	flex-direction: column;
	gap:            var(--space-2);
	padding-inline: var(--space-4);
	border-right:   1px solid rgba(255, 255, 255, 0.06);
}

.stat-item:last-child {
	border-right: none;
}

.stat-item__number {
	font-family:    var(--font-display);
	font-size:      var(--text-5xl);
	color:          var(--color-accent);
	letter-spacing: var(--tracking-tight);
	line-height:    1;
}

.stat-item__label {
	font-size:      var(--text-sm);
	font-weight:    var(--weight-medium);
	color:          var(--color-text-secondary);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
}

/* =============================================================================
   SERVICE CARDS GRID
   ============================================================================= */

.services-grid {
	display:               grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap:                   var(--gap-md);
}

.service-card {
	background-color: var(--color-dark-mid);
	border:           1px solid rgba(255, 255, 255, 0.06);
	border-radius:    var(--radius-lg);
	padding:          var(--space-8);
	display:          flex;
	flex-direction:   column;
	gap:              var(--space-4);
	transition:       var(--transition-base);
	position:         relative;
	overflow:         hidden;
}

.service-card::before {
	content:    '';
	position:   absolute;
	top:        0;
	left:       0;
	right:      0;
	height:     3px;
	background: var(--gradient-accent);
	transform:  scaleX(0);
	transform-origin: left;
	transition: transform var(--duration-slow) var(--ease-out);
}

.service-card:hover {
	border-color: rgba(244, 98, 31, 0.25);
	box-shadow:   var(--shadow-card-hover);
	transform:    translateY(-4px);
}

.service-card:hover::before {
	transform: scaleX(1);
}

.service-card__icon {
	width:            56px;
	height:           56px;
	background-color: var(--color-accent-muted);
	border-radius:    var(--radius-md);
	display:          flex;
	align-items:      center;
	justify-content:  center;
	color:            var(--color-accent);
	flex-shrink:      0;
}

.service-card__title {
	font-family:    var(--font-display);
	font-size:      var(--text-2xl);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	color:          var(--color-text-primary);
	line-height:    var(--leading-snug);
}

.service-card__desc {
	font-size:   var(--text-sm);
	color:       var(--color-text-secondary);
	line-height: var(--leading-relaxed);
	flex:        1;
}

.service-card__link {
	display:     inline-flex;
	align-items: center;
	gap:         var(--space-2);
	font-size:   var(--text-sm);
	font-weight: var(--weight-semibold);
	color:       var(--color-accent);
	transition:  var(--transition-color);
	margin-top:  auto;
}

.service-card__link:hover {
	color: var(--color-accent-hover);
	gap:   var(--space-3);
}

/* =============================================================================
   HOW IT WORKS — STEP BLOCKS
   ============================================================================= */

.steps-grid {
	display:               grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap:                   var(--gap-lg);
	position:              relative;
}

/* Connecting line between steps — desktop only */
.steps-grid::before {
	content:      '';
	position:     absolute;
	top:          40px;
	left:         calc(var(--space-10) + 20px);
	right:        calc(var(--space-10) + 20px);
	height:       2px;
	background:   repeating-linear-gradient(
	                90deg,
	                var(--color-accent) 0,
	                var(--color-accent) 8px,
	                transparent 8px,
	                transparent 20px
	              );
	z-index:      0;
}

@media (max-width: 767px) {
	.steps-grid::before {
		display: none;
	}
}

.step-item {
	display:        flex;
	flex-direction: column;
	align-items:    flex-start;
	gap:            var(--space-4);
	position:       relative;
	z-index:        var(--z-raised);
}

.step-item__number {
	width:            56px;
	height:           56px;
	border-radius:    var(--radius-full);
	background:       var(--gradient-accent);
	display:          flex;
	align-items:      center;
	justify-content:  center;
	font-family:      var(--font-display);
	font-size:        var(--text-2xl);
	color:            var(--color-white);
	flex-shrink:      0;
	box-shadow:       var(--shadow-accent-sm);
}

.step-item__title {
	font-family:    var(--font-display);
	font-size:      var(--text-2xl);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	color:          var(--color-text-primary);
}

.step-item__desc {
	font-size:   var(--text-sm);
	color:       var(--color-text-secondary);
	line-height: var(--leading-relaxed);
}

/* =============================================================================
   TESTIMONIALS
   ============================================================================= */

.testimonials-grid {
	display:               grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap:                   var(--gap-md);
}

.testimonial-card {
	background-color: var(--color-dark-mid);
	border:           1px solid rgba(255, 255, 255, 0.06);
	border-radius:    var(--radius-lg);
	padding:          var(--space-8);
	display:          flex;
	flex-direction:   column;
	gap:              var(--space-4);
	transition:       var(--transition-base);
}

.testimonial-card:hover {
	border-color: rgba(244, 98, 31, 0.15);
	transform:    translateY(-2px);
}

.testimonial-card__stars {
	display: flex;
	gap:     var(--space-1);
	color:   var(--color-accent);
}

.testimonial-card__quote {
	font-size:   var(--text-md);
	line-height: var(--leading-relaxed);
	color:       var(--color-text-secondary);
	font-style:  italic;
	flex:        1;
}

.testimonial-card__quote::before {
	content:        '\201C';
	font-family:    Georgia, serif;
	font-size:      3rem;
	color:          var(--color-accent);
	line-height:    0.5;
	display:        block;
	margin-bottom:  var(--space-2);
	opacity:        0.8;
}

.testimonial-card__author {
	display:     flex;
	align-items: center;
	gap:         var(--space-3);
	border-top:  1px solid rgba(255, 255, 255, 0.06);
	padding-top: var(--space-4);
}

.testimonial-card__avatar {
	width:         44px;
	height:        44px;
	border-radius: var(--radius-full);
	background-color: var(--color-dark-surface);
	overflow:      hidden;
	flex-shrink:   0;
	display:       flex;
	align-items:   center;
	justify-content:center;
	font-family:   var(--font-display);
	font-size:     var(--text-lg);
	color:         var(--color-accent);
}

.testimonial-card__name {
	font-weight:  var(--weight-semibold);
	color:        var(--color-text-primary);
	font-size:    var(--text-sm);
	line-height:  1.2;
}

.testimonial-card__location {
	font-size: var(--text-xs);
	color:     var(--color-text-tertiary);
}

/* =============================================================================
   CTA BANNER STRIP
   Full-width orange/dark call to action.
   ============================================================================= */

.cta-strip {
	background:     var(--gradient-accent);
	padding-block:  var(--space-16);
	text-align:     center;
	position:       relative;
	overflow:       hidden;
}

/* Decorative texture overlay */
.cta-strip::before {
	content:    '';
	position:   absolute;
	inset:      0;
	background: repeating-linear-gradient(
	              -45deg,
	              rgba(0,0,0,0.05) 0,
	              rgba(0,0,0,0.05) 1px,
	              transparent 1px,
	              transparent 10px
	            );
	pointer-events: none;
}

.cta-strip__inner {
	position: relative;
	z-index:  var(--z-raised);
}

.cta-strip__label {
	font-size:      var(--text-xs);
	font-weight:    var(--weight-semibold);
	letter-spacing: var(--tracking-widest);
	text-transform: uppercase;
	color:          rgba(255, 255, 255, 0.75);
	margin-bottom:  var(--space-3);
}

.cta-strip__title {
	font-size:      var(--text-4xl);
	color:          var(--color-white);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	margin-bottom:  var(--space-6);
}

.cta-strip__actions {
	display:         flex;
	align-items:     center;
	justify-content: center;
	gap:             var(--space-4);
	flex-wrap:       wrap;
}

/* White button variant for use on orange background */
.btn--white {
	background-color: var(--color-white);
	color:            var(--color-accent);
	border-color:     var(--color-white);
}

.btn--white:hover {
	background-color: var(--color-light);
	border-color:     var(--color-light);
	color:            var(--color-accent-dark);
	box-shadow:       0 4px 20px rgba(0, 0, 0, 0.20);
	transform:        translateY(-2px);
}

.btn--outline-white {
	background:   transparent;
	color:        var(--color-white);
	border-color: rgba(255, 255, 255, 0.60);
}

.btn--outline-white:hover {
	background:   rgba(255, 255, 255, 0.10);
	border-color: var(--color-white);
	color:        var(--color-white);
}

/* =============================================================================
   SKIP LINK
   Accessibility — jump to main content.
   ============================================================================= */

.skip-link {
	position:         absolute;
	top:              -100%;
	left:             var(--space-4);
	z-index:          var(--z-toast);
	padding:          var(--space-3) var(--space-6);
	background:       var(--color-accent);
	color:            var(--color-white);
	font-weight:      var(--weight-semibold);
	border-radius:    0 0 var(--radius-md) var(--radius-md);
	text-decoration:  none;
	transition:       top var(--duration-fast) var(--ease-out);
}

.skip-link:focus {
	top: 0;
}

/* =============================================================================
   RESPONSIVE IMAGES
   ============================================================================= */

.aspect-video {
	aspect-ratio:    16 / 9;
	object-fit:      cover;
	width:           100%;
}

.aspect-square {
	aspect-ratio:    1;
	object-fit:      cover;
	width:           100%;
}

.aspect-portrait {
	aspect-ratio:    4 / 5;
	object-fit:      cover;
	width:           100%;
}

/* =============================================================================
   SCROLL REVEAL ANIMATIONS
   Applied via JS adding .is-visible class on scroll.
   ============================================================================= */

.reveal {
	opacity:          0;
	transform:        translateY(24px);
	transition:       opacity  var(--duration-slower) var(--ease-out),
	                  transform var(--duration-slower) var(--ease-out);
}

.reveal.is-visible {
	opacity:   1;
	transform: translateY(0);
}

/* Staggered children */
.reveal-group > * {
	opacity:          0;
	transform:        translateY(20px);
	transition:       opacity  var(--duration-slow) var(--ease-out),
	                  transform var(--duration-slow) var(--ease-out);
}

.reveal-group.is-visible > *:nth-child(1)  { transition-delay: 0ms;   opacity: 1; transform: none; }
.reveal-group.is-visible > *:nth-child(2)  { transition-delay: 80ms;  opacity: 1; transform: none; }
.reveal-group.is-visible > *:nth-child(3)  { transition-delay: 160ms; opacity: 1; transform: none; }
.reveal-group.is-visible > *:nth-child(4)  { transition-delay: 240ms; opacity: 1; transform: none; }
.reveal-group.is-visible > *:nth-child(5)  { transition-delay: 320ms; opacity: 1; transform: none; }
.reveal-group.is-visible > *:nth-child(6)  { transition-delay: 400ms; opacity: 1; transform: none; }

/* Respect reduced motion preference */
@media (prefers-reduced-motion: reduce) {
	.reveal,
	.reveal-group > * {
		opacity:    1;
		transform:  none;
		transition: none;
	}
}

/* =============================================================================
   BLOG ARCHIVE (index.php)
   Two-column layout with post grid and sidebar.
   ============================================================================= */

.blog-layout {
	display:               grid;
	grid-template-columns: 1fr 300px;
	gap:                   var(--gap-xl);
	align-items:           start;
}
@media (max-width: 1024px) {
	.blog-layout { grid-template-columns: 1fr; }
}

/* Post grid */
.post-grid {
	display:               grid;
	grid-template-columns: repeat(2, 1fr);
	gap:                   var(--gap-md);
}
@media (max-width: 768px) {
	.post-grid { grid-template-columns: 1fr; }
}

/* Post card */
.post-card {
	background:    var(--color-white);
	border-radius: var(--radius-xl);
	overflow:      hidden;
	box-shadow:    var(--shadow-sm);
	transition:    transform var(--transition-base), box-shadow var(--transition-base);
	display:       flex;
	flex-direction: column;
}
.post-card:hover {
	transform:  translateY(-4px);
	box-shadow: var(--shadow-lg);
}
.post-card__thumb-link  { display: block; overflow: hidden; }
.post-card__thumb       { width: 100%; height: 200px; object-fit: cover; display: block; transition: transform var(--transition-slow); }
.post-card:hover .post-card__thumb { transform: scale(1.04); }
.post-card__thumb--placeholder {
	height:          200px;
	background:      var(--color-surface);
	display:         flex;
	align-items:     center;
	justify-content: center;
	color:           var(--color-border);
}
.post-card__body    { padding: var(--space-5) var(--space-6) var(--space-6); flex: 1; display: flex; flex-direction: column; }
.post-card__meta    { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-3); }
.post-card__date    { font-size: var(--text-xs); color: var(--color-text-tertiary); }
.post-card__cat     { font-size: var(--text-xs); font-weight: var(--fw-semibold); letter-spacing: .06em; text-transform: uppercase; color: var(--color-accent); text-decoration: none; }
.post-card__cat:hover { text-decoration: underline; }
.post-card__title   { font-size: var(--text-lg); font-weight: var(--fw-bold); color: var(--color-text-dark); margin-bottom: var(--space-3); line-height: var(--leading-snug); }
.post-card__title a { color: inherit; text-decoration: none; }
.post-card__title a:hover { color: var(--color-accent); }
.post-card__excerpt { font-size: var(--text-sm); color: var(--color-text-secondary); line-height: var(--leading-relaxed); flex: 1; margin-bottom: var(--space-4); }
.post-card__read-more {
	display:     inline-flex;
	align-items: center;
	gap:         var(--space-2);
	font-size:   var(--text-sm);
	font-weight: var(--fw-semibold);
	color:       var(--color-accent);
	text-decoration: none;
	margin-top:  auto;
	transition:  gap var(--transition-base);
}
.post-card__read-more:hover { gap: var(--space-3); }

/* Pagination */
.archive-pagination { margin-top: var(--space-10); }
.archive-pagination .nav-links {
	display:         flex;
	justify-content: center;
	align-items:     center;
	gap:             var(--space-2);
	flex-wrap:       wrap;
}
.archive-pagination .page-numbers {
	display:         inline-flex;
	align-items:     center;
	justify-content: center;
	min-width:       40px;
	height:          40px;
	padding:         0 var(--space-3);
	border-radius:   var(--radius-md);
	border:          var(--border-thin) solid var(--color-border-light);
	font-size:       var(--text-sm);
	font-weight:     var(--fw-semibold);
	color:           var(--color-text-dark);
	text-decoration: none;
	transition:      all var(--transition-base);
}
.archive-pagination .page-numbers:hover,
.archive-pagination .page-numbers.current {
	background:   var(--color-accent);
	border-color: var(--color-accent);
	color:        var(--color-white);
}
.archive-pagination .page-numbers.dots { border-color: transparent; }

/* No results */
.no-results {
	text-align:  center;
	padding:     var(--space-16) var(--space-8);
	color:       var(--color-text-secondary);
}
.no-results__icon  { color: var(--color-border); margin-bottom: var(--space-4); }
.no-results__title { font-size: var(--text-2xl); font-weight: var(--fw-bold); color: var(--color-text-dark); margin-bottom: var(--space-3); }
.no-results__text  { max-width: 480px; margin: 0 auto var(--space-6); font-size: var(--text-base); }

/* Sidebar */
.blog-sidebar       { display: flex; flex-direction: column; gap: var(--space-5); }
.sidebar-widget     { background: var(--color-white); border-radius: var(--radius-xl); padding: var(--space-5) var(--space-6); box-shadow: var(--shadow-sm); }
.sidebar-widget__title {
	font-size:     var(--text-sm);
	font-weight:   var(--fw-bold);
	letter-spacing: .07em;
	text-transform: uppercase;
	color:         var(--color-text-dark);
	margin-bottom: var(--space-4);
	padding-bottom: var(--space-3);
	border-bottom: 2px solid var(--color-accent);
	display:       inline-block;
}
.sidebar-recent-posts { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-3); }
.sidebar-recent-post  { padding-bottom: var(--space-3); border-bottom: var(--border-thin) solid var(--color-border-light); }
.sidebar-recent-post:last-child { border: 0; padding-bottom: 0; }
.sidebar-recent-post__link  { font-size: var(--text-sm); font-weight: var(--fw-semibold); color: var(--color-text-dark); text-decoration: none; display: block; margin-bottom: var(--space-1); line-height: var(--leading-snug); }
.sidebar-recent-post__link:hover { color: var(--color-accent); }
.sidebar-recent-post__date  { font-size: var(--text-xs); color: var(--color-text-tertiary); }

/* Sidebar CTA */
.sidebar-cta { border-radius: var(--radius-xl); overflow: hidden; }
.sidebar-cta__inner {
	background:   var(--color-dark);
	padding:      var(--space-7) var(--space-6);
	text-align:   center;
	position:     relative;
}
.sidebar-cta__inner::before {
	content:    '';
	position:   absolute;
	inset:      0;
	background: var(--gradient-accent-overlay);
	opacity:    .08;
	pointer-events: none;
}
.sidebar-cta__eyebrow {
	font-size:      var(--text-xs);
	letter-spacing: .1em;
	text-transform: uppercase;
	color:          var(--color-accent);
	font-weight:    var(--fw-semibold);
	margin-bottom:  var(--space-2);
}
.sidebar-cta__title { font-size: var(--text-lg); font-weight: var(--fw-bold); color: var(--color-text-primary); margin-bottom: var(--space-5); line-height: var(--leading-snug); }
.sidebar-cta__call  {
	display:         flex;
	align-items:     center;
	justify-content: center;
	gap:             var(--space-2);
	margin-top:      var(--space-3);
	font-size:       var(--text-sm);
	font-weight:     var(--fw-semibold);
	color:           var(--color-text-secondary);
	text-decoration: none;
	transition:      color var(--transition-base);
}
.sidebar-cta__call:hover { color: var(--color-accent); }

/* =============================================================================
   DEFAULT PAGE (page.php)
   Centred prose container with typography and WordPress block support.
   ============================================================================= */

.container--narrow { max-width: 760px; }

/* Prose — typographic styles for editor-generated content */
.prose {
	font-size:   var(--text-base);
	line-height: var(--leading-relaxed);
	color:       var(--color-text-dark);
}
.prose h1, .prose h2, .prose h3,
.prose h4, .prose h5, .prose h6 {
	font-family:   var(--font-heading);
	font-weight:   var(--fw-bold);
	color:         var(--color-text-dark);
	margin-top:    1.6em;
	margin-bottom: .5em;
	line-height:   var(--leading-tight);
}
.prose h1 { font-size: var(--text-4xl); }
.prose h2 { font-size: var(--text-3xl); }
.prose h3 { font-size: var(--text-2xl); }
.prose h4 { font-size: var(--text-xl); }
.prose h5 { font-size: var(--text-lg); }
.prose h6 { font-size: var(--text-base); }
.prose p  { margin-bottom: 1.25em; }
.prose a  { color: var(--color-accent); text-underline-offset: 3px; }
.prose a:hover { text-decoration: none; }
.prose strong { font-weight: var(--fw-bold); }
.prose em     { font-style: italic; }
.prose ul, .prose ol {
	padding-left:  1.5em;
	margin-bottom: 1.25em;
}
.prose li { margin-bottom: .4em; }
.prose blockquote {
	border-left:   4px solid var(--color-accent);
	padding:       var(--space-4) var(--space-6);
	margin:        var(--space-6) 0;
	background:    var(--color-surface);
	border-radius: 0 var(--radius-md) var(--radius-md) 0;
	font-style:    italic;
	color:         var(--color-text-secondary);
}
.prose blockquote p:last-child { margin-bottom: 0; }
.prose hr {
	border:     none;
	border-top: var(--border-thin) solid var(--color-border-light);
	margin:     var(--space-10) 0;
}
.prose img {
	max-width:     100%;
	border-radius: var(--radius-lg);
	height:        auto;
}
.prose figure { margin: var(--space-8) 0; }
.prose figcaption {
	font-size:  var(--text-sm);
	color:      var(--color-text-tertiary);
	text-align: center;
	margin-top: var(--space-2);
}
.prose pre {
	background:    var(--color-dark);
	color:         var(--color-text-primary);
	padding:       var(--space-5);
	border-radius: var(--radius-lg);
	overflow-x:    auto;
	font-size:     var(--text-sm);
	margin-bottom: var(--space-6);
}
.prose code {
	background:    rgba(244, 98, 31, .1);
	color:         var(--color-accent);
	padding:       .15em .4em;
	border-radius: var(--radius-sm);
	font-size:     .9em;
}
.prose pre code {
	background: none;
	color:      inherit;
	padding:    0;
}

/* Page links (multipage posts) */
.page-links {
	display:     flex;
	gap:         var(--space-2);
	flex-wrap:   wrap;
	margin-top:  var(--space-8);
	font-size:   var(--text-sm);
	font-weight: var(--fw-semibold);
}
.page-links a {
	display:         inline-flex;
	align-items:     center;
	justify-content: center;
	min-width:       36px;
	height:          36px;
	padding:         0 var(--space-3);
	border-radius:   var(--radius-md);
	border:          var(--border-thin) solid var(--color-border-light);
	color:           var(--color-text-dark);
	text-decoration: none;
}
.page-links a:hover { border-color: var(--color-accent); color: var(--color-accent); }

/* =============================================================================
   404 PAGE (404.php)
   Full-height dark hero with large watermark code + navigation cards.
   ============================================================================= */

.error-404-main { background: var(--color-dark); }

.error-404-hero {
	position:        relative;
	min-height:      90vh;
	display:         flex;
	align-items:     center;
	overflow:        hidden;
	background:      var(--color-dark);
}

/* Dot-grid background */
.error-404-hero__grid {
	position:         absolute;
	inset:            0;
	background-image: radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px);
	background-size:  32px 32px;
	pointer-events:   none;
}

.error-404-hero__inner {
	position:        relative;
	z-index:         1;
	padding:         var(--space-20) 0;
	width:           100%;
	max-width:       680px;
}

/* Large watermark number */
.error-404-hero__code {
	display:        block;
	font-family:    var(--font-heading);
	font-size:      clamp(160px, 22vw, 260px);
	line-height:    1;
	letter-spacing: -.02em;
	color:          rgba(255,255,255,.04);
	user-select:    none;
	pointer-events: none;
	position:       absolute;
	top:            50%;
	left:           -.02em;
	transform:      translateY(-52%);
}

.error-404-hero__title {
	font-size:     clamp(var(--text-3xl), 5vw, var(--text-5xl));
	color:         var(--color-text-primary);
	margin-bottom: var(--space-5);
	line-height:   var(--leading-tight);
}

.error-404-hero__text {
	font-size:     var(--text-lg);
	color:         var(--color-text-secondary);
	margin-bottom: var(--space-8);
	max-width:     520px;
	line-height:   var(--leading-relaxed);
}

/* Search form in 404 hero */
.error-404-hero__search {
	margin-bottom: var(--space-8);
	max-width:     480px;
}
.error-404-hero__search .search-form {
	display:   flex;
	gap:       var(--space-2);
}
.error-404-hero__search .search-field {
	flex:          1;
	background:    var(--color-dark-surface);
	border:        var(--border-thin) solid var(--color-dark-border);
	border-radius: var(--radius-md);
	padding:       var(--space-3) var(--space-4);
	color:         var(--color-text-primary);
	font-size:     var(--text-base);
}
.error-404-hero__search .search-field::placeholder { color: var(--color-text-muted); }
.error-404-hero__search .search-field:focus {
	outline:      none;
	border-color: var(--color-accent);
}
.error-404-hero__search .search-submit {
	white-space: nowrap;
}

/* Quick links row */
.error-404-hero__links {
	display:   flex;
	flex-wrap: wrap;
	gap:       var(--space-3);
}

/* Navigation cards section */
.error-404-nav { background: var(--color-surface); }
.error-404-nav__label {
	font-size:      var(--text-sm);
	font-weight:    var(--fw-semibold);
	letter-spacing: .08em;
	text-transform: uppercase;
	color:          var(--color-text-secondary);
	margin-bottom:  var(--space-6);
	text-align:     center;
}

.error-404-cards {
	display:               grid;
	grid-template-columns: repeat(4, 1fr);
	gap:                   var(--gap-md);
}
@media (max-width: 1024px) { .error-404-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .error-404-cards { grid-template-columns: 1fr; } }

.error-404-card {
	background:    var(--color-white);
	border-radius: var(--radius-xl);
	padding:       var(--space-7);
	text-decoration: none;
	display:       flex;
	flex-direction: column;
	gap:           var(--space-2);
	border:        var(--border-thin) solid transparent;
	transition:    all var(--transition-base);
	position:      relative;
	overflow:      hidden;
}
.error-404-card:hover {
	border-color: var(--color-accent);
	transform:    translateY(-4px);
	box-shadow:   var(--shadow-lg);
}
.error-404-card__icon {
	width:           48px;
	height:          48px;
	border-radius:   var(--radius-md);
	background:      var(--color-accent-muted);
	display:         flex;
	align-items:     center;
	justify-content: center;
	color:           var(--color-accent);
	margin-bottom:   var(--space-2);
	transition:      background var(--transition-base);
}
.error-404-card:hover .error-404-card__icon { background: var(--color-accent); color: var(--color-white); }
.error-404-card__title { font-size: var(--text-lg); font-weight: var(--fw-bold); color: var(--color-text-dark); }
.error-404-card__text  { font-size: var(--text-sm); color: var(--color-text-secondary); line-height: var(--leading-relaxed); flex: 1; }
.error-404-card__arrow {
	font-size:   var(--text-xl);
	color:       var(--color-accent);
	align-self:  flex-end;
	transition:  transform var(--transition-base);
}
.error-404-card:hover .error-404-card__arrow { transform: translateX(4px); }

/* Btn ghost light variant (for dark backgrounds) */
.btn--ghost-light {
	background:  transparent;
	border:      var(--border-thin) solid rgba(255,255,255,.2);
	color:       var(--color-text-secondary);
}
.btn--ghost-light:hover {
	border-color: rgba(255,255,255,.5);
	color:        var(--color-text-primary);
	background:   rgba(255,255,255,.06);
}
.btn--outline-light {
	background:  transparent;
	border:      var(--border-thin) solid var(--color-accent);
	color:       var(--color-accent);
}
.btn--outline-light:hover { background: var(--color-accent); color: var(--color-white); }
