/* =========================================================================
   SPARKS BUILDERS — DESIGN SYSTEM
   Mobile-first. mobile base styles, then progressive enhancement at
   768px (tablet) and 1024px (desktop).
   ========================================================================= */

/* -------------------------------------------------------------------------
   1. DESIGN TOKENS
   ------------------------------------------------------------------------- */
:root {
	/* Color */
	--sb-navy: #0A2647;
	--sb-navy-deep: #061A33;
	--sb-navy-soft: #14335C;
	--sb-orange: #FF6B00;
	--sb-orange-dark: #D85A00;
	--sb-yellow: #FFC857;
	--sb-surface: #F7F8FA;
	--sb-white: #FFFFFF;
	--sb-charcoal: #1A1D23;
	--sb-grey: #5B6470;
	--sb-grey-light: #9AA3AD;
	--sb-line: #E2E6EA;
	--sb-success: #1B8A5A;
	--sb-error: #C0392B;

	/* Type */
	--sb-font-display: 'Archivo', 'Helvetica Neue', Arial, sans-serif;
	--sb-font-body: 'Inter', 'Helvetica Neue', Arial, sans-serif;
	--sb-font-mono: 'JetBrains Mono', 'Courier New', monospace;

	/* Layout */
	--sb-container-width: 1240px;
	--sb-radius-sm: 4px;
	--sb-radius-md: 8px;
	--sb-header-height: 76px;

	/* Motion */
	--sb-transition: 200ms ease;
}

/* -------------------------------------------------------------------------
   2. RESET & BASE
   ------------------------------------------------------------------------- */
*, *::before, *::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	font-family: var(--sb-font-body);
	font-size: 16px;
	line-height: 1.65;
	color: var(--sb-charcoal);
	background: var(--sb-white);
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}

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

a {
	color: var(--sb-orange);
	text-decoration: none;
	transition: color var(--sb-transition);
}

a:hover {
	color: var(--sb-orange-dark);
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--sb-font-display);
	font-weight: 800;
	color: var(--sb-navy);
	line-height: 1.15;
	margin: 0 0 0.5em;
}

p {
	margin: 0 0 1em;
}

ul, ol {
	padding-left: 1.25em;
}

button {
	font-family: inherit;
	cursor: pointer;
}

.screen-reader-text {
	position: absolute;
	left: -9999px;
}

.sb-skip-link:focus {
	position: fixed;
	top: 8px;
	left: 8px;
	z-index: 10000;
	background: var(--sb-navy);
	color: var(--sb-white);
	padding: 10px 16px;
	border-radius: var(--sb-radius-sm);
}

/* Visible keyboard focus states throughout */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
	outline: 3px solid var(--sb-yellow);
	outline-offset: 2px;
}

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

/* -------------------------------------------------------------------------
   3. LAYOUT PRIMITIVES
   ------------------------------------------------------------------------- */
.sb-container {
	width: 100%;
	max-width: var(--sb-container-width);
	margin: 0 auto;
	padding: 0 20px;
}

.sb-section {
	padding: 56px 0;
}

@media (min-width: 768px) {
	.sb-section {
		padding: 80px 0;
	}
}

.sb-section-eyebrow {
	font-family: var(--sb-font-mono);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--sb-orange);
	margin-bottom: 12px;
}

.sb-section-title {
	font-size: clamp(28px, 4vw, 40px);
	max-width: 720px;
}

.sb-section-sub,
.sb-archive-sub {
	color: var(--sb-grey);
	font-size: 17px;
	max-width: 640px;
}

/* Rebar-tick divider — signature structural motif */
.sb-rebar-divider {
	position: relative;
	height: 1px;
	background: var(--sb-line);
	margin: 48px 0;
}

.sb-rebar-divider::before {
	content: '';
	position: absolute;
	left: 0;
	top: -6px;
	width: 1px;
	height: 13px;
	background: var(--sb-line);
}

.sb-intro-rebar-divider {
	display: none;
}

@media (min-width: 1024px) {
	.sb-intro-rebar-divider {
		display: block;
		width: 1px;
		background: var(--sb-line);
		position: relative;
	}
	.sb-intro-rebar-divider::before,
	.sb-intro-rebar-divider::after {
		content: '';
		position: absolute;
		left: -6px;
		width: 13px;
		height: 1px;
		background: var(--sb-line);
	}
	.sb-intro-rebar-divider::before { top: 0; }
	.sb-intro-rebar-divider::after { bottom: 0; }
}

/* -------------------------------------------------------------------------
   4. BUTTONS
   ------------------------------------------------------------------------- */
