/**
 * Policy Page Styles
 *
 * Archive and single template styles for Policy Recommendations.
 * Matches wireframe: sovereign-debt-hub-policy-recommendations-wireframe.html
 *
 * @package CPDC_Sovereign_Debt_Hub
 * @since 0.1.0
 */

/* ==========================================================================
   Policy Archive - Page Header
   ========================================================================== */

.policy-header {
	background-color: var(--wp--preset--color--gray-100);
	color: var(--wp--preset--color--white);
	border-bottom: 2px solid var(--wp--preset--color--gray-900);
	background-image: url('/wp-content/uploads/2026/03/page-policy.jpg');
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	min-height: 280px;
	display: flex;
	align-items: flex-end;
}

@media (min-width: 768px) {
	.policy-header {
		min-height: 360px;
	}
}

.policy-header__container {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--md);
	width: 100%;
	max-width: 1280px;
	margin-inline: auto;
	padding: var(--wp--preset--spacing--lg) var(--wp--preset--spacing--md);
	position: relative;
	z-index: 1;
}

@media (min-width: 1024px) {
	.policy-header__container {
		padding: var(--wp--preset--spacing--lg);
	}
}

.policy-header__eyebrow {
	margin: 0;
	font-size: var(--wp--preset--font-size--xs);
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--wp--preset--color--gray-600);
}

.policy-header__title {
	margin: 0;
	font-size: var(--wp--preset--font-size--xl);
	font-weight: 600;
	color: var(--wp--preset--color--white);
}

.policy-header__subtitle {
	margin: 0;
	max-width: 480px;
	font-size: var(--wp--preset--font-size--md);
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.85);
}

.policy-header__actions {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--sm);
	margin-block-start: var(--wp--preset--spacing--sm);
}

@media (min-width: 640px) {
	.policy-header__actions {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
	}
}

.policy-header__search {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xs);
	width: 100%;
}

@media (min-width: 640px) {
	.policy-header__search {
		flex-direction: row;
		width: auto;
	}
}

.policy-header__search-input {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 2px solid var(--wp--preset--color--gray-900);
	background-color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-600);
}

.policy-header__search-input:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

@media (min-width: 640px) {
	.policy-header__search-input {
		width: 420px;
	}
}

.policy-header__search-btn {
	padding: 0.75rem 1.5rem;
	border: 2px solid var(--wp--preset--color--gray-900);
	background: transparent;
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	color: var(--wp--preset--color--gray-900);
	cursor: pointer;
}

.policy-header__search-btn:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.policy-header__ctas {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xs);
}

@media (min-width: 640px) {
	.policy-header__ctas {
		flex-direction: row;
	}
}

.policy-header__cta-btn {
	padding: 0.75rem 1.5rem;
	border: 2px solid var(--wp--preset--color--white);
	background: transparent;
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	color: var(--wp--preset--color--gray-900);
	text-decoration: none;
	text-align: center;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.policy-header__cta-btn:hover {
	background-color: var(--wp--preset--color--white);
	color: var(--wp--preset--color--gray-900);
}

/* ==========================================================================
   Policy Archive - Layout
   ========================================================================== */

.policy-layout {
	padding-block: var(--wp--preset--spacing--lg);
}

.policy-layout__container {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wp--preset--spacing--lg);
	max-width: 1280px;
	margin-inline: auto;
	padding-inline: var(--wp--preset--spacing--md);
}

@media (min-width: 1024px) {
	.policy-layout__container {
		grid-template-columns: minmax(280px, 320px) 1fr;
		padding-inline: var(--wp--preset--spacing--lg);
	}
}

/* ==========================================================================
   Policy Archive - Filters Sidebar
   ========================================================================== */

.policy-filters {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--md);
}

.policy-filters__panel {
	padding: var(--wp--preset--spacing--md);
	border: 2px solid var(--wp--preset--color--gray-900);
	background-color: var(--wp--preset--color--white);
}

.policy-filters__header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--wp--preset--spacing--sm);
}

.policy-filters__title {
	margin: 0;
	font-size: var(--wp--preset--font-size--md);
	font-weight: 700;
	color: var(--wp--preset--color--gray-900);
}

