/*
 * Renew Co Contracting — Main Stylesheet
 * Design system + all non-critical styles
 *
 * Architecture:
 *   1. Self-hosted fonts (woff2)
 *   2. Typography & link styles
 *   3. Layout primitives (sections, containers, grid)
 *   4. Component library (buttons, cards, forms, etc.)
 *   5. Page-specific blocks (hero variants, service grid, reviews, FAQ, CTA, footer)
 *   6. Utility classes
 *   7. Responsive refinements
 *   8. Print
 */

/* ============================================================
 * 1. SELF-HOSTED FONTS
 * Fraunces (variable display) + Geist (variable body)
 * ============================================================ */

@font-face {
	font-family: 'Fraunces';
	src: url('../fonts/fraunces-variable.woff2') format('woff2-variations');
	font-weight: 100 900;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: 'Fraunces';
	src: url('../fonts/fraunces-italic-variable.woff2') format('woff2-variations');
	font-weight: 100 900;
	font-style: italic;
	font-display: swap;
}
@font-face {
	font-family: 'Geist';
	src: url('../fonts/geist-regular.woff2') format('woff2');
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: 'Geist';
	src: url('../fonts/geist-medium.woff2') format('woff2');
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: 'Geist';
	src: url('../fonts/geist-semibold.woff2') format('woff2');
	font-weight: 600;
	font-style: normal;
	font-display: swap;
}

/* ============================================================
 * 2. TYPOGRAPHY
 * ============================================================ */

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-display);
	font-weight: 400;
	line-height: 1.15;
	letter-spacing: -0.015em;
	color: var(--ink);
	margin: 0 0 var(--space-4);
}

h1 { font-size: clamp(2.25rem, 5.5vw, 4rem); line-height: 1.05; letter-spacing: -0.02em; }
h2 { font-size: clamp(1.875rem, 4vw, 2.75rem); }
h3 { font-size: clamp(1.5rem, 3vw, 2rem); }
h4 { font-size: var(--text-xl); }
h5 { font-size: var(--text-lg); }
h6 { font-size: var(--text-base); font-family: var(--font-body); font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; }

h1 em, h2 em, h3 em {
	font-style: italic;
	font-feature-settings: 'ss01';
	color: var(--accent);
}

p {
	margin: 0 0 var(--space-4);
}
p:last-child { margin-bottom: 0; }

.lede {
	font-size: var(--text-lg);
	line-height: 1.55;
	color: var(--ink-soft);
	max-width: 56ch;
}

.eyebrow {
	font-family: var(--font-mono);
	font-size: var(--text-xs);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--accent);
	margin-bottom: var(--space-3);
	display: inline-block;
}

a {
	color: var(--ink);
	text-decoration: underline;
	text-decoration-color: var(--line);
	text-underline-offset: 4px;
	transition: text-decoration-color var(--transition);
}
a:hover { text-decoration-color: var(--accent); }

.content a, .prose a {
	color: var(--accent);
	text-decoration-color: var(--accent-soft);
}
.content a:hover, .prose a:hover {
	text-decoration-color: var(--accent);
}

strong { font-weight: 600; }
em { font-style: italic; }

blockquote {
	border-left: 2px solid var(--accent);
	padding: var(--space-3) 0 var(--space-3) var(--space-5);
	margin: var(--space-6) 0;
	font-family: var(--font-display);
	font-size: var(--text-xl);
	line-height: 1.4;
	font-style: italic;
	color: var(--ink-soft);
}

hr {
	border: 0;
	border-top: 1px solid var(--line);
	margin: var(--space-7) 0;
}

::selection { background: var(--accent); color: var(--bg); }

/* ============================================================
 * 3. LAYOUT PRIMITIVES
 * ============================================================ */

main { display: block; min-height: 60vh; }

section {
	padding-top: clamp(3rem, 7vw, 6rem);
	padding-bottom: clamp(3rem, 7vw, 6rem);
}
section + section { padding-top: 0; }

.section--tinted { background: var(--bg-alt); }
.section--dark { background: var(--bg-dark); color: var(--bg); }
.section--dark h1, .section--dark h2, .section--dark h3 { color: var(--bg); }
.section--dark .lede { color: rgba(250,248,244,0.75); }