.sb-btn-primary,
.wp-block-button.sb-btn-primary .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--sb-orange);
	color: var(--sb-white);
	font-family: var(--sb-font-display);
	font-weight: 700;
	font-size: 15px;
	padding: 14px 28px;
	border-radius: var(--sb-radius-sm);
	border: none;
	transition: background var(--sb-transition), transform var(--sb-transition);
}

.sb-btn-primary:hover,
.wp-block-button.sb-btn-primary .wp-block-button__link:hover {
	background: var(--sb-orange-dark);
	color: var(--sb-white);
	transform: translateY(-1px);
}

.sb-btn-outline,
.wp-block-button.sb-btn-outline .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	color: var(--sb-navy);
	font-family: var(--sb-font-display);
	font-weight: 700;
	font-size: 15px;
	padding: 14px 28px;
	border-radius: var(--sb-radius-sm);
	border: 1.5px solid var(--sb-navy);
	transition: background var(--sb-transition), color var(--sb-transition);
}

.sb-btn-outline:hover {
	background: var(--sb-navy);
	color: var(--sb-white);
}

.sb-btn-outline-light {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	color: var(--sb-white);
	font-family: var(--sb-font-display);
	font-weight: 700;
	font-size: 15px;
	padding: 14px 28px;
	border-radius: var(--sb-radius-sm);
	border: 1.5px solid rgba(255,255,255,0.5);
	transition: background var(--sb-transition), border-color var(--sb-transition);
}

.sb-btn-outline-light:hover {
	background: rgba(255,255,255,0.12);
	border-color: var(--sb-white);
	color: var(--sb-white);
}

.sb-text-link {
	font-weight: 600;
	color: var(--sb-orange);
	display: inline-block;
}

button.is-loading {
	opacity: 0.6;
	pointer-events: none;
}

/* -------------------------------------------------------------------------
   5. HEADER & NAVIGATION
   ------------------------------------------------------------------------- */
.sb-site-header {
	position: sticky;
	top: 0;
	z-index: 999;
	background: var(--sb-white);
	border-bottom: 1px solid var(--sb-line);
	transition: box-shadow var(--sb-transition);
}

.sb-site-header.is-scrolled {
	box-shadow: 0 2px 16px rgba(10, 38, 71, 0.08);
}

.sb-header-inner {
	max-width: var(--sb-container-width);
	margin: 0 auto;
	padding: 0 20px;
	height: var(--sb-header-height);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}

.sb-header-brand img {
	max-height: 48px;
	width: auto;
}

.sb-text-logo {
	font-family: var(--sb-font-display);
	font-weight: 900;
	font-size: 22px;
	color: var(--sb-navy);
	letter-spacing: -0.01em;
}

.sb-primary-nav {
	display: none;
}

.sb-nav-list {
	display: flex;
	gap: 28px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.sb-nav-list a {
	font-family: var(--sb-font-display);
	font-weight: 600;
	font-size: 15px;
	color: var(--sb-charcoal);
}

.sb-nav-list a:hover {
	color: var(--sb-orange);
}

.sb-header-actions {
	display: none;
	align-items: center;
	gap: 20px;
}

.sb-header-phone {
	font-family: var(--sb-font-mono);
	font-weight: 700;
	font-size: 14px;
	color: var(--sb-navy);
	white-space: nowrap;
}

.sb-header-cta {
	white-space: nowrap;
	padding: 11px 22px;
}

.sb-mobile-toggle {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 40px;
	height: 40px;
	background: transparent;
	border: none;
	padding: 0;
}

.sb-burger-line {
	display: block;
	width: 100%;
	height: 2px;
	background: var(--sb-navy);
	transition: transform var(--sb-transition), opacity var(--sb-transition);
}

.sb-menu-open .sb-burger-line:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.sb-menu-open .sb-burger-line:nth-child(2) {
	opacity: 0;
}
.sb-menu-open .sb-burger-line:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

.sb-mobile-menu {
	display: none;
	position: fixed;
	top: var(--sb-header-height);
	left: 0;
	right: 0;
	bottom: 0;
	background: var(--sb-white);
	z-index: 998;
	padding: 24px 20px;
	overflow-y: auto;
}

.sb-mobile-menu.is-open {
	display: block;
}

.sb-mobile-nav-list {
	list-style: none;
	margin: 0 0 24px;
	padding: 0;
}

.sb-mobile-nav-list li {
	border-bottom: 1px solid var(--sb-line);
}

.sb-mobile-nav-list a {
	display: block;
	padding: 16px 4px;
	font-family: var(--sb-font-display);
	font-weight: 700;
	font-size: 18px;
	color: var(--sb-navy);
}

.sb-mobile-cta {
	display: block;
	width: 100%;
	text-align: center;
}

@media (min-width: 1024px) {
	.sb-primary-nav {
		display: block;
	}
	.sb-header-actions {
		display: flex;
	}
	.sb-mobile-toggle {
		display: none;
	}
}

/* Breadcrumb bar */
.sb-breadcrumb-bar {
	background: var(--sb-surface);
	border-bottom: 1px solid var(--sb-line);
	padding: 14px 0;
}

.sb-breadcrumbs ol {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: 13px;
	color: var(--sb-grey);
}

.sb-breadcrumbs li:not(:last-child)::after {
	content: '/';
	margin-left: 6px;
	color: var(--sb-grey-light);
}

.sb-breadcrumbs a {
	color: var(--sb-grey);
}

.sb-breadcrumbs a:hover {
	color: var(--sb-orange);
}

/* -------------------------------------------------------------------------
   6. HERO — blueprint-grid signature
   ------------------------------------------------------------------------- */
.sb-hero {
	position: relative;
	background: var(--sb-navy-deep);
	color: var(--sb-white);
	padding: 72px 0 64px;
	overflow: hidden;
}

.sb-hero-grid-bg {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(to right, rgba(255,255,255,0.06) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(255,255,255,0.06) 1px, transparent 1px);
	background-size: 40px 40px;
	mask-image: radial-gradient(ellipse 80% 70% at 50% 30%, black 40%, transparent 100%);
	-webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 30%, black 40%, transparent 100%);
}

