/**
 * Civic Group — Track Record sections
 *
 * Scoped under .civic-track-record to prevent collisions with the
 * existing civic theme styles. Brand spec:
 *   Black  #0D0D0D
 *   White  #FDFFFC
 *   Blue   #3F8EFC
 *   Teal   #28C498
 *   Grays  #4D4D4D #999999 #D9D9D9
 *   Type   Figtree (Google Fonts), Arial fallback
 */

:root {
	--civic-black: #0D0D0D;
	--civic-white: #FDFFFC;
	--civic-blue:  #3F8EFC;
	--civic-teal:  #28C498;
	--civic-gray-dark:   #4D4D4D;
	--civic-gray-mid:    #999999;
	--civic-gray-light:  #D9D9D9;
}

.civic-track-record,
.civic-track-record * {
	box-sizing: border-box;
	font-family: "Figtree", Arial, sans-serif;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* The theme's existing .container handles width, centering, and side
   padding. We intentionally don't override it so all three Track
   Record blocks align with the rest of the page. */

/* ------------------------------------------------------------------ */
/* Homepage band                                                      */
/* ------------------------------------------------------------------ */

.civic-track-record--homepage {
	background-color: var(--civic-black);
	color: var(--civic-white);
	padding: 96px 0 72px;
	margin-bottom: 80px;
}

.civic-track-record__eyebrow {
	font-size: 13px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	font-weight: 600;
	color: var(--civic-blue);
	margin: 0 0 20px;
}

.civic-track-record__eyebrow--dark {
	color: var(--civic-black);
}

.civic-track-record__headline {
	font-size: 44px;
	line-height: 1.15;
	font-weight: 700;
	letter-spacing: -0.01em;
	color: var(--civic-white);
	margin: 0 0 24px;
	max-width: 920px;
}

.civic-track-record__lede {
	font-size: 18px;
	line-height: 1.55;
	color: var(--civic-gray-light);
	margin: 0 0 56px;
	max-width: 780px;
}

/* Homepage hero image strip — large images between lede and stats.
   Supports 1 to 4 images side by side; falls to 2-up then 1-up on
   smaller viewports. */
.civic-track-record__hero-strip {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px;
	margin: 0 0 64px;
}

/* Single image renders as a smaller supporting visual rather than a
   full-width hero. Right-aligned so the headline and lede on the left
   keep visual lead. */
.civic-track-record__hero-strip[data-count="1"] {
	grid-template-columns: 1fr;
	max-width: 420px;
	margin: 0 0 56px auto;
}

.civic-track-record__hero-strip[data-count="3"],
.civic-track-record__hero-strip[data-count="4"] {
	grid-template-columns: repeat(2, 1fr);
}

.civic-track-record__hero-figure {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.civic-track-record__hero-figure-media {
	position: relative;
	overflow: hidden;
	border-radius: 4px;
	aspect-ratio: 16 / 10;
	background-color: var(--civic-gray-dark);
}

.civic-track-record__hero-figure-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.civic-track-record__hero-caption {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.civic-track-record__hero-caption-title {
	font-size: 16px;
	font-weight: 600;
	color: var(--civic-white);
	letter-spacing: -0.005em;
}

.civic-track-record__hero-caption-sub {
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--civic-gray-mid);
}

.civic-track-record__stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 48px;
	margin-bottom: 56px;
	padding-bottom: 56px;
	border-bottom: 1px solid rgba(253, 255, 252, 0.12);
}

.civic-track-record__stat {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.civic-track-record__stat-number {
	font-size: 56px;
	line-height: 1;
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--civic-white);
}

.civic-track-record__stat-label {
	font-size: 14px;
	line-height: 1.45;
	color: var(--civic-gray-mid);
	max-width: 280px;
}

.civic-track-record__cta {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 15px;
	font-weight: 600;
	letter-spacing: 0.01em;
	color: var(--civic-white);
	text-decoration: none;
	padding-bottom: 4px;
	border-bottom: 1px solid var(--civic-white);
	transition: gap 180ms ease, color 180ms ease, border-color 180ms ease;
}

.civic-track-record__cta:hover,
.civic-track-record__cta:focus-visible {
	gap: 16px;
	color: var(--civic-blue);
	border-bottom-color: var(--civic-blue);
}

.civic-track-record__cta--dark {
	color: var(--civic-black);
	border-bottom-color: var(--civic-black);
}

.civic-track-record__cta--dark:hover,
.civic-track-record__cta--dark:focus-visible {
	color: var(--civic-blue);
	border-bottom-color: var(--civic-blue);
}

.civic-track-record__cta-arrow {
	font-size: 18px;
	line-height: 1;
	transform: translateY(-1px);
}

/* ------------------------------------------------------------------ */
/* Portfolio Track Record section                                     */
/* ------------------------------------------------------------------ */

.civic-track-record--portfolio {
	background-color: var(--civic-white);
	color: var(--civic-black);
	padding: 72px 0 96px;
	border-top: 1px solid var(--civic-gray-light);
	margin-top: 80px;
}

.civic-track-record__header {
	max-width: 720px;
	margin: 0 0 48px;
}

/* Tuned down from a hero-scale title (52px) to a subsection scale.
   This block sits below the active project grid as supporting context,
   not a competing page-level section. */
.civic-track-record__section-title {
	font-size: 32px;
	line-height: 1.2;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--civic-black);
	margin: 0 0 16px;
}

