/* ==========================================================================
   KSM Pavecraft – Main Stylesheet
   Colour palette based on pavecraftpavingandmasonry.com
   ========================================================================== */

/* ── 1. Custom Properties ─────────────────────────────────────────────────── */
:root {
	--clr-navy:       #0a2c4e;
	--clr-gold:       #fdb514;
	--clr-dark:       #444444;
	--clr-body:       #404040;
	--clr-white:      #ffffff;
	--clr-light:      #e2e2e2;
	--clr-footer-lnk: rgb(203, 150, 55);

	--font-main: 'Poppins', sans-serif;

	--container-max:  1400px;
	--container-pad:  20px;

	--transition: 0.3s ease;
}

/* ── 2. Reset & Base ──────────────────────────────────────────────────────── */
*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	scroll-behavior: smooth;
}

body {
	font-family: var(--font-main);
	font-size: 18px;
	line-height: 1.6;
	color: var(--clr-body);
	background: var(--clr-white);
	-webkit-font-smoothing: antialiased;
}

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

a {
	color: inherit;
	text-decoration: none;
}

ul,
ol {
	list-style: none;
}

h1, h2, h3, h4, h5, h6 {
	font-weight: 700;
	line-height: 1.2;
	color: var(--clr-body);
}

h2 { font-size: 30px; }
h3 { font-size: 25px; color: var(--clr-gold); }
h4 { font-size: 20px; }

p { margin-bottom: 1em; }
p:last-child { margin-bottom: 0; }

/* ── 3. Container ─────────────────────────────────────────────────────────── */
.pavecraft_div_container {
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--container-pad);
}

/* ── 4. Buttons ───────────────────────────────────────────────────────────── */
.pavecraft_div_btn {
	display: inline-block;
	padding: 10px 20px;
	font-family: var(--font-main);
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	border: none;
	cursor: pointer;
	transition: opacity var(--transition);
	border-radius: 3px;
}
.content-output img {
  width: 100%;
}
.pavecraft_div_btn:hover { opacity: 0.88; }

.pavecraft_div_btn--primary {
	background: var(--clr-navy);
	color: var(--clr-white);
}

.pavecraft_div_btn--gold {
	background: var(--clr-gold);
	color: var(--clr-white);
	border-radius: 0;
	text-align:center;
	padding: 15px 25px;
}

.pavecraft_div_btn--dark {
	background: var(--clr-dark);
	color: var(--clr-white);
}

.pavecraft_div_btn--full {
	display: block;
	width: 100%;
	text-align: center;
}

/* ── 5. Header ────────────────────────────────────────────────────────────── */
.pavecraft_div_site-header {
	position: relative;
	z-index: 100;
}

/* Row 1 – Utility bar */
.pavecraft_div_header-utility {
	background: var(--clr-white);
	border-bottom: 1px solid var(--clr-light);
}

.pavecraft_div_header-utility .pavecraft_div_container {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	min-height: 48px;
}

.pavecraft_div_utility-menu {
	display: flex;
	gap: 0;
}

.pavecraft_div_utility-menu li a {
	display: block;
	padding: 10px 18px;
	font-size: 16px;
	font-weight: 400;
	text-transform: uppercase;
	color: var(--clr-body);
	transition: color var(--transition);
}

.pavecraft_div_utility-menu li a:hover {
	color: var(--clr-navy);
}

/* Row 2 – Logo + primary nav */
.pavecraft_div_header-main {
	background: var(--clr-navy);
}

.pavecraft_div_header-main-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	min-height: 85px;
	position: relative;
}

/* Logo */
.pavecraft_div_logo-wrap a img {
	max-height: 80px;
	width: auto;
}

.pavecraft_div_logo-text {
	font-size: 22px;
	font-weight: 700;
	color: var(--clr-white);
	text-transform: uppercase;
}

/* Custom logo (WordPress native) */
.pavecraft_div_logo-wrap .custom-logo-link img {
	max-height: 80px;
	width: 200px;
}

/* Primary nav */
.pavecraft_div_nav-menu {
	display: flex;
	align-items: center;
	gap: 0;
}

