/* =================================================================
 * Advocate — Custom Theme for Banner Law Group
 * Editorial, plaintiff-side, California employment law
 * ================================================================= */

/* ---------- 1. Design tokens ------------------------------------ */
:root {
	/* Color — blue / black / white */
	--c-bg:          #f8fafc;          /* near-white with faint cool cast */
	--c-bg-alt:      #f1f5f9;          /* slate-100, slightly bluer for footer */
	--c-bg-paper:    #ffffff;          /* pure white for elevated surfaces */
	--c-ink:         #0a0e1a;          /* near-black with blue undertone */
	--c-ink-soft:    #1e293b;          /* slate-800 */
	--c-muted:       #475569;          /* slate-600 */
	--c-muted-soft:  #94a3b8;          /* slate-400 — readable on dark bg too */
	--c-line:        #cbd5e1;          /* slate-300 hairline */
	--c-line-soft:   #e2e8f0;          /* slate-200 */
	--c-accent:      #1e40af;          /* blue-800, the primary blue */
	--c-accent-deep: #1e3a8a;          /* blue-900 */
	--c-accent-soft: #60a5fa;          /* blue-400 — for use on dark bg */
	--c-sage:        #0e7490;          /* cyan-700 — secondary accent (mediation) */

	/* Typography */
	--f-display: 'Fraunces', 'Cormorant Garamond', 'Iowan Old Style', 'Palatino Linotype', Georgia, serif;
	--f-body:    'Manrope', 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;

	--fs-xs:  0.75rem;
	--fs-sm:  0.875rem;
	--fs-base: 1rem;
	--fs-md:  1.125rem;
	--fs-lg:  1.25rem;
	--fs-xl:  1.5rem;
	--fs-2xl: 2rem;
	--fs-3xl: 2.75rem;
	--fs-4xl: 3.75rem;
	--fs-5xl: clamp(3rem, 7vw, 5.75rem);

	/* Spacing */
	--s-1: 0.25rem;
	--s-2: 0.5rem;
	--s-3: 0.75rem;
	--s-4: 1rem;
	--s-5: 1.5rem;
	--s-6: 2rem;
	--s-7: 3rem;
	--s-8: 4rem;
	--s-9: 6rem;
	--s-10: 8rem;

	/* Layout */
	--container: 1280px;
	--container-narrow: 880px;
	--radius: 2px;
	--radius-lg: 8px;

	/* Misc */
	--shadow-soft: 0 1px 2px rgba(10, 14, 26, 0.04), 0 8px 24px rgba(10, 14, 26, 0.06);
	--shadow-lift: 0 2px 6px rgba(10, 14, 26, 0.06), 0 24px 48px rgba(10, 14, 26, 0.10);
	--ease: cubic-bezier(0.2, 0.7, 0.2, 1);
}

/* ---------- 2. Reset / base ------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	margin: 0;
	background: var(--c-bg);
	color: var(--c-ink);
	font-family: var(--f-body);
	font-size: var(--fs-base);
	line-height: 1.6;
	font-feature-settings: "kern", "liga", "ss01";
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

/* Subtle paper grain */
body::before {
	content: "";
	position: fixed;
	inset: 0;
	pointer-events: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.04 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
	opacity: 0.7;
	z-index: 1;
	mix-blend-mode: multiply;
}
body > * { position: relative; z-index: 2; }

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

a { color: var(--c-ink); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 4px; text-decoration-color: var(--c-line); transition: color 200ms var(--ease), text-decoration-color 200ms var(--ease); }
a:hover { color: var(--c-accent); text-decoration-color: var(--c-accent); }

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

h1, h2, h3, h4 { font-family: var(--f-display); font-weight: 400; color: var(--c-ink); line-height: 1.05; margin: 0 0 var(--s-4); font-variation-settings: "opsz" 144, "SOFT" 30; letter-spacing: -0.015em; }
h1 { font-size: var(--fs-4xl); }
h2 { font-size: var(--fs-3xl); }
h3 { font-size: var(--fs-xl); }
p  { margin: 0 0 var(--s-4); }

.screen-reader-text { position: absolute; clip: rect(1px, 1px, 1px, 1px); width: 1px; height: 1px; overflow: hidden; }
.skip-link {
	position: absolute; left: -9999px;
	background: var(--c-ink); color: var(--c-bg);
	padding: var(--s-3) var(--s-5); z-index: 100;
}
.skip-link:focus { left: var(--s-5); top: var(--s-5); }

/* ---------- 3. Buttons / shared ---------------------------------- */
.btn {
	display: inline-flex; align-items: center; gap: var(--s-2);
	padding: 0.95rem 1.5rem;
	border: 1px solid var(--c-ink);
	background: var(--c-ink); color: var(--c-bg-paper);
	font-family: var(--f-body); font-weight: 600; font-size: var(--fs-sm);
	letter-spacing: 0.02em; text-transform: uppercase;
	text-decoration: none;
	cursor: pointer;
	transition: transform 200ms var(--ease), background 200ms var(--ease), color 200ms var(--ease), border-color 200ms var(--ease);
}
.btn:hover { background: var(--c-accent); border-color: var(--c-accent); color: var(--c-bg-paper); transform: translateY(-1px); }
.btn-primary { background: var(--c-accent); border-color: var(--c-accent); color: var(--c-bg-paper); }
.btn-primary:hover { background: var(--c-accent-deep); border-color: var(--c-accent-deep); color: var(--c-bg-paper); }
.btn-ghost { background: transparent; color: var(--c-ink); }
.btn-ghost:hover { background: var(--c-ink); color: var(--c-bg-paper); }
.btn-lg { padding: 1.1rem 1.75rem; font-size: var(--fs-base); }
.btn-sm { padding: 0.625rem 1rem; font-size: var(--fs-xs); }

