/**
 * Industry CPT Template Styles
 *
 * Drop into your Hello Elementor child theme :
 *   /wp-content/themes/hello-elementor-child/industry-style.css
 *
 * Enqueue via functions.php (see functions-snippet.php).
 *
 * Brand foundation (matches datadestruction.com inspection):
 *   Primary   #00477f (Navy)
 *   Secondary #004bed (Vivid Blue — CTAs)
 *   Accent    #00aed9 (Teal)
 *   Text      #333333
 *   Light     #f8f9fa
 *   Border    #e1e1e1
 *   Font      Open Sans (Google Fonts)
 */

/* ------------------------------------------------------------------ */
/* 0. Design tokens                                                    */
/* ------------------------------------------------------------------ */
:root {
	--dd-primary:        #00477f;
	--dd-primary-dark:   #003a6a;
	--dd-secondary:      #004bed;
	--dd-secondary-dark: #003ec4;
	--dd-accent:         #00aed9;
	--dd-text:           #333333;
	--dd-text-muted:     #555555;
	--dd-white:          #ffffff;
	--dd-light:          #f8f9fa;
	--dd-light-2:        #f1f3f5;
	--dd-border:         #e1e1e1;
	--dd-success:        #28a745;

	--dd-font-body:    'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	--dd-radius-sm:    4px;
	--dd-radius-md:    8px;
	--dd-radius-lg:    12px;

	--dd-shadow-sm:    0 1px 3px rgba(0, 0, 0, 0.08);
	--dd-shadow-md:    0 4px 12px rgba(0, 0, 0, 0.12);
	--dd-shadow-lg:    0 10px 30px rgba(0, 0, 0, 0.15);

	--dd-section-pad:  80px;
	--dd-section-pad-mobile: 48px;
	--dd-container-max: 1200px;
}

/* ------------------------------------------------------------------ */
/* 1. Base + container                                                  */
/* ------------------------------------------------------------------ */
.industry-single {
	font-family: var(--dd-font-body);
	color: var(--dd-text);
	line-height: 1.6;
	overflow-x: hidden;
}

.industry-single * {
	box-sizing: border-box;
}

.industry-container {
	max-width: var(--dd-container-max);
	margin: 0 auto;
	padding: 0 24px;
	width: 100%;
}

.industry-section-heading {
	text-align: center;
	margin-bottom: 48px;
}

.industry-h2 {
	font-size: 36px;
	font-weight: 700;
	color: var(--dd-primary);
	line-height: 1.25;
	margin: 0 0 24px;
}

.industry-single h3 {
	font-size: 22px;
	font-weight: 600;
	color: var(--dd-primary);
	line-height: 1.3;
	margin: 0 0 12px;
}

.industry-single p {
	margin: 0 0 16px;
}

.industry-single a {
	color: var(--dd-secondary);
	text-decoration: underline;
	text-underline-offset: 3px;
	transition: color 150ms ease;
}

.industry-single a:hover {
	color: var(--dd-secondary-dark);
}

/* ------------------------------------------------------------------ */
/* 2. Buttons                                                           */
/* ------------------------------------------------------------------ */
.industry-btn {
	display: inline-block;
	font-family: var(--dd-font-body);
	font-weight: 600;
	font-size: 16px;
	line-height: 1;
	text-decoration: none !important;
	padding: 16px 32px;
	border-radius: var(--dd-radius-md);
	border: 2px solid transparent;
	cursor: pointer;
	transition: all 180ms ease;
	letter-spacing: 0.2px;
	white-space: nowrap;
}

.industry-btn--primary {
	background: var(--dd-secondary);
	color: var(--dd-white) !important;
	border-color: var(--dd-secondary);
}

.industry-btn--primary:hover {
	background: var(--dd-secondary-dark);
	border-color: var(--dd-secondary-dark);
	color: var(--dd-white) !important;
	transform: translateY(-2px);
	box-shadow: var(--dd-shadow-md);
}

.industry-btn--secondary {
	background: transparent;
	color: var(--dd-white) !important;
	border-color: var(--dd-white);
}

.industry-btn--secondary:hover {
	background: var(--dd-white);
	color: var(--dd-primary) !important;
}

.industry-btn--large {
	font-size: 18px;
	padding: 20px 40px;
}

/* ------------------------------------------------------------------ */
/* 3. BLOCK 01 — Hero                                                   */
/* ------------------------------------------------------------------ */
.industry-hero {
	background: var(--dd-primary);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	color: var(--dd-white);
	padding: var(--dd-section-pad) 0;
	min-height: 480px;
	display: flex;
	align-items: center;
	position: relative;
}

.industry-eyebrow {
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--dd-accent);
	margin: 0 0 16px;
}

.industry-hero__headline {
	font-size: 48px;
	font-weight: 700;
	line-height: 1.15;
	margin: 0 0 20px;
	color: var(--dd-white);
	max-width: 900px;
}

.industry-hero__subhead {
	font-size: 20px;
	line-height: 1.55;
	max-width: 780px;
	color: rgba(255, 255, 255, 0.95);
	margin: 0 0 32px;
}

.industry-hero__cta {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
}

/* ------------------------------------------------------------------ */
/* 4. BLOCK 02 — Trust Bar                                              */
/* ------------------------------------------------------------------ */
.industry-trust-bar {
	background: var(--dd-primary-dark);
	color: var(--dd-white);
	padding: 24px 0;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.industry-trust-bar__list {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px 24px;
	list-style: none;
	margin: 0;
	padding: 0;
	align-items: center;
}

.industry-trust-bar__item {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	font-size: 14px;
	font-weight: 600;
	color: var(--dd-white);
	text-align: center;
}

.industry-trust-bar__icon {
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: var(--dd-accent);
	color: var(--dd-primary-dark);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 900;
	font-size: 14px;
	flex-shrink: 0;
}

/* ------------------------------------------------------------------ */
/* 5. BLOCK 03 — Overview                                               */
/* ------------------------------------------------------------------ */
.industry-overview {
	background: var(--dd-white);
	padding: var(--dd-section-pad) 0;
}

.industry-overview__grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr;
	gap: 56px;
	align-items: start;
}

.industry-overview__body p {
	font-size: 17px;
	color: var(--dd-text);
	margin-bottom: 18px;
}

.industry-overview__stats {
	background: var(--dd-light);
	border-left: 4px solid var(--dd-accent);
	padding: 32px;
	border-radius: var(--dd-radius-md);
	box-shadow: var(--dd-shadow-sm);
}

.industry-overview__stats-title {
	font-size: 18px;
	font-weight: 700;
	color: var(--dd-primary);
	text-transform: uppercase;
	letter-spacing: 1.5px;
	margin: 0 0 24px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--dd-border);
}

.industry-stats-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.industry-stat {
	display: flex;
	flex-direction: column;
	padding: 14px 0;
	border-bottom: 1px solid var(--dd-border);
}

.industry-stat:last-child {
	border-bottom: 0;
}

.industry-stat__number {
	font-size: 24px;
	font-weight: 700;
	color: var(--dd-secondary);
	line-height: 1.2;
}

.industry-stat__label {
	font-size: 14px;
	color: var(--dd-text);
	margin-top: 4px;
	line-height: 1.4;
}

.industry-stat__source {
	font-size: 12px;
	color: var(--dd-text-muted);
	margin-top: 4px;
	font-style: italic;
}

/* ------------------------------------------------------------------ */
/* 6. BLOCK 04 — Regulations + BLOCK 07 — FAQ                           */
/* ------------------------------------------------------------------ */
.industry-regulations,
.industry-faq {
	background: var(--dd-light);
	padding: var(--dd-section-pad) 0;
}

.industry-faq {
	background: var(--dd-white);
}