.pavecraft_div_nav-menu > li > a {
	display: block;
	padding: 15px clamp(8px, 1.2vw, 18px);
	padding-left:8px;
	padding-right:8px;
	font-size: clamp(13px, 1.1vw, 16px);
	font-weight: 400;
	text-transform: uppercase;
	color: var(--clr-white);
	letter-spacing: 0.03em;
	transition: color var(--transition);
}

.pavecraft_div_nav-menu > li > a:hover,
.pavecraft_div_nav-menu > li.current-menu-item > a,
.pavecraft_div_nav-menu > li.current-menu-ancestor > a {
	color: var(--clr-gold);
}

/* Hamburger (hidden on desktop) */
.pavecraft_div_hamburger {
	display: none;
	flex-direction: column;
	justify-content: space-between;
	width: 32px;
	height: 22px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
}

.pavecraft_div_hamburger-bar {
	display: block;
	width: 100%;
	height: 3px;
	background: var(--clr-white);
	border-radius: 2px;
	transition: transform var(--transition), opacity var(--transition);
}

/* Row 3 – CTA + phone */
.pavecraft_div_header-cta-row {
	background: transparent;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255,255,255,0.05);
}

.pavecraft_div_header-cta-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 52px;
}

.pavecraft_div_header-cta-link {
	font-size: 16px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--clr-white);
	transition: color var(--transition);
	background-color: var(--clr-gold);
	padding: 0.5rem;
}
.pavecraft_div_header-cta-link a {color:#000; }
.pavecraft_div_header-cta-link:hover { color: var(--clr-gold); }

.pavecraft_div_header-phone {
	font-size: 20px;
	font-weight: 400;
	color: var(--clr-navy);
	background: var(--clr-white);
	padding: 6px 16px;
	transition: background var(--transition);
}

.pavecraft_div_header-phone { background: var(--clr-light); }

/* ── 6. Mobile Panel ──────────────────────────────────────────────────────── */
.pavecraft_div_mobile-panel {
	position: fixed;
	top: 0;
	left: 0;
	width: 290px;
	height: 100%;
	background: #1d1d20;
	z-index: 200;
	display: flex;
	flex-direction: column;
	padding: 60px 0 30px;
	overflow-y: auto;
	transform: translateX(-100%);
	transition: transform 0.5s ease;
}

.pavecraft_div_mobile-panel.is-open {
	transform: translateX(0);
}

.pavecraft_div_mobile-panel-close {
	position: absolute;
	top: 14px;
	right: 16px;
	background: none;
	border: none;
	font-size: 32px;
	color: var(--clr-white);
	cursor: pointer;
	line-height: 1;
}

.pavecraft_div_mobile-menu {
	flex: 1;
}

.pavecraft_div_mobile-menu li a {
	display: block;
	padding: 14px 24px;
	font-size: 16px;
	font-weight: 600;
	text-transform: uppercase;
	color: var(--clr-white);
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	transition: color var(--transition);
}

.pavecraft_div_mobile-menu li a:hover { color: var(--clr-gold); }

.pavecraft_div_mobile-contact {
	padding: 24px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.pavecraft_div_mobile-phone {
	font-size: 20px;
	font-weight: 700;
	color: var(--clr-gold);
	text-align: center;
}

.pavecraft_div_mobile-overlay {
	display: none;
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.55);
	z-index: 150;
}

.pavecraft_div_mobile-overlay.is-visible { display: block; }

/* ── 6b. No-JS mobile menu fallback ──────────────────────────────────────── */
.pavecraft_div_noscript-checkbox {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.pavecraft_div_noscript-toggle {
	display: none;
	flex-direction: column;
	justify-content: space-between;
	width: 32px;
	height: 22px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
}

.pavecraft_div_noscript-dropdown {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	background: var(--clr-navy);
	z-index: 100;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.pavecraft_div_noscript-menu {
	padding: 0;
}

.pavecraft_div_noscript-menu li a {
	display: block;
	padding: 14px 20px;
	font-size: 16px;
	font-weight: 600;
	text-transform: uppercase;
	color: var(--clr-white);
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	transition: color var(--transition);
}

.pavecraft_div_noscript-menu li a:hover {
	color: var(--clr-gold);
}

/* ── 7. Hero – Interior pages ─────────────────────────────────────────────── */
.pavecraft_div_hero {
	position: relative;
	overflow: hidden;
}

.pavecraft_div_hero--interior {
	height: 500px;
	display: flex;
	align-items: stretch;
}

.pavecraft_div_hero-bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 50%;
	z-index: 0;
}

/* Left dark overlay panel — matches live site div_block-1521-2275 */
.pavecraft_div_hero-panel {
	background: rgba(0, 0, 0, 0.77);
	border-right: 3px solid var(--clr-white);
	width: 50%;
	max-width: 700px;
	padding: 24px 28px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	position: relative;
	z-index: 2;
}

.pavecraft_div_hero-title {
	font-size: 36px;
	font-weight: 700;
	color: var(--clr-white);
	margin-top: 8px;
	line-height: 1.15;
}

.pavecraft_div_hero-subtitle {
	font-size: 16px;
	color: rgba(255, 255, 255, 0.9);
	margin-top: 8px;
	line-height: 1.6;
}

.pavecraft_div_hero-buttons {
	display: flex;
	gap: 12px;
	margin-top: 20px;
	flex-wrap: wrap;
}

/* ── 9. Breadcrumbs ───────────────────────────────────────────────────────── */
.pavecraft_div_breadcrumbs {
	margin-bottom: 8px;
}

.pavecraft_div_breadcrumbs-list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px;
	list-style: none;
	padding: 0;
	margin: 0;
}

.pavecraft_div_breadcrumb-item {
	display: flex;
	align-items: center;
	gap: 4px;
	font-size: 16px;
	color: rgba(255, 255, 255, 0.85);
}

.pavecraft_div_breadcrumb-item a {
	color: rgba(255, 255, 255, 0.85);
	text-decoration: none;
	transition: color var(--transition);
}

.pavecraft_div_breadcrumb-item a:hover {
	color: var(--clr-gold);
}

.pavecraft_div_breadcrumb-sep {
	color: rgba(255, 255, 255, 0.6);
	font-size: 14px;
}

.pavecraft_div_breadcrumb-current span {
	color: var(--clr-gold);
}

/* ── 10. Sections ─────────────────────────────────────────────────────────── */
.pavecraft_div_section {
	padding-block: 60px;
}

.pavecraft_div_section--light {
	background: var(--clr-light);
}

.pavecraft_div_section-title {
	font-size: 30px;
	color: var(--clr-body);
	margin-bottom: 36px;
	text-align: center;
}

/* ── 11. Content Output (page.php) ────────────────────────────────────────── */
/* Page grid — content + optional sidebar */
.pavecraft_div_page-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 48px;
}

