/**
 * Biltmore Theme - Custom CSS
 * All custom styles for the luxury personal injury law firm theme
 */

/* ============================================================
   ROOT & GLOBAL STYLES
   ============================================================ */

:root {
	--color-cream: #F7F3ED;
	--color-terracotta: #A67B5B;
	--color-clay: #8B6F4E;
	--color-forest-green: #3D4F3D;
	--color-deep-brown: #3D2E1F;
	--font-serif: "DM Serif Display", Georgia, serif;
	--font-sans: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--spacing-xs: 0.5rem;
	--spacing-sm: 1rem;
	--spacing-md: 1.5rem;
	--spacing-lg: 2rem;
	--spacing-xl: 3rem;
	--spacing-2xl: 4rem;
	--spacing-3xl: 5rem;
	--border-radius: 2px;
	--box-shadow: 0 2px 8px rgba(61, 46, 31, 0.1);
	--box-shadow-lg: 0 8px 24px rgba(61, 46, 31, 0.15);
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	font-family: var(--font-sans);
	color: var(--color-deep-brown);
	background-color: var(--color-cream);
	line-height: 1.6;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-serif);
	font-weight: 400;
	line-height: 1.2;
	color: var(--color-deep-brown);
	margin-top: var(--spacing-lg);
	margin-bottom: var(--spacing-md);
}

h1 {
	font-size: 3.5rem;
}

h2 {
	font-size: 2.5rem;
}

h3 {
	font-size: 1.5rem;
}

h4 {
	font-size: 1.25rem;
}

p {
	margin-bottom: var(--spacing-md);
}

a {
	color: var(--color-terracotta);
	text-decoration: none;
	transition: color 0.3s ease;
}

a:hover {
	color: var(--color-clay);
}

/* ============================================================
   HEADER & NAVIGATION
   ============================================================ */

.site-header {
	background-color: var(--color-cream);
	border-bottom: 1px solid rgba(166, 123, 91, 0.1);
	padding: var(--spacing-lg) 0;
	position: sticky;
	top: 0;
	z-index: 1000;
	box-shadow: 0 2px 4px rgba(61, 46, 31, 0.05);
}

.header-container {
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 var(--spacing-lg);
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.site-branding {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
}

.site-branding img {
	height: 50px;
	width: auto;
}

.site-title {
	font-size: 1.75rem;
	font-family: var(--font-serif);
	font-weight: 400;
	color: var(--color-deep-brown);
	margin: 0;
}

.primary-navigation {
	display: flex;
	gap: var(--spacing-lg);
	list-style: none;
	margin: 0;
	padding: 0;
}

.primary-navigation a {
	font-family: var(--font-sans);
	font-weight: 400;
	color: var(--color-deep-brown);
	padding: var(--spacing-xs) var(--spacing-sm);
	position: relative;
}

.primary-navigation a::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 2px;
	background-color: var(--color-terracotta);
	transition: width 0.3s ease;
}

.primary-navigation a:hover::after {
	width: 100%;
}

/* ============================================================
   FOOTER
   ============================================================ */

.site-footer {
	background-color: var(--color-deep-brown);
	color: var(--color-cream);
	padding: var(--spacing-3xl) var(--spacing-lg);
	margin-top: var(--spacing-3xl);
}

.footer-container {
	max-width: 1400px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: var(--spacing-2xl);
	margin-bottom: var(--spacing-2xl);
}

.footer-section h3 {
	color: var(--color-terracotta);
	font-size: 1.25rem;
	margin-bottom: var(--spacing-md);
}

.footer-section p,
.footer-section ul {
	font-size: 0.9rem;
	line-height: 1.8;
	color: rgba(247, 243, 237, 0.9);
}

.footer-section a {
	color: var(--color-terracotta);
}

.footer-section a:hover {
	color: var(--color-clay);
}

.footer-section ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-section li {
	margin-bottom: var(--spacing-sm);
}

.footer-divider {
	border-color: var(--color-terracotta) !important;
	opacity: 0.3;
	margin: var(--spacing-2xl) 0;
}