.sb-hero-inner {
	position: relative;
	z-index: 1;
	max-width: 760px;
}

.sb-hero-eyebrow {
	font-family: var(--sb-font-mono);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.1em;
	color: var(--sb-yellow);
	margin-bottom: 18px;
}

.sb-hero-headline {
	color: var(--sb-white);
	font-size: clamp(34px, 6vw, 58px);
	line-height: 1.08;
	margin-bottom: 20px;
}

.sb-hero-sub {
	font-size: 18px;
	color: rgba(255,255,255,0.78);
	max-width: 580px;
	margin-bottom: 32px;
}

.sb-hero-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
}

.sb-hero .sb-btn-outline {
	color: var(--sb-white);
	border-color: rgba(255,255,255,0.5);
}
.sb-hero .sb-btn-outline:hover {
	background: var(--sb-white);
	color: var(--sb-navy);
}

@media (min-width: 768px) {
	.sb-hero {
		padding: 120px 0 100px;
	}
}

/* -------------------------------------------------------------------------
   7. COMPANY INTRO
   ------------------------------------------------------------------------- */
.sb-intro-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
}

.sb-intro-copy {
	max-width: 680px;
}

@media (min-width: 1024px) {
	.sb-intro-grid {
		grid-template-columns: 1fr auto;
		align-items: start;
	}
}

/* -------------------------------------------------------------------------
   8. SERVICES OVERVIEW GRID
   ------------------------------------------------------------------------- */
.sb-services-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	margin-top: 40px;
}

.sb-service-card {
	position: relative;
	display: block;
	background: var(--sb-surface);
	border: 1px solid var(--sb-line);
	border-radius: var(--sb-radius-md);
	padding: 28px 24px 56px;
	color: var(--sb-charcoal);
	transition: border-color var(--sb-transition), transform var(--sb-transition);
}

.sb-service-card:hover {
	border-color: var(--sb-orange);
	transform: translateY(-2px);
}

.sb-service-num {
	display: block;
	font-family: var(--sb-font-mono);
	font-weight: 700;
	color: var(--sb-orange);
	font-size: 14px;
	margin-bottom: 10px;
}

.sb-service-card h3 {
	font-size: 19px;
	margin-bottom: 10px;
}

.sb-service-card p {
	color: var(--sb-grey);
	font-size: 14.5px;
	margin-bottom: 0;
}

.sb-service-arrow {
	position: absolute;
	bottom: 22px;
	left: 24px;
	color: var(--sb-orange);
	font-weight: 700;
}

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

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

/* -------------------------------------------------------------------------
   9. WHY CHOOSE US
   ------------------------------------------------------------------------- */
.sb-why-us {
	background: var(--sb-surface);
}

.sb-why-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	margin-top: 40px;
}

.sb-why-item h3 {
	font-size: 18px;
}

.sb-why-mark {
	display: block;
	width: 32px;
	height: 4px;
	background: var(--sb-orange);
	margin-bottom: 16px;
}

.sb-why-item p {
	color: var(--sb-grey);
	font-size: 15px;
}

@media (min-width: 768px) {
	.sb-why-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 40px;
	}
}

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

/* -------------------------------------------------------------------------
   10. FEATURED / PORTFOLIO PROJECTS GRID
   ------------------------------------------------------------------------- */
.sb-section-header-row {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 24px;
}

.sb-projects-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 24px;
}

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

.sb-project-card:hover {
	box-shadow: 0 12px 28px rgba(10, 38, 71, 0.1);
	transform: translateY(-3px);
}

