/* ==========================================================================
   PRACTICE.CSS — The Law Offices of Jimmy Cha, APC.
   SHARED stylesheet for all practice-area pages (DUI, Domestic Violence, Drug,
   Theft, Felony, Misdemeanor, Juvenile, Prostitution). Map each practice page
   ID to 'practice' in functions.php. Uses generic .pa-* classes.
   Pattern: Hero · Charges/Stakes · Defense · Local Court · Reviews · CTA
   (Final CTA + reviews widget styling come from component.css.)
   ========================================================================== */

@keyframes jcFadeUp {
	from { opacity: 0; transform: translateY(28px); }
	to   { opacity: 1; transform: none; }
}

/* ==========================================================================
   HERO
   ========================================================================== */
.pa-hero {
	position: relative;
	overflow: hidden;
	background: var(--ink);
	border-bottom: 1px solid var(--crimson-dim);
}
.pa-hero-inner {
	position: relative;
	z-index: 1;
	max-width: 900px;
	margin-inline: auto;
	text-align: center;
	padding-block: 96px 76px;
}
.pa-hero-title {
	font-size: clamp(32px, 4.6vw, 54px);
	font-weight: 700;
	color: var(--warm-white);
	line-height: 1.1;
	letter-spacing: -0.4px;
	margin-bottom: 20px;
	animation: jcFadeUp 0.7s ease both;
}
.pa-hero-title em {
	font-style: italic;
	background: var(--grad-crimson);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
.pa-hero-sub {
	font-size: clamp(16px, 2vw, 20px);
	color: var(--silver-light);
	max-width: 680px;
	margin: 0 auto 32px;
	animation: jcFadeUp 0.7s ease 0.12s both;
}
.pa-hero-actions {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 16px;
	margin-bottom: 22px;
	animation: jcFadeUp 0.7s ease 0.24s both;
}
.pa-hero .reassurance-line {
	color: var(--gold);
	animation: jcFadeUp 0.7s ease 0.32s both;
}

/* ==========================================================================
   CARD GRID (charges/stakes + defense)
   ========================================================================== */
.pa-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
	margin-top: 12px;
	align-items: start;
}
.pa-card {
	border: 1px solid var(--gunmetal);
	border-radius: var(--radius-lg);
	padding: 28px;
	background: var(--grad-surface);
	height: 100%;
	transition: transform 0.3s ease, border-color 0.3s ease;
}
.pa-card:hover {
	transform: translateY(-3px);
	border-color: rgba(166, 24, 44, 0.35);
}
.pa-card-icon {
	display: grid;
	place-items: center;
	width: 48px;
	height: 48px;
	border-radius: 12px;
	font-size: 19px;
	color: var(--crimson-light);
	background: rgba(166, 24, 44, 0.12);
	border: 1px solid rgba(166, 24, 44, 0.25);
	margin-bottom: 16px;
}
.pa-card-title {
	font-size: 21px;
	color: var(--warm-white);
	margin-bottom: 10px;
	line-height: 1.25;
}
.pa-card-title .pa-code {
	display: inline-block;
	font-family: var(--font-mono);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 1px;
	color: var(--gold);
	margin-left: 6px;
	vertical-align: middle;
}
.pa-card p {
	font-size: 14.5px;
	color: var(--silver-light);
	line-height: 1.7;
}
.pa-card--wide {
	grid-column: 1 / -1;
}
/* Alert card — crimson emphasis for critical info (e.g. protective-order warning) */
.pa-card--alert {
	border: 1px solid transparent;
	background:
		linear-gradient(160deg, rgba(166, 24, 44, 0.14), rgba(20, 20, 25, 0.5)) padding-box,
		var(--grad-crimson) border-box;
}
.pa-card--alert .pa-card-icon {
	color: #fff;
	background: var(--grad-crimson);
	border-color: transparent;
}