.civic-track-record__eyebrow--dark {
	font-size: 12px;
	margin: 0 0 14px;
}

.civic-track-record__section-lede {
	font-size: 16px;
	line-height: 1.55;
	color: var(--civic-gray-dark);
	margin: 0;
}

.civic-track-record__projects {
	display: flex;
	flex-direction: column;
	gap: 80px;
}

.civic-track-record__card {
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: 56px;
	align-items: start;
}

.civic-track-record__card:nth-child(even) {
	grid-template-columns: 1fr 1.05fr;
}

.civic-track-record__card:nth-child(even) .civic-track-record__card-media {
	order: 2;
}

.civic-track-record__card:nth-child(even) .civic-track-record__card-body {
	order: 1;
}

.civic-track-record__card-media {
	position: relative;
	overflow: hidden;
	border-radius: 4px;
	aspect-ratio: 16 / 10;
	background-color: var(--civic-gray-light);
}

.civic-track-record__card-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.civic-track-record__card-media--placeholder {
	background: linear-gradient(135deg, #1a3a5c 0%, #2a5d8c 50%, #3F8EFC 100%);
}

.civic-track-record__card-body {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.civic-track-record__card-head {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.civic-track-record__card-name {
	font-size: 36px;
	line-height: 1.1;
	font-weight: 700;
	letter-spacing: -0.01em;
	color: var(--civic-black);
	margin: 0;
}

.civic-track-record__card-name a {
	color: inherit;
	text-decoration: none;
	border-bottom: 2px solid transparent;
	transition: border-color 180ms ease;
}

.civic-track-record__card-name a:hover {
	border-bottom-color: var(--civic-blue);
}

.civic-track-record__card-location {
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--civic-gray-mid);
	margin: 0;
}

.civic-track-record__card-tags {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.civic-track-record__card-tag {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--civic-gray-dark);
	background-color: var(--civic-gray-light);
	padding: 6px 12px;
	border-radius: 2px;
}

.civic-track-record__card-description {
	font-size: 16px;
	line-height: 1.6;
	color: var(--civic-gray-dark);
	margin: 0;
}

.civic-track-record__card-role {
	font-size: 15px;
	line-height: 1.6;
	color: var(--civic-gray-dark);
	margin: 0;
	padding: 16px 0 0;
	border-top: 1px solid var(--civic-gray-light);
}

.civic-track-record__card-role-label {
	display: inline;
	font-weight: 700;
	color: var(--civic-black);
	margin-right: 4px;
}

.civic-track-record__card-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	padding: 20px 0;
	border-top: 1px solid var(--civic-gray-light);
	border-bottom: 1px solid var(--civic-gray-light);
}

.civic-track-record__card-stat {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.civic-track-record__card-stat-number {
	font-size: 28px;
	line-height: 1;
	font-weight: 700;
	letter-spacing: -0.01em;
	color: var(--civic-black);
}

.civic-track-record__card-stat-label {
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--civic-gray-mid);
}

.civic-track-record__card-attribution {
	font-size: 13px;
	line-height: 1.5;
	color: var(--civic-gray-mid);
	margin: 0;
	font-style: italic;
}

.civic-track-record__continue {
	margin-top: 96px;
	padding-top: 56px;
	border-top: 1px solid var(--civic-gray-light);
	display: flex;
	justify-content: flex-start;
}

/* ------------------------------------------------------------------ */
/* About page bio paragraphs                                          */
/* ------------------------------------------------------------------ */

.civic-track-record--founder-bio {
	max-width: 760px;
}

.civic-track-record__bio-paragraph {
	font-size: 18px;
	line-height: 1.65;
	color: var(--civic-gray-dark);
	margin: 0 0 20px;
}

.civic-track-record__bio-paragraph:last-child {
	margin-bottom: 0;
}

/* ------------------------------------------------------------------ */
/* About page Experience timeline                                     */
/* ------------------------------------------------------------------ */

.civic-track-record--timeline {
	background-color: var(--civic-white);
	color: var(--civic-black);
	padding: 96px 0 120px;
}

/* Horizontal scrolling timeline. Markers along a single row, connected
   by a horizontal line. Cards have fixed width; container scrolls on
   overflow so the layout never breaks regardless of milestone count. */
.civic-track-record__timeline-scroll {
	overflow-x: auto;
	overflow-y: hidden;
	-webkit-overflow-scrolling: touch;
	scroll-snap-type: x proximity;
	margin: 0 -24px;
	padding: 0 24px 24px;
	scrollbar-width: thin;
	scrollbar-color: var(--civic-gray-mid) transparent;
}

.civic-track-record__timeline-scroll::-webkit-scrollbar {
	height: 6px;
}

.civic-track-record__timeline-scroll::-webkit-scrollbar-track {
	background: transparent;
}

.civic-track-record__timeline-scroll::-webkit-scrollbar-thumb {
	background-color: var(--civic-gray-light);
	border-radius: 3px;
}

.civic-track-record__timeline {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: 32px;
	min-width: max-content;
	position: relative;
}

/* Each card is a flex column: image, marker row, body. Every card has
   the image area regardless of whether an image is set. Era cards (no
   image) render a brand-colored solid in the image slot so the row
   stays uniform and the metadata aligns horizontally. */
.civic-track-record__milestone {
	flex: 0 0 280px;
	scroll-snap-align: start;
	display: flex;
	flex-direction: column;
}

.civic-track-record__milestone-image {
	aspect-ratio: 16 / 10;
	overflow: hidden;
	border-radius: 4px;
	background-color: var(--civic-gray-light);
}

.civic-track-record__milestone--era .civic-track-record__milestone-image {
	background-color: var(--civic-black);
}

.civic-track-record__milestone-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 320ms ease;
}