.sb-project-card-image {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--sb-navy-soft);
}

.sb-project-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.sb-project-placeholder {
	width: 100%;
	height: 100%;
	background:
		repeating-linear-gradient(45deg, var(--sb-navy-soft), var(--sb-navy-soft) 10px, var(--sb-navy) 10px, var(--sb-navy) 20px);
	min-height: 180px;
}

.sb-project-placeholder-hero {
	min-height: 320px;
}

.sb-project-tag {
	position: absolute;
	top: 12px;
	left: 12px;
	background: var(--sb-orange);
	color: var(--sb-white);
	font-family: var(--sb-font-mono);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	padding: 5px 10px;
	border-radius: var(--sb-radius-sm);
}

.sb-project-card-body {
	padding: 18px 20px;
}

.sb-project-card-body h3 {
	font-size: 17px;
	margin-bottom: 4px;
}

.sb-project-location {
	font-size: 13px;
	color: var(--sb-grey);
	margin: 0;
}

.sb-no-results {
	grid-column: 1 / -1;
	color: var(--sb-grey);
	background: var(--sb-surface);
	border-radius: var(--sb-radius-md);
	padding: 32px;
	text-align: center;
}

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

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

/* Project filter bar */
.sb-project-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 32px;
}

.sb-filter-btn {
	background: var(--sb-white);
	border: 1.5px solid var(--sb-line);
	color: var(--sb-charcoal);
	font-family: var(--sb-font-display);
	font-weight: 600;
	font-size: 13.5px;
	padding: 9px 18px;
	border-radius: 999px;
	transition: all var(--sb-transition);
}

.sb-filter-btn:hover {
	border-color: var(--sb-orange);
}

.sb-filter-btn.is-active {
	background: var(--sb-navy);
	border-color: var(--sb-navy);
	color: var(--sb-white);
}

/* -------------------------------------------------------------------------
   11. INDUSTRIES SERVED
   ------------------------------------------------------------------------- */
.sb-industries-list {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	list-style: none;
	padding: 0;
	margin: 32px 0 0;
}

.sb-industries-list li {
	background: var(--sb-navy);
	color: var(--sb-white);
	font-family: var(--sb-font-display);
	font-weight: 600;
	font-size: 14px;
	padding: 10px 20px;
	border-radius: var(--sb-radius-sm);
}

/* -------------------------------------------------------------------------
   12. COMPANY STATS BAND
   ------------------------------------------------------------------------- */
.sb-stats-band {
	background: var(--sb-navy);
	padding: 48px 0;
}

.sb-stats-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 32px;
	text-align: center;
}

.sb-stat {
	display: flex;
	flex-direction: column;
	align-items: center;
	position: relative;
}

.sb-stat-number,
.sb-stat-suffix {
	font-family: var(--sb-font-mono);
	font-weight: 700;
	font-size: clamp(34px, 5vw, 48px);
	color: var(--sb-yellow);
	line-height: 1;
}

.sb-stat-label {
	margin-top: 10px;
	font-size: 14px;
	color: rgba(255,255,255,0.75);
	font-weight: 500;
}

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

/* -------------------------------------------------------------------------
   13. TESTIMONIALS
   ------------------------------------------------------------------------- */
.sb-testimonials-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 20px;
	margin-top: 40px;
}

.sb-testimonial-card {
	background: var(--sb-surface);
	border-left: 3px solid var(--sb-orange);
	border-radius: var(--sb-radius-md);
	padding: 28px;
	margin: 0;
}

.sb-testimonial-card p {
	font-size: 16px;
	font-style: italic;
	color: var(--sb-charcoal);
}

.sb-testimonial-card footer {
	font-size: 13.5px;
	font-weight: 600;
	color: var(--sb-grey);
}

.sb-testimonials-note {
	margin-top: 20px;
	font-size: 13px;
	color: var(--sb-grey-light);
}

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

/* -------------------------------------------------------------------------
   14. CTA BAND
   ------------------------------------------------------------------------- */
.sb-cta-band {
	background: linear-gradient(135deg, var(--sb-navy) 0%, var(--sb-navy-deep) 100%);
	color: var(--sb-white);
	padding: 64px 0;
	text-align: center;
}

.sb-cta-heading {
	color: var(--sb-white);
	font-size: clamp(26px, 4vw, 36px);
}

.sb-cta-sub {
	color: rgba(255,255,255,0.8);
	max-width: 480px;
	margin: 0 auto 28px;
}

.sb-cta-buttons {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 14px;
}

/* -------------------------------------------------------------------------
   15. HOME CONTACT SECTION + GENERIC CONTACT PAGE
   ------------------------------------------------------------------------- */
.sb-home-contact-grid,
.sb-contact-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
}