.link-arrow {
	display: inline-flex; align-items: center; gap: var(--s-2);
	font-weight: 600; font-size: var(--fs-sm);
	letter-spacing: 0.04em; text-transform: uppercase;
	text-decoration: none;
	border-bottom: 1px solid var(--c-ink);
	padding-bottom: 2px;
	transition: gap 200ms var(--ease), color 200ms var(--ease);
}
.link-arrow:hover { gap: var(--s-3); color: var(--c-accent); border-color: var(--c-accent); }

.section-eyebrow {
	display: inline-flex; align-items: center; gap: var(--s-3);
	font-size: var(--fs-xs); font-weight: 600;
	letter-spacing: 0.18em; text-transform: uppercase;
	color: var(--c-muted);
	margin: 0 0 var(--s-5);
}
.section-eyebrow::before { content: ""; width: 32px; height: 1px; background: var(--c-muted); }

.section-title { font-size: var(--fs-3xl); max-width: 22ch; }
.section-lede { font-size: var(--fs-md); color: var(--c-muted); max-width: 56ch; line-height: 1.5; }

.adv-icon { display: inline-block; vertical-align: middle; flex-shrink: 0; }

/* ---------- 4. Header ------------------------------------------- */
.site-header {
	position: sticky; top: 0; z-index: 50;
	background: rgba(248, 250, 252, 0.85);
	backdrop-filter: saturate(180%) blur(10px);
	-webkit-backdrop-filter: saturate(180%) blur(10px);
	border-bottom: 1px solid var(--c-line);
}
.site-header__inner {
	max-width: var(--container);
	margin: 0 auto;
	padding: var(--s-4) var(--s-6);
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: var(--s-6);
	align-items: center;
}
.site-header__brand .custom-logo-link { display: block; }
.site-header__brand .custom-logo { max-height: 48px; width: auto; }
.site-header__title { text-decoration: none; }
.site-header__title-mark {
	font-family: var(--f-display);
	font-weight: 500;
	font-size: var(--fs-xl);
	letter-spacing: -0.02em;
	font-variation-settings: "opsz" 9, "SOFT" 50;
}

.site-nav { justify-self: center; }
.site-nav__menu {
	display: flex; gap: var(--s-7);
	list-style: none; margin: 0; padding: 0;
}
.site-nav__menu a {
	font-size: var(--fs-sm);
	font-weight: 500;
	letter-spacing: 0.02em;
	text-decoration: none;
	color: var(--c-ink);
	padding: var(--s-2) 0;
	position: relative;
}
.site-nav__menu a::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: -2px;
	height: 1px; background: var(--c-accent);
	transform: scaleX(0); transform-origin: left;
	transition: transform 250ms var(--ease);
}
.site-nav__menu a:hover::after,
.site-nav__menu .current-menu-item > a::after,
.site-nav__menu .current_page_item > a::after { transform: scaleX(1); }
.site-nav__menu .sub-menu { display: none; }

.site-nav__toggle {
	display: none;
	background: transparent; border: none;
	color: var(--c-ink); cursor: pointer;
	padding: var(--s-2);
	font-family: var(--f-body); font-size: var(--fs-sm);
	letter-spacing: 0.04em; text-transform: uppercase;
	align-items: center; gap: var(--s-2);
}
.site-nav__toggle-bars { display: inline-flex; flex-direction: column; gap: 4px; }
.site-nav__toggle-bars span { display: block; width: 22px; height: 1.5px; background: var(--c-ink); }

.site-header__cta { display: flex; align-items: center; gap: var(--s-5); }
.site-header__phone {
	display: inline-flex; align-items: center; gap: var(--s-2);
	font-size: var(--fs-sm); font-weight: 600; text-decoration: none;
	color: var(--c-ink);
}
.site-header__phone:hover { color: var(--c-accent); }

@media (max-width: 960px) {
	.site-header__inner { grid-template-columns: 1fr auto; }
	.site-nav { order: 3; grid-column: 1 / -1; }
	.site-nav__toggle { display: inline-flex; }
	.site-nav__menu {
		display: none;
		flex-direction: column;
		gap: var(--s-3);
		padding: var(--s-4) 0;
		border-top: 1px solid var(--c-line);
		margin-top: var(--s-3);
	}
	.site-nav.is-open .site-nav__menu { display: flex; }
	.site-nav__menu a { font-size: var(--fs-md); }
	.site-header__cta .btn { display: none; }
}

/* ---------- 5. Hero --------------------------------------------- */
.hero {
	position: relative;
	overflow: hidden;
	border-bottom: 1px solid var(--c-line);
}
.hero__inner {
	max-width: var(--container);
	margin: 0 auto;
	padding: var(--s-10) var(--s-6) var(--s-9);
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--s-5);
	position: relative;
	z-index: 2;
}
.hero__eyebrow {
	display: inline-flex; align-items: center; gap: var(--s-3);
	font-size: var(--fs-xs); font-weight: 600;
	letter-spacing: 0.18em; text-transform: uppercase;
	color: var(--c-accent);
	margin: 0;
	animation: rise 700ms var(--ease) both;
}
.hero__eyebrow-dot {
	width: 8px; height: 8px; border-radius: 50%;
	background: var(--c-accent);
	box-shadow: 0 0 0 4px rgba(30, 64, 175, 0.15);
	animation: pulse 2.5s ease-in-out infinite;
}
@keyframes pulse {
	0%, 100% { box-shadow: 0 0 0 4px rgba(30, 64, 175, 0.15); }
	50%      { box-shadow: 0 0 0 8px rgba(30, 64, 175, 0.05); }
}
.hero__headline {
	font-family: var(--f-display);
	font-size: var(--fs-5xl);
	line-height: 1.0;
	letter-spacing: -0.025em;
	font-weight: 400;
	font-variation-settings: "opsz" 144, "SOFT" 20;
	max-width: 16ch;
	margin: var(--s-4) 0 var(--s-5);
	animation: rise 800ms 100ms var(--ease) both;
}
.hero__headline em {
	font-style: italic;
	font-variation-settings: "opsz" 144, "SOFT" 80;
	color: var(--c-accent);
}
.hero__sub {
	font-size: var(--fs-lg);
	color: var(--c-muted);
	max-width: 58ch;
	line-height: 1.5;
	animation: rise 800ms 200ms var(--ease) both;
}
.hero__cta {
	display: flex; flex-wrap: wrap; align-items: center;
	gap: var(--s-5);
	margin-top: var(--s-5);
	animation: rise 800ms 300ms var(--ease) both;
}
.hero__phone {
	display: inline-flex; align-items: center; gap: var(--s-2);
	font-size: var(--fs-base); font-weight: 600;
	text-decoration: none;
	color: var(--c-ink);
}
.hero__phone:hover { color: var(--c-accent); }

