/**
 * FiveCubes — Systems of Intelligence
 * Brand blues: #1e73be (primary), #092139 / #071a2e (nav/dark), #2eb9cc / #1f9fc6 (accents)
 */

:root {
	--fc-navy-900: #071a2e;
	--fc-navy-800: #092139;
	--fc-blue-600: #1e73be;
	--fc-blue-500: #1c8cbc;
	--fc-cyan-400: #2eb9cc;
	--fc-cyan-350: #1f9fc6;
	--fc-link-deep: #144b93;
	--fc-text: #e8f1ff;
	--fc-text-muted: rgba(232, 241, 255, 0.72);
	--fc-surface: rgba(9, 33, 57, 0.55);
	--fc-surface-strong: rgba(7, 26, 46, 0.85);
	--fc-border: rgba(46, 185, 204, 0.22);
	--fc-radius: 14px;
	--fc-section-pad: 92px;
	--fc-font: "Plus Jakarta Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
	/* fivecubes.html alignment */
	--navy: #071428;
	--navy2: #0a1f3d;
	--navy3: #0d2d58;
	--r2: 14px;
	--blue: #2563eb;
	--blue2: #3b82f6;
	--blue3: #93c5fd;
	--g50: #f8fafc;
	--g200: #e2e8f0;
	--g400: #94a3b8;
	--g500: #64748b;
	--g700: #334155;
	--g900: #0f172a;
}

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

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	min-height: 100vh;
	font-family: var(--fc-font);
	color: var(--fc-text);
	background-color: var(--fc-navy-900);
	background-image:
		radial-gradient(circle at 1px 1px, rgba(46, 185, 204, 0.14) 1px, transparent 0),
		radial-gradient(900px 500px at 10% -10%, rgba(30, 115, 190, 0.35), transparent 55%),
		radial-gradient(800px 480px at 90% 0%, rgba(46, 185, 204, 0.12), transparent 50%),
		linear-gradient(180deg, #071a2e 0%, #050f1a 100%);
	background-size: 24px 24px, auto, auto, auto;
	line-height: 1.65;
}

body.home {
	background: #fff;
	color: var(--g900);
}

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

a {
	color: var(--fc-cyan-400);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.2em;
}

a:hover {
	color: var(--fc-text);
}

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

.skip-link:focus {
	position: fixed;
	top: 8px;
	left: 8px;
	z-index: 100000;
	padding: 12px 16px;
	background: var(--fc-blue-600);
	color: #fff;
	clip: auto;
	width: auto;
	height: auto;
}

/* —— Header (frosted glass, matches fivecubes.html .nw) —— */
.site-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	padding: 0 24px;
	backdrop-filter: blur(20px) saturate(140%);
	-webkit-backdrop-filter: blur(20px) saturate(140%);
	background: rgba(7, 26, 46, 0.72);
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	min-height: 70px;
	display: flex;
	align-items: center;
}

.site-header__inner.nv {
	max-width: 1280px;
	margin: 0 auto;
	width: 100%;
	height: 70px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.nl {
	display: flex;
	align-items: center;
	gap: 12px;
}

.site-branding__link {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	text-decoration: none;
	color: inherit;
}

.tb-i img {
	filter: brightness(0) invert(1);
	height: 48px;
	width: auto;
}

/* Coded header logo (replaces raster logo in .nl) */
.fb {
	display: flex;
	align-items: center;
	gap: 9px;
	cursor: pointer;
}

.fb-cubes {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 3px;
	width: 24px;
	height: 24px;
}

.fb-cube {
	border-radius: 3px;
}

.fb-cube:nth-child(1) {
	background: #2563eb;
}

.fb-cube:nth-child(2) {
	background: #93c5fd;
}

.fb-cube:nth-child(3) {
	background: #0d2d58;
}

.fb-cube:nth-child(4) {
	background: #3b82f6;
}

.fb-txt {
	font-size: 19px;
	font-weight: 800;
	color: #ffffff;
	letter-spacing: -0.03em;
}

.fb-txt span {
	color: #3b82f6;
}

.primary-nav {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 12px;
	flex-wrap: wrap;
	position: relative;
}

.primary-nav .menu.nm {
	flex: 1;
	justify-content: flex-end;
}

.menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px 20px;
	align-items: center;
	justify-content: flex-end;
}

.site-header .nm {
	display: flex;
	align-items: center;
	list-style: none;
}

.site-header .nm > li {
	position: relative;
}

.site-header .nm > li > a {
	display: flex;
	align-items: center;
	gap: 4px;
	padding: 0 14px;
	height: 70px;
	font-size: 13px;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.72);
	transition: color 0.18s;
	text-decoration: none;
}

.site-header .nm > li > a:hover,
.site-header .nm > li.current-menu-item > a {
	color: #fff;
}

.site-header .nm > li > a svg {
	width: 10px;
	height: 10px;
	stroke: currentColor;
	fill: none;
	stroke-width: 2;
	transition: transform 0.2s;
	flex-shrink: 0;
}

.site-header .nm > li.dropdown:hover > a svg,
.site-header .nm > li.dropdown.is-open > a svg {
	transform: rotate(180deg);
}

.site-header .nm .dd {
	visibility: hidden;
	opacity: 0;
	position: absolute;
	top: calc(100% + 4px);
	left: 0;
	background: #fff;
	border: 1px solid var(--g200);
	border-radius: var(--r2);
	min-width: 240px;
	padding: 8px;
	box-shadow: 0 20px 56px rgba(0, 0, 0, 0.11);
	transition: opacity 0.2s, transform 0.2s, visibility 0.2s;
	transform: translateY(-5px);
	z-index: 1100;
}

.site-header .nm > li.dropdown:hover .dd {
	visibility: visible;
	opacity: 1;
	transform: translateY(0);
}

.site-header .nm .dd a {
	display: block;
	padding: 10px 14px;
	font-size: 13px;
	color: var(--g500);
	font-weight: 500;
	border-radius: 8px;
	transition: background 0.15s, color 0.15s;
	text-decoration: none;
}

.site-header .nm .dd a:hover,
.site-header .nm .dd a[aria-current="page"] {
	background: #eff6ff;
	color: var(--blue);
}

.site-header .ncta {
	background: var(--blue);
	color: #fff;
	border: none;
	border-radius: 8px;
	padding: 10px 22px;
	font-size: 13px;
	font-weight: 700;
	transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
	display: inline-flex;
	align-items: center;
	gap: 7px;
	text-decoration: none;
	white-space: nowrap;
}

.site-header .ncta:hover {
	background: #1d4ed8;
	transform: translateY(-1px);
	box-shadow: 0 8px 20px rgba(37, 99, 235, 0.3);
	color: #fff;
}

.site-header .ncta svg {
	width: 14px;
	height: 14px;
	stroke: #fff;
	fill: none;
	stroke-width: 2.5;
	flex-shrink: 0;
}