.industry-accordion {
	max-width: 960px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.industry-accordion__item {
	background: var(--dd-white);
	border: 1px solid var(--dd-border);
	border-radius: var(--dd-radius-md);
	overflow: hidden;
	transition: box-shadow 180ms ease;
}

.industry-accordion__item[open] {
	box-shadow: var(--dd-shadow-md);
	border-color: var(--dd-accent);
}

.industry-accordion__summary {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 16px;
	padding: 20px 24px;
	font-weight: 600;
	color: var(--dd-primary);
	cursor: pointer;
	list-style: none;
	user-select: none;
	transition: background 150ms ease;
}

.industry-accordion__summary::-webkit-details-marker {
	display: none;
}

.industry-accordion__summary:hover {
	background: var(--dd-light-2);
}

.industry-accordion__title {
	flex: 1 1 auto;
	font-size: 18px;
	margin: 0;
}

.industry-accordion__citation {
	font-size: 14px;
	color: var(--dd-text-muted);
	font-weight: 400;
	font-family: 'Courier New', Courier, monospace;
	background: var(--dd-light-2);
	padding: 2px 10px;
	border-radius: var(--dd-radius-sm);
}

.industry-accordion__arrow {
	transition: transform 200ms ease;
	color: var(--dd-secondary);
	font-size: 14px;
	margin-left: auto;
}

.industry-accordion__item[open] .industry-accordion__arrow {
	transform: rotate(90deg);
}

.industry-accordion__body {
	padding: 0 24px 22px;
	color: var(--dd-text);
	font-size: 16px;
	line-height: 1.65;
}

.industry-accordion__body p {
	margin: 0 0 12px;
}

.industry-accordion--faq .industry-accordion__title {
	font-size: 17px;
}

/* ------------------------------------------------------------------ */
/* 7. BLOCK 05 — Pain Points                                            */
/* ------------------------------------------------------------------ */
.industry-pain-points {
	background: var(--dd-white);
	padding: var(--dd-section-pad) 0;
}

.industry-pain-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.industry-pain {
	background: var(--dd-light);
	border: 1px solid var(--dd-border);
	border-radius: var(--dd-radius-md);
	padding: 32px 28px;
	transition: transform 200ms ease, box-shadow 200ms ease;
}

.industry-pain:hover {
	transform: translateY(-4px);
	box-shadow: var(--dd-shadow-md);
	border-color: var(--dd-accent);
}

.industry-pain__icon {
	display: inline-block;
	width: 48px;
	height: 48px;
	background: var(--dd-accent);
	border-radius: 50%;
	margin-bottom: 18px;
	position: relative;
}

.industry-pain__icon::before {
	content: '!';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: var(--dd-white);
	font-weight: 700;
	font-size: 22px;
}

.industry-pain__title {
	font-size: 18px;
	color: var(--dd-primary);
	margin: 0 0 12px;
	line-height: 1.35;
}

.industry-pain__solution {
	font-size: 15px;
	color: var(--dd-text);
	margin: 0;
}

/* ------------------------------------------------------------------ */
/* 8. BLOCK 06 — Audit Docs                                             */
/* ------------------------------------------------------------------ */
.industry-audit-docs {
	background: var(--dd-primary);
	color: var(--dd-white);
	padding: var(--dd-section-pad) 0;
}

.industry-audit-docs .industry-h2 {
	color: var(--dd-white);
}

.industry-audit-docs__grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 56px;
	align-items: center;
}

.industry-audit-docs__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.industry-audit-doc {
	display: flex;
	gap: 18px;
	padding: 18px 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

.industry-audit-doc:last-child {
	border-bottom: 0;
}

.industry-audit-doc__icon {
	font-size: 28px;
	color: var(--dd-accent);
	flex-shrink: 0;
	line-height: 1;
}

.industry-single .industry-audit-doc__name {
	font-size: 18px;
	color: var(--dd-white);
	margin: 0 0 6px;
}

.industry-audit-doc__purpose {
	font-size: 15px;
	color: rgba(255, 255, 255, 0.9);
	margin: 0;
	line-height: 1.55;
}

.industry-audit-doc__purpose a {
	color: var(--dd-accent);
}

.industry-audit-docs__certificate {
	display: flex;
	align-items: center;
	justify-content: center;
}

.industry-certificate-placeholder {
	background: var(--dd-white);
	color: var(--dd-primary);
	width: 100%;
	max-width: 380px;
	padding: 40px 32px;
	text-align: center;
	border-radius: var(--dd-radius-md);
	border: 8px double var(--dd-primary);
	box-shadow: var(--dd-shadow-lg);
}

.industry-certificate-placeholder__seal {
	display: inline-block;
	width: 80px;
	height: 80px;
	border-radius: 50%;
	background: var(--dd-secondary);
	color: var(--dd-white);
	line-height: 80px;
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 1px;
	margin-bottom: 16px;
}

.industry-certificate-placeholder__title {
	font-size: 18px;
	font-weight: 700;
	color: var(--dd-primary);
	margin: 0 0 8px;
	text-transform: uppercase;
	letter-spacing: 2px;
}

.industry-certificate-placeholder__sub {
	font-size: 13px;
	color: var(--dd-text-muted);
	margin: 0;
	line-height: 1.45;
}

.industry-certificate-img {
	width: 100%;
	max-width: 420px;
	height: auto;
	display: block;
	border-radius: var(--dd-radius-md);
	box-shadow: var(--dd-shadow-lg);
}

/* ------------------------------------------------------------------ */
/* 9. BLOCK 08 — Related Internal Links                                 */
/* ------------------------------------------------------------------ */
.industry-related {
	background: var(--dd-light);
	padding: var(--dd-section-pad) 0;
}

.industry-related__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}

.industry-related__col {
	background: var(--dd-white);
	border-top: 4px solid var(--dd-accent);
	border-radius: var(--dd-radius-md);
	padding: 32px 28px;
	box-shadow: var(--dd-shadow-sm);
}

.industry-related__col-title {
	font-size: 18px;
	color: var(--dd-primary);
	text-transform: uppercase;
	letter-spacing: 1.5px;
	margin: 0 0 18px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--dd-border);
}

.industry-related__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.industry-related__list li {
	padding: 10px 0;
	border-bottom: 1px solid var(--dd-border);
}

.industry-related__list li:last-child {
	border-bottom: 0;
}

.industry-related__list a {
	font-size: 15px;
	color: var(--dd-secondary);
	text-decoration: none;
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	transition: gap 180ms ease, color 150ms ease;
}

.industry-related__list a::after {
	content: '\2192';
	transition: transform 180ms ease;
}

.industry-related__list a:hover {
	color: var(--dd-secondary-dark);
}

.industry-related__list a:hover::after {
	transform: translateX(4px);
}

/* ------------------------------------------------------------------ */
/* 10. BLOCK 09 — CTA                                                   */
/* ------------------------------------------------------------------ */
.industry-cta {
	background: var(--dd-primary);
	color: var(--dd-white);
	padding: var(--dd-section-pad) 0;
	text-align: center;
	background-image: linear-gradient(135deg, var(--dd-primary) 0%, var(--dd-primary-dark) 100%);
}

.industry-cta__inner {
	max-width: 820px;
}

.industry-cta__headline {
	font-size: 36px;
	font-weight: 700;
	color: var(--dd-white);
	line-height: 1.25;
	margin: 0 0 16px;
}

.industry-cta__trust {
	font-size: 15px;
	color: rgba(255, 255, 255, 0.85);
	margin: 0 0 32px;
	letter-spacing: 0.4px;
}

.industry-cta__buttons {
	display: flex;
	gap: 16px;
	justify-content: center;
	flex-wrap: wrap;
}