.hero__pillars {
	border-top: 1px solid var(--c-line);
	padding-top: var(--s-6);
	margin-top: var(--s-7);
	animation: rise 800ms 400ms var(--ease) both;
}
.hero__pillars ul {
	list-style: none; margin: 0; padding: 0;
	display: grid; grid-template-columns: repeat(5, 1fr);
	gap: var(--s-5);
}
.hero__pillars li {
	display: flex; flex-direction: column; gap: var(--s-2);
	border-left: 1px solid var(--c-line);
	padding-left: var(--s-4);
}
.hero__pillars-num {
	font-family: var(--f-display);
	font-size: var(--fs-xs);
	font-weight: 500;
	color: var(--c-accent);
	letter-spacing: 0.1em;
}
.hero__pillars-text {
	font-size: var(--fs-sm);
	line-height: 1.4;
	color: var(--c-ink-soft);
}

.hero__ornament {
	position: absolute;
	top: -10%; right: -10%;
	width: 70vw; max-width: 900px;
	pointer-events: none;
	z-index: 1;
	opacity: 0.9;
}

@keyframes rise {
	from { opacity: 0; transform: translateY(12px); }
	to   { opacity: 1; transform: translateY(0); }
}

@media (max-width: 900px) {
	.hero__inner { padding: var(--s-8) var(--s-5) var(--s-7); }
	.hero__pillars ul { grid-template-columns: repeat(2, 1fr); gap: var(--s-4); }
	.hero__ornament { width: 110vw; top: 10%; opacity: 0.5; }
}
@media (max-width: 540px) {
	.hero__pillars ul { grid-template-columns: 1fr; }
}

/* ---------- 6. Trust strip -------------------------------------- */
.trust {
	background: var(--c-ink); color: var(--c-bg-paper);
	border-bottom: 1px solid var(--c-ink);
}
.trust__inner {
	max-width: var(--container);
	margin: 0 auto;
	padding: var(--s-5) var(--s-6);
	display: flex; align-items: center; gap: var(--s-7);
	flex-wrap: wrap;
}
.trust__lead {
	margin: 0;
	font-size: var(--fs-sm);
	font-weight: 600;
	letter-spacing: 0.04em;
	color: var(--c-bg);
	flex-shrink: 0;
}
.trust__list {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-wrap: wrap;
	gap: var(--s-3) var(--s-6);
	font-size: var(--fs-sm);
	color: var(--c-muted-soft);
}
.trust__list strong { color: var(--c-bg-paper); font-weight: 600; }

/* ---------- 7. Section containers ------------------------------- */
.practice, .approach, .results, .testimonials, .cta {
	padding: var(--s-10) var(--s-6);
	max-width: var(--container);
	margin: 0 auto;
}

/* ---------- 8. Practice areas ----------------------------------- */
.practice__head {
	max-width: 60ch;
	margin-bottom: var(--s-8);
}
.practice__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1px;
	background: var(--c-line);
	border: 1px solid var(--c-line);
}
.practice-card {
	position: relative;
	display: flex; flex-direction: column; gap: var(--s-3);
	padding: var(--s-7) var(--s-5) var(--s-6);
	background: var(--c-bg);
	text-decoration: none;
	color: var(--c-ink);
	transition: background 250ms var(--ease), color 250ms var(--ease);
	overflow: hidden;
	min-height: 280px;
}
.practice-card:hover { background: var(--c-ink); color: var(--c-bg-paper); }
.practice-card__icon { color: var(--c-accent); transition: color 250ms var(--ease); margin-bottom: var(--s-3); }
.practice-card:hover .practice-card__icon { color: var(--c-bg-paper); }
.practice-card__title {
	font-family: var(--f-display);
	font-size: var(--fs-xl);
	font-weight: 400;
	letter-spacing: -0.01em;
	font-variation-settings: "opsz" 24, "SOFT" 30;
	margin: 0;
}
.practice-card__blurb {
	font-size: var(--fs-sm);
	line-height: 1.55;
	color: inherit;
	opacity: 0.75;
	margin: 0;
}
.practice-card__num {
	position: absolute; top: var(--s-5); right: var(--s-5);
	font-family: var(--f-display);
	font-size: var(--fs-xs);
	font-style: italic;
	font-variation-settings: "opsz" 9;
	color: var(--c-muted);
	transition: color 250ms var(--ease);
}
.practice-card:hover .practice-card__num { color: var(--c-bg-paper); opacity: 0.6; }
.practice-card__arrow {
	position: absolute; bottom: var(--s-5); right: var(--s-5);
	color: var(--c-ink); opacity: 0; transform: translate(-6px, 6px);
	transition: opacity 250ms var(--ease), transform 250ms var(--ease), color 250ms var(--ease);
}
.practice-card:hover .practice-card__arrow { color: var(--c-bg-paper); opacity: 1; transform: translate(0, 0); }

@media (max-width: 960px) { .practice__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .practice__grid { grid-template-columns: 1fr; } }