.site-header .menu a {
	color: rgba(255, 255, 255, 0.88);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.8125rem;
}

.site-header .menu a:hover,
.site-header .menu .current-menu-item > a {
	color: var(--blue3);
}

.mobile-nav-toggle {
	display: none;
	background: transparent;
	border: 1px solid var(--fc-border);
	border-radius: 10px;
	padding: 10px 12px;
	cursor: pointer;
}

.mobile-nav-toggle__bar {
	display: block;
	width: 22px;
	height: 2px;
	background: var(--fc-text);
	margin: 4px 0;
	border-radius: 2px;
	transition: transform 0.2s ease, opacity 0.2s ease;
}

body.is-menu-open .mobile-nav-toggle__bar:nth-child(2) {
	opacity: 0;
}

body.is-menu-open .mobile-nav-toggle__bar:nth-child(1) {
	transform: translateY(6px) rotate(45deg);
}

body.is-menu-open .mobile-nav-toggle__bar:nth-child(3) {
	transform: translateY(-6px) rotate(-45deg);
}

@media (max-width: 900px) {
	.mobile-nav-toggle {
		display: inline-block;
	}

	.primary-nav {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: var(--fc-surface-strong);
		border-bottom: 1px solid var(--fc-border);
		padding: 16px 24px 24px;
		display: none;
		flex-direction: column;
		align-items: stretch;
		gap: 16px;
	}

	body.is-menu-open .primary-nav {
		display: flex;
	}

	.primary-nav .menu.nm {
		flex: none;
		width: 100%;
	}

	.menu--primary {
		flex-direction: column;
		align-items: flex-start;
		gap: 0;
		width: 100%;
	}

	.site-header .nm > li {
		width: 100%;
	}

	.site-header .nm > li > a {
		height: auto;
		min-height: 44px;
		padding: 12px 8px;
		width: 100%;
	}

	.site-header .nm > li.dropdown .dd {
		visibility: visible;
		opacity: 1;
		position: static;
		transform: none;
		display: none;
		box-shadow: none;
		border: 1px solid rgba(255, 255, 255, 0.1);
		background: rgba(0, 0, 0, 0.2);
		margin-top: 4px;
		padding: 4px 0;
	}

	.site-header .nm > li.dropdown:hover .dd {
		display: none;
	}

	.site-header .nm > li.dropdown.is-open .dd {
		display: block;
	}

	.site-header .nm .dd a {
		color: rgba(255, 255, 255, 0.85);
	}

	.site-header .nm .dd a:hover,
	.site-header .nm .dd a[aria-current="page"] {
		background: rgba(255, 255, 255, 0.08);
		color: var(--blue3);
	}

	.site-header .ncta {
		justify-content: center;
		width: 100%;
	}
}

/* —— Layout —— */
.section {
	padding: var(--fc-section-pad) 24px;
}

.section--tight {
	padding-top: calc(var(--fc-section-pad) * 0.55);
	padding-bottom: calc(var(--fc-section-pad) * 0.55);
}

.section__inner {
	max-width: 1120px;
	margin: 0 auto;
}

.section--alt {
	background: rgba(9, 33, 57, 0.35);
	border-block: 1px solid var(--fc-border);
}

.section__title {
	font-size: clamp(1.75rem, 3vw, 2.25rem);
	font-weight: 700;
	margin: 0 0 12px;
	letter-spacing: -0.02em;
}

.section__subtitle {
	margin: 0 0 40px;
	color: var(--fc-text-muted);
	max-width: 56ch;
}

/* —— Hero —— */
.hero {
	position: relative;
	overflow: hidden;
	padding: calc(var(--fc-section-pad) + 12px) 24px calc(var(--fc-section-pad) * 0.85);
}

.hero__orbs {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.hero__orb {
	position: absolute;
	border-radius: 50%;
	filter: blur(60px);
	opacity: 0.55;
	mix-blend-mode: screen;
}

.hero__orb--a {
	width: 380px;
	height: 380px;
	background: radial-gradient(circle, rgba(46, 185, 204, 0.9), transparent 65%);
	top: -80px;
	left: -60px;
}

.hero__orb--b {
	width: 420px;
	height: 420px;
	background: radial-gradient(circle, rgba(30, 115, 190, 0.85), transparent 65%);
	bottom: -120px;
	right: -80px;
}

.hero__orb--c {
	width: 260px;
	height: 260px;
	background: radial-gradient(circle, rgba(46, 185, 204, 0.45), transparent 70%);
	top: 40%;
	left: 45%;
}

.hero__inner {
	position: relative;
	max-width: 1120px;
	margin: 0 auto;
}

.hero__eyebrow {
	text-transform: uppercase;
	letter-spacing: 0.16em;
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--fc-cyan-400);
	margin: 0 0 16px;
}

.hero__title {
	font-size: clamp(2.1rem, 4.2vw, 3.25rem);
	line-height: 1.12;
	margin: 0 0 20px;
	letter-spacing: -0.03em;
}

.hero__lead {
	max-width: 62ch;
	color: var(--fc-text-muted);
	font-size: 1.05rem;
	margin: 0 0 32px;
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

/* —— Buttons —— */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px 22px;
	border-radius: 999px;
	font-weight: 600;
	font-size: 0.95rem;
	border: 1px solid transparent;
	cursor: pointer;
	text-decoration: none;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
	font-family: inherit;
}

.btn--primary {
	background: linear-gradient(135deg, var(--fc-blue-600), var(--fc-blue-500));
	color: #fff;
	box-shadow: 0 12px 40px rgba(30, 115, 190, 0.35);
}

.btn--primary:hover {
	color: #fff;
	filter: brightness(1.06);
}

.btn--ghost {
	background: rgba(255, 255, 255, 0.04);
	border-color: var(--fc-border);
	color: var(--fc-text);
}

.btn--ghost:hover {
	border-color: var(--fc-cyan-400);
	color: var(--fc-cyan-400);
}

.btn--link {
	background: none;
	border: none;
	color: var(--fc-text-muted);
	padding: 8px 0;
}

.btn--link:hover {
	color: var(--fc-cyan-400);
}

/* Primary blue CTA (fivecubes.html .btn-blue) */
.btn-blue {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: var(--blue);
	color: #fff;
	border: none;
	border-radius: 8px;
	padding: 13px 26px;
	font-size: 13.5px;
	font-weight: 700;
	font-family: inherit;
	text-decoration: none;
	cursor: pointer;
	transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
}

.btn-blue:hover {
	background: #1d4ed8;
	transform: translateY(-1px);
	box-shadow: 0 8px 24px rgba(37, 99, 235, 0.3);
	color: #fff;
}