.policy-filters__desc {
	margin: var(--wp--preset--spacing--2xs) 0 0;
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-600);
}

.policy-filters__reset {
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-700);
	text-decoration: underline;
	text-underline-offset: 4px;
}

.policy-filters__groups {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--md);
	margin-block-start: var(--wp--preset--spacing--md);
}

.policy-filters__group {
	margin: 0;
	padding: 0;
	border: none;
}

.policy-filters__group-title {
	margin: 0 0 var(--wp--preset--spacing--sm);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--wp--preset--color--gray-900);
}

.policy-filters__checkboxes {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.policy-filters__checkbox-label {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-700);
	cursor: pointer;
}

.policy-filters__checkbox {
	width: 1rem;
	height: 1rem;
	border: 2px solid var(--wp--preset--color--gray-900);
	cursor: pointer;
}

.policy-filters__select {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 2px solid var(--wp--preset--color--gray-900);
	background-color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-900);
}

.policy-filters__note {
	margin: var(--wp--preset--spacing--2xs) 0 0;
	font-size: var(--wp--preset--font-size--xs);
	color: var(--wp--preset--color--gray-600);
}

.policy-filters__submit {
	padding-block-start: var(--wp--preset--spacing--xs);
}

.policy-filters__apply-btn {
	width: 100%;
	padding: 0.75rem 1.5rem;
	border: 2px solid var(--wp--preset--color--gray-900);
	background: transparent;
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	color: var(--wp--preset--color--gray-900);
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.policy-filters__apply-btn:hover {
	background-color: var(--wp--preset--color--gray-900);
	color: var(--wp--preset--color--white);
}

/* Advocacy Note Panel */
.policy-filters__advocacy {
	padding: var(--wp--preset--spacing--md);
	border: 2px solid var(--wp--preset--color--gray-900);
	background-color: var(--wp--preset--color--gray-100);
}

.policy-filters__advocacy-title {
	margin: 0 0 var(--wp--preset--spacing--xs);
	font-size: var(--wp--preset--font-size--md);
	font-weight: 700;
	color: var(--wp--preset--color--gray-900);
}

.policy-filters__advocacy-text {
	margin: 0;
	font-size: var(--wp--preset--font-size--sm);
	line-height: 1.6;
	color: var(--wp--preset--color--gray-700);
}

.policy-filters__advocacy-ctas {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	margin-block-start: var(--wp--preset--spacing--sm);
}

.policy-filters__advocacy-btn {
	display: block;
	padding: 0.75rem 1.5rem;
	border: 2px solid var(--wp--preset--color--gray-900);
	background: transparent;
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	color: var(--wp--preset--color--gray-900);
	text-decoration: none;
	text-align: center;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.policy-filters__advocacy-btn:hover {
	background-color: var(--wp--preset--color--gray-900);
	color: var(--wp--preset--color--white);
}

/* ==========================================================================
   Policy Archive - Results Area
   ========================================================================== */

.policy-results {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--md);
}

.policy-results__header {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--sm);
}

@media (min-width: 640px) {
	.policy-results__header {
		flex-direction: row;
		align-items: flex-end;
		justify-content: space-between;
	}
}

.policy-results__count p {
	margin: 0;
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-600);
}

.policy-results__count strong {
	color: var(--wp--preset--color--gray-900);
}

.policy-results__note {
	font-size: var(--wp--preset--font-size--xs);
	color: var(--wp--preset--color--gray-500);
}

.policy-results__sort {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.policy-results__sort-label {
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-600);
}

.policy-results__sort-select {
	padding: 0.75rem 1rem;
	border: 2px solid var(--wp--preset--color--gray-900);
	background-color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-900);
}

.policy-results__grid {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--md);
}

/* ==========================================================================
   Policy Card
   ========================================================================== */

.policy-card {
	padding: var(--wp--preset--spacing--md);
	border: 2px solid var(--wp--preset--color--gray-900);
	background-color: var(--wp--preset--color--white);
}

.policy-card--featured .policy-card__content {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--md);
}

@media (min-width: 768px) {
	.policy-card--featured .policy-card__content {
		flex-direction: row;
	}
}

.policy-card--featured .policy-card__body {
	flex: 1;
}

.policy-card__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-block-end: var(--wp--preset--spacing--sm);
}