.sb-contact-details {
	list-style: none;
	padding: 0;
	margin: 24px 0;
}

.sb-contact-details li {
	margin-bottom: 12px;
	font-size: 15px;
}

.sb-home-contact-map iframe,
.sb-contact-map-section iframe {
	width: 100%;
	height: 320px;
	border: 0;
	border-radius: var(--sb-radius-md);
}

.sb-contact-map-section iframe {
	height: 420px;
	border-radius: 0;
	display: block;
}

.sb-map-placeholder {
	background: var(--sb-surface);
	border: 1px dashed var(--sb-line);
	border-radius: var(--sb-radius-md);
	height: 320px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: var(--sb-grey);
	padding: 20px;
}

@media (min-width: 1024px) {
	.sb-home-contact-grid,
	.sb-contact-grid {
		grid-template-columns: 1.1fr 0.9fr;
		align-items: start;
	}
}

/* -------------------------------------------------------------------------
   16. FORMS
   ------------------------------------------------------------------------- */
.sb-form {
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.sb-form-row {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.sb-form-row-group {
	display: grid;
	grid-template-columns: 1fr;
	gap: 18px;
}

@media (min-width: 600px) {
	.sb-form-row-group {
		grid-template-columns: 1fr 1fr;
	}
}

.sb-form-row label {
	font-weight: 600;
	font-size: 14px;
	color: var(--sb-navy);
}

.sb-form-row input,
.sb-form-row select,
.sb-form-row textarea {
	font-family: var(--sb-font-body);
	font-size: 15px;
	padding: 12px 14px;
	border: 1.5px solid var(--sb-line);
	border-radius: var(--sb-radius-sm);
	background: var(--sb-white);
	color: var(--sb-charcoal);
	width: 100%;
}

.sb-form-row input:focus,
.sb-form-row select:focus,
.sb-form-row textarea:focus {
	border-color: var(--sb-orange);
	outline: none;
}

.sb-form-submit {
	align-self: flex-start;
	border: none;
}

.sb-form-feedback {
	font-size: 14px;
	min-height: 20px;
	margin: 0;
}

.sb-form-feedback.is-success {
	color: var(--sb-success);
}

.sb-form-feedback.is-error {
	color: var(--sb-error);
}

.sb-honeypot {
	position: absolute !important;
	left: -9999px !important;
	width: 1px;
	height: 1px;
	opacity: 0;
}

.sb-newsletter-form {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 16px;
}

.sb-newsletter-form input[type="email"] {
	flex: 1;
	min-width: 160px;
	padding: 10px 12px;
	border: 1.5px solid rgba(255,255,255,0.2);
	background: rgba(255,255,255,0.06);
	color: var(--sb-white);
	border-radius: var(--sb-radius-sm);
}

.sb-newsletter-form input[type="email"]::placeholder {
	color: rgba(255,255,255,0.5);
}

.sb-newsletter-form button {
	background: var(--sb-orange);
	color: var(--sb-white);
	border: none;
	padding: 10px 18px;
	font-weight: 700;
	border-radius: var(--sb-radius-sm);
}

.sb-newsletter-form .sb-form-feedback {
	width: 100%;
	color: rgba(255,255,255,0.85);
}

/* -------------------------------------------------------------------------
   17. FOOTER
   ------------------------------------------------------------------------- */
.sb-site-footer {
	background: var(--sb-navy-deep);
	color: rgba(255,255,255,0.8);
}

.sb-footer-top {
	padding: 56px 0 40px;
}

.sb-footer-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 36px;
}

.sb-footer-brand .sb-text-logo {
	color: var(--sb-white);
}

.sb-footer-brand img {
	max-height: 44px;
	filter: brightness(0) invert(1);
}

.sb-footer-tagline {
	margin-top: 14px;
	font-size: 14.5px;
	color: rgba(255,255,255,0.6);
	max-width: 280px;
}

.sb-footer-socials {
	display: flex;
	gap: 10px;
	margin-top: 18px;
}

.sb-social-link {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(255,255,255,0.08);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.sb-social-link::before {
	content: '●';
	color: var(--sb-white);
	font-size: 12px;
}

.sb-social-link:hover {
	background: var(--sb-orange);
}

.sb-footer-widget-title {
	color: var(--sb-white);
	font-size: 15px;
	margin-bottom: 16px;
}

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

.sb-footer-links li {
	margin-bottom: 10px;
}

.sb-footer-links a {
	color: rgba(255,255,255,0.65);
	font-size: 14.5px;
}

.sb-footer-links a:hover {
	color: var(--sb-orange);
}

.sb-footer-contact address {
	font-style: normal;
	font-size: 14.5px;
	color: rgba(255,255,255,0.65);
	margin-bottom: 10px;
}

.sb-footer-contact p {
	font-size: 14.5px;
	margin-bottom: 6px;
}

.sb-footer-contact a {
	color: rgba(255,255,255,0.85);
}

.sb-footer-bottom {
	border-top: 1px solid rgba(255,255,255,0.1);
	padding: 20px 0;
}

.sb-footer-bottom-inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 12px;
	font-size: 13px;
	color: rgba(255,255,255,0.5);
}

.sb-download-profile {
	color: var(--sb-yellow);
	font-weight: 600;
}

@media (min-width: 768px) {
	.sb-footer-grid {
		grid-template-columns: 1.4fr 1fr 1fr 1.3fr;
	}
}

/* -------------------------------------------------------------------------
   18. FLOATING WHATSAPP + STICKY MOBILE CTA
   ------------------------------------------------------------------------- */
.sb-whatsapp-float {
	position: fixed;
	bottom: 84px;
	right: 20px;
	width: 56px;
	height: 56px;
	background: #25D366;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 6px 16px rgba(0,0,0,0.25);
	z-index: 900;
	transition: transform var(--sb-transition);
}

.sb-whatsapp-float:hover {
	transform: scale(1.08);
}

.sb-whatsapp-icon {
	width: 28px;
	height: 28px;
	display: block;
	position: relative;
}

.sb-whatsapp-icon::before {
	content: '';
	position: absolute;
	inset: 0;
	background: var(--sb-white);
	-webkit-mask: radial-gradient(circle at 65% 65%, transparent 6px, black 7px);
	mask: radial-gradient(circle at 65% 65%, transparent 6px, black 7px);
	border-radius: 50%;
}

@media (min-width: 1024px) {
	.sb-whatsapp-float {
		bottom: 28px;
	}
}

.sb-sticky-mobile-cta {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	display: flex;
	z-index: 850;
	box-shadow: 0 -4px 16px rgba(0,0,0,0.12);
	transition: transform var(--sb-transition);
}

.sb-sticky-mobile-cta.is-hidden {
	transform: translateY(100%);
}

.sb-sticky-call,
.sb-sticky-quote {
	flex: 1;
	text-align: center;
	padding: 16px 8px;
	font-family: var(--sb-font-display);
	font-weight: 700;
	font-size: 14px;
}

.sb-sticky-call {
	background: var(--sb-navy);
	color: var(--sb-white);
}

.sb-sticky-quote {
	background: var(--sb-orange);
	color: var(--sb-white);
}

@media (min-width: 1024px) {
	.sb-sticky-mobile-cta {
		display: none;
	}
}

/* -------------------------------------------------------------------------
   19. SINGLE PROJECT PAGE
   ------------------------------------------------------------------------- */
.sb-project-hero {
	width: 100%;
	max-height: 480px;
	overflow: hidden;
}

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

.sb-project-detail-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 40px;
	padding: 48px 0;
}