.btn-blue svg {
	width: 14px;
	height: 14px;
	stroke: #fff;
	fill: none;
	stroke-width: 2.5;
	flex-shrink: 0;
}

.btn-blue--outline {
	background: transparent;
	color: var(--blue);
	border: 1.5px solid var(--blue);
	box-shadow: none;
}

.btn-blue--outline:hover {
	background: #eff6ff;
	transform: translateY(-1px);
	box-shadow: none;
	color: var(--blue);
}

/* —— Grids —— */
.grid {
	display: grid;
	gap: 20px;
}

.grid--services {
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.grid--why {
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.grid--focus {
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.service-card {
	padding: 24px;
	border-radius: var(--fc-radius);
	background: var(--fc-surface);
	border: 1px solid var(--fc-border);
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.25);
	transition: transform 0.2s ease, border-color 0.2s ease;
}

.service-card:hover {
	transform: translateY(-3px);
	border-color: rgba(46, 185, 204, 0.45);
}

.service-card__title {
	margin: 0 0 10px;
	font-size: 1.1rem;
}

.service-card__text {
	margin: 0 0 16px;
	color: var(--fc-text-muted);
	font-size: 0.95rem;
}

.service-card__link {
	font-weight: 600;
	color: var(--fc-cyan-400);
	text-decoration: none;
}

.service-card__link:hover {
	color: #fff;
}

.pill-card {
	padding: 20px;
	border-radius: var(--fc-radius);
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.06);
}

.pill-card__title {
	margin: 0 0 8px;
	font-size: 1rem;
}

.principles {
	margin-top: 48px;
	padding: 28px;
	border-radius: var(--fc-radius);
	border: 1px dashed var(--fc-border);
	background: rgba(7, 26, 46, 0.4);
}

.principles__title {
	margin: 0 0 16px;
}

.principles__list {
	margin: 0;
	padding-left: 1.2em;
	color: var(--fc-text-muted);
}

.focus-tile {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	min-height: 100px;
	padding: 20px;
	border-radius: var(--fc-radius);
	background: linear-gradient(145deg, rgba(30, 115, 190, 0.25), rgba(7, 26, 46, 0.8));
	border: 1px solid var(--fc-border);
	color: var(--fc-text);
	font-weight: 600;
	text-decoration: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.focus-tile:hover {
	border-color: var(--fc-cyan-400);
	box-shadow: 0 0 0 1px rgba(46, 185, 204, 0.25);
	color: #fff;
}

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

.cta-block {
	max-width: 720px;
	margin: 0 auto;
	padding: 48px 32px;
	border-radius: 20px;
	background: rgba(9, 33, 57, 0.55);
	border: 1px solid var(--fc-border);
}

.cta-block__title {
	margin: 0 0 12px;
}

.cta-block__text {
	color: var(--fc-text-muted);
	margin: 0 0 24px;
}

/* —— Inner pages —— */
.site-main {
	min-height: 100vh;
}

.content-card {
	max-width: 880px;
	margin: 0 auto;
	padding: 48px 24px 96px;
}

.content-card--prose .entry-content {
	font-size: 1.05rem;
	color: var(--fc-text-muted);
}

.content-card--prose h2 {
	color: var(--fc-text);
	margin-top: 2rem;
}

.page-title {
	font-size: clamp(1.85rem, 3vw, 2.5rem);
	margin: 0 0 16px;
}

.page-header {
	max-width: 880px;
	margin: 0 auto;
	padding: 48px 24px 0;
}

.page-intro {
	color: var(--fc-text-muted);
	margin: 0;
}

.page-lead {
	font-size: 1.15rem;
	color: var(--fc-text-muted);
}

.services-grid {
	max-width: 960px;
	margin: 0 auto;
	padding: 24px 24px 96px;
	display: flex;
	flex-direction: column;
	gap: 48px;
}

.service-block {
	padding: 32px;
	border-radius: var(--fc-radius);
	background: var(--fc-surface);
	border: 1px solid var(--fc-border);
}

.service-block h2 {
	margin-top: 0;
	color: var(--fc-text);
}

.service-block ul {
	color: var(--fc-text-muted);
}

/* —— Contact —— */
.contact-layout {
	display: grid;
	grid-template-columns: 1fr 1.4fr;
	gap: 40px;
	margin-top: 32px;
}

@media (max-width: 800px) {
	.contact-layout {
		grid-template-columns: 1fr;
	}
}

.contact-form label {
	display: block;
	font-weight: 600;
	margin-bottom: 6px;
}

.contact-form input,
.contact-form textarea {
	width: 100%;
	padding: 12px 14px;
	border-radius: 10px;
	border: 1px solid var(--fc-border);
	background: rgba(7, 26, 46, 0.65);
	color: var(--fc-text);
	font-family: inherit;
}

.contact-form input:focus,
.contact-form textarea:focus {
	outline: 2px solid var(--fc-cyan-400);
	outline-offset: 1px;
}

.honeypot {
	position: absolute;
	left: -9999px;
	height: 0;
	overflow: hidden;
}

.notice {
	padding: 12px 16px;
	border-radius: 10px;
	margin-bottom: 20px;
}

.notice--success {
	background: rgba(46, 185, 204, 0.15);
	border: 1px solid rgba(46, 185, 204, 0.4);
}

.notice--error {
	background: rgba(221, 51, 51, 0.12);
	border: 1px solid rgba(221, 51, 51, 0.35);
}

.req {
	color: var(--fc-cyan-400);
}

.btn-row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 12px;
}

.rule {
	border: none;
	border-top: 1px solid var(--fc-border);
	margin: 32px 0;
}

.fineprint {
	font-size: 0.85rem;
	color: var(--fc-text-muted);
}

/* —— Footer (fivecubes.html · 4-column + bottom bar) —— */
.site-footer {
	position: relative;
	background: #071428;
	background: var(--navy);
	color: rgba(255, 255, 255, 0.88);
	padding: 0 0 28px;
	border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.site-footer__fm.fm {
	max-width: 1280px;
	margin: 0 auto;
	padding: 68px 48px 40px;
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: 52px;
	align-items: start;
}

.site-footer__logo-link {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	color: inherit;
	margin-bottom: 18px;
}

.site-footer__logo-link .fb {
	cursor: pointer;
}

.site-footer__tagline {
	margin: 0 0 13px;
	font-size: 13.5px;
	color: rgba(255, 255, 255, 0.3);
	line-height: 1.85;
}

.site-footer__brand .fe {
	font-size: 13px;
	font-weight: 600;
	margin-bottom: 14px;
}

.site-footer__brand .fe a {
	color: var(--blue3);
	text-decoration: none;
	transition: opacity 0.18s;
}

.site-footer__brand .fe a:hover {
	opacity: 0.9;
	text-decoration: underline;
}

.site-footer__chat {
	margin-top: 4px;
	align-self: flex-start;
	border-radius: 8px;
	border: 1.5px solid rgba(255, 255, 255, 0.22);
	background: transparent;
	color: rgba(255, 255, 255, 0.75);
}

.site-footer__chat:hover {
	border-color: rgba(255, 255, 255, 0.45);
	color: #fff;
}

.site-footer__col.fc2 h4 {
	font-size: 10.5px;
	font-weight: 800;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.2);
	margin: 0 0 16px;
}

.site-footer__col-heading-link {
	color: inherit;
	text-decoration: none;
	transition: color 0.18s;
}

.site-footer__col-heading-link:hover {
	color: var(--blue3);
}

.site-footer__col.fc2 ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.site-footer__col.fc2 a {
	font-size: 13.5px;
	color: rgba(255, 255, 255, 0.38);
	text-decoration: none;
	transition: color 0.18s;
}

.site-footer__col.fc2 a:hover {
	color: var(--blue3);
}

.site-footer__divider.fd {
	border: none;
	border-top: 1px solid rgba(255, 255, 255, 0.06);
	margin: 0 48px;
	height: 0;
	max-width: none;
}

.site-footer__bottom.fbot {
	max-width: 1280px;
	margin: 0 auto;
	padding: 20px 48px 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 16px 24px;
}

.site-footer__copyright {
	margin: 0;
	font-size: 12px;
	color: rgba(255, 255, 255, 0.2);
}

.fleg {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px 22px;
}

.fleg a {
	font-size: 12px;
	color: rgba(255, 255, 255, 0.2);
	text-decoration: none;
	transition: color 0.18s;
}

.fleg a:hover {
	color: var(--blue3);
}

.fleg__sep {
	color: rgba(255, 255, 255, 0.15);
	font-weight: 300;
	user-select: none;
}

@media (max-width: 960px) {
	.site-footer__fm.fm {
		grid-template-columns: 1fr 1fr;
		padding: 48px 24px 32px;
		gap: 40px;
	}

	.site-footer__divider.fd {
		margin: 0 24px;
	}

	.site-footer__bottom.fbot {
		padding: 20px 24px 0;
	}
}

@media (max-width: 640px) {
	.site-footer__fm.fm {
		grid-template-columns: 1fr;
	}

	.site-footer__bottom.fbot {
		flex-direction: column;
		align-items: flex-start;
	}
}

/* —— Chatbot —— */
.chatbot-panel {
	position: fixed;
	bottom: 24px;
	right: 24px;
	width: min(380px, calc(100vw - 32px));
	background: var(--fc-surface-strong);
	border: 1px solid var(--fc-border);
	border-radius: 16px;
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.45);
	z-index: 2000;
	display: flex;
	flex-direction: column;
	max-height: min(480px, 70vh);
}