.section-header {
	max-width: 56ch;
	margin: 0 auto var(--space-7);
	text-align: center;
}
.section-header--left {
	text-align: left;
	margin-left: 0;
	margin-right: 0;
}

/* Grid */
.grid {
	display: grid;
	gap: var(--space-6);
}
.grid-2 { grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr)); }
.grid-3 { grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr)); }
.grid-4 { grid-template-columns: repeat(auto-fit, minmax(min(240px, 100%), 1fr)); }

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

/* Asymmetric magazine layout */
.split {
	display: grid;
	gap: var(--space-7);
	align-items: start;
}
@media (min-width: 900px) {
	.split--40-60 { grid-template-columns: 5fr 7fr; }
	.split--60-40 { grid-template-columns: 7fr 5fr; }
	.split--50-50 { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
 * 4. COMPONENT LIBRARY
 * ============================================================ */

/* Trust strip — sits below header on every page */
.trust-strip {
	background: var(--bg-alt);
	border-bottom: 1px solid var(--line);
	padding: var(--space-3) 0;
	font-size: var(--text-xs);
	letter-spacing: 0.02em;
}
.trust-strip__inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: var(--space-3) var(--space-6);
	color: var(--ink-soft);
}
.trust-strip__item {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	white-space: nowrap;
}
.trust-strip__item svg {
	width: 14px; height: 14px;
	color: var(--accent);
	flex-shrink: 0;
}
.trust-strip__item--review { color: var(--ink); font-weight: 500; }
.trust-strip__item a {
	text-decoration: none;
	color: inherit;
}
.trust-strip__item a:hover { color: var(--accent); }

/* Card */
.card {
	background: var(--bg);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	overflow: hidden;
	transition: all var(--transition);
	display: flex;
	flex-direction: column;
}
.card:hover {
	border-color: var(--accent);
	transform: translateY(-2px);
	box-shadow: 0 24px 48px -16px rgba(26, 31, 27, 0.08);
}
.card__media {
	aspect-ratio: 4 / 3;
	background: var(--bg-alt);
	overflow: hidden;
	position: relative;
}
.card__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 600ms var(--ease);
}
.card:hover .card__media img { transform: scale(1.04); }
.card__body {
	padding: var(--space-5);
	flex: 1;
	display: flex;
	flex-direction: column;
}
.card__eyebrow {
	font-family: var(--font-mono);
	font-size: var(--text-xs);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ink-muted);
	margin-bottom: var(--space-2);
}
.card__title {
	font-size: var(--text-xl);
	margin: 0 0 var(--space-3);
	line-height: 1.2;
}
.card__excerpt {
	color: var(--ink-soft);
	font-size: var(--text-sm);
	line-height: 1.6;
	margin: 0;
	flex: 1;
}
.card__footer {
	margin-top: var(--space-4);
	padding-top: var(--space-4);
	border-top: 1px solid var(--line);
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: var(--text-sm);
}
.card__cta {
	color: var(--accent);
	font-weight: 500;
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	text-decoration: none;
}
.card__cta::after {
	content: '→';
	transition: transform var(--transition);
}
.card:hover .card__cta::after { transform: translateX(4px); }

/* Forms */
.form-group { margin-bottom: var(--space-5); }
.form-label {
	display: block;
	font-size: var(--text-sm);
	font-weight: 500;
	margin-bottom: var(--space-2);
	color: var(--ink);
}
.form-label .required { color: var(--accent); }
.form-input,
.form-select,
.form-textarea {
	width: 100%;
	padding: var(--space-3) var(--space-4);
	background: var(--bg);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	font-family: inherit;
	font-size: var(--text-base);
	color: var(--ink);
	transition: border-color var(--transition), box-shadow var(--transition);
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
	outline: 0;
	border-color: var(--accent);
	box-shadow: 0 0 0 3px var(--accent-soft);
}
.form-textarea { min-height: 140px; resize: vertical; }
.form-help {
	margin-top: var(--space-2);
	font-size: var(--text-xs);
	color: var(--ink-muted);
}
.form-error {
	margin-top: var(--space-2);
	font-size: var(--text-xs);
	color: var(--error);
}
.form-row {
	display: grid;
	gap: var(--space-4);
}
@media (min-width: 640px) {
	.form-row--2 { grid-template-columns: 1fr 1fr; }
}