.policy-card__tag {
	padding: 0.25rem 0.5rem;
	border: 1px solid var(--wp--preset--color--gray-300);
	font-size: var(--wp--preset--font-size--xs);
	color: var(--wp--preset--color--gray-700);
}

.policy-card__tag--featured {
	border: 2px solid var(--wp--preset--color--gray-900);
	font-weight: 700;
	color: var(--wp--preset--color--gray-900);
}

.policy-card__title {
	margin: 0 0 var(--wp--preset--spacing--xs);
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 700;
	color: var(--wp--preset--color--gray-900);
}

.policy-card--featured .policy-card__title {
	font-size: var(--wp--preset--font-size--xl);
}

.policy-card__excerpt {
	margin: 0 0 var(--wp--preset--spacing--sm);
	font-size: var(--wp--preset--font-size--sm);
	line-height: 1.6;
	color: var(--wp--preset--color--gray-700);
}

.policy-card__ctas {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

@media (min-width: 640px) {
	.policy-card__ctas {
		flex-direction: row;
	}
}

.policy-card__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 1.5rem;
	border: 2px solid var(--wp--preset--color--gray-900);
	background: transparent;
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	color: var(--wp--preset--color--gray-900);
	text-decoration: none;
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.policy-card__cta:hover {
	background-color: var(--wp--preset--color--gray-900);
	color: var(--wp--preset--color--white);
}

/* Featured image placeholder */
.policy-card__image {
	width: 100%;
}

@media (min-width: 768px) {
	.policy-card__image {
		width: 240px;
		flex-shrink: 0;
	}
}

.policy-card__image-placeholder {
	height: 140px;
	border: 2px solid var(--wp--preset--color--gray-900);
	background-color: var(--wp--preset--color--gray-200);
	background-image: repeating-linear-gradient(
		-45deg,
		transparent,
		transparent 8px,
		rgba(0,0,0,0.05) 8px,
		rgba(0,0,0,0.05) 9px
	);
}

.policy-card__img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
}

.policy-card__image-caption {
	margin: var(--wp--preset--spacing--2xs) 0 0;
	font-size: var(--wp--preset--font-size--xs);
	color: var(--wp--preset--color--gray-600);
}

/* Non-featured card: flex container so order works */
.policy-card:not(.policy-card--featured) .policy-card__content {
	display: flex;
	flex-direction: column;
}

/* Non-featured card: full-width stacked image */
.policy-card:not(.policy-card--featured) .policy-card__image {
	width: 100%;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	order: -1;
	margin-bottom: var(--wp--preset--spacing--sm);
}

.policy-card:not(.policy-card--featured) .policy-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.policy-card:not(.policy-card--featured) .policy-card__image-placeholder {
	height: 100%;
}

/* ==========================================================================
   Policy Archive - Pagination
   ========================================================================== */

.policy-results__pagination {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--sm);
	padding-block-start: var(--wp--preset--spacing--md);
	border-top: 2px solid var(--wp--preset--color--gray-900);
}

@media (min-width: 640px) {
	.policy-results__pagination {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
	}
}

.policy-results__pagination-info {
	margin: 0;
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-600);
}

.policy-results__pagination-btns {
	display: flex;
	gap: 0.75rem;
}

.policy-results__pagination-btn {
	padding: 0.5rem 1.5rem;
	border: 2px solid var(--wp--preset--color--gray-900);
	background: transparent;
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	color: var(--wp--preset--color--gray-900);
	text-decoration: none;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.policy-results__pagination-btn:hover:not(.is-disabled) {
	background-color: var(--wp--preset--color--gray-900);
	color: var(--wp--preset--color--white);
}

.policy-results__pagination-btn.is-disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* ==========================================================================
   Policy Single - Header
   ========================================================================== */

.policy-single__header {
	padding-block: var(--wp--preset--spacing--lg);
	background-color: var(--wp--preset--color--gray-100);
	border-bottom: 2px solid var(--wp--preset--color--gray-900);
}

.policy-single__breadcrumb {
	margin-block-end: var(--wp--preset--spacing--sm);
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-600);
}

.policy-single__breadcrumb a {
	color: inherit;
	text-decoration: none;
}