/* When sidebar is present, use 2-col layout */
.pavecraft_div_page-grid .pavecraft_div_sidebar {
	display: flex;
	flex-direction: column;
	gap: 28px;
}

.pavecraft_div_page-grid:has(.pavecraft_div_sidebar) {
	grid-template-columns: 1fr 340px;
}

@media ( max-width: 991px ) {
	.pavecraft_div_page-grid:has(.pavecraft_div_sidebar) {
		grid-template-columns: 1fr;
	}
}

.content-output {
	max-width: 900px;
}

.pavecraft_div_page-grid:has(.pavecraft_div_sidebar) .content-output {
	max-width: none;
}

.content-output h2,
.front-page-box h2 {
	margin-bottom: 16px;
	margin-top: 32px;
	padding-bottom: 10px;
	position: relative;
}

.content-output h2::after,
.front-page-box h2::after {
	content: '';
	display: block;
	width: 50%;
	height: 3px;
	background: var(--clr-gold);
	margin-top: 10px;
}
.gallery-columns-3 {
  display: flex;
}
.pavecraft_div_sidebar h3 {
  margin-bottom: 2rem;
  border-bottom: 5px solid var(--clr-navy);
}
.content-output h3 { margin-bottom: 12px; margin-top: 28px; }
.content-output p  { margin-bottom: 18px; }
.content-output ul { list-style: disc; padding-left: 24px; margin-bottom: 18px; }
.content-output ol { list-style: decimal; padding-left: 24px; margin-bottom: 18px; }
.content-output li { margin-bottom: 6px; }
.content-output a {
  color: var(--clr-gold);
  text-decoration: underline;
  font-weight: 500;
}
.content-output img { max-width: 100%; height: auto; margin: 16px 0; }