/* ---------- 9. Approach ----------------------------------------- */
.approach { background: var(--c-bg-paper); max-width: none; padding-left: 0; padding-right: 0; border-top: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line); }
.approach__inner { max-width: var(--container); margin: 0 auto; padding: 0 var(--s-6); display: grid; grid-template-columns: 0.8fr 1.4fr; gap: var(--s-9); align-items: start; }
.approach__head { position: sticky; top: 120px; }
.approach__lede { font-family: var(--f-display); font-size: var(--fs-2xl); line-height: 1.25; font-weight: 400; font-variation-settings: "opsz" 24, "SOFT" 40; margin-bottom: var(--s-7); max-width: 32ch; color: var(--c-ink); }
.approach__lede em { font-style: italic; color: var(--c-accent); }
.approach__list { list-style: none; margin: 0; padding: 0; }
.approach__list li { display: grid; grid-template-columns: 80px 1fr; gap: var(--s-5); padding: var(--s-6) 0; border-top: 1px solid var(--c-line); }
.approach__list li:last-child { border-bottom: 1px solid var(--c-line); }
.approach__list-num { font-family: var(--f-display); font-style: italic; font-size: var(--fs-xl); color: var(--c-accent); font-variation-settings: "opsz" 24; }
.approach__list h3 { font-family: var(--f-display); font-size: var(--fs-lg); font-weight: 500; margin: 0 0 var(--s-2); font-variation-settings: "opsz" 24, "SOFT" 50; }
.approach__list p { margin: 0; color: var(--c-muted); font-size: var(--fs-base); line-height: 1.55; }

@media (max-width: 960px) {
	.approach__inner { grid-template-columns: 1fr; gap: var(--s-6); }
	.approach__head { position: static; }
	.approach__list li { grid-template-columns: 60px 1fr; }
}

/* ---------- 10. Results ----------------------------------------- */
.results__head { max-width: 60ch; margin-bottom: var(--s-7); }
.results__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--s-5);
	margin-bottom: var(--s-6);
}
.results__grid--archive { grid-template-columns: repeat(3, 1fr); }
.result-card {
	display: flex; flex-direction: column; gap: var(--s-3);
	padding: var(--s-6) var(--s-5);
	border: 1px solid var(--c-line);
	background: var(--c-bg-paper);
	text-decoration: none; color: var(--c-ink);
	transition: border-color 200ms var(--ease), transform 250ms var(--ease), box-shadow 250ms var(--ease);
	min-height: 240px;
	justify-content: space-between;
}
.result-card:hover { border-color: var(--c-accent); transform: translateY(-4px); box-shadow: var(--shadow-soft); }
.result-card__amount {
	font-family: var(--f-display);
	font-size: var(--fs-3xl);
	font-weight: 400;
	letter-spacing: -0.025em;
	color: var(--c-accent);
	margin: 0;
	font-variation-settings: "opsz" 144, "SOFT" 30;
	line-height: 1;
}
.result-card__type {
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--c-muted);
	margin: 0;
}
.result-card__desc {
	font-size: var(--fs-sm);
	line-height: 1.5;
	color: var(--c-ink-soft);
	margin: 0;
}
.results__disclaimer {
	font-size: var(--fs-xs);
	font-style: italic;
	color: var(--c-muted);
	max-width: 80ch;
	line-height: 1.55;
	border-left: 2px solid var(--c-line);
	padding-left: var(--s-4);
	margin: var(--s-6) 0;
}
.results__more { margin-top: var(--s-5); }

@media (max-width: 960px) { .results__grid, .results__grid--archive { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .results__grid, .results__grid--archive { grid-template-columns: 1fr; } }

/* ---------- 11. Testimonials ------------------------------------ */
.testimonials__head { margin-bottom: var(--s-7); }
.testimonials__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-6); }
.testimonial {
	margin: 0;
	padding: var(--s-6);
	background: var(--c-bg-paper);
	border: 1px solid var(--c-line);
	position: relative;
}
.testimonial::before {
	content: "“"; position: absolute; top: -0.5rem; left: var(--s-4);
	font-family: var(--f-display); font-size: 4rem;
	color: var(--c-accent); line-height: 1;
	font-style: italic;
}
.testimonial__quote { font-family: var(--f-display); font-size: var(--fs-lg); line-height: 1.4; color: var(--c-ink); margin: 0 0 var(--s-4); font-variation-settings: "opsz" 24, "SOFT" 40; font-weight: 400; font-style: italic; }
.testimonial__quote p:last-child { margin-bottom: 0; }
.testimonial__attribution { font-size: var(--fs-xs); font-weight: 600; letter-spacing: 0.06em; color: var(--c-muted); text-transform: uppercase; }
@media (max-width: 960px) { .testimonials__grid { grid-template-columns: 1fr; } }

/* ---------- 12. CTA -------------------------------------------- */
.cta { background: var(--c-ink); max-width: none; color: var(--c-bg-paper); padding-left: 0; padding-right: 0; }
.cta__inner { max-width: var(--container); margin: 0 auto; padding: 0 var(--s-6); display: grid; grid-template-columns: 1fr 1.1fr; gap: var(--s-9); align-items: start; }
.cta__eyebrow { color: var(--c-accent-soft); }
.cta__eyebrow::before { background: var(--c-accent-soft); }
.cta__headline { color: var(--c-bg-paper); font-family: var(--f-display); font-size: var(--fs-4xl); font-weight: 400; line-height: 1.05; max-width: 14ch; font-variation-settings: "opsz" 144, "SOFT" 30; letter-spacing: -0.02em; }
.cta__sub { font-size: var(--fs-md); color: var(--c-muted-soft); max-width: 50ch; line-height: 1.55; margin-bottom: var(--s-6); }
.cta__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--s-3); }
.cta__list li { display: flex; align-items: center; gap: var(--s-3); font-size: var(--fs-sm); color: var(--c-bg); }
.cta__list .adv-icon { color: var(--c-accent-soft); }

.cta--slim { padding: var(--s-7) var(--s-6); }
.cta--slim .cta__inner { grid-template-columns: 1fr auto; align-items: center; padding: 0; gap: var(--s-6); }
.cta--slim .cta__headline { font-size: var(--fs-2xl); max-width: 24ch; margin: 0; }
.cta--slim .cta__sub { margin: 0; }
.cta--slim .cta__actions { display: flex; gap: var(--s-3); flex-wrap: wrap; }