/* ------------------------------------------------------------------ */
/* 11. Responsive : tablet                                              */
/* ------------------------------------------------------------------ */
@media (max-width: 1024px) {
	.industry-hero__headline { font-size: 40px; }
	.industry-h2 { font-size: 30px; }

	/* Trust bar: collapse 5-col grid to 3 on smaller desktops/tablets */
	.industry-trust-bar__list {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.industry-overview__grid,
	.industry-audit-docs__grid {
		grid-template-columns: 1fr;
		gap: 40px;
	}

	.industry-pain-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.industry-related__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ------------------------------------------------------------------ */
/* 12. Responsive : mobile                                              */
/* ------------------------------------------------------------------ */
@media (max-width: 720px) {
	:root {
		--dd-section-pad: var(--dd-section-pad-mobile);
	}

	.industry-container { padding: 0 18px; }

	.industry-hero { min-height: 360px; padding: 56px 0; }
	.industry-hero__headline { font-size: 30px; }
	.industry-hero__subhead { font-size: 17px; }
	.industry-eyebrow { font-size: 12px; }

	.industry-h2 { font-size: 26px; }
	.industry-cta__headline { font-size: 26px; }

	/* Trust bar: 1 column on mobile */
	.industry-trust-bar__list {
		grid-template-columns: 1fr;
		gap: 10px;
	}

	.industry-trust-bar__item {
		justify-content: flex-start;
		text-align: left;
	}

	.industry-pain-grid,
	.industry-related__grid {
		grid-template-columns: 1fr;
	}

	.industry-accordion__summary {
		padding: 16px 18px;
		gap: 10px;
	}

	.industry-accordion__title { font-size: 16px; }

	.industry-accordion__citation {
		font-size: 12px;
		width: 100%;
		flex-basis: 100%;
	}

	.industry-hero__cta,
	.industry-cta__buttons {
		flex-direction: column;
		align-items: stretch;
	}

	.industry-btn {
		text-align: center;
		padding: 14px 24px;
	}

	.industry-btn--large {
		padding: 16px 28px;
		font-size: 16px;
	}

	.industry-overview__stats {
		padding: 24px;
	}

	.industry-certificate-placeholder {
		padding: 28px 22px;
	}
}

/* ------------------------------------------------------------------ */
/* 12b. Industries archive hub (/industries/) — card grid               */
/* Reference layout: compliance card archive (All Green Recycling)    */
/* ------------------------------------------------------------------ */
.industry-archive {
	font-family: var(--dd-font-body);
	color: var(--dd-text);
	line-height: 1.6;
}

.industry-archive * {
	box-sizing: border-box;
}

/*
 * Archive hero — matches the dark-red geometric banner on /services/.
 * If a custom background image is set (inline style via PHP), it is used.
 * Fallback is the CSS dark-red radial gradient to match the same look.
 */
.industry-archive-hero {
	position: relative;
	background-color: #1a0000;
	/* Fallback gradient — same dark-red tone as the services banner */
	background-image: radial-gradient(ellipse at 60% 40%, #5a0a0a 0%, #2d0000 45%, #0e0000 100%);
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	color: var(--dd-white);
	padding: 56px 0 52px;
	overflow: hidden;
}

/* Dark overlay so text stays readable over any background image */
.industry-archive-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.45);
	z-index: 0;
}

.industry-archive-hero .industry-container {
	position: relative;
	z-index: 1;
}

.industry-archive-hero__title {
	margin: 0 0 8px;
	font-size: clamp(1.6rem, 3.5vw, 2.25rem);
	font-weight: 700;
	line-height: 1.2;
	color: var(--dd-white);
	/* Thin white underline accent — matching the services banner style */
	padding-bottom: 12px;
}

.industry-archive-hero__title::after {
	content: '';
	display: block;
	width: 56px;
	height: 2px;
	background: var(--dd-white);
	margin-top: 10px;
	opacity: 0.85;
}

.industry-archive-hero__lead {
	margin: 0;
	max-width: 680px;
	font-size: 1rem;
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.88);
}

.industry-archive-cards {
	background: var(--dd-light);
	padding: 48px 0 64px;
}

.industry-archive-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
}

.industry-archive-card {
	margin: 0;
	background: var(--dd-white);
	border: 1px solid var(--dd-border);
	border-radius: var(--dd-radius-md);
	box-shadow: var(--dd-shadow-sm);
	transition: box-shadow 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
	overflow: hidden;
}

.industry-archive-card:hover,
.industry-archive-card:focus-within {
	box-shadow: var(--dd-shadow-md);
	transform: translateY(-3px);
	border-color: rgba(0, 71, 127, 0.25);
}

.industry-archive-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	color: inherit;
	text-decoration: none !important;
}

.industry-archive-card__link:hover,
.industry-archive-card__link:focus,
.industry-archive-card__link .industry-archive-card__badge,
.industry-archive-card__link .industry-archive-card__title,
.industry-archive-card__link .industry-archive-card__excerpt,
.industry-archive-card__link .industry-archive-card__cta {
	text-decoration: none !important;
}

.industry-archive-card__link:focus-visible {
	outline: 3px solid var(--dd-secondary);
	outline-offset: 2px;
}

.industry-archive-card__media {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 200px;
	min-height: 200px;
	max-height: 200px;
	padding: 0;
	overflow: hidden;
	background: #0a1628;
	border-bottom: 1px solid var(--dd-border);
}

.industry-archive-card__img {
	display: block;
	width: 100%;
	height: 100%;
	max-width: 100%;
	max-height: 100%;
	object-fit: cover;
	object-position: center center;
}

.industry-archive-card__body {
	display: flex;
	flex-direction: column;
	flex: 1;
	padding: 12px 14px 14px;
}

.industry-archive-card__badge {
	margin: 0 0 4px;
	font-size: 0.62rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--dd-secondary);
	line-height: 1.2;
}

.industry-archive-card__title {
	margin: 0 0 6px;
	font-size: 0.9rem;
	font-weight: 700;
	line-height: 1.3;
	color: var(--dd-primary);
}

.industry-archive-card__excerpt {
	margin: 0 0 8px;
	flex: 1;
	font-size: 0.78rem;
	line-height: 1.4;
	color: var(--dd-text-muted);
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.industry-archive-card__cta {
	margin-top: auto;
	font-size: 0.72rem;
	font-weight: 700;
	color: var(--dd-secondary);
}

.industry-archive-card__cta span[aria-hidden="true"] {
	margin-left: 4px;
	transition: transform 0.15s ease;
}

.industry-archive-card:hover .industry-archive-card__cta span[aria-hidden="true"] {
	transform: translateX(3px);
}

.industry-archive-empty {
	text-align: center;
	color: var(--dd-text-muted);
	padding: 2rem 0;
}

.industry-archive .nav-links,
.industry-archive .pagination {
	margin-top: 40px;
	text-align: center;
}

@media (max-width: 1024px) {
	.industry-archive-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.industry-archive-hero {
		padding: 40px 0 32px;
	}

	.industry-archive-cards {
		padding: 32px 0 48px;
	}

	.industry-archive-grid {
		grid-template-columns: 1fr;
		gap: 16px;
	}

	.industry-archive-card__media {
		height: 180px;
		min-height: 180px;
		max-height: 180px;
	}
}

/* ------------------------------------------------------------------ */
/* 12c. Compliance archive hub (/compliance/) — card grid                 */
/* ------------------------------------------------------------------ */
.compliance-archive {
	font-family: var(--dd-font-body);
	color: var(--dd-text);
	line-height: 1.6;
}

.compliance-archive * {
	box-sizing: border-box;
}

.compliance-archive-hero {
	position: relative;
	background-color: #1a0000;
	background-image: radial-gradient(ellipse at 60% 40%, #5a0a0a 0%, #2d0000 45%, #0e0000 100%);
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	color: var(--dd-white);
	padding: 56px 0 52px;
	overflow: hidden;
}

.compliance-archive-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.45);
	z-index: 0;
}

.compliance-archive-hero .compliance-container {
	position: relative;
	z-index: 1;
}

.compliance-archive-hero__title {
	margin: 0 0 8px;
	font-size: clamp(1.6rem, 3.5vw, 2.25rem);
	font-weight: 700;
	line-height: 1.2;
	color: var(--dd-white);
	padding-bottom: 12px;
}

.compliance-archive-hero__title::after {
	content: '';
	display: block;
	width: 56px;
	height: 2px;
	background: var(--dd-white);
	margin-top: 10px;
	opacity: 0.85;
}

.compliance-archive-hero__lead {
	margin: 0;
	max-width: 720px;
	font-size: 1rem;
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.88);
}

.compliance-archive-cards {
	background: var(--dd-light);
	padding: 48px 0 64px;
}

.compliance-archive-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
}

.compliance-archive-card {
	margin: 0;
	background: var(--dd-white);
	border: 1px solid var(--dd-border);
	border-radius: var(--dd-radius-md);
	box-shadow: var(--dd-shadow-sm);
	transition: box-shadow 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
	overflow: hidden;
}

.compliance-archive-card:hover,
.compliance-archive-card:focus-within {
	box-shadow: var(--dd-shadow-md);
	transform: translateY(-3px);
	border-color: rgba(0, 71, 127, 0.25);
}

.compliance-archive-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	color: inherit;
	text-decoration: none !important;
}

.compliance-archive-card__link:hover,
.compliance-archive-card__link:focus,
.compliance-archive-card__link .compliance-archive-card__badge,
.compliance-archive-card__link .compliance-archive-card__title,
.compliance-archive-card__link .compliance-archive-card__excerpt,
.compliance-archive-card__link .compliance-archive-card__cta {
	text-decoration: none !important;
}

.compliance-archive-card__link:focus-visible {
	outline: 3px solid var(--dd-secondary);
	outline-offset: 2px;
}

.compliance-archive-card__media {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 200px;
	min-height: 200px;
	max-height: 200px;
	padding: 12px 16px;
	overflow: hidden;
	background: #f4f7fa;
	border-bottom: 1px solid var(--dd-border);
}

.compliance-archive-card__img {
	display: block;
	width: 100%;
	height: 100%;
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	object-position: center center;
}

.compliance-archive-card__body {
	display: flex;
	flex-direction: column;
	flex: 1;
	padding: 12px 14px 14px;
}