/* WordPress gallery — 4 cols desktop, responsive down to 1 */
.content-output .gallery,
.content-output .wp-block-gallery,
.front-page-box .gallery,
.front-page-box .wp-block-gallery {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 10px;
	margin: 24px 0;
}

.content-output .gallery img,
.content-output .wp-block-gallery img,
.front-page-box .gallery img,
.front-page-box .wp-block-gallery img {
	width: 100%;
	height: auto;
	object-fit: cover;
	aspect-ratio: 1 / 1;
	margin: 0;
}

.content-output .gallery .gallery-item,
.front-page-box .gallery .gallery-item {
	margin: 0;
	padding: 0;
	width: auto;
}

.content-output .gallery br,
.front-page-box .gallery br {
	display: none;
}

/* Override WP gallery column classes to always use our grid */
.content-output .gallery-columns-1,
.content-output .gallery-columns-2,
.content-output .gallery-columns-3,
.content-output .gallery-columns-4,
.content-output .gallery-columns-5,
.content-output .gallery-columns-6,
.front-page-box .gallery-columns-1,
.front-page-box .gallery-columns-2,
.front-page-box .gallery-columns-3,
.front-page-box .gallery-columns-4,
.front-page-box .gallery-columns-5,
.front-page-box .gallery-columns-6 {
	grid-template-columns: repeat(4, 1fr);
}