.footer-bottom {
	max-width: 1400px;
	margin: 0 auto;
	border-top: 1px solid rgba(166, 123, 91, 0.2);
	padding-top: var(--spacing-xl);
	font-size: 0.85rem;
	color: rgba(247, 243, 237, 0.8);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--spacing-xl);
}

.footer-bottom p {
	margin: 0;
}

/* ============================================================
   HERO SECTION - SPLIT SCREEN
   ============================================================ */

.hero-section {
	padding: var(--spacing-3xl) var(--spacing-lg);
	background-color: var(--color-cream);
}

.hero-columns {
	max-width: 1400px;
	margin: 0 auto;
	display: flex;
	gap: var(--spacing-3xl);
	align-items: center;
}

.hero-columns .wp-block-column {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.hero-image {
	border-radius: 8px;
	box-shadow: var(--box-shadow-lg);
	overflow: hidden;
	margin: 0 !important;
}

.hero-image img {
	width: 100%;
	height: auto;
	display: block;
}

.hero-title {
	font-size: 3.5rem;
	font-family: var(--font-serif);
	color: var(--color-deep-brown);
	margin-bottom: var(--spacing-lg);
	line-height: 1.2;
}

.hero-subtitle {
	font-size: 1.25rem;
	color: var(--color-clay);
	margin-bottom: var(--spacing-xl);
	line-height: 1.6;
	font-weight: 300;
}

.hero-button-primary {
	margin-right: var(--spacing-md);
}

.wp-block-button__link {
	padding: 1rem 2rem !important;
	font-size: 1rem;
	font-family: var(--font-sans);
	border-radius: var(--border-radius);
	transition: all 0.3s ease;
	display: inline-block;
}

.hero-button-primary .wp-block-button__link {
	background-color: var(--color-terracotta) !important;
	color: var(--color-cream) !important;
}

.hero-button-primary .wp-block-button__link:hover {
	background-color: var(--color-clay) !important;
	transform: translateY(-2px);
	box-shadow: var(--box-shadow-lg);
}

.hero-button-secondary .wp-block-button__link {
	background-color: var(--color-cream) !important;
	color: var(--color-terracotta) !important;
	border: 2px solid var(--color-terracotta) !important;
}

.hero-button-secondary .wp-block-button__link:hover {
	background-color: var(--color-terracotta) !important;
	color: var(--color-cream) !important;
	transform: translateY(-2px);
}

/* ============================================================
   STATS SECTION
   ============================================================ */

.stats-section {
	background-color: var(--color-deep-brown);
	padding: var(--spacing-3xl) var(--spacing-lg);
	color: var(--color-cream);
}

.stats-grid {
	max-width: 1400px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: var(--spacing-2xl);
}

.stat-number {
	font-size: 3rem;
	color: var(--color-terracotta);
	font-family: var(--font-serif);
	margin-bottom: var(--spacing-sm);
}

.stats-grid p {
	font-size: 1rem;
	color: rgba(247, 243, 237, 0.9);
	margin: 0;
}

/* ============================================================
   ALTERNATING SECTIONS
   ============================================================ */

.alternating-section {
	padding: var(--spacing-3xl) var(--spacing-lg);
	background-color: var(--color-cream);
}

.alternating-section .wp-block-columns {
	max-width: 1400px;
	margin: 0 auto;
	display: flex;
	gap: var(--spacing-3xl);
	align-items: center;
}

.alternating-section .wp-block-column {
	flex: 1;
}

.alternating-section img {
	border-radius: 8px;
	box-shadow: var(--box-shadow-lg);
	width: 100%;
	height: auto;
}

.section-title {
	font-size: 2.5rem;
	font-family: var(--font-serif);
	color: var(--color-deep-brown);
	margin-bottom: var(--spacing-lg);
}

.alternating-section p {
	font-size: 1.125rem;
	color: var(--color-clay);
	line-height: 1.8;
}

/* ============================================================
   FEATURED RESULTS SECTION
   ============================================================ */

.featured-results-section {
	background-color: var(--color-forest-green);
	color: var(--color-cream);
	padding: var(--spacing-3xl) var(--spacing-lg);
}

.featured-results-section > * {
	max-width: 1400px;
	margin: 0 auto;
}

.featured-results-section .section-title {
	color: var(--color-cream);
	margin-bottom: var(--spacing-md);
}

.featured-results-section > .wp-block-paragraph {
	color: rgba(247, 243, 237, 0.9);
	font-size: 1.125rem;
	margin-bottom: var(--spacing-2xl);
}

.featured-results-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--spacing-lg);
	margin-bottom: var(--spacing-2xl);
}