.chatbot-panel[hidden] {
	display: none;
}

.chatbot-panel__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 12px 16px;
	border-bottom: 1px solid var(--fc-border);
}

.chatbot-panel__close {
	background: none;
	border: none;
	color: var(--fc-text);
	font-size: 1.5rem;
	cursor: pointer;
	line-height: 1;
}

.chatbot-panel__body {
	flex: 1;
	overflow: auto;
	padding: 16px;
	font-size: 0.95rem;
}

.chatbot-msg {
	margin: 0 0 10px;
	padding: 10px 12px;
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.04);
	color: var(--fc-text-muted);
}

.chatbot-msg--user {
	background: rgba(30, 115, 190, 0.35);
	color: var(--fc-text);
	align-self: flex-end;
}

.chatbot-panel__form {
	display: flex;
	gap: 8px;
	padding: 12px;
	border-top: 1px solid var(--fc-border);
}

.chatbot-panel__form input {
	flex: 1;
	padding: 10px 12px;
	border-radius: 10px;
	border: 1px solid var(--fc-border);
	background: rgba(7, 26, 46, 0.65);
	color: var(--fc-text);
	font-family: inherit;
}

/* —— Modal —— */
.modal[hidden] {
	display: none;
}

.modal {
	position: fixed;
	inset: 0;
	z-index: 3000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
}

.modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(5, 15, 26, 0.75);
	backdrop-filter: blur(4px);
}

.modal__dialog {
	position: relative;
	z-index: 1;
	max-width: 520px;
	width: 100%;
	padding: 28px;
	border-radius: 16px;
	background: var(--fc-navy-800);
	border: 1px solid var(--fc-border);
	box-shadow: 0 30px 100px rgba(0, 0, 0, 0.5);
}

.modal__close {
	position: absolute;
	top: 12px;
	right: 12px;
	background: none;
	border: none;
	color: var(--fc-text);
	font-size: 1.5rem;
	cursor: pointer;
}

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

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

.entry-content h1,
.entry-content h2,
.entry-content h3 {
	color: var(--fc-text);
}

/* —— Homepage: fivecubes.html structure —— */
.fc-home .home-hero.hero {
	min-height: 620px;
	background: var(--navy);
	display: flex;
	align-items: center;
	position: relative;
	overflow: hidden;
	padding: 0;
}

.fc-home .hero-dots {
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(255, 255, 255, 0.07) 1.5px, transparent 1.5px);
	background-size: 36px 36px;
	pointer-events: none;
}

.fc-home .hero-o1 {
	position: absolute;
	top: -140px;
	right: -80px;
	width: 520px;
	height: 520px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(37, 99, 235, 0.22) 0%, transparent 68%);
	pointer-events: none;
}

.fc-home .hero-o2 {
	position: absolute;
	bottom: -80px;
	left: -60px;
	width: 380px;
	height: 380px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(59, 130, 246, 0.12) 0%, transparent 70%);
	pointer-events: none;
}

.fc-home .hero-in {
	position: relative;
	z-index: 2;
	max-width: 1280px;
	margin: 0 auto;
	padding: 96px 48px 100px;
	width: 100%;
	display: grid;
	grid-template-columns: 1fr 420px;
	gap: 72px;
	align-items: center;
}

@media (max-width: 1024px) {
	.fc-home .hero-in {
		grid-template-columns: 1fr;
		padding: 72px 24px 88px;
		gap: 48px;
	}
}

.fc-home .hero-sub {
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.3);
	margin-bottom: 18px;
}

.fc-home .hero-home__title {
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 800;
	color: #fff;
	line-height: 1.08;
	letter-spacing: -0.04em;
	margin: 0 0 18px;
}