/* Tags / Pills */
.pill {
	display: inline-flex;
	align-items: center;
	padding: var(--space-1) var(--space-3);
	background: var(--accent-soft);
	color: var(--accent-deep);
	font-size: var(--text-xs);
	font-weight: 500;
	letter-spacing: 0.02em;
	border-radius: 999px;
	white-space: nowrap;
}

/* ============================================================
 * 5. PAGE-SPECIFIC BLOCKS
 * ============================================================ */

/* Hero variants */
.hero--editorial {
	padding-top: var(--space-9);
	padding-bottom: var(--space-9);
}
.hero--editorial .container {
	display: grid;
	gap: var(--space-7);
}
@media (min-width: 900px) {
	.hero--editorial .container {
		grid-template-columns: 7fr 5fr;
		align-items: center;
	}
}
.hero__visual {
	position: relative;
	aspect-ratio: 4 / 5;
	overflow: hidden;
	border-radius: var(--radius-lg);
	background: var(--bg-alt);
}
.hero__visual img {
	width: 100%; height: 100%;
	object-fit: cover;
}
.hero__decorative {
	position: absolute;
	font-family: var(--font-display);
	font-style: italic;
	font-size: clamp(8rem, 18vw, 16rem);
	color: var(--accent-soft);
	opacity: 0.4;
	z-index: -1;
	user-select: none;
	pointer-events: none;
}

/* Service grid block */
.service-grid {
	padding: var(--space-8) 0;
}
.service-grid__list {
	display: grid;
	gap: var(--space-5);
	grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr));
}
.service-card {
	display: flex;
	flex-direction: column;
	background: var(--bg);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: var(--space-6);
	text-decoration: none;
	color: var(--ink);
	transition: all var(--transition);
	position: relative;
	overflow: hidden;
}
.service-card::before {
	content: '';
	position: absolute;
	top: 0; left: 0;
	width: 0; height: 2px;
	background: var(--accent);
	transition: width 360ms var(--ease);
}
.service-card:hover {
	border-color: var(--accent);
	transform: translateY(-3px);
}
.service-card:hover::before { width: 100%; }
.service-card__icon {
	width: 48px; height: 48px;
	color: var(--accent);
	margin-bottom: var(--space-4);
}
.service-card__title {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	line-height: 1.2;
	margin: 0 0 var(--space-3);
}
.service-card__excerpt {
	color: var(--ink-soft);
	font-size: var(--text-sm);
	line-height: 1.6;
	margin: 0 0 var(--space-5);
	flex: 1;
}
.service-card__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	color: var(--accent);
	font-weight: 500;
	font-size: var(--text-sm);
}
.service-card__cta::after { content: '→'; transition: transform var(--transition); }
.service-card:hover .service-card__cta::after { transform: translateX(4px); }
.service-card__meta {
	font-family: var(--font-mono);
	font-size: var(--text-xs);
	color: var(--ink-muted);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin-bottom: var(--space-2);
}

/* Reviews block */
.reviews {
	padding: var(--space-8) 0;
}
.reviews__summary {
	text-align: center;
	margin-bottom: var(--space-7);
}
.reviews__rating {
	display: inline-flex;
	align-items: baseline;
	gap: var(--space-2);
	font-family: var(--font-display);
	font-size: var(--text-3xl);
	color: var(--ink);
	margin-bottom: var(--space-2);
}
.reviews__stars {
	color: var(--warm);
	letter-spacing: 0.1em;
	font-size: var(--text-2xl);
}
.reviews__count {
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--ink-soft);
}
.reviews__list {
	display: grid;
	gap: var(--space-5);
	grid-template-columns: repeat(auto-fit, minmax(min(320px, 100%), 1fr));
}
.review {
	background: var(--bg);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: var(--space-6);
	display: flex;
	flex-direction: column;
}
.review__rating {
	color: var(--warm);
	font-size: var(--text-base);
	letter-spacing: 0.05em;
	margin-bottom: var(--space-3);
}
.review__text {
	font-size: var(--text-sm);
	line-height: 1.65;
	color: var(--ink-soft);
	margin: 0 0 var(--space-5);
	flex: 1;
}
.review__author {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	padding-top: var(--space-4);
	border-top: 1px solid var(--line);
}
.review__avatar {
	width: 40px; height: 40px;
	border-radius: 50%;
	background: var(--bg-alt);
	color: var(--accent);
	font-family: var(--font-display);
	font-size: var(--text-base);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	overflow: hidden;
}
.review__avatar img { width: 100%; height: 100%; object-fit: cover; }
.review__name {
	font-weight: 500;
	font-size: var(--text-sm);
	color: var(--ink);
	display: block;
}
.review__date {
	font-size: var(--text-xs);
	color: var(--ink-muted);
}
.reviews__cta {
	margin-top: var(--space-7);
	text-align: center;
}