.compliance-archive-card__badge {
	margin: 0 0 4px;
	font-size: 0.62rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--dd-secondary);
	line-height: 1.2;
}

.compliance-archive-card__title {
	margin: 0 0 6px;
	font-size: 0.9rem;
	font-weight: 700;
	line-height: 1.3;
	color: var(--dd-primary);
}

.compliance-archive-card__excerpt {
	margin: 0 0 8px;
	flex: 1;
	font-size: 0.78rem;
	line-height: 1.4;
	color: var(--dd-text-muted);
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.compliance-archive-card__cta {
	margin-top: auto;
	font-size: 0.72rem;
	font-weight: 700;
	color: var(--dd-secondary);
}

.compliance-archive-card__cta span[aria-hidden="true"] {
	margin-left: 4px;
	transition: transform 0.15s ease;
}

.compliance-archive-card:hover .compliance-archive-card__cta span[aria-hidden="true"] {
	transform: translateX(3px);
}

.compliance-archive-empty {
	text-align: center;
	color: var(--dd-text-muted);
	padding: 2rem 0;
}

@media (max-width: 1024px) {
	.compliance-archive-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.compliance-archive-hero {
		padding: 40px 0 32px;
	}

	.compliance-archive-cards {
		padding: 32px 0 48px;
	}

	.compliance-archive-grid {
		grid-template-columns: 1fr;
		gap: 16px;
	}

	.compliance-archive-card__media {
		height: 180px;
		min-height: 180px;
		max-height: 180px;
	}
}

/* ------------------------------------------------------------------ */
/* 13. Print                                                            */
/* ------------------------------------------------------------------ */
@media print {
	.industry-hero,
	.industry-cta,
	.industry-audit-docs { background: var(--dd-white) !important; color: var(--dd-text) !important; }
	.industry-hero__headline,
	.industry-cta__headline,
	.industry-audit-doc__name { color: var(--dd-primary) !important; }
	.industry-btn { display: none !important; }
	.industry-accordion__item { box-shadow: none !important; }
	.industry-accordion__item[open],
	.industry-accordion__item:not([open]) > .industry-accordion__body { display: block !important; }
}

/* =========================================================================
   QUOTE MODAL
   ========================================================================= */

/* Hidden state — the [hidden] attribute drives visibility */
.ddi-modal[hidden] {
	display: none;
}

/* Full-screen container */
.ddi-modal {
	position: fixed;
	inset: 0;
	z-index: 99999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
}

/* Semi-transparent backdrop */
.ddi-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba( 0, 0, 0, 0.65 );
	cursor: pointer;
}

/* Centered dialog card */
.ddi-modal__dialog {
	position: relative;
	background: #ffffff;
	border-radius: 10px;
	width: 100%;
	max-width: 580px;
	max-height: 90vh;
	overflow-y: auto;
	box-shadow: 0 24px 64px rgba( 0, 0, 0, 0.35 );
	padding: 2.5rem 2.5rem 2rem;
	/* Sit above the backdrop */
	z-index: 1;
}

/* Close × button */
.ddi-modal__close {
	position: absolute;
	top: 1rem;
	right: 1rem;
	background: none;
	border: none;
	font-size: 1.75rem;
	line-height: 1;
	color: #555555;
	cursor: pointer;
	padding: 0.3rem 0.6rem;
	border-radius: 4px;
	transition: background 0.15s ease, color 0.15s ease;
}
.ddi-modal__close:hover,
.ddi-modal__close:focus-visible {
	background: #f0f0f0;
	color: #000000;
	outline: none;
}

/* Content inside the dialog */
.ddi-modal__content {
	padding-top: 0.25rem;
}