@media ( max-width: 991px ) {
	.content-output .gallery,
	.content-output .wp-block-gallery,
	.front-page-box .gallery,
	.front-page-box .wp-block-gallery,
	.content-output [class*="gallery-columns-"],
	.front-page-box [class*="gallery-columns-"] {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media ( max-width: 767px ) {
	.content-output .gallery,
	.content-output .wp-block-gallery,
	.front-page-box .gallery,
	.front-page-box .wp-block-gallery,
	.content-output [class*="gallery-columns-"],
	.front-page-box [class*="gallery-columns-"] {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media ( max-width: 479px ) {
	.content-output .gallery,
	.content-output .wp-block-gallery,
	.front-page-box .gallery,
	.front-page-box .wp-block-gallery,
	.content-output [class*="gallery-columns-"],
	.front-page-box [class*="gallery-columns-"] {
		grid-template-columns: 1fr;
	}
}

.content-output blockquote {
	border-left: 4px solid var(--clr-gold);
	margin: 24px 0;
	padding: 12px 20px;
	background: var(--clr-light);
	font-style: italic;
}

/* ── 12. Content + Sidebar (single-driveways.php) ────────────────────────── */
.pavecraft_div_content-sidebar-grid {
	display: grid;
	grid-template-columns: 1fr 340px;
	gap: 48px;
	align-items: start;
}

.pavecraft_div_main-col .front-page-box {
	color: var(--clr-body);
}

.pavecraft_div_main-col .front-page-box h2,
.pavecraft_div_main-col .front-page-box h3 { color: var(--clr-body); }
.pavecraft_div_main-col .front-page-box h3 { color: var(--clr-gold); }
.pavecraft_div_main-col .front-page-box p  { margin-bottom: 18px; }
.pavecraft_div_main-col .front-page-box ul { list-style: disc; padding-left: 24px; margin-bottom: 18px; }
.pavecraft_div_main-col .front-page-box ol { list-style: decimal; padding-left: 24px; margin-bottom: 18px; }
.pavecraft_div_main-col .front-page-box a  { color: var(--clr-navy); text-decoration: underline; }
.pavecraft_div_main-col .front-page-box img { max-width: 100%; height: auto; margin: 16px 0; }

/* Sidebar */
.pavecraft_div_sidebar {
	display: flex;
	flex-direction: column;
	gap: 28px;
}

.pavecraft_div_sidebar-services h3,
.pavecraft_div_sidebar-contact h3 {
	font-size: 18px;
	font-weight: 700;
	color: var(--clr-navy);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	background: var(--clr-navy);
	color: var(--clr-white);
	padding: 12px 16px;
	margin-bottom: 0;
}

.pavecraft_div_sidebar-menu {
	border: 1px solid var(--clr-light);
	border-top: none;
}

.pavecraft_div_sidebar-menu li a {
	display: block;
	padding: 12px 16px;
	font-size: 16px;
	font-weight: 700;
	text-transform: uppercase;
	color: var(--clr-navy);
	border-bottom: 1px solid var(--clr-light);
	transition: background var(--transition), color var(--transition);
}

.pavecraft_div_sidebar-menu li a:hover,
.pavecraft_div_sidebar-menu li.current-menu-item a {
	background: var(--clr-navy);
	color: var(--clr-white);
}

.pavecraft_div_sidebar-contact {
	border: 1px solid var(--clr-light);
}

.pavecraft_div_sidebar-contact .pavecraft_div_sidebar-company,
.pavecraft_div_sidebar-contact .pavecraft_div_sidebar-area,
.pavecraft_div_sidebar-contact .pavecraft_div_sidebar-address {
	padding: 10px 16px 0;
	font-size: 15px;
	color: var(--clr-body);
}

.pavecraft_div_sidebar-phone {
	display: block;
	padding: 10px 16px;
	font-size: 20px;
	font-weight: 700;
	color: var(--clr-navy);
	transition: color var(--transition);
}

.pavecraft_div_sidebar-phone:hover { color: var(--clr-gold); }

/* Sidebar widgets */
.pavecraft_div_sidebar-widget {
	margin-bottom: 24px;
}

.pavecraft_div_sidebar-widget h3 {
	font-size: 18px;
	font-weight: 700;
	color: var(--clr-white);
	background: var(--clr-navy);
	padding: 12px 16px;
	margin-bottom: 0;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.pavecraft_div_sidebar-widget ul {
	border: 1px solid var(--clr-light);
	border-top: none;
	padding: 0;
}

.pavecraft_div_sidebar-widget ul li a {
	display: block;
	padding: 10px 16px;
	font-size: 15px;
	color: var(--clr-navy);
	border-bottom: 1px solid var(--clr-light);
	transition: background var(--transition);
}

.pavecraft_div_sidebar-widget ul li a:hover {
	background: var(--clr-light);
}

.pavecraft_div_sidebar-widget ul li:last-child a {
	border-bottom: none;
}

.pavecraft_div_sidebar-contact .pavecraft_div_btn--gold {
	margin: 12px 16px 16px;
	width: calc(100% - 32px);
	text-align: center;
	font-size: 14px;
}

/* ── 13. Services Grid (front-page.php) ───────────────────────────────────── */
.pavecraft_div_services-cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
}

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

.pavecraft_div_service-card-img-link { display: block; overflow: hidden; }

.pavecraft_div_service-card-img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.pavecraft_div_service-card-img-link:hover .pavecraft_div_service-card-img {
	transform: scale(1.04);
}

.pavecraft_div_service-card-body {
	padding: 16px 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
	flex: 1;
}

.pavecraft_div_service-card-title {
	font-size: 18px;
	font-weight: 700;
	color: var(--clr-body);
}

.pavecraft_div_service-card-title a {
	color: inherit;
	transition: color var(--transition);
}

.pavecraft_div_service-card-title a:hover { color: var(--clr-navy); }

.pavecraft_div_service-card-excerpt {
	font-size: 16px;
	color: var(--clr-body);
	flex: 1;
}

/* ── 13b. CTA Callout Boxes (directly below hero) ────────────────────────── */
.pavecraft_div_callouts-section {
	background: #d3d3d3;
	padding: 20px 0;
}

.pavecraft_div_callouts-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--container-pad);
}

.pavecraft_div_callout-box {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 20px 16px;
	min-height: 98px;
	text-decoration: none;
	transition: opacity var(--transition);
}

.pavecraft_div_callout-box:hover { opacity: 0.88; }

/* Alternating box colours matching live site */
.pavecraft_div_callout-box--1 {
	background: var(--clr-navy);
	border-radius: 15px 0 0 15px;
}
.pavecraft_div_callout-box--2 { background: var(--clr-dark); }
.pavecraft_div_callout-box--3 { background: rgb(188, 136, 24); }
.pavecraft_div_callout-box--4 {
	background: rgb(61, 47, 20);
	border-radius: 0 15px 15px 0;
}

.pavecraft_div_callout-box-title {
	font-size: 18px;
	font-weight: 700;
	color: var(--clr-white);
	text-transform: uppercase;
	letter-spacing: 0.03em;
	line-height: 1.3;
}

@media ( max-width: 991px ) {
	.pavecraft_div_callouts-grid { grid-template-columns: repeat(2, 1fr); }
	.pavecraft_div_callout-box--1 { border-radius: 15px 0 0 0; }
	.pavecraft_div_callout-box--2 { border-radius: 0 15px 0 0; }
	.pavecraft_div_callout-box--3 { border-radius: 0; }
	.pavecraft_div_callout-box--4 { border-radius: 0 0 15px 0; }
}

@media ( max-width: 479px ) {
	.pavecraft_div_callouts-grid { grid-template-columns: 1fr; }
	.pavecraft_div_callout-box--1 { border-radius: 15px 15px 0 0; }
	.pavecraft_div_callout-box--2,
	.pavecraft_div_callout-box--3 { border-radius: 0; }
	.pavecraft_div_callout-box--4 { border-radius: 0 0 15px 15px; }
}

/* ── 14. Callout Banners ──────────────────────────────────────────────────── */
.pavecraft_div_callout-gold {
	background: var(--clr-gold);
	padding-block: 20px;
}

.pavecraft_div_callout-gold p {
	font-size: 18px;
	font-weight: 600;
	color: var(--clr-body);
	text-align: center;
	margin: 0;
}

.pavecraft_div_callout-gold a {
	color: var(--clr-navy);
	text-decoration: underline;
	transition: color var(--transition);
}

.pavecraft_div_callout-gold a:hover { color: var(--clr-white); }

.pavecraft_div_callout-navy {
	background: var(--clr-navy);
	min-height: 72px;
	display: flex;
	align-items: center;
}

.pavecraft_div_callout-navy p {
	font-size: 20px;
	font-weight: 600;
	color: var(--clr-white);
	text-align: center;
	margin: 0;
	width: 100%;
}

.pavecraft_div_callout-navy a {
	color: var(--clr-gold);
	transition: color var(--transition);
}

.pavecraft_div_callout-navy a:hover { color: var(--clr-white); }

/* ── 15. Reviews ──────────────────────────────────────────────────────────── */
.pavecraft_div_reviews .pavecraft_div_section-title,
.pavecraft_div_reviews-home .pavecraft_div_section-title {
	text-align: center;
	margin-bottom: 32px;
}

/* ── 16. Footer ───────────────────────────────────────────────────────────── */
.pavecraft_div_site-footer {
	background: var(--clr-navy);
	padding-top: 48px;
	padding-bottom: 0;
}

.pavecraft_div_footer-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	padding-bottom: 40px;
}

.pavecraft_div_footer-col h4 {
	font-size: 20px;
	font-weight: 700;
	color: var(--clr-white);
	margin-bottom: 14px;
	padding-bottom: 10px;
	border-bottom: 3px solid var(--clr-gold);
}

.pavecraft_div_site-footer a {
	color: var(--clr-gold);
	transition: color var(--transition);
}

.pavecraft_div_site-footer a:hover {
	color: var(--clr-white);
}

.pavecraft_div_footer-address,
.pavecraft_div_footer-col p {
	font-size: 15px;
	color: rgba(255, 255, 255, 0.8);
	line-height: 1.7;
}

.pavecraft_div_footer-phone a {
	font-size: 16px;
	font-weight: 600;
}

/* Footer menus */
.pavecraft_div_footer-menu li a {
	display: block;
	padding: 5px 0;
	font-size: 16px;
}

/* Footer about */
.pavecraft_div_footer-about {
	font-size: 16px;
	color: rgba(255, 255, 255, 0.8);
	line-height: 1.7;
}

/* Social icons */
.pavecraft_div_footer-social { margin-top: 16px; }

.pavecraft_div_footer-social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.12);
	color: var(--clr-white);
	transition: background var(--transition);
}