/* Highlighted callout (e.g. the 10-day DMV window) — full width, crimson */
.pa-callout {
	grid-column: 1 / -1;
	display: flex;
	gap: 22px;
	border: 1px solid transparent;
	border-radius: var(--radius-lg);
	padding: 30px 32px;
	background:
		linear-gradient(160deg, rgba(166, 24, 44, 0.16), rgba(20, 20, 25, 0.5)) padding-box,
		var(--grad-crimson) border-box;
}
.pa-callout-icon {
	flex-shrink: 0;
	display: grid;
	place-items: center;
	width: 56px;
	height: 56px;
	border-radius: 15px;
	font-size: 24px;
	color: #fff;
	background: var(--grad-crimson);
	box-shadow: 0 10px 24px rgba(166, 24, 44, 0.32);
}
.pa-callout-title {
	font-size: 23px;
	color: var(--warm-white);
	margin-bottom: 10px;
}
.pa-callout p {
	font-size: 15.5px;
	color: var(--silver-light);
	line-height: 1.7;
}

/* Defense section gets a charcoal background */
.pa-defense-section {
	background: var(--charcoal);
}

/* ==========================================================================
   PATTERN A — CHARGES (statute cards: crimson left-rail + inline icon/title)
   ========================================================================== */
.pa-charges {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
	margin-top: 12px;
	align-items: start;
}
.pa-charge {
	border: 1px solid var(--gunmetal);
	border-left: 3px solid var(--crimson);
	border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
	padding: 26px 28px;
	background: var(--grad-surface);
	height: 100%;
	transition: transform 0.3s ease, border-left-color 0.3s ease;
}
.pa-charge:hover {
	transform: translateY(-3px);
	border-left-color: var(--crimson-light);
}
.pa-charge-head {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 12px;
}
.pa-charge-icon {
	flex-shrink: 0;
	display: grid;
	place-items: center;
	width: 42px;
	height: 42px;
	border-radius: 10px;
	font-size: 18px;
	color: var(--crimson-light);
	background: rgba(166, 24, 44, 0.12);
	border: 1px solid rgba(166, 24, 44, 0.25);
}
.pa-charge-title {
	font-size: 19px;
	color: var(--warm-white);
	line-height: 1.25;
}
.pa-charge p {
	font-size: 14.5px;
	color: var(--silver-light);
	line-height: 1.7;
}
.pa-charge-emphasis {
	margin-top: 12px;
	font-weight: 600;
	color: var(--crimson-light) !important;
}
.pa-charge--wide {
	grid-column: 1 / -1;
}

/* ==========================================================================
   PATTERN B — DEFENSE (big italic numbered cards, no icon, glass border)
   ========================================================================== */
.pa-approach {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 22px;
	margin-top: 12px;
	align-items: start;
}
.pa-approach-item {
	position: relative;
	border: 1px solid transparent;
	border-radius: var(--radius-lg);
	padding: 30px 32px;
	overflow: hidden;
	height: 100%;
	background:
		linear-gradient(160deg, #20202b, #16161c) padding-box,
		linear-gradient(160deg, rgba(166, 24, 44, 0.25), rgba(255, 255, 255, 0.05)) border-box;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.pa-approach-item:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-md);
}
.pa-approach-num {
	display: block;
	font-family: var(--font-display);
	font-style: italic;
	font-weight: 700;
	font-size: 50px;
	line-height: 1;
	color: rgba(166, 24, 44, 0.4);
	margin-bottom: 10px;
}
.pa-approach-title {
	font-size: 22px;
	color: var(--warm-white);
	margin-bottom: 10px;
	line-height: 1.2;
}
.pa-approach-item p {
	font-size: 14.5px;
	color: var(--silver-light);
	line-height: 1.7;
}
.pa-approach-emphasis {
	margin-top: 12px;
	font-weight: 600;
	color: var(--crimson-light) !important;
}
.pa-approach-item--wide {
	grid-column: 1 / -1;
}

/* ==========================================================================
   PATTERN C — PROTECTIVE ORDERS / FEATURES (horizontal split: icon band + body)
   ========================================================================== */