.ddi-modal__heading {
	font-size: 1.5rem;
	font-weight: 700;
	color: var( --dd-primary, #00477f );
	margin: 0 0 0.4rem;
	padding-right: 2.5rem; /* clear close button */
	line-height: 1.25;
}

.ddi-modal__subhead {
	font-size: 0.875rem;
	color: #555555;
	margin: 0 0 1.5rem;
}

.ddi-modal__phone {
	color: var( --dd-primary, #00477f );
	font-weight: 600;
	text-decoration: none;
}
.ddi-modal__phone:hover {
	text-decoration: underline;
}

/* Prevent body scroll when modal is open */
body.ddi-modal-open {
	overflow: hidden;
}

/* ---- Gravity Forms inside modal ---- */
.ddi-modal .gform_wrapper {
	margin: 0;
}
.ddi-modal .gform_wrapper .gform_title,
.ddi-modal .gform_wrapper .gform_description {
	display: none; /* title/description suppressed via shortcode attr */
}
.ddi-modal .gform_wrapper input[type="text"],
.ddi-modal .gform_wrapper input[type="email"],
.ddi-modal .gform_wrapper input[type="tel"],
.ddi-modal .gform_wrapper textarea,
.ddi-modal .gform_wrapper select {
	width: 100%;
	border: 1px solid #cccccc;
	border-radius: 6px;
	padding: 0.6rem 0.75rem;
	font-size: 0.95rem;
	font-family: inherit;
	transition: border-color 0.15s ease;
}
.ddi-modal .gform_wrapper input:focus,
.ddi-modal .gform_wrapper textarea:focus,
.ddi-modal .gform_wrapper select:focus {
	border-color: var( --dd-primary, #00477f );
	outline: none;
	box-shadow: 0 0 0 3px rgba( 0, 71, 127, 0.18 );
}
.ddi-modal .gform_wrapper .gform_footer .gform_button,
.ddi-modal .gform_wrapper .gform_page_footer .gform_next_button,
.ddi-modal .gform_wrapper .gform_page_footer .button {
	background: var( --dd-secondary, #004bed );
	color: #ffffff;
	border: none;
	border-radius: 6px;
	padding: 0.75rem 2rem;
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s ease;
	width: 100%;
	margin-top: 0.5rem;
}
.ddi-modal .gform_wrapper .gform_footer .gform_button:hover,
.ddi-modal .gform_wrapper .gform_page_footer .gform_next_button:hover {
	background: var( --dd-secondary-dark, #003ec4 );
}
/* Confirmation message inside modal */
.ddi-modal .gform_confirmation_wrapper {
	text-align: center;
	padding: 1.5rem 0;
	color: #1a6e2e;
	font-weight: 600;
}

/* ---- Mobile adjustments ---- */
@media ( max-width: 600px ) {
	.ddi-modal {
		align-items: flex-end;
		padding: 0;
	}
	.ddi-modal__dialog {
		border-bottom-left-radius: 0;
		border-bottom-right-radius: 0;
		max-height: 92vh;
		padding: 2rem 1.25rem 1.5rem;
	}
}

/* ================================================================== */
/* COMPLIANCE ENCYCLOPEDIA CPT — single-compliance.php styles         */
/* ================================================================== */

/* ------------------------------------------------------------------ */
/* C0. Base + container                                                */
/* ------------------------------------------------------------------ */
.compliance-single {
	font-family: var(--dd-font-body);
	color: var(--dd-text);
	line-height: 1.7;
	overflow-x: hidden;
}

.compliance-single * {
	box-sizing: border-box;
}

.compliance-container {
	max-width: var(--dd-container-max);
	margin: 0 auto;
	padding: 0 24px;
	width: 100%;
}

/* ------------------------------------------------------------------ */
/* C1. Breadcrumb                                                      */
/* ------------------------------------------------------------------ */
.compliance-breadcrumb {
	background: var(--dd-light-2);
	border-bottom: 1px solid var(--dd-border);
	padding: 10px 0;
	font-size: 13px;
	color: var(--dd-text-muted);
}

.compliance-breadcrumb__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	align-items: center;
}

.compliance-breadcrumb__list li + li::before {
	content: '›';
	margin-right: 4px;
	color: var(--dd-text-muted);
}

.compliance-breadcrumb__list a {
	color: var(--dd-secondary);
	text-decoration: none;
}

.compliance-breadcrumb__list a:hover {
	text-decoration: underline;
}

/* Rank Math breadcrumb override (uses span.separator) */
.compliance-breadcrumb .rank-math-breadcrumb {
	font-size: 13px;
	color: var(--dd-text-muted);
}

.compliance-breadcrumb .rank-math-breadcrumb a {
	color: var(--dd-secondary);
	text-decoration: none;
}

/* ------------------------------------------------------------------ */
/* C2. Hero                                                            */
/* ------------------------------------------------------------------ */
.compliance-hero {
	background-color: #0a2540;
	background-image:
		url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%2300aed9' fill-opacity='0.06'%3E%3Cpath d='M50 50c0-5.523 4.477-10 10-10s10 4.477 10 10-4.477 10-10 10c0 5.523-4.477 10-10 10s-10-4.477-10-10 4.477-10 10-10zM10 10c0-5.523 4.477-10 10-10s10 4.477 10 10-4.477 10-10 10c0 5.523-4.477 10-10 10S0 25.523 0 20s4.477-10 10-10z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
		radial-gradient(ellipse at 75% 40%, rgba(0,75,237,0.30) 0%, transparent 60%),
		radial-gradient(ellipse at 15% 75%, rgba(0,174,217,0.15) 0%, transparent 50%);
	background-size: 80px 80px, cover, cover;
	background-position: center, center, center;
	min-height: 480px;
	display: flex;
	align-items: center;
	padding: 80px 0;
	color: var(--dd-white);
	position: relative;
}

.compliance-eyebrow {
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--dd-accent);
	margin: 0 0 14px;
	opacity: 0.9;
}

.compliance-hero__headline {
	font-size: clamp(30px, 4vw, 48px);
	font-weight: 700;
	line-height: 1.15;
	color: var(--dd-white);
	margin: 0 0 20px;
	max-width: 860px;
}

.compliance-hero__lead {
	font-size: 18px;
	line-height: 1.55;
	color: rgba(255,255,255,0.90);
	max-width: 760px;
	margin: 0 0 32px;
}

/* ------------------------------------------------------------------ */
/* C2b. Trust Bar (mirrors industry-trust-bar)                         */
/* ------------------------------------------------------------------ */
.compliance-trust-bar {
	background: var(--dd-primary-dark);
	color: var(--dd-white);
	padding: 24px 0;
	border-top: 1px solid rgba(255,255,255,0.08);
}

.compliance-trust-bar__list {
	display: grid;
	grid-template-columns: repeat( auto-fit, minmax( 200px, 1fr ) );
	gap: 14px 20px;
	list-style: none;
	margin: 0;
	padding: 0;
	align-items: center;
}

.compliance-trust-bar__item {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	font-size: 13px;
	font-weight: 600;
	color: var(--dd-white);
	text-align: center;
	line-height: 1.45;
}

.compliance-trust-bar__item > span:last-child {
	flex: 1;
	min-width: 0;
}

.compliance-trust-bar__icon {
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: var(--dd-accent);
	color: var(--dd-primary-dark);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	font-weight: 700;
	flex-shrink: 0;
}

@media ( max-width: 960px ) {
	.compliance-trust-bar__list {
		grid-template-columns: repeat( 3, minmax( 0, 1fr ) );
	}
}

@media ( max-width: 640px ) {
	.compliance-trust-bar__list {
		grid-template-columns: 1fr;
		gap: 10px;
	}
	.compliance-trust-bar__item {
		justify-content: flex-start;
		text-align: left;
	}
}

/* Legacy badge pills (kept for backward compat, no longer in hero) */
.compliance-badge {
	display: flex;
	align-items: center;
	gap: 8px;
	background: rgba(255,255,255,0.10);
	border: 1px solid rgba(255,255,255,0.18);
	border-radius: 6px;
	padding: 8px 14px;
	font-size: 13px;
	color: rgba(255,255,255,0.92);
	line-height: 1.3;
}

.compliance-badge__icon {
	font-size: 15px;
	flex-shrink: 0;
}

/* Hero CTA buttons */
.compliance-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: center;
}

/* ------------------------------------------------------------------ */
/* C3. Buttons                                                         */
/* ------------------------------------------------------------------ */
.compliance-btn {
	display: inline-block;
	font-family: var(--dd-font-body);
	font-weight: 600;
	font-size: 15px;
	line-height: 1;
	text-decoration: none !important;
	padding: 14px 28px;
	border-radius: var(--dd-radius-md);
	border: 2px solid transparent;
	cursor: pointer;
	transition: all 180ms ease;
	white-space: nowrap;
	text-align: center;
}

.compliance-btn--primary {
	background: var(--dd-secondary);
	color: var(--dd-white) !important;
	border-color: var(--dd-secondary);
}

.compliance-btn--primary:hover {
	background: var(--dd-secondary-dark);
	border-color: var(--dd-secondary-dark);
	color: var(--dd-white) !important;
	transform: translateY(-1px);
	box-shadow: var(--dd-shadow-md);
}

.compliance-btn--ghost {
	background: transparent;
	color: rgba(255,255,255,0.92) !important;
	border-color: rgba(255,255,255,0.5);
}

.compliance-btn--ghost:hover {
	background: rgba(255,255,255,0.10);
	border-color: rgba(255,255,255,0.8);
	color: var(--dd-white) !important;
}

.compliance-btn--large {
	font-size: 16px;
	padding: 16px 36px;
}

.compliance-btn--block {
	display: block;
	width: 100%;
}

/* ------------------------------------------------------------------ */
/* C4. Main layout: content + sidebar                                  */
/* ------------------------------------------------------------------ */
.compliance-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 300px;
	gap: 48px;
	padding-top: 56px;
	padding-bottom: 64px;
	align-items: start;
}

@media ( max-width: 1024px ) {
	.compliance-layout {
		grid-template-columns: 1fr;
	}
	.compliance-sidebar {
		order: -1; /* Show sidebar above content on smaller screens */
	}
}

/* ------------------------------------------------------------------ */
/* C5. Content column — Gutenberg body styles                         */
/* ------------------------------------------------------------------ */
.compliance-content {
	min-width: 0;
}

.compliance-content h2 {
	font-size: 28px;
	font-weight: 700;
	color: var(--dd-primary);
	line-height: 1.25;
	margin: 56px 0 20px;
	padding: 0 0 14px 18px;
	border-bottom: 1px solid var(--dd-border);
	border-left: 4px solid var(--dd-accent);
	background: transparent;
}

.compliance-content h2:first-child {
	margin-top: 0;
}

.compliance-content h3 {
	font-size: 20px;
	font-weight: 700;
	color: var(--dd-primary-dark);
	line-height: 1.35;
	margin: 32px 0 12px;
}

.compliance-content h4 {
	font-size: 16px;
	font-weight: 700;
	color: var(--dd-text);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin: 24px 0 8px;
}

.compliance-content p {
	font-size: 16px;
	line-height: 1.75;
	margin: 0 0 18px;
	color: var(--dd-text);
}

.compliance-content a {
	color: var(--dd-secondary);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.compliance-content a:hover {
	color: var(--dd-secondary-dark);
}

.compliance-content strong {
	font-weight: 700;
	color: var(--dd-text);
}

.compliance-content ul,
.compliance-content ol {
	margin: 0 0 20px 24px;
	padding: 0;
}

.compliance-content li {
	font-size: 16px;
	line-height: 1.7;
	margin-bottom: 6px;
}

/* Section citation style (inline code used for reg citations) */
.compliance-content code {
	font-family: 'Courier New', Courier, monospace;
	font-size: 13px;
	background: var(--dd-light-2);
	border: 1px solid var(--dd-border);
	border-radius: 3px;
	padding: 2px 6px;
	color: var(--dd-primary-dark);
	white-space: nowrap;
}

.compliance-content pre {
	background: var(--dd-light-2);
	border: 1px solid var(--dd-border);
	border-left: 4px solid var(--dd-primary);
	border-radius: var(--dd-radius-sm);
	padding: 16px 20px;
	font-size: 14px;
	overflow-x: auto;
	margin: 0 0 24px;
}

/* Tables — used for regulation requirements, method mapping */
.compliance-content table,
.compliance-content .wp-block-table table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
	margin: 0 0 28px;
	background: var(--dd-white);
	border: 1px solid var(--dd-border);
	border-radius: var(--dd-radius-sm);
	overflow: hidden;
}

.compliance-content th,
.compliance-content .wp-block-table th {
	background: var(--dd-primary);
	color: var(--dd-white);
	font-weight: 700;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 12px 16px;
	text-align: left;
	vertical-align: top;
}

.compliance-content td,
.compliance-content .wp-block-table td {
	padding: 11px 16px;
	border-bottom: 1px solid var(--dd-border);
	vertical-align: top;
	line-height: 1.55;
}

.compliance-content tr:last-child td {
	border-bottom: none;
}

.compliance-content tr:nth-child(even) td {
	background: var(--dd-light);
}

/* Responsive tables */
@media ( max-width: 640px ) {
	.compliance-content table,
	.compliance-content .wp-block-table table {
		display: block;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
}

/* Blockquotes — used for citing official definitions */
.compliance-content blockquote,
.compliance-content .wp-block-quote {
	margin: 24px 0;
	padding: 20px 24px;
	border-left: 4px solid var(--dd-accent);
	background: var(--dd-light);
	border-radius: 0 var(--dd-radius-sm) var(--dd-radius-sm) 0;
	font-style: italic;
	color: var(--dd-text-muted);
}

.compliance-content blockquote p,
.compliance-content .wp-block-quote p {
	margin: 0 0 8px;
}

.compliance-content blockquote p:last-child,
.compliance-content .wp-block-quote p:last-child {
	margin-bottom: 0;
}

.compliance-content blockquote cite,
.compliance-content .wp-block-quote cite {
	font-size: 13px;
	font-style: normal;
	color: var(--dd-text-muted);
}

/* Rank Math FAQ block — interactive accordion (JS adds toggle behavior) */
.compliance-content .wp-block-rank-math-faq-block {
	margin: 8px 0 32px;
}

.compliance-content .rank-math-faq-item {
	border: 1px solid var(--dd-border);
	border-radius: var(--dd-radius-md);
	margin-bottom: 8px;
	overflow: hidden;
}

.compliance-content .rank-math-question {
	font-size: 16px;
	font-weight: 700;
	color: var(--dd-primary);
	padding: 18px 48px 18px 20px;
	margin: 0;
	cursor: pointer;
	user-select: none;
	position: relative;
	background: var(--dd-white);
	transition: background 150ms ease;
}

.compliance-content .rank-math-question:hover {
	background: var(--dd-light);
}

/* Arrow indicator — CSS-only, toggled by aria-expanded via JS */
.compliance-content .rank-math-question::after {
	content: '›';
	position: absolute;
	right: 18px;
	top: 50%;
	transform: translateY(-50%) rotate(90deg);
	font-size: 20px;
	color: var(--dd-primary);
	transition: transform 200ms ease;
}

.compliance-content .rank-math-question[aria-expanded="false"]::after {
	transform: translateY(-50%) rotate(0deg);
}

.compliance-content .rank-math-answer {
	padding: 0 20px 20px;
	font-size: 15px;
	line-height: 1.7;
	border-top: 1px solid var(--dd-border);
	background: var(--dd-light);
}

.compliance-content .rank-math-answer p:first-child {
	margin-top: 16px;
}

/* ------------------------------------------------------------------ */
/* C6. Sidebar                                                         */
/* ------------------------------------------------------------------ */
.compliance-sidebar {
	position: sticky;
	top: 24px;
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.compliance-sidebar__widget {
	background: var(--dd-white);
	border: 1px solid var(--dd-border);
	border-radius: var(--dd-radius-lg);
	padding: 20px 22px;
	box-shadow: var(--dd-shadow-sm);
}

.compliance-sidebar__widget-title {
	font-size: 13px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--dd-text-muted);
	margin: 0 0 14px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--dd-border);
}

.compliance-sidebar__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.compliance-sidebar__list li {
	border-bottom: 1px solid var(--dd-light-2);
}

.compliance-sidebar__list li:last-child {
	border-bottom: none;
}

.compliance-sidebar__list a {
	display: block;
	padding: 9px 4px;
	font-size: 14px;
	color: var(--dd-secondary);
	text-decoration: none;
	line-height: 1.4;
	transition: color 150ms ease, padding-left 150ms ease;
}

.compliance-sidebar__list a:hover {
	color: var(--dd-primary);
	padding-left: 8px;
}

.compliance-sidebar__item--active,
.compliance-sidebar__list a[aria-current="page"] {
	color: var(--dd-primary) !important;
	font-weight: 700;
}

.compliance-sidebar__hub-link {
	font-size: 13px;
	color: var(--dd-text-muted) !important;
	font-weight: 600;
}

/* Sidebar CTA card */
.compliance-sidebar__cta-card {
	background: var(--dd-primary);
	border-radius: var(--dd-radius-lg);
	padding: 24px 22px;
	text-align: center;
	box-shadow: var(--dd-shadow-md);
}

.compliance-sidebar__cta-title {
	font-size: 17px;
	font-weight: 700;
	color: var(--dd-white);
	margin: 0 0 8px;
}

.compliance-sidebar__cta-sub {
	font-size: 13px;
	color: rgba(255,255,255,0.82);
	line-height: 1.5;
	margin: 0 0 18px;
}

.compliance-sidebar__quote-link {
	display: block;
	margin-top: 12px;
	font-size: 13px;
	color: rgba(255,255,255,0.75);
	text-decoration: underline;
	text-underline-offset: 3px;
	transition: color 150ms ease;
}

.compliance-sidebar__quote-link:hover {
	color: var(--dd-white);
}

/* ------------------------------------------------------------------ */
/* C7. Related industries strip                                        */
/* ------------------------------------------------------------------ */
.compliance-related-industries {
	background: var(--dd-light);
	border-top: 1px solid var(--dd-border);
	border-bottom: 1px solid var(--dd-border);
	padding: 56px 0;
}

.compliance-related-industries__title {
	font-size: 26px;
	font-weight: 700;
	color: var(--dd-primary);
	text-align: center;
	margin: 0 0 36px;
}

.compliance-related-industries__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
}