/* FAQ */
.faq {
	padding: var(--space-8) 0;
	background: var(--bg-alt);
}
.faq__heading {
	text-align: center;
	margin-bottom: var(--space-7);
}
.faq__list {
	max-width: 760px;
	margin: 0 auto;
}
.faq__item {
	border-bottom: 1px solid var(--line);
	padding: var(--space-4) 0;
}
.faq__item[open] { padding-bottom: var(--space-5); }
.faq__question {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-4);
	font-family: var(--font-display);
	font-size: var(--text-lg);
	line-height: 1.3;
	color: var(--ink);
	cursor: pointer;
	list-style: none;
	padding: var(--space-3) 0;
	transition: color var(--transition);
}
.faq__question::-webkit-details-marker { display: none; }
.faq__question:hover { color: var(--accent); }
.faq__chevron {
	width: 18px; height: 18px;
	transition: transform var(--transition);
	flex-shrink: 0;
	color: var(--accent);
}
.faq__item[open] .faq__chevron { transform: rotate(180deg); }
.faq__answer {
	color: var(--ink-soft);
	font-size: var(--text-base);
	line-height: 1.65;
	padding-top: var(--space-3);
	max-width: 70ch;
}

/* CTA block */
.cta-block {
	background: var(--accent);
	color: var(--bg);
	padding: var(--space-8) 0;
	text-align: center;
}
.cta-block__heading {
	color: var(--bg);
	font-size: clamp(2rem, 4vw, 3rem);
	margin-bottom: var(--space-4);
	max-width: 22ch;
	margin-left: auto;
	margin-right: auto;
}
.cta-block__text {
	font-size: var(--text-lg);
	color: rgba(250,248,244,0.85);
	max-width: 56ch;
	margin: 0 auto var(--space-6);
}
.cta-block__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-4);
	justify-content: center;
}
.cta-block .btn--primary {
	background: var(--bg);
	color: var(--accent-deep);
}
.cta-block .btn--primary:hover {
	background: var(--bg-alt);
	transform: translateY(-1px);
}
.cta-block .btn--ghost {
	border-color: rgba(250,248,244,0.3);
	color: var(--bg);
}
.cta-block .btn--ghost:hover {
	border-color: var(--bg);
}

/* Breadcrumbs */
.breadcrumbs {
	padding: var(--space-4) 0;
	font-size: var(--text-xs);
	letter-spacing: 0.02em;
	color: var(--ink-muted);
}
.breadcrumbs__list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
	align-items: center;
}
.breadcrumbs__item {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
}
.breadcrumbs__item a {
	color: var(--ink-soft);
	text-decoration: none;
	transition: color var(--transition);
}
.breadcrumbs__item a:hover { color: var(--accent); }
.breadcrumbs__separator {
	color: var(--ink-muted);
	font-size: var(--text-sm);
}
.breadcrumbs__item--current {
	color: var(--ink);
	font-weight: 500;
}

/* Footer */
.site-footer {
	background: var(--bg-dark);
	color: rgba(250,248,244,0.7);
	padding: var(--space-8) 0 var(--space-5);
	font-size: var(--text-sm);
}
.site-footer__top {
	display: grid;
	gap: var(--space-7);
	padding-bottom: var(--space-7);
	border-bottom: 1px solid rgba(250,248,244,0.1);
}
@media (min-width: 768px) {
	.site-footer__top {
		grid-template-columns: 2fr 1fr 1fr 1fr;
	}
}
.site-footer__brand h3 {
	font-family: var(--font-display);
	color: var(--bg);
	font-size: var(--text-2xl);
	margin: 0 0 var(--space-3);
}
.site-footer__brand p {
	color: rgba(250,248,244,0.6);
	max-width: 36ch;
	font-size: var(--text-sm);
	line-height: 1.6;
}
.site-footer__group-heading {
	font-family: var(--font-mono);
	font-size: var(--text-xs);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(250,248,244,0.5);
	margin-bottom: var(--space-4);
}
.site-footer__links {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}
.site-footer__links a {
	color: rgba(250,248,244,0.7);
	text-decoration: none;
	transition: color var(--transition);
	font-size: var(--text-sm);
}
.site-footer__links a:hover { color: var(--bg); }