.sb-project-tag-row {
	display: flex;
	gap: 8px;
	margin-bottom: 16px;
}

.sb-project-tag-row .sb-project-tag {
	position: static;
}

.sb-project-title {
	font-size: clamp(28px, 4vw, 38px);
}

.sb-project-description {
	font-size: 16px;
	color: var(--sb-charcoal);
}

.sb-project-outcome {
	background: var(--sb-surface);
	border-left: 3px solid var(--sb-orange);
	padding: 20px 24px;
	border-radius: var(--sb-radius-md);
	margin-top: 24px;
}

.sb-project-outcome h3 {
	font-size: 16px;
	margin-bottom: 8px;
}

.sb-before-after {
	margin-top: 32px;
}

.sb-before-after-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-top: 16px;
}

.sb-before-after-grid figure {
	margin: 0;
}

.sb-before-after-grid figcaption {
	text-align: center;
	font-size: 13px;
	color: var(--sb-grey);
	margin-top: 6px;
	font-weight: 600;
}

.sb-project-info-card {
	background: var(--sb-surface);
	border-radius: var(--sb-radius-md);
	padding: 28px;
}

.sb-project-info-card h3 {
	font-size: 17px;
}

.sb-project-info-card dl {
	margin: 16px 0 0;
}

.sb-project-info-card dt {
	font-family: var(--sb-font-mono);
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--sb-grey);
	margin-top: 14px;
}

.sb-project-info-card dd {
	margin: 2px 0 0;
	font-weight: 600;
}

.sb-project-cta {
	display: block;
	text-align: center;
	margin-top: 24px;
}

.sb-related-projects {
	padding: 48px 0 64px;
	border-top: 1px solid var(--sb-line);
}

@media (min-width: 1024px) {
	.sb-project-detail-grid {
		grid-template-columns: 2fr 1fr;
	}
	.sb-project-info-card {
		position: sticky;
		top: calc(var(--sb-header-height) + 24px);
	}
}