@media ( max-width: 900px ) {
	.compliance-related-industries__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media ( max-width: 480px ) {
	.compliance-related-industries__grid {
		grid-template-columns: 1fr;
	}
}

.compliance-industry-card {
	display: flex;
	flex-direction: column;
	border-radius: var(--dd-radius-lg);
	overflow: hidden;
	background: var(--dd-white);
	border: 1px solid var(--dd-border);
	text-decoration: none;
	transition: box-shadow 180ms ease, transform 180ms ease;
	box-shadow: var(--dd-shadow-sm);
}

.compliance-industry-card:hover {
	box-shadow: var(--dd-shadow-md);
	transform: translateY(-3px);
}

.compliance-industry-card__img {
	height: 120px;
	background-size: cover;
	background-position: center;
	background-color: var(--dd-primary);
}

.compliance-industry-card__img--placeholder {
	background: linear-gradient(135deg, var(--dd-primary) 0%, var(--dd-accent) 100%);
}

.compliance-industry-card__label {
	display: block;
	padding: 14px 16px;
	font-size: 14px;
	font-weight: 700;
	color: var(--dd-primary);
	line-height: 1.35;
}

/* ------------------------------------------------------------------ */
/* C8. Bottom CTA section                                             */
/* ------------------------------------------------------------------ */
.compliance-cta {
	background: linear-gradient(135deg, var(--dd-primary-dark) 0%, var(--dd-primary) 100%);
	padding: var(--dd-section-pad) 0;
	text-align: center;
}

.compliance-cta__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
}

.compliance-cta__headline {
	font-size: clamp(22px, 3vw, 34px);
	font-weight: 700;
	color: var(--dd-white);
	line-height: 1.25;
	margin: 0;
	max-width: 700px;
}

.compliance-cta__trust {
	font-size: 14px;
	color: rgba(255,255,255,0.72);
	margin: 0;
	letter-spacing: 0.01em;
}

.compliance-cta__buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	justify-content: center;
	margin-top: 8px;
}

/* ------------------------------------------------------------------ */
/* C9. Mobile responsive overrides                                    */
/* ------------------------------------------------------------------ */
@media ( max-width: 960px ) {
	.compliance-hero {
		min-height: 400px;
		padding: 64px 0 56px;
	}
	.compliance-hero__headline {
		font-size: 34px;
	}
}

@media ( max-width: 768px ) {
	.compliance-hero {
		min-height: auto;
		padding: 52px 0 44px;
	}

	.compliance-hero__headline {
		font-size: 26px;
	}

	.compliance-hero__lead {
		font-size: 15px;
	}

	.compliance-hero__cta {
		flex-direction: column;
	}

	.compliance-btn {
		width: 100%;
		text-align: center;
	}

	.compliance-layout {
		padding-top: 36px;
		padding-bottom: 40px;
		gap: 32px;
	}

	.compliance-content h2 {
		font-size: 22px;
	}

	.compliance-related-industries {
		padding: 40px 0;
	}

	.compliance-cta {
		padding: var(--dd-section-pad-mobile) 0;
	}

	.compliance-cta__buttons {
		flex-direction: column;
		width: 100%;
		max-width: 320px;
	}
}