.case-result-featured {
	background-color: var(--color-clay);
	padding: var(--spacing-xl);
	border-radius: var(--border-radius);
	color: var(--color-cream);
	text-align: center;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.case-result-featured:hover {
	transform: translateY(-4px);
	box-shadow: var(--box-shadow-lg);
}

.case-result-featured h3 {
	color: var(--color-cream);
	font-size: 2rem;
	margin-bottom: var(--spacing-sm);
}

.case-result-featured p {
	color: rgba(247, 243, 237, 0.95);
	font-size: 0.95rem;
	margin: 0;
}

/* ============================================================
   CASE RESULTS PAGE - FILTERS & TABLE
   ============================================================ */

.results-page-wrapper {
	background-color: var(--color-cream);
	padding: var(--spacing-3xl) var(--spacing-lg);
}

.results-header {
	max-width: 1200px;
	margin: 0 auto var(--spacing-3xl);
	text-align: center;
}

.results-page-title {
	font-size: 3.5rem;
	font-family: var(--font-serif);
	color: var(--color-deep-brown);
	margin-bottom: var(--spacing-md);
}

.results-subtitle {
	font-size: 1.25rem;
	color: var(--color-clay);
	margin: 0;
}

.results-filters {
	max-width: 1200px;
	margin: 0 auto var(--spacing-3xl);
	gap: var(--spacing-md);
	justify-content: center !important;
}

.filter-pill {
	margin: var(--spacing-sm);
}

.filter-pill .wp-block-button__link {
	padding: 0.75rem 1.5rem !important;
	font-size: 0.95rem;
	border-radius: 25px;
	background-color: var(--color-terracotta) !important;
	color: var(--color-cream) !important;
	transition: all 0.3s ease;
	border: 2px solid transparent;
}

.filter-pill-active .wp-block-button__link {
	background-color: var(--color-clay) !important;
	box-shadow: var(--box-shadow);
}

.filter-pill .wp-block-button__link:hover {
	background-color: var(--color-clay) !important;
	transform: scale(1.05);
}

.results-table-wrapper {
	max-width: 1200px;
	margin: 0 auto var(--spacing-3xl);
	overflow-x: auto;
}

.results-table {
	width: 100%;
	margin: 0 !important;
	border-collapse: collapse;
	background: white;
	box-shadow: var(--box-shadow);
	border-radius: var(--border-radius);
	overflow: hidden;
}

.results-table table {
	width: 100%;
}

.results-table th {
	background-color: var(--color-clay);
	color: var(--color-cream);
	padding: 1rem;
	text-align: left;
	font-family: var(--font-sans);
	font-weight: 400;
	font-size: 0.9rem;
	border-bottom: 2px solid var(--color-terracotta);
}

.results-table td {
	padding: 1rem;
	border-bottom: 1px solid rgba(166, 123, 91, 0.1);
	font-size: 0.95rem;
	color: var(--color-deep-brown);
}

.results-table tbody tr:hover {
	background-color: rgba(247, 243, 237, 0.5);
}

.results-table tbody tr:last-child td {
	border-bottom: none;
}

/* Badges */
.badge {
	display: inline-block;
	padding: 0.5rem 1rem;
	border-radius: 20px;
	font-size: 0.85rem;
	font-weight: 400;
	white-space: nowrap;
}

.badge-eight-figure {
	background-color: var(--color-forest-green);
	color: var(--color-cream);
	font-family: var(--font-serif);
	font-size: 1rem;
}

.badge-multi-million {
	background-color: var(--color-terracotta);
	color: var(--color-cream);
	font-family: var(--font-serif);
	font-size: 0.95rem;
}

.badge-type {
	display: inline-block;
	padding: 0.4rem 0.8rem;
	border-radius: 4px;
	font-size: 0.75rem;
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.badge-type.verdict {
	background-color: rgba(166, 123, 91, 0.2);
	color: var(--color-terracotta);
}

.badge-type.settlement {
	background-color: rgba(139, 111, 78, 0.2);
	color: var(--color-clay);
}

/* Case Result Cards Grid */
.results-cards-view {
	max-width: 1200px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
	gap: var(--spacing-lg);
}

.case-result-card {
	background: white;
	padding: var(--spacing-xl);
	border-radius: var(--border-radius);
	box-shadow: var(--box-shadow);
	transition: all 0.3s ease;
	border-left: 4px solid var(--color-terracotta);
}

.case-result-card:hover {
	box-shadow: var(--box-shadow-lg);
	transform: translateY(-4px);
}

.case-result-card h3 {
	color: var(--color-deep-brown);
	margin-top: 0;
	margin-bottom: var(--spacing-md);
}

.case-result-card p {
	margin-bottom: var(--spacing-sm);
	font-size: 0.95rem;
}

.case-result-card p:last-child {
	margin-bottom: 0;
}

.results-cta-section {
	max-width: 1200px;
	margin: var(--spacing-3xl) auto 0;
	padding: var(--spacing-3xl) var(--spacing-xl);
	text-align: center;
	border-radius: var(--border-radius);
}

.results-cta-section h2 {
	color: var(--color-cream);
	margin-top: 0;
}

.results-cta-section p {
	color: rgba(247, 243, 237, 0.95);
}

/* ============================================================
   TEAM PAGE
   ============================================================ */

.team-page-wrapper {
	background-color: var(--color-cream);
	padding: var(--spacing-3xl) var(--spacing-lg);
}

.team-header {
	max-width: 1200px;
	margin: 0 auto var(--spacing-3xl);
	text-align: center;
}

.team-page-title {
	font-size: 3.5rem;
	font-family: var(--font-serif);
	color: var(--color-deep-brown);
	margin-bottom: var(--spacing-md);
}

.team-subtitle {
	font-size: 1.25rem;
	color: var(--color-clay);
	margin: 0;
}

.team-grid {
	max-width: 1400px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: var(--spacing-2xl);
}

.attorney-card {
	background-color: var(--color-clay);
	color: var(--color-cream);
	padding: var(--spacing-xl);
	border-radius: var(--border-radius);
	text-align: center;
	transition: all 0.3s ease;
	display: flex;
	flex-direction: column;
}

.attorney-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--box-shadow-lg);
}