.pavecraft_div_footer-social-link:hover { background: var(--clr-gold); }

/* Footer bottom bar */
.pavecraft_div_footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	padding-block: 20px;
}

.pavecraft_div_footer-bottom p {
	font-size: 14px;
	color: rgba(255, 255, 255, 0.6);
	text-align: center;
	margin: 0;
}

/* ── 17. 404 ──────────────────────────────────────────────────────────────── */
.pavecraft_div_404-inner {
	text-align: center;
	padding-block: 80px;
}

.pavecraft_div_404-title {
	font-size: 120px;
	font-weight: 900;
	color: var(--clr-light);
	line-height: 1;
	margin-bottom: 16px;
}

.pavecraft_div_404-text {
	font-size: 20px;
	color: var(--clr-body);
	margin-bottom: 32px;
}

/* ── 18. Page wrap ────────────────────────────────────────────────────────── */
#pavecraft_div_page-wrap {
	overflow-x: hidden;
}

/* ── 19. Responsive – 1400px ─────────────────────────────────────────────── */
@media ( max-width: 1400px ) {
}

/* ── 20. Responsive – 991px ──────────────────────────────────────────────── */
@media ( max-width: 991px ) {
	/* Header */
	.pavecraft_div_header-main-inner { justify-content: space-between; }
	.pavecraft_div_primary-nav { display: none; }
	.pavecraft_div_hamburger { display: flex; }

	/* Hero — full-width panel on tablet/mobile, auto height so content never clips */
	.pavecraft_div_hero--interior { height: 350px; }
	.pavecraft_div_hero-panel {
		width: 100%;
		max-width: none;
		border-right: none;
		padding: 28px 20px;
	}
	.pavecraft_div_hero-title { font-size: 28px; }

	/* Content + sidebar */
	.pavecraft_div_content-sidebar-grid {
		grid-template-columns: 1fr;
	}

	/* Services */
	.pavecraft_div_services-cards { grid-template-columns: repeat(2, 1fr); }

	/* Footer */
	.pavecraft_div_footer-grid { grid-template-columns: 1fr; }
}