/* ------------------------------------------------------------------ */
/* C10. FAQ Accordion — uses <details>/<summary> tags                  */
/*     Any <details> placed inside .compliance-content is styled as   */
/*     a card-style accordion that matches the industry page FAQ.     */
/* ------------------------------------------------------------------ */
.compliance-content details,
.compliance-content .compliance-faq-item {
	background: var(--dd-white);
	border: 1px solid var(--dd-border);
	border-radius: var(--dd-radius-md);
	margin: 0 0 12px;
	overflow: hidden;
	transition: box-shadow 180ms ease, border-color 180ms ease;
	box-shadow: var(--dd-shadow-sm);
}

.compliance-content details[open],
.compliance-content .compliance-faq-item[open] {
	box-shadow: var(--dd-shadow-md);
	border-color: var(--dd-accent);
}

.compliance-content summary,
.compliance-content .compliance-faq-summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 20px 24px;
	font-size: 17px;
	font-weight: 600;
	color: var(--dd-primary);
	cursor: pointer;
	list-style: none;
	user-select: none;
	transition: background 150ms ease;
	line-height: 1.4;
}

.compliance-content summary::-webkit-details-marker,
.compliance-content .compliance-faq-summary::-webkit-details-marker {
	display: none;
}

.compliance-content summary::after,
.compliance-content .compliance-faq-summary::after {
	content: '\203A';
	color: var(--dd-secondary);
	font-size: 22px;
	font-weight: 400;
	transition: transform 200ms ease;
	flex-shrink: 0;
	line-height: 1;
}

.compliance-content details[open] summary::after,
.compliance-content .compliance-faq-item[open] .compliance-faq-summary::after {
	transform: rotate(90deg);
}

.compliance-content summary:hover,
.compliance-content .compliance-faq-summary:hover {
	background: var(--dd-light-2);
}

/* Body content inside the open accordion */
.compliance-content details > *:not(summary),
.compliance-content .compliance-faq-body {
	padding: 0 24px 22px;
	color: var(--dd-text);
	font-size: 16px;
	line-height: 1.7;
}

.compliance-content details > p:not(summary):first-of-type,
.compliance-content .compliance-faq-body > *:first-child {
	padding-top: 4px;
}

.compliance-content details p,
.compliance-content .compliance-faq-body p {
	margin: 0 0 12px;
}

.compliance-content details p:last-child,
.compliance-content .compliance-faq-body p:last-child {
	margin-bottom: 0;
}

/* Section wrapper for the FAQ heading + list                         */
.compliance-content .compliance-faq-section {
	margin: 40px 0 32px;
}

/* ------------------------------------------------------------------ */
/* C11. Definition / Methods / Requirement callout labels             */
/* ------------------------------------------------------------------ */
.compliance-content p strong:first-child {
	color: var(--dd-primary);
}

/* Native <hr> dividers between requirement / category blocks         */
.compliance-content hr {
	border: 0;
	height: 1px;
	background: var(--dd-border);
	margin: 36px 0;
}

/* ------------------------------------------------------------------ */
/* C12. Method-selection matrix wrapper                                */
/*     Wraps .compliance-content table for horizontal scroll on       */
/*     narrow screens without breaking the layout.                    */
/* ------------------------------------------------------------------ */
.compliance-method-matrix {
	overflow-x: auto;
	margin: 0 0 36px;
	border-radius: var(--dd-radius-md);
	border: 1px solid var(--dd-border);
}
.compliance-method-matrix table {
	margin: 0;
	border-radius: 0;
	border: none;
}

/* ------------------------------------------------------------------ */
/* C13. Related-regulations card grid                                  */
/* ------------------------------------------------------------------ */
.compliance-reg-grid {
	display: grid;
	grid-template-columns: repeat( 3, 1fr );
	gap: 14px;
	margin: 24px 0 36px;
}
.compliance-content a.compliance-reg-card,
.compliance-reg-card {
	background: var(--dd-primary);
	border: none;
	border-radius: var(--dd-radius-md);
	padding: 18px 20px;
	text-decoration: none !important;
	display: block;
	transition: background 150ms ease, box-shadow 150ms ease, transform 150ms ease;
}
.compliance-content a.compliance-reg-card:hover,
.compliance-reg-card:hover {
	background: var(--dd-primary-dark);
	box-shadow: var(--dd-shadow-md);
	transform: translateY( -2px );
	color: #ffffff !important;
	text-decoration: none !important;
}
.compliance-reg-card__title {
	display: block;
	font-size: 14px;
	font-weight: 700;
	color: #ffffff !important;
	margin: 0 0 6px;
	line-height: 1.3;
	text-decoration: none !important;
}
.compliance-reg-card__desc {
	display: block;
	font-size: 12px;
	color: #ffffff !important;
	margin: 0;
	line-height: 1.5;
	text-decoration: none !important;
}
.compliance-content a.compliance-reg-card:hover .compliance-reg-card__title,
.compliance-content a.compliance-reg-card:hover .compliance-reg-card__desc {
	color: #ffffff !important;
	text-decoration: none !important;
}

/* ------------------------------------------------------------------ */
/* C14. Source & reference card                                        */
/* ------------------------------------------------------------------ */
.compliance-source-card {
	display: grid;
	grid-template-columns: 1fr 1fr;
	border: 1px solid var(--dd-border);
	border-radius: var(--dd-radius-md);
	overflow: hidden;
	margin: 24px 0 36px;
}
.compliance-source-box {
	padding: 28px 28px 24px;
	background: var(--dd-light-2);
}
.compliance-source-box--dark {
	background: var(--dd-primary);
}
.compliance-source-box__label {
	display: block;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: var(--dd-secondary);
	margin: 0 0 10px;
}
.compliance-source-box--dark .compliance-source-box__label {
	color: rgba( 255, 255, 255, 0.55 );
}
.compliance-source-box__title {
	font-size: 16px;
	font-weight: 700;
	color: var(--dd-primary);
	margin: 0 0 8px;
	line-height: 1.35;
}
.compliance-source-box--dark .compliance-source-box__title {
	color: var(--dd-white);
}
.compliance-source-box__link {
	font-size: 13px;
	color: var(--dd-secondary);
	word-break: break-all;
	text-decoration: none;
}
.compliance-source-box--dark .compliance-source-box__link {
	color: rgba( 255, 255, 255, 0.65 );
}
.compliance-source-btn {
	display: inline-block;
	margin-top: 18px;
	background: var(--dd-accent);
	color: var(--dd-white) !important;
	padding: 10px 22px;
	border-radius: var(--dd-radius-sm);
	font-size: 14px;
	font-weight: 700;
	text-decoration: none;
	transition: background 150ms ease;
}
.compliance-source-btn:hover {
	background: #b01c2c;
	color: var(--dd-white) !important;
}

/* ------------------------------------------------------------------ */
/* C15. Sidebar Gravity Form widget — brand primary                    */
/* ------------------------------------------------------------------ */

/* Outer container — standalone class, no longer inherits base widget  */
.compliance-sidebar__widget--form {
	background: var(--dd-primary) !important;
	border: none !important;
	border-radius: var(--dd-radius-md) !important;
	padding: 24px 20px 20px !important;
	overflow: hidden !important;
	box-shadow: var(--dd-shadow-md) !important;
}

/* Our custom H3 title inside the form widget */
.compliance-sidebar__widget--form .compliance-form-title {
	color: #ffffff !important;
	font-size: 13px !important;
	font-weight: 700 !important;
	letter-spacing: 0.07em !important;
	text-transform: uppercase !important;
	margin: 0 0 18px !important;
	padding-bottom: 14px !important;
	border-bottom: 1px solid rgba( 255,255,255,0.2 ) !important;
}

/* ---- GF internals ---- */
.compliance-sidebar__widget--form .gform_wrapper,
.compliance-sidebar__widget--form .gform_wrapper form {
	margin: 0 !important;
	padding: 0 !important;
	background: transparent !important;
	border: none !important;
}