/* -------------------------------------------------------------------------
   20. SERVICES LANDING + SERVICE DETAIL PAGES
   ------------------------------------------------------------------------- */
.sb-services-landing-hero {
	background: var(--sb-surface);
	padding-bottom: 40px;
}

.sb-service-row {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	padding: 32px 0;
	border-bottom: 1px solid var(--sb-line);
}

.sb-service-row:first-child {
	padding-top: 0;
}

.sb-service-row-num {
	font-family: var(--sb-font-mono);
	font-size: 36px;
	font-weight: 700;
	color: var(--sb-line);
}

.sb-service-row-body h2 {
	font-size: 24px;
	margin-bottom: 10px;
}

.sb-service-row-items {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	padding: 0;
	margin: 16px 0;
}

.sb-service-row-items li {
	background: var(--sb-surface);
	border: 1px solid var(--sb-line);
	font-size: 13px;
	padding: 6px 12px;
	border-radius: 999px;
	color: var(--sb-grey);
}

@media (min-width: 768px) {
	.sb-service-row {
		grid-template-columns: 100px 1fr;
	}
}

.sb-service-detail-hero {
	background: linear-gradient(135deg, var(--sb-navy) 0%, var(--sb-navy-deep) 100%);
	color: var(--sb-white);
	padding: 64px 0 56px;
}

.sb-service-detail-hero .sb-section-title {
	color: var(--sb-white);
}

.sb-service-tagline {
	font-size: 19px;
	color: rgba(255,255,255,0.8);
	max-width: 600px;
	margin-top: 8px;
}

.sb-service-intro-text {
	font-size: 18px;
	max-width: 760px;
	color: var(--sb-charcoal);
}

.sb-service-items-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	margin-top: 32px;
}

.sb-service-item-card {
	background: var(--sb-surface);
	border-radius: var(--sb-radius-md);
	padding: 22px;
}

.sb-service-item-card h3 {
	font-size: 16px;
	margin-bottom: 8px;
}

.sb-service-item-card p {
	font-size: 14px;
	color: var(--sb-grey);
	margin: 0;
}

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

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

/* -------------------------------------------------------------------------
   21. ABOUT US PAGE
   ------------------------------------------------------------------------- */
.sb-about-hero {
	background: var(--sb-surface);
	padding-bottom: 32px;
}

.sb-about-story-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	align-items: center;
}

.sb-about-story-image .sb-project-placeholder {
	border-radius: var(--sb-radius-md);
	min-height: 280px;
}

.sb-image-caption {
	font-size: 12.5px;
	color: var(--sb-grey-light);
	margin-top: 8px;
}

.sb-mvv {
	background: var(--sb-surface);
}

.sb-mvv-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 24px;
}

.sb-mvv-card {
	background: var(--sb-white);
	border-radius: var(--sb-radius-md);
	padding: 28px;
	border: 1px solid var(--sb-line);
}

.sb-mvv-card h3 {
	font-size: 18px;
}

.sb-leadership-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px;
	margin-top: 32px;
}

.sb-leader-photo {
	border-radius: 50%;
	aspect-ratio: 1;
	min-height: 0;
	margin-bottom: 14px;
}

.sb-leader-card {
	text-align: center;
}

.sb-leader-card h3 {
	font-size: 16px;
	margin-bottom: 2px;
}

.sb-leader-title {
	font-size: 13.5px;
	color: var(--sb-grey);
}

.sb-cert-list {
	margin-top: 20px;
}

.sb-hse {
	background: var(--sb-surface);
}

.sb-hse-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 28px;
	align-items: center;
}

.sb-hse-image .sb-project-placeholder {
	border-radius: var(--sb-radius-md);
	min-height: 220px;
}

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

@media (min-width: 1024px) {
	.sb-about-story-grid,
	.sb-hse-grid {
		grid-template-columns: 1fr 1fr;
	}
}

/* -------------------------------------------------------------------------
   22. CAREERS PAGE
   ------------------------------------------------------------------------- */
.sb-jobs-list {
	display: flex;
	flex-direction: column;
	gap: 16px;
	margin-top: 32px;
}

.sb-job-card {
	background: var(--sb-surface);
	border-radius: var(--sb-radius-md);
	padding: 24px;
	border: 1px solid var(--sb-line);
}

.sb-job-card h3 {
	font-size: 19px;
	margin-bottom: 8px;
}

.sb-job-excerpt {
	color: var(--sb-grey);
	margin-bottom: 16px;
}

.sb-no-jobs {
	background: var(--sb-surface);
	border-radius: var(--sb-radius-md);
	padding: 28px;
	color: var(--sb-grey);
}