@media (max-width: 900px) {
	.cta__inner { grid-template-columns: 1fr; gap: var(--s-7); }
	.cta--slim .cta__inner { grid-template-columns: 1fr; }
}

/* ---------- 13. Intake form ------------------------------------ */
.intake-form { display: flex; flex-direction: column; gap: var(--s-4); padding: var(--s-6); background: var(--c-bg-paper); color: var(--c-ink); border-radius: var(--radius-lg); box-shadow: var(--shadow-lift); }
.intake-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-4); }
.intake-form__field { display: flex; flex-direction: column; gap: var(--s-2); }
.intake-form__field--wide { grid-column: 1 / -1; }
.intake-form__label { font-size: var(--fs-xs); font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--c-muted); }
.intake-form input[type="text"], .intake-form input[type="email"], .intake-form input[type="tel"], .intake-form textarea {
	font-family: var(--f-body); font-size: var(--fs-base);
	background: var(--c-bg); color: var(--c-ink);
	border: 1px solid var(--c-line);
	padding: 0.875rem 1rem;
	border-radius: var(--radius);
	transition: border-color 200ms var(--ease), box-shadow 200ms var(--ease);
}
.intake-form input:focus, .intake-form textarea:focus {
	outline: none; border-color: var(--c-accent);
	box-shadow: 0 0 0 3px rgba(30, 64, 175, 0.12);
}
.intake-form textarea { min-height: 120px; resize: vertical; line-height: 1.5; }
.intake-form__honeypot { position: absolute; left: -9999px; opacity: 0; pointer-events: none; }
.intake-form__notice { font-size: var(--fs-sm); padding: var(--s-3) var(--s-4); border-radius: var(--radius); margin: 0; }
.intake-form__notice.is-success { background: rgba(14, 116, 144, 0.1); color: var(--c-sage); border-left: 3px solid var(--c-sage); }
.intake-form__notice.is-error { background: rgba(30, 64, 175, 0.08); color: var(--c-accent-deep); border-left: 3px solid var(--c-accent); }
.intake-form__notice--info { font-size: var(--fs-xs); color: var(--c-muted); background: var(--c-bg-alt); border-left: 3px solid var(--c-line); font-style: italic; }
.intake-form__submit-row { display: flex; align-items: center; flex-wrap: wrap; gap: var(--s-4); margin-top: var(--s-2); }
.intake-form__or { font-size: var(--fs-sm); color: var(--c-muted); }
.intake-form__phone { color: var(--c-ink); font-weight: 600; }

.intake-form.is-compact { padding: var(--s-5); }
.intake-form.is-compact .intake-form__row { grid-template-columns: 1fr; gap: var(--s-3); }
@media (max-width: 540px) { .intake-form__row { grid-template-columns: 1fr; } }

/* ---------- 14. Footer ----------------------------------------- */
.site-footer { background: var(--c-bg-alt); padding: var(--s-9) var(--s-6) var(--s-5); border-top: 1px solid var(--c-line); }
.site-footer__top { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: var(--s-7); padding-bottom: var(--s-7); border-bottom: 1px solid var(--c-line); }
.site-footer__col--brand .site-footer__mark { font-family: var(--f-display); font-size: var(--fs-2xl); font-weight: 500; text-decoration: none; color: var(--c-ink); font-variation-settings: "opsz" 24, "SOFT" 50; letter-spacing: -0.02em; }
.site-footer__tagline { font-size: var(--fs-sm); color: var(--c-muted); margin-top: var(--s-3); max-width: 36ch; }
.site-footer__heading { font-family: var(--f-body); font-size: var(--fs-xs); font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--c-muted); margin: 0 0 var(--s-4); }
.site-footer__menu { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--s-2); }
.site-footer__menu a { font-size: var(--fs-sm); text-decoration: none; color: var(--c-ink); }
.site-footer__menu a:hover { color: var(--c-accent); }
.site-footer__contact { display: flex; align-items: center; gap: var(--s-2); margin: 0 0 var(--s-2); font-size: var(--fs-sm); }
.site-footer__contact a { text-decoration: none; color: var(--c-ink); }
.site-footer__address { font-size: var(--fs-sm); font-style: normal; color: var(--c-ink); margin-top: var(--s-3); line-height: 1.55; }
.site-footer__hours { font-size: var(--fs-xs); color: var(--c-muted); margin-top: var(--s-2); }

.site-footer__legal { max-width: var(--container); margin: 0 auto; padding-top: var(--s-5); }
.site-footer__disclaimer { font-size: var(--fs-xs); line-height: 1.55; color: var(--c-muted); max-width: 90ch; font-style: italic; }
.site-footer__meta { display: flex; justify-content: space-between; align-items: center; gap: var(--s-4); margin-top: var(--s-4); flex-wrap: wrap; }
.site-footer__copy { font-size: var(--fs-xs); color: var(--c-muted); margin: 0; }
.site-footer__legal-menu { list-style: none; margin: 0; padding: 0; display: flex; gap: var(--s-5); }
.site-footer__legal-menu a { font-size: var(--fs-xs); color: var(--c-muted); text-decoration: none; }
.site-footer__legal-menu a:hover { color: var(--c-accent); }

@media (max-width: 960px) { .site-footer__top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .site-footer__top { grid-template-columns: 1fr; gap: var(--s-5); } }

/* ---------- 15. Single page templates --------------------------- */
.page-article, .post-article, .pa-single, .result-single { max-width: var(--container-narrow); margin: 0 auto; padding: var(--s-9) var(--s-6); }
.page-article__header, .post-article__header, .pa-single__header, .result-single__header { margin-bottom: var(--s-7); }
.page-article__title, .post-article__title, .pa-single__title { font-size: var(--fs-4xl); max-width: 22ch; line-height: 1.05; margin: var(--s-3) 0 var(--s-4); }
.post-article__dek { font-family: var(--f-display); font-size: var(--fs-xl); line-height: 1.35; color: var(--c-muted); font-style: italic; font-variation-settings: "opsz" 24, "SOFT" 40; max-width: 50ch; margin-bottom: var(--s-5); }
.post-article__byline { font-size: var(--fs-xs); letter-spacing: 0.06em; text-transform: uppercase; color: var(--c-muted); }
.page-article__media, .post-article__media { margin: var(--s-6) 0; }
.page-article__media img, .post-article__media img { border-radius: var(--radius); }