.site-footer__contact {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}
.site-footer__contact a {
	color: rgba(250,248,244,0.85);
	text-decoration: none;
}
.site-footer__contact a:hover { color: var(--bg); }
.site-footer__contact strong { color: var(--bg); font-weight: 500; }

.site-footer__bottom {
	padding-top: var(--space-5);
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: var(--space-3);
	font-size: var(--text-xs);
	color: rgba(250,248,244,0.5);
}
.site-footer__bottom a {
	color: rgba(250,248,244,0.6);
	text-decoration: none;
}
.site-footer__bottom a:hover { color: var(--bg); }
.site-footer__legal-links {
	display: flex;
	gap: var(--space-5);
	flex-wrap: wrap;
}

/* Section: Process / numbered steps */
.process {
	padding: var(--space-8) 0;
}
.process__list {
	display: grid;
	gap: var(--space-6);
	counter-reset: step;
}
@media (min-width: 768px) {
	.process__list { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
	.process__list { grid-template-columns: repeat(4, 1fr); }
}
.process__step {
	position: relative;
	padding-top: var(--space-6);
	border-top: 1px solid var(--line);
}
.process__step::before {
	counter-increment: step;
	content: counter(step, decimal-leading-zero);
	font-family: var(--font-mono);
	font-size: var(--text-xs);
	letter-spacing: 0.1em;
	color: var(--accent);
	position: absolute;
	top: var(--space-3);
	left: 0;
}
.process__step h3 {
	font-size: var(--text-xl);
	margin: 0 0 var(--space-3);
	font-family: var(--font-display);
}
.process__step p {
	font-size: var(--text-sm);
	color: var(--ink-soft);
	line-height: 1.6;
}

/* Stat / metric block */
.stats {
	padding: var(--space-7) 0;
	background: var(--bg-alt);
}
.stats__list {
	display: grid;
	gap: var(--space-6);
	text-align: center;
}
@media (min-width: 640px) {
	.stats__list { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 900px) {
	.stats__list { grid-template-columns: repeat(4, 1fr); }
}
.stat__number {
	font-family: var(--font-display);
	font-size: clamp(2.5rem, 5vw, 4rem);
	color: var(--accent);
	line-height: 1;
	display: block;
	margin-bottom: var(--space-2);
}
.stat__label {
	font-size: var(--text-sm);
	color: var(--ink-soft);
	letter-spacing: 0.02em;
}

/* Page header (used on single posts, services, locations, etc.) */
.page-header {
	padding: var(--space-7) 0 var(--space-6);
	border-bottom: 1px solid var(--line);
}
.page-header__eyebrow {
	font-family: var(--font-mono);
	font-size: var(--text-xs);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--accent);
	margin-bottom: var(--space-3);
}
.page-header__title {
	max-width: 24ch;
	margin: 0 0 var(--space-4);
}
.page-header__subtitle {
	font-size: var(--text-lg);
	color: var(--ink-soft);
	max-width: 56ch;
	margin: 0;
	line-height: 1.55;
}
.page-header__meta {
	font-family: var(--font-mono);
	font-size: var(--text-xs);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--ink-muted);
	margin-top: var(--space-4);
	display: flex;
	gap: var(--space-5);
}