.civic-track-record__milestone--has-image:hover .civic-track-record__milestone-image img,
.civic-track-record__milestone--has-image:focus-within .civic-track-record__milestone-image img {
	transform: scale(1.04);
}

/* Marker row: sits between the image and the body. The connecting line
   passes through the vertical center of this row, drawn as a
   pseudo-element that extends from this card's marker into the next
   card. Last card draws no line. */
.civic-track-record__milestone-marker-row {
	position: relative;
	height: 16px;
	margin: 20px 0 16px;
}

.civic-track-record__milestone-marker-row::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 8px;
	right: -32px;
	height: 1px;
	background-color: var(--civic-gray-light);
	transform: translateY(-50%);
}

.civic-track-record__milestone:last-child .civic-track-record__milestone-marker-row::before {
	display: none;
}

.civic-track-record__milestone-marker {
	position: absolute;
	left: 0;
	top: 0;
	width: 16px;
	height: 16px;
	border-radius: 50%;
	background-color: var(--civic-black);
	border: 3px solid var(--civic-white);
	box-shadow: 0 0 0 1px var(--civic-black);
	z-index: 1;
}

.civic-track-record__milestone-year {
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--civic-blue);
	margin: 0 0 8px;
}

.civic-track-record__milestone-title {
	font-size: 22px;
	line-height: 1.2;
	font-weight: 700;
	letter-spacing: -0.005em;
	color: var(--civic-black);
	margin: 0 0 12px;
}

.civic-track-record__milestone-title a {
	color: inherit;
	text-decoration: none;
	border-bottom: 2px solid transparent;
	transition: border-color 180ms ease;
}

.civic-track-record__milestone-title a:hover {
	border-bottom-color: var(--civic-blue);
}

.civic-track-record__milestone-description {
	font-size: 15px;
	line-height: 1.55;
	color: var(--civic-gray-dark);
	margin: 0;
}

/* ------------------------------------------------------------------ */
/* Responsive                                                         */
/* ------------------------------------------------------------------ */

@media (max-width: 960px) {
	.civic-track-record--homepage,
	.civic-track-record--portfolio,
	.civic-track-record--timeline {
		padding: 72px 0;
	}

	.civic-track-record__headline {
		font-size: 32px;
	}

	.civic-track-record__section-title {
		font-size: 26px;
	}

	.civic-track-record__stats {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.civic-track-record__stat-number {
		font-size: 44px;
	}

	.civic-track-record__hero-strip,
	.civic-track-record__hero-strip[data-count="3"],
	.civic-track-record__hero-strip[data-count="4"] {
		grid-template-columns: 1fr;
		gap: 20px;
	}

	.civic-track-record__card,
	.civic-track-record__card:nth-child(even) {
		grid-template-columns: 1fr;
		gap: 28px;
	}

	.civic-track-record__card:nth-child(even) .civic-track-record__card-media {
		order: 0;
	}

	.civic-track-record__card:nth-child(even) .civic-track-record__card-body {
		order: 0;
	}

	.civic-track-record__card-name {
		font-size: 28px;
	}

	.civic-track-record__card-stats {
		grid-template-columns: repeat(3, 1fr);
		gap: 16px;
	}

	.civic-track-record__card-stat-number {
		font-size: 22px;
	}

	.civic-track-record__milestone {
		flex: 0 0 240px;
	}

	.civic-track-record__milestone-title {
		font-size: 20px;
	}
}

@media (max-width: 560px) {
	.civic-track-record__card-stats {
		grid-template-columns: 1fr;
	}

	.civic-track-record__milestone {
		flex: 0 0 220px;
	}
}

/* ------------------------------------------------------------------ */
/* Portfolio Featured Hero (Beatty Integration)                       */
/* ------------------------------------------------------------------ */

.civic-portfolio-featured {
	padding: 72px 0 32px;
	background-color: var(--civic-white);
	font-family: "Figtree", Arial, sans-serif;
}

.civic-portfolio-featured__layout {
	display: grid;
	grid-template-columns: 1.15fr 1fr;
	gap: 56px;
	align-items: center;
}

.civic-portfolio-featured__image {
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	border-radius: 4px;
	background-color: var(--civic-gray-light);
	position: relative;
}

.civic-portfolio-featured__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 320ms ease;
}