.pa-single__icon { color: var(--c-accent); margin-bottom: var(--s-5); }
.pa-single__dek { font-family: var(--f-display); font-size: var(--fs-xl); line-height: 1.35; color: var(--c-muted); font-style: italic; max-width: 50ch; font-variation-settings: "opsz" 24; }

.result-single__amount { font-family: var(--f-display); font-size: var(--fs-5xl); font-weight: 400; color: var(--c-accent); margin: var(--s-3) 0; line-height: 1; letter-spacing: -0.03em; font-variation-settings: "opsz" 144, "SOFT" 20; }
.result-single__title { font-size: var(--fs-2xl); max-width: 30ch; }
.result-single__type { font-size: var(--fs-sm); font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--c-muted); margin-bottom: var(--s-4); }
.result-single__disclaimer { margin-top: var(--s-7); }

/* Prose */
.prose { font-size: var(--fs-md); line-height: 1.7; color: var(--c-ink-soft); max-width: 68ch; }
.prose p { margin: 0 0 var(--s-5); }
.prose h2 { font-size: var(--fs-2xl); margin: var(--s-7) 0 var(--s-3); }
.prose h3 { font-size: var(--fs-xl); margin: var(--s-6) 0 var(--s-3); }
.prose ul, .prose ol { padding-left: var(--s-5); margin: 0 0 var(--s-5); }
.prose li { margin: var(--s-2) 0; }
.prose blockquote { font-family: var(--f-display); font-style: italic; font-size: var(--fs-xl); line-height: 1.4; border-left: 3px solid var(--c-accent); padding: var(--s-3) var(--s-5); margin: var(--s-6) 0; color: var(--c-ink); font-variation-settings: "opsz" 24, "SOFT" 50; }
.prose a { color: var(--c-accent); }

/* ---------- 16. Attorney pages --------------------------------- */
.attorney-single { max-width: var(--container); margin: 0 auto; padding: var(--s-9) var(--s-6); }
.attorney-single__inner { display: grid; grid-template-columns: 1fr 1.3fr; gap: var(--s-8); align-items: start; }
.attorney-single__media img { border-radius: var(--radius); box-shadow: var(--shadow-lift); }
.attorney-single__name { font-size: var(--fs-4xl); margin: var(--s-3) 0 var(--s-2); }
.attorney-single__title { font-family: var(--f-display); font-style: italic; font-size: var(--fs-lg); color: var(--c-accent); margin-bottom: var(--s-5); font-variation-settings: "opsz" 24; }
.attorney-single__contact { list-style: none; margin: 0 0 var(--s-5); padding: 0; display: flex; flex-direction: column; gap: var(--s-2); }
.attorney-single__contact li { display: flex; align-items: center; gap: var(--s-2); font-size: var(--fs-sm); }
.attorney-single__contact a { text-decoration: none; }
.attorney-single__bar { padding: var(--s-4) 0; border-top: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line); }
.attorney-single__label { font-size: var(--fs-xs); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--c-muted); margin: 0 0 var(--s-2); }
.attorney-single__content { margin-top: var(--s-7); max-width: 68ch; }

.attorney-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-6); max-width: var(--container); margin: 0 auto; padding: 0 var(--s-6) var(--s-9); }
.attorney-card { text-decoration: none; color: var(--c-ink); display: flex; flex-direction: column; gap: var(--s-3); }
.attorney-card__media { overflow: hidden; aspect-ratio: 4 / 5; }
.attorney-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 600ms var(--ease); }
.attorney-card:hover .attorney-card__media img { transform: scale(1.04); }
.attorney-card__name { font-size: var(--fs-xl); margin: var(--s-2) 0 0; }
.attorney-card__title { font-family: var(--f-display); font-style: italic; font-size: var(--fs-sm); color: var(--c-accent); margin: 0; }
.attorney-card__excerpt { font-size: var(--fs-sm); color: var(--c-muted); margin: 0; line-height: 1.55; }

@media (max-width: 900px) {
	.attorney-single__inner { grid-template-columns: 1fr; }
	.attorney-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) { .attorney-grid { grid-template-columns: 1fr; } }

/* ---------- 17. Archive / blog --------------------------------- */
.archive-header { max-width: var(--container); margin: 0 auto; padding: var(--s-9) var(--s-6) var(--s-6); }
.archive-header__title { font-size: var(--fs-4xl); max-width: 22ch; }
.archive-header__desc { font-size: var(--fs-md); color: var(--c-muted); max-width: 60ch; }

.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-7); max-width: var(--container); margin: 0 auto; padding: 0 var(--s-6) var(--s-9); }
.post-card { display: flex; flex-direction: column; gap: var(--s-3); }
.post-card__media { overflow: hidden; aspect-ratio: 4 / 3; }
.post-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 600ms var(--ease); }
.post-card:hover .post-card__media img { transform: scale(1.04); }
.post-card__meta { font-size: var(--fs-xs); letter-spacing: 0.06em; text-transform: uppercase; color: var(--c-muted); margin: 0; }
.post-card__title { font-size: var(--fs-xl); margin: var(--s-2) 0; }
.post-card__title a { text-decoration: none; }
.post-card__excerpt { font-size: var(--fs-sm); color: var(--c-muted); margin: 0; line-height: 1.55; }

.pagination { max-width: var(--container); margin: 0 auto; padding: 0 var(--s-6) var(--s-9); }
.pagination .nav-links { display: flex; gap: var(--s-3); flex-wrap: wrap; }
.pagination .page-numbers { padding: var(--s-2) var(--s-4); border: 1px solid var(--c-line); text-decoration: none; font-size: var(--fs-sm); }
.pagination .page-numbers.current { background: var(--c-ink); color: var(--c-bg); border-color: var(--c-ink); }

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