.policy-single__breadcrumb a:hover {
	text-decoration: underline;
}

.policy-single__breadcrumb-sep {
	margin-inline: 0.5em;
	color: var(--wp--preset--color--gray-400);
}

.policy-single__breadcrumb-current {
	color: var(--wp--preset--color--gray-900);
}

.policy-single__title-area {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--md);
}

@media (min-width: 768px) {
	.policy-single__title-area {
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-start;
	}
}

.policy-single__title-content {
	flex: 1;
}

.policy-single__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-block-end: var(--wp--preset--spacing--sm);
}

.policy-single__tag {
	padding: 0.25rem 0.5rem;
	border: 1px solid var(--wp--preset--color--gray-300);
	font-size: var(--wp--preset--font-size--xs);
	color: var(--wp--preset--color--gray-700);
}

.policy-single__tag--link {
	text-decoration: none;
	transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.policy-single__tag--link:hover {
	background-color: var(--wp--preset--color--gray-900);
	border-color: var(--wp--preset--color--gray-900);
	color: var(--wp--preset--color--white);
}

.policy-single__title {
	margin: 0 0 var(--wp--preset--spacing--sm);
	font-size: var(--wp--preset--font-size--3xl);
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--wp--preset--color--gray-900);
}

.policy-single__summary {
	margin: 0 0 var(--wp--preset--spacing--sm);
	max-width: 60ch;
	font-size: var(--wp--preset--font-size--lg);
	line-height: 1.6;
	color: var(--wp--preset--color--gray-700);
}

.policy-single__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--md);
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-600);
}

.policy-single__header-cta {
	flex-shrink: 0;
}

.policy-single__support-btn {
	padding: 0.75rem 1.5rem;
	border: 2px solid var(--wp--preset--color--gray-900);
	background-color: var(--wp--preset--color--gray-900);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	color: var(--wp--preset--color--white);
	cursor: pointer;
	transition: background-color 0.15s ease;
}

.policy-single__support-btn:hover {
	background-color: var(--wp--preset--color--gray-800);
}

/* ==========================================================================
   Policy Single - Content Layout
   ========================================================================== */

.policy-single__content {
	padding-block: var(--wp--preset--spacing--xl);
}

.policy-single__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wp--preset--spacing--xl);
}

@media (min-width: 1024px) {
	.policy-single__layout {
		grid-template-columns: 1fr minmax(280px, 320px);
	}
}

.policy-single__main {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xl);
}

/* Single page featured image */
.policy-single__featured-image {
	width: 100%;
	overflow: hidden;
	border-radius: var(--wp--preset--spacing--xs, 4px);
}

.policy-single__featured-img {
	width: 100%;
	height: auto;
	display: block;
}

.policy-single__section {
	padding-block-end: var(--wp--preset--spacing--lg);
	border-bottom: 1px solid var(--wp--preset--color--gray-300);
}

.policy-single__section:last-child {
	padding-block-end: 0;
	border-bottom: none;
}

.policy-single__section-title {
	margin: 0 0 var(--wp--preset--spacing--sm);
	font-size: var(--wp--preset--font-size--xl);
	font-weight: 700;
	color: var(--wp--preset--color--gray-900);
}

.policy-single__body {
	max-width: 65ch;
	font-size: var(--wp--preset--font-size--md);
	line-height: 1.7;
	color: var(--wp--preset--color--gray-700);
}

.policy-single__body p {
	margin: 0 0 var(--wp--preset--spacing--sm);
}

.policy-single__body p:last-child {
	margin-block-end: 0;
}

/* How to Support Section */
.policy-single__section--cta {
	padding: var(--wp--preset--spacing--md);
	background-color: var(--wp--preset--color--gray-100);
	border: 2px solid var(--wp--preset--color--gray-900);
	border-bottom: 2px solid var(--wp--preset--color--gray-900);
}

.policy-single__support-intro {
	margin: 0 0 var(--wp--preset--spacing--sm);
	font-size: var(--wp--preset--font-size--md);
	color: var(--wp--preset--color--gray-700);
}