.attorney-photo {
	margin: 0 0 var(--spacing-lg) 0;
	border-radius: 4px;
	overflow: hidden;
}

.attorney-photo img {
	width: 100%;
	height: auto;
	display: block;
}

.attorney-name {
	color: var(--color-cream);
	font-size: 1.5rem;
	margin: 0 0 var(--spacing-sm);
	font-family: var(--font-serif);
}

.attorney-title {
	color: rgba(247, 243, 237, 0.85);
	font-size: 0.95rem;
	margin: 0 0 var(--spacing-md);
	font-weight: 400;
}

.attorney-bio {
	color: rgba(247, 243, 237, 0.9);
	font-size: 0.9rem;
	line-height: 1.6;
	margin: 0 0 var(--spacing-lg);
	flex-grow: 1;
}

.attorney-card .wp-block-buttons {
	margin-top: auto;
	justify-content: center;
}

.team-cta-section {
	max-width: 1200px;
	margin: var(--spacing-3xl) auto 0;
	padding: var(--spacing-3xl) var(--spacing-xl);
	background-color: var(--color-forest-green);
	text-align: center;
	border-radius: var(--border-radius);
}

.team-cta-section h2 {
	color: var(--color-cream);
	margin-top: 0;
}

.team-cta-section p {
	color: rgba(247, 243, 237, 0.95);
}