/* ---------- 18. Contact page ----------------------------------- */
.contact-page { max-width: var(--container); margin: 0 auto; padding: var(--s-9) var(--s-6); }
.contact-page__inner { display: grid; grid-template-columns: 1fr 1.1fr; gap: var(--s-8); align-items: start; }
.contact-page__title { font-size: var(--fs-4xl); margin: var(--s-3) 0 var(--s-5); max-width: 18ch; }
.contact-page__intro { color: var(--c-muted); font-size: var(--fs-md); margin-bottom: var(--s-6); }
.contact-page__details { display: flex; flex-direction: column; gap: var(--s-4); margin: var(--s-6) 0; padding: var(--s-5) 0; border-top: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line); }
.contact-page__details > div { display: grid; grid-template-columns: 80px 1fr; gap: var(--s-3); align-items: baseline; }
.contact-page__details dt { font-size: var(--fs-xs); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--c-muted); margin: 0; }
.contact-page__details dd { margin: 0; font-size: var(--fs-sm); }
.contact-page__details a { text-decoration: none; }
.contact-page__note { font-size: var(--fs-xs); color: var(--c-muted); font-style: italic; line-height: 1.55; }

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

/* ---------- 19. 404 -------------------------------------------- */
.error-404 { max-width: var(--container-narrow); margin: 0 auto; padding: var(--s-10) var(--s-6); text-align: center; }
.error-404__num { font-family: var(--f-display); font-size: 8rem; font-weight: 400; color: var(--c-accent); line-height: 1; letter-spacing: -0.04em; margin: 0 0 var(--s-3); font-variation-settings: "opsz" 144, "SOFT" 20; }
.error-404__title { font-size: var(--fs-3xl); margin: 0 0 var(--s-4); }
.error-404__sub { color: var(--c-muted); margin-bottom: var(--s-6); }
.error-404 .search-form { max-width: 480px; margin: 0 auto var(--s-5); display: flex; gap: var(--s-2); }
.error-404 .search-form__input { flex: 1; padding: 0.875rem 1rem; border: 1px solid var(--c-line); background: var(--c-bg-paper); font: inherit; }
.error-404 .search-form__submit { padding: 0.875rem 1.25rem; background: var(--c-ink); color: var(--c-bg); border: none; font: inherit; font-size: var(--fs-sm); cursor: pointer; }

/* ---------- 20. Misc utilities --------------------------------- */
.empty { max-width: var(--container-narrow); margin: var(--s-8) auto; padding: 0 var(--s-6); font-size: var(--fs-md); color: var(--c-muted); }

/* =================================================================
 * 21. BLG-specific homepage sections
 * (added with the bannerlawgroup.com content integration)
 * ================================================================= */

/* ---- Trust strip variants ---- */
.trust__list--stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--s-4) var(--s-6);
	width: 100%;
}
.trust__list--stats li {
	font-size: var(--fs-sm);
	color: var(--c-bg-paper);
	padding-left: var(--s-4);
	border-left: 1px solid rgba(255, 255, 255, 0.18);
	line-height: 1.4;
}
.trust__list--stats strong {
	color: var(--c-bg-paper);
	font-weight: 600;
	letter-spacing: 0.01em;
}
@media (max-width: 960px) {
	.trust__list--stats { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
	.trust__list--stats { grid-template-columns: 1fr; }
	.trust__list--stats li { border-left: none; padding-left: 0; }
}

/* ---- Larger 3-up practice cards (homepage primary practice areas) ---- */
.practice__grid--three { grid-template-columns: repeat(3, 1fr); }
.practice-card--lg { min-height: 340px; padding: var(--s-7) var(--s-6) var(--s-7); }
.practice-card--lg .practice-card__title { font-size: var(--fs-2xl); }
.practice-card--lg .practice-card__blurb { font-size: var(--fs-base); line-height: 1.6; }
.practice__cta-row { margin-top: var(--s-6); }

@media (max-width: 960px) { .practice__grid--three { grid-template-columns: 1fr; } }

/* ---- Value cards (3-up "Why Banner Law Group" homepage section) ---- */
.value-cards {
	max-width: var(--container);
	margin: 0 auto;
	padding: var(--s-10) var(--s-6);
}
.value-cards__head { max-width: 50ch; margin-bottom: var(--s-8); }
.value-cards__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--s-5);
}
.value-card {
	display: flex;
	flex-direction: column;
	gap: var(--s-3);
	padding: var(--s-7) var(--s-6) var(--s-6);
	background: var(--c-bg-paper);
	border: 1px solid var(--c-line);
	border-top: 3px solid var(--c-accent);
	text-decoration: none;
	color: var(--c-ink);
	transition: transform 250ms var(--ease), box-shadow 250ms var(--ease), border-top-color 250ms var(--ease);
	position: relative;
}
.value-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lift);
	border-top-color: var(--c-accent-deep);
}
.value-card__num {
	font-family: var(--f-display);
	font-style: italic;
	font-size: var(--fs-lg);
	color: var(--c-accent);
	font-variation-settings: "opsz" 24;
	margin-bottom: var(--s-2);
}
.value-card__title {
	font-family: var(--f-display);
	font-size: var(--fs-xl);
	font-weight: 400;
	letter-spacing: -0.01em;
	font-variation-settings: "opsz" 24, "SOFT" 30;
	margin: 0;
	max-width: 22ch;
}
.value-card__blurb {
	font-size: var(--fs-sm);
	line-height: 1.55;
	color: var(--c-muted);
	margin: 0;
	flex: 1;
}
.value-card__link {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	font-size: var(--fs-xs);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--c-ink);
	margin-top: var(--s-3);
	transition: gap 200ms var(--ease), color 200ms var(--ease);
}
.value-card:hover .value-card__link { gap: var(--s-3); color: var(--c-accent); }

@media (max-width: 960px) { .value-cards__grid { grid-template-columns: 1fr; } }