.policy-single__support-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.policy-single__action-btn {
	display: inline-flex;
	align-items: center;
	padding: 0.75rem 1.5rem;
	border: 2px solid var(--wp--preset--color--gray-900);
	background: transparent;
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	color: var(--wp--preset--color--gray-900);
	text-decoration: none;
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.policy-single__action-btn:hover {
	background-color: var(--wp--preset--color--gray-900);
	color: var(--wp--preset--color--white);
}

.policy-single__action-btn--primary {
	background-color: var(--wp--preset--color--gray-900);
	color: var(--wp--preset--color--white);
}

.policy-single__action-btn--primary:hover {
	background-color: var(--wp--preset--color--gray-800);
}

/* ==========================================================================
   Policy Single - Sidebar
   ========================================================================== */

.policy-single__sidebar {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--md);
}

.policy-single__sidebar-section {
	padding: var(--wp--preset--spacing--md);
	border: 2px solid var(--wp--preset--color--gray-900);
	background-color: var(--wp--preset--color--white);
}

.policy-single__sidebar-section--cta {
	background-color: var(--wp--preset--color--gray-100);
}

.policy-single__sidebar-title {
	margin: 0 0 var(--wp--preset--spacing--sm);
	font-size: var(--wp--preset--font-size--md);
	font-weight: 700;
	color: var(--wp--preset--color--gray-900);
}

.policy-single__related-list {
	margin: 0;
	padding: 0;
	list-style: none;
}

.policy-single__related-list li {
	margin-block-end: 0.5rem;
}

.policy-single__related-list li:last-child {
	margin-block-end: 0;
}

.policy-single__related-list a {
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-700);
	text-decoration: none;
}

.policy-single__related-list a:hover {
	color: var(--wp--preset--color--gray-900);
	text-decoration: underline;
}

.policy-single__sidebar-note {
	margin: var(--wp--preset--spacing--xs) 0 0;
	font-size: var(--wp--preset--font-size--xs);
	color: var(--wp--preset--color--gray-500);
}

.policy-single__sidebar-section p {
	margin: 0 0 var(--wp--preset--spacing--sm);
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-700);
}

.policy-single__sidebar-btn {
	display: block;
	width: 100%;
	padding: 0.75rem 1rem;
	border: 2px solid var(--wp--preset--color--gray-900);
	background: transparent;
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	color: var(--wp--preset--color--gray-900);
	text-decoration: none;
	text-align: center;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.policy-single__sidebar-btn:hover {
	background-color: var(--wp--preset--color--gray-900);
	color: var(--wp--preset--color--white);
}

/* ==========================================================================
   Policy Single - Footer
   ========================================================================== */

.policy-single__footer {
	padding-block: var(--wp--preset--spacing--md) var(--wp--preset--spacing--lg);
	border-top: 1px solid var(--wp--preset--color--gray-300);
}

.policy-single__back-link {
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-700);
	text-decoration: none;
}

.policy-single__back-link:hover {
	color: var(--wp--preset--color--gray-900);
	text-decoration: underline;
}

/* ==========================================================================
   Policy Briefs Section (cross-CPT from resources)
   ========================================================================== */

.policy-briefs-section {
	margin-top: var(--wp--preset--spacing--xl);
	padding-top: var(--wp--preset--spacing--lg);
	border-top: 1px solid var(--wp--preset--color--gray-200);
}

.policy-briefs-section__title {
	font-size: var(--wp--preset--font-size--xl);
	font-weight: 600;
	margin: 0 0 var(--wp--preset--spacing--md);
}

.policy-briefs-section__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wp--preset--spacing--md);
}

@media (min-width: 640px) {
	.policy-briefs-section__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.policy-briefs-section__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.policy-briefs-section__more {
	margin-top: var(--wp--preset--spacing--md);
	text-align: center;
}

.policy-briefs-section__link {
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 500;
	text-decoration: none;
}

.policy-briefs-section__link:hover {
	text-decoration: underline;
}

/* ==========================================================================
   Reduced Motion
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
	.policy-header__cta-btn,
	.policy-filters__apply-btn,
	.policy-filters__advocacy-btn,
	.policy-card__cta,
	.policy-results__pagination-btn,
	.policy-single__support-btn,
	.policy-single__action-btn,
	.policy-single__sidebar-btn,
	.policy-single__tag--link {
		transition: none;
	}
}