/* ============================================================
   ATTORNEY SINGLE PAGE
   ============================================================ */

.attorney-single-wrapper {
	background-color: var(--color-cream);
	padding: var(--spacing-3xl) var(--spacing-lg);
}

.attorney-hero {
	max-width: 1200px;
	margin: 0 auto var(--spacing-3xl);
	gap: var(--spacing-3xl);
}

.attorney-single-image {
	border-radius: 8px;
	overflow: hidden;
	box-shadow: var(--box-shadow-lg);
	margin: 0 !important;
}

.attorney-single-image img {
	width: 100%;
	height: auto;
	display: block;
}

.attorney-single-title {
	font-size: 3rem;
	margin-top: 0;
	margin-bottom: var(--spacing-md);
}

.attorney-roles {
	color: var(--color-terracotta);
	font-size: 0.95rem;
	margin-bottom: var(--spacing-md);
}

.attorney-single-subtitle {
	font-size: 1.125rem;
	color: var(--color-clay);
	margin-bottom: var(--spacing-lg);
}

.attorney-contact-info {
	background-color: rgba(166, 123, 91, 0.05);
	padding: var(--spacing-lg);
	border-radius: var(--border-radius);
	margin-bottom: var(--spacing-lg);
	border-left: 4px solid var(--color-terracotta);
}

.attorney-contact-info p {
	margin-bottom: var(--spacing-sm);
	font-size: 0.95rem;
}

.attorney-contact-info a {
	color: var(--color-terracotta);
	font-weight: 400;
}

.attorney-content {
	max-width: 1200px;
	margin: 0 auto var(--spacing-3xl);
}

.attorney-specialties {
	max-width: 1200px;
	margin: 0 auto var(--spacing-3xl);
	padding: var(--spacing-2xl) var(--spacing-xl);
	background-color: var(--color-forest-green);
	border-radius: var(--border-radius);
}

.attorney-specialties h2 {
	color: var(--color-cream);
	margin-top: 0;
}

.attorney-specialties ul {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: var(--spacing-md);
	color: var(--color-cream);
	list-style: none;
	padding: 0;
	margin: 0;
}

.attorney-specialties li {
	padding-left: 1.5rem;
	position: relative;
}

.attorney-specialties li::before {
	content: '▪';
	position: absolute;
	left: 0;
	color: var(--color-terracotta);
}

.related-attorneys {
	max-width: 1200px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--spacing-lg);
}

.attorney-card-related {
	background: white;
	padding: var(--spacing-lg);
	border-radius: var(--border-radius);
	box-shadow: var(--box-shadow);
	transition: all 0.3s ease;
}

.attorney-card-related:hover {
	box-shadow: var(--box-shadow-lg);
	transform: translateY(-4px);
}

/* ============================================================
   PAGE LAYOUTS
   ============================================================ */

.page-content-wrapper {
	background-color: var(--color-cream);
	padding: var(--spacing-3xl) var(--spacing-lg);
}

.page-header {
	max-width: 1200px;
	margin: 0 auto var(--spacing-3xl);
	text-align: center;
}

.page-title {
	font-size: 3.5rem;
	margin-top: 0;
}

.page-content {
	background: white;
	padding: var(--spacing-2xl);
	border-radius: var(--border-radius);
	box-shadow: var(--box-shadow);
	margin: 0 auto var(--spacing-3xl);
}

/* ============================================================
   CTA SECTION
   ============================================================ */

.cta-section {
	background-color: var(--color-terracotta);
	color: var(--color-cream);
	padding: var(--spacing-3xl) var(--spacing-lg);
	text-align: center;
	margin-top: var(--spacing-3xl);
}

.cta-section > * {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
}

.cta-title {
	color: var(--color-cream);
	margin-top: 0;
	font-size: 2.5rem;
}

.cta-section p {
	color: rgba(247, 243, 237, 0.95);
	font-size: 1.125rem;
	margin-bottom: var(--spacing-xl);
}