/* Prose / WYSIWYG content */
.prose {
	max-width: 70ch;
	font-size: var(--text-md);
	line-height: 1.7;
	color: var(--ink-soft);
}
.prose h2, .prose h3, .prose h4 {
	color: var(--ink);
	margin-top: var(--space-7);
	margin-bottom: var(--space-3);
}
.prose h2 { font-size: var(--text-2xl); }
.prose h3 { font-size: var(--text-xl); }
.prose ul, .prose ol {
	margin: 0 0 var(--space-5);
	padding-left: var(--space-5);
}
.prose ul { list-style: disc; }
.prose ol { list-style: decimal; }
.prose ul li, .prose ol li {
	margin-bottom: var(--space-2);
	padding-left: var(--space-1);
}
.prose img {
	border-radius: var(--radius);
	margin: var(--space-6) 0;
}
.prose figure {
	margin: var(--space-6) 0;
}
.prose figure figcaption {
	font-size: var(--text-sm);
	color: var(--ink-muted);
	text-align: center;
	margin-top: var(--space-3);
}

/* ============================================================
 * 6. UTILITY CLASSES
 * ============================================================ */

.text-center { text-align: center; }
.text-right  { text-align: right; }
.text-accent { color: var(--accent); }
.text-muted  { color: var(--ink-muted); }
.text-soft   { color: var(--ink-soft); }

.mb-0 { margin-bottom: 0 !important; }
.mb-3 { margin-bottom: var(--space-3); }
.mb-5 { margin-bottom: var(--space-5); }
.mb-7 { margin-bottom: var(--space-7); }

.mt-7 { margin-top: var(--space-7); }
.mt-8 { margin-top: var(--space-8); }

.flex { display: flex; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.gap-3 { gap: var(--space-3); }
.gap-4 { gap: var(--space-4); }
.gap-5 { gap: var(--space-5); }

.w-full { width: 100%; }

/* Animation utilities */
@keyframes renewco-fade-up {
	from { opacity: 0; transform: translateY(16px); }
	to { opacity: 1; transform: translateY(0); }
}
@keyframes renewco-fade-in {
	from { opacity: 0; }
	to { opacity: 1; }
}

.reveal {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 600ms var(--ease), transform 600ms var(--ease);
}
.reveal--visible {
	opacity: 1;
	transform: none;
}

/* ============================================================
 * 7. RESPONSIVE REFINEMENTS
 * ============================================================ */

/* Mobile menu */
.mobile-menu-toggle {
	display: inline-flex;
	width: 44px;
	height: 44px;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	color: var(--ink);
	transition: all var(--transition);
}
.mobile-menu-toggle:hover {
	background: var(--bg-alt);
}
.mobile-menu-toggle svg {
	width: 20px; height: 20px;
}
@media (min-width: 1024px) {
	.mobile-menu-toggle { display: none; }
}

.mobile-menu {
	position: fixed;
	top: 0; left: 0; right: 0; bottom: 0;
	background: var(--bg);
	z-index: 200;
	padding: var(--space-5);
	overflow-y: auto;
	transform: translateX(100%);
	transition: transform 360ms var(--ease);
	visibility: hidden;
}
.mobile-menu[aria-hidden="false"] {
	transform: translateX(0);
	visibility: visible;
}
.mobile-menu__close {
	position: absolute;
	top: var(--space-4);
	right: var(--space-5);
	width: 44px; height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.mobile-menu__list {
	margin-top: var(--space-9);
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}
.mobile-menu__list a {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	color: var(--ink);
	text-decoration: none;
	padding: var(--space-2) 0;
	border-bottom: 1px solid var(--line);
}
.mobile-menu__cta {
	margin-top: var(--space-7);
	padding-top: var(--space-5);
	border-top: 1px solid var(--line);
}

/* ============================================================
 * 8. PRINT
 * ============================================================ */

@media print {
	.site-header, .site-footer, .mobile-bar, .cta-block, .reviews, .breadcrumbs {
		display: none !important;
	}
	body { background: white; color: black; font-size: 11pt; }
	a { color: black; text-decoration: underline; }
	a[href]::after { content: " (" attr(href) ")"; font-size: 9pt; color: #555; }
}

/* Reduced motion */
@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;
	}
}





/* ============================================================
 * Blog Page
 * ============================================================ */
.grid {
  display: grid;
  gap: 2rem;
}

.grid-3 {
  grid-template-columns: repeat(3, 1fr);
}

/* Responsive: 2 columns on tablet, 1 on mobile */
@media (max-width: 1024px) {
  .grid-3 {
    grid-template-columns: repeat(2, 1fr);
  }
}

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