.fc-home .hero-home__title em {
	font-style: normal;
	background: linear-gradient(135deg, var(--blue2), var(--blue3));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

.fc-home .hero-home__lead {
	font-size: 16.5px;
	color: rgba(255, 255, 255, 0.52);
	line-height: 1.8;
	margin-bottom: 0;
	max-width: 480px;
}

.fc-home .btn--white {
	background: #fff;
	color: var(--blue);
	border: none;
	border-radius: 8px;
	padding: 13px 26px;
	font-size: 13.5px;
	font-weight: 700;
	box-shadow: none;
}

.fc-home .btn--white:hover {
	background: #eff6ff;
	color: var(--blue);
	filter: none;
}

.fc-home .btn--white svg {
	stroke: var(--blue);
}

.fc-home .home-hero .btn--ghost {
	border-radius: 8px;
	padding: 13px 26px;
	font-size: 13.5px;
	font-weight: 600;
	border: 1.5px solid rgba(255, 255, 255, 0.25);
	background: transparent;
	color: #fff;
}

.fc-home .home-hero .btn--ghost:hover {
	border-color: rgba(255, 255, 255, 0.55);
	background: rgba(255, 255, 255, 0.07);
	color: #fff;
}

.fc-home .hero-stats {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.fc-home .hsc {
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.09);
	border-radius: 14px;
	padding: 20px 24px;
	display: flex;
	align-items: center;
	gap: 18px;
	transition: background 0.2s;
}

.fc-home .hsc:hover {
	background: rgba(255, 255, 255, 0.09);
}

.fc-home .hsc-icon {
	width: 42px;
	height: 42px;
	border-radius: 10px;
	background: linear-gradient(135deg, var(--blue), var(--blue2));
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.fc-home .hsc-num {
	font-size: 26px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.03em;
	line-height: 1;
}

.fc-home .hsc-lbl {
	font-size: 12px;
	color: rgba(255, 255, 255, 0.38);
	font-weight: 500;
	margin-top: 3px;
}

/* Who we are band */
.fc-home .home-about.ab {
	background: var(--navy2);
	border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.fc-home .ab-in {
	max-width: 1280px;
	margin: 0 auto;
	padding: 72px 48px;
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 88px;
	align-items: center;
}

@media (max-width: 900px) {
	.fc-home .ab-in {
		grid-template-columns: 1fr;
		padding: 48px 24px;
	}
}

.fc-home .lbl {
	font-size: 11.5px;
	font-weight: 700;
	color: var(--blue);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin-bottom: 10px;
}

.fc-home .lbl--muted {
	color: var(--blue3);
}

.fc-home .ab__h2 {
	font-size: 30px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.03em;
	margin-bottom: 18px;
	line-height: 1.25;
}

.fc-home .home-about p {
	font-size: 15px;
	color: rgba(255, 255, 255, 0.45);
	line-height: 1.88;
	margin-bottom: 16px;
}

.fc-home .ab__p2 {
	margin-bottom: 24px;
}

.fc-home .pl-head {
	font-size: 10.5px;
	font-weight: 700;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.28);
	margin-bottom: 16px;
}

.fc-home .pl {
	display: flex;
	flex-direction: column;
	gap: 11px;
}

.fc-home .pl-i {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 14px;
	color: rgba(255, 255, 255, 0.58);
	font-weight: 500;
}

.fc-home .pl-i::before {
	content: "";
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--blue2);
	flex-shrink: 0;
}

.fc-home .ab-nums {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1px;
	background: rgba(255, 255, 255, 0.06);
	border-radius: 14px;
	overflow: hidden;
}

.fc-home .anum {
	background: var(--navy2);
	padding: 28px 24px;
}

.fc-home .anum-v {
	font-size: 38px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.04em;
	line-height: 1;
}

.fc-home .anum-v em {
	font-style: normal;
	background: linear-gradient(135deg, var(--blue2), var(--blue3));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

.fc-home .anum-l {
	font-size: 11px;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.35);
	margin-top: 6px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

/* Services grid (light) */
.fc-home .home-services.sa {
	padding: 92px 0;
	background: var(--g50);
}

.fc-home .ct {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 48px;
}

.fc-home .s-hrow {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	margin-bottom: 48px;
	flex-wrap: wrap;
	gap: 16px;
}

.fc-home .sh {
	font-size: 40px;
	font-weight: 800;
	color: var(--g900);
	letter-spacing: -0.035em;
	line-height: 1.1;
	margin-bottom: 0;
}

.fc-home .va {
	font-size: 13px;
	font-weight: 700;
	color: var(--blue);
	display: inline-flex;
	align-items: center;
	gap: 6px;
	text-decoration: none;
}

.fc-home .va:hover {
	gap: 10px;
}

.fc-home .va svg {
	stroke: var(--blue);
}

.fc-home .sg {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

@media (max-width: 1000px) {
	.fc-home .sg {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 600px) {
	.fc-home .sg {
		grid-template-columns: 1fr;
	}
}

.fc-home a.scard {
	background: #fff;
	border: 1px solid var(--g200);
	border-radius: 14px;
	padding: 28px;
	display: block;
	text-decoration: none;
	color: inherit;
	transition: all 0.22s;
	cursor: pointer;
}

.fc-home a.scard:hover {
	box-shadow: 0 14px 44px rgba(37, 99, 235, 0.1);
	transform: translateY(-4px);
	border-color: #dbeafe;
}

.fc-home .si {
	width: 46px;
	height: 46px;
	border-radius: 11px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 18px;
}

.fc-home .si-b {
	background: var(--navy);
}

.fc-home .si svg {
	width: 21px;
	height: 21px;
	stroke: var(--blue3);
	fill: none;
	stroke-width: 1.8;
}

.fc-home .scard h3 {
	font-size: 16.5px;
	font-weight: 800;
	color: var(--g900);
	margin-bottom: 9px;
	letter-spacing: -0.02em;
}

.fc-home .scard p {
	font-size: 13.5px;
	color: var(--g500);
	line-height: 1.75;
	margin: 0;
}

.fc-home .scard-lm {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 16px;
	font-size: 12.5px;
	font-weight: 700;
	color: var(--blue);
}

.fc-home a.scard:hover .scard-lm {
	gap: 10px;
}

/* Why section */
.fc-home .home-why.sd {
	padding: 92px 0;
	background: var(--navy);
}

.fc-home .why-head {
	text-align: center;
	margin-bottom: 56px;
}

.fc-home .lbl.lt {
	color: var(--blue3);
}

.fc-home .sh.lt {
	color: #fff;
	margin-top: 8px;
}

.fc-home .wg {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
}

@media (max-width: 900px) {
	.fc-home .wg {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 520px) {
	.fc-home .wg {
		grid-template-columns: 1fr;
	}
}

.fc-home .wcard {
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 14px;
	padding: 28px 22px;
	transition: all 0.22s;
}

.fc-home .wcard:hover {
	background: rgba(59, 130, 246, 0.08);
	border-color: rgba(59, 130, 246, 0.2);
	transform: translateY(-3px);
}

.fc-home .wicon {
	width: 50px;
	height: 50px;
	border-radius: 13px;
	background: rgba(37, 99, 235, 0.2);
	border: 1px solid rgba(59, 130, 246, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 18px;
	color: var(--blue3);
}

.fc-home .wcard h3 {
	font-size: 15.5px;
	font-weight: 800;
	color: #fff;
	margin-bottom: 9px;
	letter-spacing: -0.02em;
}

.fc-home .wcard p {
	font-size: 13.5px;
	color: rgba(255, 255, 255, 0.42);
	line-height: 1.7;
	margin: 0;
}

/* Focus areas */
.fc-home .home-focus.s {
	padding: 92px 0;
}

.fc-home .fg {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
}

@media (max-width: 700px) {
	.fc-home .fg {
		grid-template-columns: 1fr;
	}
}

.fc-home a.fcard {
	background: #fff;
	border: 1px solid var(--g200);
	border-radius: 14px;
	padding: 26px;
	display: flex;
	gap: 18px;
	text-decoration: none;
	color: inherit;
	transition: all 0.22s;
}

.fc-home a.fcard:hover {
	border-color: var(--blue);
	box-shadow: 0 10px 34px rgba(37, 99, 235, 0.1);
	transform: translateY(-3px);
}

.fc-home .ficon {
	width: 48px;
	height: 48px;
	border-radius: 11px;
	background: var(--navy);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: var(--blue3);
}

.fc-home .ftitle {
	font-size: 15.5px;
	font-weight: 800;
	color: var(--g900);
	margin-bottom: 7px;
	letter-spacing: -0.02em;
}

.fc-home .fdesc {
	font-size: 13px;
	color: var(--g500);
	line-height: 1.72;
}

.fc-home .flm {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	margin-top: 11px;
	font-size: 12px;
	font-weight: 700;
	color: var(--blue);
}

.fc-home a.fcard:hover .flm {
	gap: 9px;
}

/* CTA band */
.fc-home .home-cta.cta {
	background: linear-gradient(135deg, var(--blue), #1d4ed8);
	padding: 76px 0;
}

.fc-home .cta-in {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 48px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
	flex-wrap: wrap;
}

.fc-home .home-cta h2 {
	font-size: 36px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.04em;
	line-height: 1.2;
	max-width: 540px;
	margin: 0;
}

.fc-home .home-cta .btn--white {
	margin: 0;
}

/* —— About page (templates/page-about.php · fivecubes.html #pg-about) —— */
body.fc-about-page,
body.fc-focus-page {
	background: #fff;
	color: var(--g900);
}

.fc-page-about .ph,
.fc-page-focus .ph {
	background: var(--navy);
	padding: 68px 0 56px;
	position: relative;
	overflow: hidden;
}

.fc-page-about .ph::after,
.fc-page-focus .ph::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(90deg, var(--blue), var(--blue2), transparent);
}

.fc-page-about .ph-dots,
.fc-page-focus .ph-dots {
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(255, 255, 255, 0.06) 1.5px, transparent 1.5px);
	background-size: 32px 32px;
	pointer-events: none;
}

.fc-page-about .ph-orb,
.fc-page-focus .ph-orb {
	position: absolute;
	right: -60px;
	top: -60px;
	width: 280px;
	height: 280px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(37, 99, 235, 0.18) 0%, transparent 70%);
	pointer-events: none;
}

.fc-page-about .ph-in,
.fc-page-focus .ph-in {
	position: relative;
	z-index: 1;
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 48px;
}

.fc-page-about .bc,
.fc-page-focus .bc {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	color: rgba(255, 255, 255, 0.3);
	margin-bottom: 20px;
}

.fc-page-about .bc a,
.fc-page-focus .bc a {
	color: rgba(255, 255, 255, 0.3);
	transition: color 0.2s;
	text-decoration: none;
}

.fc-page-about .bc a:hover,
.fc-page-focus .bc a:hover {
	color: var(--blue3);
}

.fc-page-about .bc span,
.fc-page-focus .bc span {
	color: var(--blue3);
}

.fc-page-about .bc svg,
.fc-page-focus .bc svg {
	width: 12px;
	height: 12px;
	stroke: currentColor;
	fill: none;
	flex-shrink: 0;
}

.fc-page-about .ph h1,
.fc-page-focus .ph h1 {
	font-size: 44px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.04em;
	line-height: 1.12;
	margin: 0 0 14px;
}

.fc-page-about .ph > .ph-in > p,
.fc-page-focus .ph > .ph-in > p {
	font-size: 16px;
	color: rgba(255, 255, 255, 0.48);
	max-width: 560px;
	line-height: 1.8;
	margin: 0;
}

.fc-page-about .page-about-main.s {
	padding: 92px 0;
	background: #fff;
}

.fc-page-about .ct {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 48px;
}

.fc-page-about .about-lead {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 72px;
	align-items: start;
}

.fc-page-about .about-lead .lbl {
	font-size: 11.5px;
	font-weight: 700;
	color: var(--blue);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin-bottom: 10px;
}

.fc-page-about .about-lead .lbl--principles {
	margin-bottom: 14px;
	margin-top: 0;
}

.fc-page-about .about-lead .sh {
	font-size: 40px;
	font-weight: 800;
	color: var(--g900);
	letter-spacing: -0.035em;
	line-height: 1.1;
	margin: 0 0 14px;
}

.fc-page-about .about-lead__p {
	font-size: 15.5px;
	color: var(--g500);
	line-height: 1.88;
	margin: 0 0 16px;
}

.fc-page-about .about-lead__p--last {
	margin-bottom: 32px;
}

.fc-page-about .about-nums {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
	margin-bottom: 22px;
}

.fc-page-about .abox {
	background: var(--navy);
	border-radius: var(--r2);
	padding: 26px 22px;
}

.fc-page-about .abox-v {
	font-size: 40px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.04em;
	line-height: 1;
}

.fc-page-about .abox-v em {
	font-style: normal;
	background: linear-gradient(135deg, var(--blue2), var(--blue3));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

.fc-page-about .abox-l {
	font-size: 11px;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.35);
	margin-top: 6px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.fc-page-about .prlist {
	display: flex;
	flex-direction: column;
	gap: 11px;
	margin-top: 20px;
}

.fc-page-about .pri {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 14.5px;
	color: #334155;
	font-weight: 500;
}

.fc-page-about .pri::before {
	content: "";
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--blue);
	flex-shrink: 0;
}

.fc-page-about .two-col {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-top: 0;
}

.fc-page-about .info-card {
	background: var(--g50);
	border: 1px solid var(--g200);
	border-radius: var(--r2);
	padding: 24px;
}

.fc-page-about .info-card h4 {
	font-size: 14px;
	font-weight: 800;
	color: var(--g900);
	margin: 0 0 8px;
	letter-spacing: -0.01em;
}

.fc-page-about .info-card p {
	font-size: 13.5px;
	color: var(--g500);
	line-height: 1.7;
	margin: 0;
}

.fc-page-about .page-about-cta.home-cta.cta {
	background: linear-gradient(135deg, var(--blue), #1d4ed8);
	padding: 76px 0;
}

.fc-page-about .page-about-cta .cta-in {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 48px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
	flex-wrap: wrap;
}

.fc-page-about .page-about-cta h2 {
	font-size: 36px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.04em;
	line-height: 1.2;
	max-width: 540px;
	margin: 0;
}

.fc-page-about .page-about-cta .btn--white {
	margin: 0;
	background: #fff;
	color: var(--blue);
	border: none;
	border-radius: 8px;
	padding: 13px 26px;
	font-size: 13.5px;
	font-weight: 700;
	box-shadow: none;
}

.fc-page-about .page-about-cta .btn--white:hover {
	background: #eff6ff;
	color: var(--blue);
	filter: none;
}

.fc-page-about .page-about-cta .btn--white svg {
	stroke: var(--blue);
}

@media (max-width: 960px) {
	.fc-page-about .about-lead {
		grid-template-columns: 1fr;
		gap: 48px;
	}

	.fc-page-about .ph-in,
	.fc-page-about .ct,
	.fc-page-focus .ph-in,
	.fc-page-focus .ct {
		padding: 0 24px;
	}

	.fc-page-about .ph h1,
	.fc-page-focus .ph h1 {
		font-size: 32px;
	}

	.fc-page-about .page-about-cta .cta-in,
	.fc-page-focus .page-focus-cta .cta-in {
		padding: 0 24px;
	}
}

/* —— Focus Areas page (templates/page-focus-areas.php · fivecubes.html #pg-focus) —— */
.fc-page-focus .page-focus-main.s {
	padding: 92px 0;
	background: #fff;
}

.fc-page-focus .focus-detail {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
}

.fc-page-focus .fd2 {
	background: #fff;
	border: 1px solid var(--g200);
	border-radius: var(--r2);
	padding: 28px;
}

.fc-page-focus .fd2 .ficon {
	margin-bottom: 16px;
	color: var(--blue);
}

.fc-page-focus .fd2 h3 {
	font-size: 17px;
	font-weight: 800;
	color: var(--g900);
	margin: 0 0 10px;
	letter-spacing: -0.02em;
}

.fc-page-focus .fd2 p {
	font-size: 14px;
	color: var(--g500);
	line-height: 1.75;
	margin: 0 0 0;
}

.fc-page-focus .fd2 ul {
	margin-top: 12px;
	padding-left: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.fc-page-focus .fd2 ul li {
	font-size: 13.5px;
	color: var(--g500);
	display: flex;
	align-items: flex-start;
	gap: 9px;
}

.fc-page-focus .fd2 ul li::before {
	content: "";
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--blue);
	flex-shrink: 0;
	margin-top: 7px;
}

.fc-page-focus .fd2-more {
	display: inline-block;
	margin-top: 16px;
	font-size: 13.5px;
	font-weight: 700;
	color: var(--blue);
	text-decoration: none;
}

.fc-page-focus .fd2-more:hover {
	color: var(--blue2);
}

.fc-page-focus .page-focus-cta.home-cta.cta {
	background: linear-gradient(135deg, var(--blue), #1d4ed8);
	padding: 76px 0;
}

.fc-page-focus .page-focus-cta .cta-in {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 48px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
	flex-wrap: wrap;
}

.fc-page-focus .page-focus-cta h2 {
	font-size: 36px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.04em;
	line-height: 1.2;
	max-width: 540px;
	margin: 0;
}

.fc-page-focus .page-focus-cta .btn--white {
	margin: 0;
	background: #fff;
	color: var(--blue);
	border: none;
	border-radius: 8px;
	padding: 13px 26px;
	font-size: 13.5px;
	font-weight: 700;
	box-shadow: none;
}

.fc-page-focus .page-focus-cta .btn--white:hover {
	background: #eff6ff;
	color: var(--blue);
	filter: none;
}

.fc-page-focus .page-focus-cta .btn--white svg {
	stroke: var(--blue);
}

@media (max-width: 900px) {
	.fc-page-focus .focus-detail {
		grid-template-columns: 1fr;
	}
}

/* —— Universal service template (templates/page-service-single.php) —— */
body.fc-service-page {
	background: #fff;
	color: var(--g900);
}

.fc-service-single .service-hero.ph {
	background: var(--navy);
	padding: 68px 0 56px;
	position: relative;
	overflow: hidden;
}

.fc-service-single .service-hero.ph::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(90deg, var(--blue), var(--blue2), transparent);
}

.fc-service-single .ph-dots {
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(255, 255, 255, 0.06) 1.5px, transparent 1.5px);
	background-size: 32px 32px;
	pointer-events: none;
}

.fc-service-single .ph-orb {
	position: absolute;
	right: -60px;
	top: -60px;
	width: 280px;
	height: 280px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(37, 99, 235, 0.18) 0%, transparent 70%);
	pointer-events: none;
}

.fc-service-single .ph-in {
	position: relative;
	z-index: 1;
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 48px;
}

.fc-service-single .service-hero__back {
	display: inline-block;
	font-size: 13px;
	font-weight: 700;
	color: var(--blue3);
	margin-bottom: 16px;
	text-decoration: none;
	transition: opacity 0.18s;
}

.fc-service-single .service-hero__back:hover {
	opacity: 0.85;
	text-decoration: underline;
}

.fc-service-single .service-hero__bc.bc {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	color: rgba(255, 255, 255, 0.3);
	margin-bottom: 20px;
	flex-wrap: wrap;
}

.fc-service-single .service-hero__bc a {
	color: rgba(255, 255, 255, 0.3);
	text-decoration: none;
	transition: color 0.2s;
}

.fc-service-single .service-hero__bc a:hover {
	color: var(--blue3);
}

.fc-service-single .service-hero__bc span {
	color: var(--blue3);
}

.fc-service-single .service-hero__bc svg {
	width: 12px;
	height: 12px;
	stroke: currentColor;
	fill: none;
	flex-shrink: 0;
}

.fc-service-single .service-hero__title {
	font-size: 44px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.04em;
	line-height: 1.12;
	margin: 0 0 14px;
}

.fc-service-single .service-hero__lead {
	font-size: 16px;
	color: rgba(255, 255, 255, 0.48);
	max-width: 640px;
	line-height: 1.8;
	margin: 0;
}

.fc-service-single .service-body.s {
	padding: 92px 0;
	background: #fff;
}

.fc-service-single .ct {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 48px;
}

.fc-service-single .service-grid {
	display: grid;
	grid-template-columns: 1.15fr 0.85fr;
	gap: 56px;
	align-items: start;
}

.fc-service-single .service-grid__h {
	font-size: 22px;
	font-weight: 800;
	color: var(--g900);
	margin: 0 0 18px;
	letter-spacing: -0.02em;
}

.fc-service-single .service-grid__prose {
	font-size: 15.5px;
	color: var(--g500);
	line-height: 1.88;
}

.fc-service-single .service-grid__prose p {
	margin: 0 0 16px;
}

.fc-service-single .service-grid__aside {
	background: var(--g50);
	border: 1px solid var(--g200);
	border-radius: var(--r2);
	padding: 24px 26px;
	position: sticky;
	top: 96px;
}

.fc-service-single .service-grid__aside h3 {
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--blue);
	margin: 0 0 14px;
}

.fc-service-single .service-deliverables {
	margin: 0;
	padding-left: 1.1em;
	color: var(--g700);
	font-size: 14px;
	line-height: 1.65;
}

.fc-service-single .service-deliverables li {
	margin-bottom: 8px;
}

.fc-service-single .service-cta.home-cta.cta {
	background: linear-gradient(135deg, var(--blue), #1d4ed8);
	padding: 76px 0;
}

.fc-service-single .service-cta .cta-in {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 48px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
	flex-wrap: wrap;
}

.fc-service-single .service-cta h2 {
	font-size: 36px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.04em;
	line-height: 1.2;
	max-width: 540px;
	margin: 0;
}

.fc-service-single .service-cta .btn--white {
	margin: 0;
	background: #fff;
	color: var(--blue);
	border: none;
	border-radius: 8px;
	padding: 13px 26px;
	font-size: 13.5px;
	font-weight: 700;
	box-shadow: none;
}

.fc-service-single .service-cta .btn--white:hover {
	background: #eff6ff;
	color: var(--blue);
	filter: none;
}

.fc-service-single .service-cta .btn--white svg {
	stroke: var(--blue);
}

@media (max-width: 960px) {
	.fc-service-single .service-grid {
		grid-template-columns: 1fr;
	}

	.fc-service-single .service-grid__aside {
		position: static;
	}

	.fc-service-single .ph-in,
	.fc-service-single .ct {
		padding: 0 24px;
	}

	.fc-service-single .service-hero__title {
		font-size: 32px;
	}

	.fc-service-single .service-cta .cta-in {
		padding: 0 24px;
	}
}

/* —— Contact page (templates/page-contact.php) —— */
body.fc-contact-page {
	background: #fff;
	color: var(--g900);
}

.fc-contact .contact-hero.ph {
	background: var(--navy);
	padding: 68px 0 56px;
	position: relative;
	overflow: hidden;
}

.fc-contact .contact-hero.ph::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(90deg, var(--blue), var(--blue2), transparent);
}

.fc-contact .ph-dots {
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(255, 255, 255, 0.06) 1.5px, transparent 1.5px);
	background-size: 32px 32px;
	pointer-events: none;
}

.fc-contact .ph-orb {
	position: absolute;
	right: -60px;
	top: -60px;
	width: 280px;
	height: 280px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(37, 99, 235, 0.18) 0%, transparent 70%);
	pointer-events: none;
}