/* Remove bullet list from GF field list */
.compliance-sidebar__widget--form ul.gform_fields,
.compliance-sidebar__widget--form .gform_fields {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

/* Each field li */
.compliance-sidebar__widget--form .gfield {
	margin: 0 0 10px !important;
	padding: 0 !important;
	list-style: none !important;
}
.compliance-sidebar__widget--form li.gfield::before,
.compliance-sidebar__widget--form li.gfield::marker {
	display: none !important;
	content: "" !important;
}

/* Hide ALL labels (rely on placeholders) */
.compliance-sidebar__widget--form label,
.compliance-sidebar__widget--form .gfield_label,
.compliance-sidebar__widget--form .gfield_description,
.compliance-sidebar__widget--form .gform-field-label,
.compliance-sidebar__widget--form .ginput_complex span > label,
.compliance-sidebar__widget--form .ginput_complex .gfield_label {
	display: none !important;
}

/* Text inputs, email, tel */
.compliance-sidebar__widget--form input[type="text"],
.compliance-sidebar__widget--form input[type="email"],
.compliance-sidebar__widget--form input[type="tel"],
.compliance-sidebar__widget--form input[type="number"] {
	background: #ffffff !important;
	border: none !important;
	border-radius: 6px !important;
	padding: 11px 14px !important;
	font-size: 14px !important;
	color: #222 !important;
	width: 100% !important;
	box-sizing: border-box !important;
	box-shadow: none !important;
}

/* Dropdowns */
.compliance-sidebar__widget--form select {
	background: #ffffff !important;
	border: none !important;
	border-radius: 6px !important;
	padding: 11px 14px !important;
	font-size: 14px !important;
	color: #222 !important;
	width: 100% !important;
	box-sizing: border-box !important;
}

/* Textarea */
.compliance-sidebar__widget--form textarea {
	background: #ffffff !important;
	border: none !important;
	border-radius: 6px !important;
	padding: 11px 14px !important;
	font-size: 14px !important;
	color: #222 !important;
	width: 100% !important;
	box-sizing: border-box !important;
	min-height: 80px !important;
	resize: vertical !important;
}

/* Placeholders */
.compliance-sidebar__widget--form input::placeholder,
.compliance-sidebar__widget--form textarea::placeholder {
	color: #999 !important;
	opacity: 1 !important;
}

/* ginput_container wrapper */
.compliance-sidebar__widget--form .ginput_container {
	margin: 0 !important;
}

/* Form footer */
.compliance-sidebar__widget--form .gform_footer,
.compliance-sidebar__widget--form .gform_page_footer {
	padding: 8px 0 0 !important;
	margin: 0 !important;
}

/* Submit button */
.compliance-sidebar__widget--form input[type="submit"],
.compliance-sidebar__widget--form button[type="submit"],
.compliance-sidebar__widget--form .gform_button {
	background: var(--dd-white) !important;
	color: var(--dd-primary) !important;
	border: none !important;
	border-radius: 6px !important;
	width: 100% !important;
	padding: 13px 20px !important;
	font-size: 13px !important;
	font-weight: 700 !important;
	letter-spacing: 0.06em !important;
	text-transform: uppercase !important;
	cursor: pointer !important;
	transition: background 150ms ease, opacity 150ms ease !important;
	display: block !important;
}
.compliance-sidebar__widget--form input[type="submit"]:hover,
.compliance-sidebar__widget--form button[type="submit"]:hover,
.compliance-sidebar__widget--form .gform_button:hover {
	background: var(--dd-light-2) !important;
	color: var(--dd-primary-dark) !important;
}

/* Hide stray <p> / <br> artifacts wpautop injects inside grid containers */
.compliance-reg-grid > p,
.compliance-reg-grid > br,
.compliance-method-matrix > p,
.compliance-method-matrix > br {
	display: none !important;
}

/* Responsive for new sections */
@media ( max-width: 640px ) {
	.compliance-source-card {
		grid-template-columns: 1fr;
	}
	.compliance-reg-grid {
		grid-template-columns: 1fr;
	}
}
@media ( min-width: 641px ) and ( max-width: 900px ) {
	.compliance-reg-grid {
		grid-template-columns: repeat( 2, 1fr );
	}
}

/* ------------------------------------------------------------------ */
/* STATE LAW PAGES (single-state-law.php)                             */
/* ------------------------------------------------------------------ */

/* Breadcrumb reuse — same as compliance-breadcrumb */

/* State Laws hub — reuses compliance-archive-hero + compliance-archive-card */
.state-law-hub-hero .state-law-hub-hero__eyebrow {
	margin: 0 0 12px;
	color: var(--dd-accent);
	opacity: 0.95;
}

.state-law-hub__intro {
	max-width: 820px;
	margin: 0 0 32px;
	font-size: 16px;
	line-height: 1.65;
}

/* State capitol photos: cover in 200px band (encyclopedia cards use contain for graphics) */
.state-law-hub-cards .compliance-archive-card__media {
	padding: 0;
	background: #0a1628;
}

.state-law-hub-cards .compliance-archive-card__img {
	object-fit: cover;
	object-position: center center;
}

/* Pinned 50-state overview — first card on hub */
@media ( min-width: 901px ) {
	.state-law-hub-cards .state-law-hub-card--featured {
		grid-column: 1 / -1;
		max-width: 420px;
	}
}

.state-law-sidebar__item--featured a {
	font-weight: 700;
}

/* Individual state page — hero (no trust bar) */
.state-law-hero {
	background-color: #0a2540;
	background-image:
		radial-gradient(ellipse at 75% 40%, rgba(0,75,237,0.28) 0%, transparent 60%),
		radial-gradient(ellipse at 15% 75%, rgba(0,174,217,0.15) 0%, transparent 50%);
	padding: 64px 0 56px;
	color: #fff;
}

.state-law-hero__title {
	font-size: clamp( 26px, 3.5vw, 44px );
	font-weight: 700;
	line-height: 1.15;
	color: #fff;
	margin: 0 0 18px;
	max-width: 860px;
}

.state-law-hero__lead {
	font-size: 17px;
	line-height: 1.6;
	color: rgba(255,255,255,0.88);
	max-width: 760px;
	margin: 0 0 28px;
}

.state-law-hero__lead p {
	margin: 0;
	font-size: inherit;
	line-height: inherit;
	color: inherit;
}

.state-law-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

/* Two-column layout */
.state-law-layout {
	display: grid;
	grid-template-columns: minmax( 0, 1fr ) 300px;
	gap: 40px;
	padding: 48px 0 64px;
	align-items: start;
}

/* 50-state overview: no sidebar — full-width content + table */
.state-law-layout--full-width {
	grid-template-columns: 1fr;
}

@media ( max-width: 960px ) {
	.state-law-layout {
		grid-template-columns: 1fr;
	}
}

/* Main content */
.state-law-content {
	min-width: 0;
	max-width: 100%;
	font-size: 16px;
	line-height: 1.7;
	overflow-wrap: break-word;
}

/* Wide tables — horizontal scroll inside content column only */
.state-law-table-scroll {
	width: 100%;
	max-width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	margin: 0 0 28px;
	border: 1px solid var(--dd-border);
	border-radius: var(--dd-radius-sm);
	background: var(--dd-white);
}

.state-law-table-scroll table {
	width: max-content;
	min-width: 100%;
	margin: 0;
	border: none;
	border-radius: 0;
	font-size: 13px;
}

.state-law-content table,
.state-law-content .matrx-content-container table {
	border-collapse: collapse;
}

.state-law-table-scroll th {
	background: var(--dd-primary);
	color: var(--dd-white);
	font-weight: 700;
	font-size: 12px;
	padding: 10px 14px;
	text-align: left;
	vertical-align: top;
	white-space: nowrap;
}

.state-law-table-scroll td {
	padding: 10px 14px;
	border-bottom: 1px solid var(--dd-border);
	vertical-align: top;
	line-height: 1.5;
	min-width: 120px;
}

.state-law-table-scroll tr:nth-child( even ) td {
	background: var(--dd-light);
}

.state-law-table-scroll tr:last-child td {
	border-bottom: none;
}

/* Sidebar */
.state-law-sidebar {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.state-law-sidebar__panel {
	background: var(--dd-white);
	border: 1px solid var(--dd-border);
	border-radius: 10px;
	padding: 20px 22px;
}


.state-law-sidebar__heading {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--dd-primary);
	margin: 0 0 14px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--dd-border);
}

.state-law-sidebar__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.state-law-sidebar__item {
	border-bottom: 1px solid var(--dd-border);
}

.state-law-sidebar__item:last-child {
	border-bottom: none;
}

.state-law-sidebar__item a {
	display: block;
	padding: 8px 0;
	font-size: 13px;
	color: var(--dd-primary);
	text-decoration: none !important;
	line-height: 1.4;
	transition: color 0.15s;
}

.state-law-sidebar__item a:hover {
	color: var(--dd-secondary);
}

.state-law-sidebar__item--back a {
	font-weight: 700;
	color: var(--dd-secondary);
	font-size: 12px;
}

.state-law-sidebar__item--active a {
	font-weight: 700;
	color: var(--dd-secondary);
}

.state-law-sidebar__empty a {
	font-size: 13px;
	color: var(--dd-secondary);
	font-weight: 700;
	text-decoration: none !important;
}

.state-law-page {
	padding-top: 0;
}