.civic-portfolio-featured__image:hover img,
.civic-portfolio-featured__image:focus-visible img {
	transform: scale(1.03);
}

.civic-portfolio-featured__body {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.civic-portfolio-featured__eyebrow {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--civic-blue);
	margin: 0;
}

.civic-portfolio-featured__title {
	font-size: 42px;
	line-height: 1.1;
	font-weight: 700;
	letter-spacing: -0.01em;
	color: var(--civic-black);
	margin: 0;
}

.civic-portfolio-featured__title a {
	color: inherit;
	text-decoration: none;
	border-bottom: 2px solid transparent;
	transition: border-color 180ms ease;
}

.civic-portfolio-featured__title a:hover {
	border-bottom-color: var(--civic-blue);
}

.civic-portfolio-featured__location {
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--civic-gray-mid);
	margin: 0;
}

.civic-portfolio-featured__categories {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.civic-portfolio-featured__categories li {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--civic-gray-dark);
	background-color: var(--civic-gray-light);
	padding: 6px 12px;
	border-radius: 2px;
}

.civic-portfolio-featured__tagline {
	font-size: 17px;
	line-height: 1.55;
	color: var(--civic-gray-dark);
	margin: 0;
}

.civic-portfolio-featured__cta {
	align-self: flex-start;
	margin-top: 8px;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 15px;
	font-weight: 600;
	color: var(--civic-black);
	text-decoration: none;
	padding-bottom: 4px;
	border-bottom: 1px solid var(--civic-black);
	transition: gap 180ms ease, color 180ms ease, border-color 180ms ease;
}

.civic-portfolio-featured__cta:hover,
.civic-portfolio-featured__cta:focus-visible {
	gap: 16px;
	color: var(--civic-blue);
	border-bottom-color: var(--civic-blue);
}

.civic-portfolio-featured__cta-arrow {
	font-size: 18px;
	transform: translateY(-1px);
}

/* ------------------------------------------------------------------ */
/* Project status badge — appears on portfolio cards and the          */
/* featured hero when a project_status ACF value is set.              */
/* ------------------------------------------------------------------ */

.loop-portfolio__status,
.civic-portfolio-featured__status {
	display: inline-block;
	font-family: "Figtree", Arial, sans-serif;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 5px 10px 4px;
	border-radius: 999px;
	background-color: var(--civic-gray-light);
	color: var(--civic-gray-dark);
	line-height: 1;
}

.loop-portfolio__status[data-status="under-construction"],
.civic-portfolio-featured__status[data-status="under-construction"] {
	background-color: rgba(243, 146, 55, 0.16);
	color: #8C4A00;
}

.loop-portfolio__status[data-status="built"],
.loop-portfolio__status[data-status="operating"],
.civic-portfolio-featured__status[data-status="built"],
.civic-portfolio-featured__status[data-status="operating"] {
	background-color: rgba(40, 196, 152, 0.16);
	color: #0F6A48;
}

.loop-portfolio__status[data-status="in-pre-development"],
.civic-portfolio-featured__status[data-status="in-pre-development"] {
	background-color: rgba(63, 142, 252, 0.14);
	color: #1F4E96;
}

.loop-portfolio__status[data-status="concept"],
.civic-portfolio-featured__status[data-status="concept"] {
	background-color: rgba(134, 22, 87, 0.12);
	color: #6E1147;
}

.loop-portfolio__status {
	margin: 10px 0 0;
}

.civic-portfolio-featured__status {
	align-self: flex-start;
}

@media (max-width: 960px) {
	.civic-portfolio-featured {
		padding: 56px 0 24px;
	}
	.civic-portfolio-featured__layout {
		grid-template-columns: 1fr;
		gap: 28px;
	}
	.civic-portfolio-featured__title {
		font-size: 30px;
	}
}