.fc-contact .ph-in {
	position: relative;
	z-index: 1;
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 48px;
}

.fc-contact .contact-hero__bc.bc {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	color: rgba(255, 255, 255, 0.3);
	margin-bottom: 20px;
	flex-wrap: wrap;
}

.fc-contact .contact-hero__bc a {
	color: rgba(255, 255, 255, 0.3);
	text-decoration: none;
}

.fc-contact .contact-hero__bc a:hover {
	color: var(--blue3);
}

.fc-contact .contact-hero__bc span {
	color: var(--blue3);
}

.fc-contact .contact-hero__bc svg {
	width: 12px;
	height: 12px;
	stroke: currentColor;
	fill: none;
}

.fc-contact .contact-hero__title {
	font-size: 44px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.04em;
	line-height: 1.12;
	margin: 0 0 14px;
}

.fc-contact .contact-hero__lead {
	font-size: 16px;
	color: rgba(255, 255, 255, 0.48);
	max-width: 560px;
	line-height: 1.8;
	margin: 0;
}

.fc-contact .contact-direct.s {
	padding: 72px 0 48px;
	background: #fff;
}

.fc-contact .contact-direct__in {
	max-width: 900px;
	margin: 0 auto;
	padding: 0 48px;
}

.fc-contact .contact-direct__h {
	font-size: 28px;
	font-weight: 800;
	color: var(--g900);
	margin: 0 0 10px;
	letter-spacing: -0.03em;
}