/* ============================================================
   MASONRY GALLERY
   ============================================================ */

.gallery-masonry {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: var(--spacing-lg);
	margin: var(--spacing-2xl) 0;
}

.gallery-item {
	position: relative;
	overflow: hidden;
	border-radius: var(--border-radius);
	box-shadow: var(--box-shadow);
	transition: all 0.3s ease;
}

.gallery-item:hover {
	box-shadow: var(--box-shadow-lg);
	transform: scale(1.05);
}

.gallery-item img {
	width: 100%;
	height: 300px;
	object-fit: cover;
	display: block;
}

/* ============================================================
   RESPONSIVE DESIGN
   ============================================================ */

@media (max-width: 1024px) {
	:root {
		--spacing-2xl: 3rem;
		--spacing-3xl: 4rem;
	}

	h1 {
		font-size: 2.5rem;
	}

	h2 {
		font-size: 2rem;
	}

	h3 {
		font-size: 1.25rem;
	}

	.hero-title {
		font-size: 2.5rem;
	}

	.stat-number {
		font-size: 2rem;
	}

	.section-title {
		font-size: 2rem;
	}

	.hero-columns,
	.alternating-section .wp-block-columns {
		gap: var(--spacing-2xl);
	}

	.primary-navigation {
		gap: var(--spacing-md);
	}

	.team-grid,
	.results-cards-view,
	.gallery-masonry {
		grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	}

	.footer-container {
		grid-template-columns: repeat(2, 1fr);
	}

	.footer-bottom {
		flex-direction: column;
		gap: var(--spacing-md);
		text-align: center;
	}
}