.sb-careers-internship {
	background: var(--sb-navy);
	color: var(--sb-white);
}

.sb-careers-internship .sb-section-title {
	color: var(--sb-white);
}

.sb-internship-grid p {
	color: rgba(255,255,255,0.8);
	max-width: 600px;
	margin-bottom: 24px;
}

.sb-application-container {
	max-width: 720px;
}

/* -------------------------------------------------------------------------
   23. BLOG
   ------------------------------------------------------------------------- */
.sb-blog-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 40px;
	padding: 48px 0;
}

.sb-archive-header {
	margin-bottom: 32px;
}

.sb-blog-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 28px;
}

.sb-blog-card-image {
	display: block;
	aspect-ratio: 16/10;
	overflow: hidden;
	border-radius: var(--sb-radius-md);
	margin-bottom: 14px;
}

.sb-blog-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.sb-blog-meta {
	font-family: var(--sb-font-mono);
	font-size: 12px;
	color: var(--sb-grey-light);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.sb-blog-card h2 {
	font-size: 21px;
}

.sb-blog-card h2 a {
	color: var(--sb-navy);
}

.sb-blog-sidebar .sb-widget {
	background: var(--sb-surface);
	border-radius: var(--sb-radius-md);
	padding: 24px;
	margin-bottom: 24px;
}

.sb-sidebar-cta p {
	color: var(--sb-grey);
	font-size: 14px;
}

.sb-pagination {
	margin-top: 40px;
}

.sb-pagination .nav-links {
	display: flex;
	gap: 12px;
	justify-content: center;
}

.sb-pagination a,
.sb-pagination span {
	padding: 8px 16px;
	border: 1px solid var(--sb-line);
	border-radius: var(--sb-radius-sm);
	font-size: 14px;
}

.sb-pagination .current {
	background: var(--sb-navy);
	color: var(--sb-white);
	border-color: var(--sb-navy);
}

/* Single post */
.sb-post-title {
	font-size: clamp(28px, 4vw, 38px);
}

.sb-post-category {
	font-family: var(--sb-font-mono);
	font-size: 12px;
	color: var(--sb-orange);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-bottom: 8px;
}

.sb-post-meta {
	color: var(--sb-grey);
	font-size: 14px;
}

.sb-post-featured-image {
	margin: 24px 0;
	border-radius: var(--sb-radius-md);
	overflow: hidden;
}

.sb-post-body {
	font-size: 16px;
}

.sb-post-body img {
	border-radius: var(--sb-radius-md);
}

.sb-post-tags {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	margin-bottom: 16px;
}

.sb-tag-chip {
	background: var(--sb-surface);
	padding: 6px 12px;
	border-radius: 999px;
	font-size: 12.5px;
	color: var(--sb-grey);
}

.sb-share-row {
	display: flex;
	gap: 12px;
	align-items: center;
	font-size: 13.5px;
	color: var(--sb-grey);
}

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

@media (min-width: 1024px) {
	.sb-blog-layout {
		grid-template-columns: 2.2fr 1fr;
	}
}

/* -------------------------------------------------------------------------
   24. PAGE / 404 / SEARCH GENERIC
   ------------------------------------------------------------------------- */
.sb-page-content {
	padding: 48px 0;
}

.sb-page-title {
	font-size: clamp(28px, 4vw, 38px);
}

.sb-page-featured-image {
	margin: 24px 0;
	border-radius: var(--sb-radius-md);
	overflow: hidden;
}

.sb-404-content {
	padding: 80px 0;
	text-align: center;
}

.sb-404-inner {
	max-width: 520px;
	margin: 0 auto;
}

.sb-404-code {
	display: block;
	font-family: var(--sb-font-mono);
	font-size: 72px;
	font-weight: 700;
	color: var(--sb-line);
	margin-bottom: 8px;
}

.sb-404-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 12px;
	margin: 28px 0;
}

.sb-404-search {
	margin-top: 24px;
}

.search-form {
	display: flex;
	gap: 8px;
	max-width: 420px;
	margin: 0 auto;
}

.search-form input[type="search"] {
	flex: 1;
	padding: 12px 14px;
	border: 1.5px solid var(--sb-line);
	border-radius: var(--sb-radius-sm);
}

.search-form button {
	background: var(--sb-orange);
	color: var(--sb-white);
	border: none;
	padding: 12px 20px;
	border-radius: var(--sb-radius-sm);
	font-weight: 700;
}

/* -------------------------------------------------------------------------
   25. EDITOR / GUTENBERG COMPATIBILITY
   ------------------------------------------------------------------------- */
.sb-page-body .wp-block-group,
.sb-page-body .wp-block-columns {
	margin-bottom: 1.5em;
}

.sb-page-body .wp-block-button__link {
	border-radius: var(--sb-radius-sm);
}