.fc-contact .contact-direct__lede {
	font-size: 16px;
	color: var(--g500);
	line-height: 1.75;
	margin: 0 0 28px;
}

.fc-contact .contact-direct__btn {
	margin-bottom: 48px;
}

.fc-contact .contact-ai-card {
	background: var(--g50);
	border: 1px solid var(--g200);
	border-radius: var(--r2);
	padding: 28px 32px;
}

.fc-contact .contact-ai-card h3 {
	font-size: 18px;
	font-weight: 800;
	color: var(--g900);
	margin: 0 0 10px;
	letter-spacing: -0.02em;
}

.fc-contact .contact-ai-card p {
	font-size: 14.5px;
	color: var(--g500);
	line-height: 1.7;
	margin: 0 0 18px;
}

.fc-contact .contact-cards {
	padding: 0 0 92px;
	background: #fff;
}

.fc-contact .contact-cards__grid {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 48px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

.fc-contact .contact-card {
	background: var(--g50);
	border: 1px solid var(--g200);
	border-radius: var(--r2);
	padding: 22px 24px;
}

.fc-contact .contact-card--link {
	display: block;
	text-decoration: none;
	color: inherit;
	transition: border-color 0.2s, box-shadow 0.2s;
}

.fc-contact .contact-card--link:hover {
	border-color: rgba(37, 99, 235, 0.35);
	box-shadow: 0 12px 40px rgba(7, 20, 40, 0.06);
}

.fc-contact .contact-card__label {
	font-size: 10.5px;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--blue);
	margin: 0 0 8px;
}

.fc-contact .contact-card__strong {
	font-size: 16px;
	font-weight: 700;
	color: var(--g900);
	margin: 0 0 6px;
}

.fc-contact .contact-card__meta {
	font-size: 13px;
	color: var(--blue);
	font-weight: 600;
	margin: 0;
}

.fc-contact .contact-card__inline {
	color: var(--blue);
	font-weight: 600;
	text-decoration: none;
}

.fc-contact .contact-card__inline:hover {
	text-decoration: underline;
}

@media (max-width: 900px) {
	.fc-contact .contact-cards__grid {
		grid-template-columns: 1fr;
	}

	.fc-contact .contact-direct__in,
	.fc-contact .contact-cards__grid {
		padding: 0 24px;
	}

	.fc-contact .contact-hero__title {
		font-size: 32px;
	}
}