@media (max-width: 768px) {
	:root {
		--spacing-lg: 1.5rem;
		--spacing-xl: 2rem;
		--spacing-2xl: 2.5rem;
		--spacing-3xl: 3rem;
	}

	h1 {
		font-size: 2rem;
	}

	h2 {
		font-size: 1.5rem;
	}

	h3 {
		font-size: 1.125rem;
	}

	.hero-section,
	.stats-section,
	.alternating-section,
	.featured-results-section,
	.results-page-wrapper,
	.team-page-wrapper,
	.page-content-wrapper,
	.attorney-single-wrapper,
	.cta-section {
		padding: var(--spacing-2xl) var(--spacing-md);
	}

	.header-container {
		padding: 0 var(--spacing-md);
		flex-direction: column;
		gap: var(--spacing-md);
	}

	.site-branding {
		flex-direction: column;
		text-align: center;
	}

	.site-title {
		font-size: 1.25rem;
	}

	.primary-navigation {
		flex-direction: column;
		gap: var(--spacing-sm);
		width: 100%;
	}

	.hero-title {
		font-size: 2rem;
	}

	.hero-subtitle {
		font-size: 1rem;
	}

	.hero-columns,
	.alternating-section .wp-block-columns {
		flex-direction: column;
		gap: var(--spacing-lg);
	}

	.hero-columns .wp-block-column,
	.alternating-section .wp-block-column {
		width: 100% !important;
		flex-basis: auto !important;
	}

	.results-page-title,
	.team-page-title,
	.page-title,
	.cta-title,
	.attorney-single-title {
		font-size: 1.75rem;
	}

	.stats-grid,
	.featured-results-grid,
	.results-filters {
		grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
		gap: var(--spacing-md);
	}

	.stat-number {
		font-size: 1.5rem;
	}

	.team-grid {
		grid-template-columns: 1fr;
	}

	.attorney-card {
		padding: var(--spacing-lg);
	}

	.results-table-wrapper {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	.results-table th,
	.results-table td {
		padding: 0.75rem 0.5rem;
		font-size: 0.85rem;
	}

	.results-table th {
		font-size: 0.8rem;
	}

	.case-result-card {
		padding: var(--spacing-lg);
	}

	.footer-container {
		grid-template-columns: 1fr;
		gap: var(--spacing-xl);
	}

	.footer-bottom {
		flex-direction: column;
		font-size: 0.8rem;
		gap: var(--spacing-md);
	}

	.page-content {
		padding: var(--spacing-lg);
	}

	.attorney-hero {
		gap: var(--spacing-xl);
		margin-bottom: var(--spacing-xl);
	}

	.attorney-specialties ul {
		grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	}

	.hero-button-primary {
		margin-right: 0;
		margin-bottom: var(--spacing-sm);
	}

	.wp-block-button {
		width: 100%;
	}

	.wp-block-button__link {
		width: 100%;
		text-align: center;
	}
}

@media (max-width: 480px) {
	:root {
		--spacing-sm: 0.75rem;
		--spacing-md: 1rem;
		--spacing-lg: 1.25rem;
		--spacing-xl: 1.5rem;
		--spacing-2xl: 2rem;
		--spacing-3xl: 2.5rem;
	}

	body {
		font-size: 0.95rem;
	}

	h1 {
		font-size: 1.5rem;
		margin-bottom: var(--spacing-md);
	}

	h2 {
		font-size: 1.25rem;
	}

	h3 {
		font-size: 1rem;
	}

	.hero-section,
	.stats-section,
	.alternating-section,
	.featured-results-section,
	.results-page-wrapper,
	.team-page-wrapper,
	.page-content-wrapper,
	.attorney-single-wrapper,
	.cta-section {
		padding: var(--spacing-xl) var(--spacing-sm);
	}

	.header-container {
		padding: 0 var(--spacing-sm);
		gap: var(--spacing-sm);
	}

	.site-title {
		font-size: 1rem;
	}

	.primary-navigation a {
		padding: var(--spacing-xs);
		font-size: 0.9rem;
	}

	.hero-title,
	.results-page-title,
	.team-page-title,
	.page-title,
	.attorney-single-title {
		font-size: 1.5rem;
		margin-bottom: var(--spacing-md);
	}

	.hero-subtitle {
		font-size: 0.95rem;
		margin-bottom: var(--spacing-lg);
	}

	.stat-number {
		font-size: 1.25rem;
	}

	.stats-grid,
	.featured-results-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-md);
	}

	.case-result-featured {
		padding: var(--spacing-lg);
	}

	.case-result-featured h3 {
		font-size: 1.25rem;
	}

	.results-filters {
		gap: var(--spacing-sm);
		margin-bottom: var(--spacing-xl);
	}

	.filter-pill {
		margin: var(--spacing-xs);
	}

	.filter-pill .wp-block-button__link {
		padding: 0.6rem 1rem !important;
		font-size: 0.85rem;
	}

	.results-table {
		font-size: 0.8rem;
	}

	.results-table th,
	.results-table td {
		padding: 0.5rem;
	}

	.badge {
		font-size: 0.75rem;
		padding: 0.35rem 0.7rem;
	}

	.team-grid {
		grid-template-columns: 1fr;
	}

	.attorney-card {
		padding: var(--spacing-md);
	}

	.attorney-name {
		font-size: 1.125rem;
	}

	.attorney-bio {
		font-size: 0.85rem;
	}

	.footer-bottom p {
		font-size: 0.75rem;
	}

	.page-content {
		padding: var(--spacing-md);
	}

	.attorney-contact-info {
		padding: var(--spacing-md);
		margin-bottom: var(--spacing-md);
	}

	.attorney-specialties ul {
		grid-template-columns: 1fr;
	}

	.wp-block-button__link {
		padding: 0.75rem 1rem !important;
		font-size: 0.9rem;
	}
}

/* ============================================================
   UTILITY CLASSES
   ============================================================ */

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

.text-left {
	text-align: left;
}

.text-right {
	text-align: right;
}

.margin-top-large {
	margin-top: var(--spacing-2xl);
}

.margin-bottom-large {
	margin-bottom: var(--spacing-2xl);
}

.padding-large {
	padding: var(--spacing-2xl);
}

/* ============================================================
   ACCESSIBILITY
   ============================================================ */

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

@media (prefers-color-scheme: dark) {
	/* Optional dark mode support */
	body {
		background-color: var(--color-deep-brown);
		color: var(--color-cream);
	}
}