/* ── 21. Responsive – 767px ──────────────────────────────────────────────── */
@media ( max-width: 767px ) {
	body { font-size: 16px; }

	/* Utility bar: hide on small screens */
	.pavecraft_div_header-utility { display: none; }

	/* Hero */
	.pavecraft_div_hero--interior { height: 350px; }
	.pavecraft_div_hero-panel { padding: 24px 16px; }
	.pavecraft_div_hero-title { font-size: 24px; }
	.pavecraft_div_hero-subtitle { font-size: 14px; }
	.pavecraft_div_hero-buttons { gap: 8px; }
	.pavecraft_div_hero-buttons .pavecraft_div_btn { font-size: 14px; padding: 10px 16px; }

	.pavecraft_div_header-cta-row .pavecraft_div_header-cta-inner {
		flex-direction: column;
		gap: 8px;
		padding-block: 10px;
		text-align: center;
	}

	/* Services */
	.pavecraft_div_services-cards { grid-template-columns: 1fr; }

}

/* ── 22. Responsive – 479px ──────────────────────────────────────────────── */
@media ( max-width: 479px ) {
	.pavecraft_div_hero--interior { height: 500px; }
	.pavecraft_div_hero-title { font-size: 2rem; }
	.pavecraft_div_hero-buttons .pavecraft_div_btn { width: 100%; text-align: center; }
	.pavecraft_div_callout-navy p { font-size: 16px; }
}