/* ---- Attorney spotlight ---- */
.attorney-spotlight {
	max-width: none;
	background: var(--c-ink);
	color: var(--c-bg-paper);
	padding: var(--s-10) var(--s-6);
}
.attorney-spotlight__inner {
	max-width: var(--container);
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.6fr 1fr;
	gap: var(--s-8);
	align-items: center;
}
.attorney-spotlight .section-eyebrow { color: var(--c-accent-soft); }
.attorney-spotlight .section-eyebrow::before { background: var(--c-accent-soft); }
.attorney-spotlight__name {
	font-family: var(--f-display);
	font-size: var(--fs-4xl);
	font-weight: 400;
	color: var(--c-bg-paper);
	margin: var(--s-2) 0 var(--s-5);
	letter-spacing: -0.02em;
	font-variation-settings: "opsz" 144, "SOFT" 30;
}
.attorney-spotlight__pull {
	font-family: var(--f-display);
	font-style: italic;
	font-size: var(--fs-xl);
	line-height: 1.4;
	color: var(--c-bg);
	max-width: 48ch;
	margin-bottom: var(--s-6);
	font-variation-settings: "opsz" 24, "SOFT" 50;
	border-left: 2px solid var(--c-accent);
	padding-left: var(--s-4);
}
.attorney-spotlight__credentials {
	margin-bottom: var(--s-5);
}
.attorney-spotlight__credentials dl {
	display: grid;
	grid-template-columns: 140px 1fr;
	gap: var(--s-3) var(--s-5);
	margin: 0;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.attorney-spotlight__credentials dl > div {
	display: contents;
}
.attorney-spotlight__credentials dt,
.attorney-spotlight__credentials dd {
	padding: var(--s-3) 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.12);
	margin: 0;
}
.attorney-spotlight__credentials dt {
	font-size: var(--fs-xs);
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--c-muted-soft);
}
.attorney-spotlight__credentials dd {
	font-size: var(--fs-sm);
	color: var(--c-bg-paper);
	line-height: 1.5;
}
.attorney-spotlight__credentials dd em { color: var(--c-accent-soft); }
.attorney-spotlight .link-arrow { color: var(--c-bg-paper); border-color: var(--c-bg-paper); }
.attorney-spotlight .link-arrow:hover { color: var(--c-accent-soft); border-color: var(--c-accent-soft); }
.attorney-spotlight__aside {
	display: flex; align-items: center; justify-content: center;
}
.attorney-spotlight__quote-mark {
	font-family: var(--f-display);
	font-size: 22rem;
	line-height: 0.8;
	font-style: italic;
	color: var(--c-accent);
	opacity: 0.35;
	font-variation-settings: "opsz" 144;
}

@media (max-width: 960px) {
	.attorney-spotlight__inner { grid-template-columns: 1fr; gap: var(--s-6); }
	.attorney-spotlight__aside { display: none; }
	.attorney-spotlight__credentials dl { grid-template-columns: 110px 1fr; }
}
@media (max-width: 540px) {
	.attorney-spotlight__credentials dl { grid-template-columns: 1fr; gap: 0; }
	.attorney-spotlight__credentials dt { padding-bottom: 0; border-bottom: none; }
	.attorney-spotlight__credentials dd { padding-top: var(--s-1); }
}

/* ---- Mediation callout ---- */
.mediation-callout {
	max-width: var(--container);
	margin: 0 auto;
	padding: var(--s-9) var(--s-6);
}
.mediation-callout__inner {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: var(--s-8);
	align-items: center;
	padding: var(--s-7);
	background: var(--c-bg-paper);
	border: 1px solid var(--c-line);
	position: relative;
	overflow: hidden;
}
.mediation-callout__inner::before {
	content: "";
	position: absolute;
	top: 0; bottom: 0; left: 0;
	width: 4px;
	background: var(--c-sage);
}
.mediation-callout__text h2 {
	font-family: var(--f-display);
	font-size: var(--fs-2xl);
	margin: var(--s-2) 0 var(--s-4);
	max-width: 22ch;
	font-variation-settings: "opsz" 24, "SOFT" 40;
}
.mediation-callout__text p { color: var(--c-muted); font-size: var(--fs-base); line-height: 1.6; max-width: 56ch; }
.mediation-callout__text p strong { color: var(--c-ink); }
.mediation-callout__cta {
	display: flex;
	flex-direction: column;
	gap: var(--s-4);
	align-items: flex-start;
}
.mediation-callout__contact {
	font-size: var(--fs-xs);
	color: var(--c-muted);
	line-height: 1.55;
	margin: 0;
}
.mediation-callout__contact a { font-weight: 600; color: var(--c-ink); text-decoration: none; border-bottom: 1px solid var(--c-line); }
.mediation-callout__contact a:hover { color: var(--c-accent); border-color: var(--c-accent); }

@media (max-width: 960px) {
	.mediation-callout__inner { grid-template-columns: 1fr; padding: var(--s-6); }
}

/* Print */
@media print {
	.site-header, .site-footer, .cta, .hero__ornament, .intake-form,
	.value-cards, .attorney-spotlight, .mediation-callout { display: none; }
	body { background: white; }
	body::before { display: none; }
}

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

/* Restored editable-home layout refinements */
.front-page-content__blocks > .hero,
.front-page-content__blocks > .trust,
.front-page-content__blocks > .practice,
.front-page-content__blocks > .value-cards,
.front-page-content__blocks > .approach,
.front-page-content__blocks > .attorney-spotlight,
.front-page-content__blocks > .mediation-callout,
.front-page-content__blocks > .cta {
	margin-block-start: 0;
	margin-block-end: 0;
}

.approach__list--cards {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--s-5);
}
.approach__list--cards li,
.approach__list--cards li:last-child {
	display: block;
	padding: var(--s-6);
	border: 1px solid var(--c-line);
	background: var(--c-bg);
}
.approach__list--cards h3 {
	margin-top: 0;
}

@media (max-width: 760px) {
	.approach__list--cards { grid-template-columns: 1fr; }
}