.pa-orders-section {
	background:
		radial-gradient(70% 90% at 100% 0%, rgba(166, 24, 44, 0.08), transparent 55%),
		var(--ink);
}
.pa-orders {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
	margin-top: 12px;
	align-items: stretch;
}
.pa-order {
	display: flex;
	border: 1px solid var(--gunmetal);
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--grad-surface);
	transition: transform 0.3s ease, border-color 0.3s ease;
}
.pa-order:hover {
	transform: translateY(-3px);
	border-color: rgba(184, 148, 94, 0.4);
}
.pa-order-side {
	flex-shrink: 0;
	width: 66px;
	display: grid;
	place-items: center;
	font-size: 23px;
	color: var(--gold);
	background: var(--gold-dim);
	border-right: 1px solid var(--gunmetal);
}
.pa-order-body {
	padding: 24px 26px;
}
.pa-order-title {
	font-size: 19px;
	color: var(--warm-white);
	margin-bottom: 10px;
	line-height: 1.25;
}
.pa-order-body p {
	font-size: 14.5px;
	color: var(--silver-light);
	line-height: 1.7;
}
.pa-order--alert {
	border-color: rgba(166, 24, 44, 0.45);
}
.pa-order--alert .pa-order-side {
	color: #fff;
	background: var(--grad-crimson);
	border-right-color: transparent;
}

/* ==========================================================================
   LOCAL COURT (two-column editorial)
   ========================================================================== */
.pa-local-grid {
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
	gap: 48px;
	align-items: start;
}
.pa-local-aside {
	position: sticky;
	top: 104px;
}
.pa-local-aside .section-title {
	margin-bottom: 18px;
}
.pa-local-stat {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	font-family: var(--font-mono);
	font-size: 12px;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: var(--gold);
	padding: 12px 18px;
	border: 1px solid var(--gold-dim);
	border-radius: 50px;
	background: var(--gold-dim);
}
.pa-local-stat i {
	font-size: 16px;
}
.pa-local-body p {
	font-size: 16px;
	color: var(--silver-light);
	line-height: 1.8;
	margin-bottom: 18px;
}
.pa-local-body p:last-child {
	margin-bottom: 0;
}

/* ==========================================================================
   REVIEWS
   ========================================================================== */
.pa-reviews-section {
	background:
		radial-gradient(60% 90% at 50% 0%, rgba(184, 148, 94, 0.08), transparent 60%),
		var(--ink);
	border-top: 1px solid var(--gold-dim);
}
.pa-reviews-section .section-label {
	justify-content: center;
	text-align: center;
}
.pa-reviews-widget {
	margin-top: 8px;
}
/* Honors block (gold) — shown beneath reviews on stakes-heavy pages (e.g. Felony) */
.pa-honors {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 12px;
	margin-top: 40px;
	padding-top: 34px;
	border-top: 1px solid var(--gold-dim);
}
.pa-honors span {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 1.4px;
	text-transform: uppercase;
	color: var(--gold);
	padding: 10px 18px;
	border: 1px solid var(--gold-dim);
	border-radius: 50px;
	background: var(--gold-dim);
}
.pa-honors i {
	font-size: 13px;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 880px) {
	.pa-grid,
	.pa-charges,
	.pa-approach,
	.pa-orders {
		grid-template-columns: 1fr;
	}
	.pa-local-grid {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.pa-local-aside {
		position: static;
	}
	.pa-order {
		flex-direction: column;
	}
	.pa-order-side {
		width: 100%;
		height: 56px;
		border-right: none;
		border-bottom: 1px solid var(--gunmetal);
	}
	.pa-order--alert .pa-order-side {
		border-bottom-color: transparent;
	}
}

@media (max-width: 680px) {
	.pa-hero-inner {
		padding-block: 66px 52px;
	}
	.pa-hero-actions .btn {
		width: 100%;
	}
	.pa-callout {
		flex-direction: column;
		gap: 16px;
		padding: 24px;
	}
}
