/**
 * Data Explorer Page Styles
 *
 * @package CPDC_Sovereign_Debt_Hub
 * @since 0.3.0
 */

.data-explorer {
	background: var(--wp--preset--color--white);
	color: var(--wp--preset--color--gray-900);
}

.data-hero {
	background: var(--wp--preset--color--ocean-indigo);
	color: var(--wp--preset--color--white);
	padding-block: var(--wp--preset--spacing--2xl);
}

.data-hero__container,
.data-nav__container,
.data-compare__container,
.data-about__container,
.data-download__container {
	width: min(100%, 75rem);
	margin-inline: auto;
	padding-inline: var(--wp--preset--spacing--md);
}

.data-hero__eyebrow {
	margin: 0 0 var(--wp--preset--spacing--xs);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.72);
}

.data-hero__title {
	margin: 0 0 var(--wp--preset--spacing--sm);
	font-family: var(--wp--preset--font-family--heading-serif);
	font-size: clamp(2rem, 5vw, 3.5rem);
	line-height: 1.05;
	color: var(--wp--preset--color--white);
}

.data-hero__description {
	max-width: 42rem;
	margin: 0;
	font-size: var(--wp--preset--font-size--lg);
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.9);
}

.data-nav {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(255, 255, 255, 0.96);
	border-bottom: 1px solid var(--wp--preset--color--gray-200);
	box-shadow: 0 0.5rem 1.5rem rgba(2, 48, 71, 0.08);
	backdrop-filter: blur(0.5rem);
}

.data-nav__container {
	display: flex;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--sm);
	padding-block: var(--wp--preset--spacing--sm);
}

.data-nav__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--wp--preset--spacing--xs) var(--wp--preset--spacing--sm);
	border-radius: 999rem;
	font-size: var(--wp--preset--font-size--md);
	font-weight: 600;
	color: var(--wp--preset--color--gray-600);
	text-decoration: none;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.data-nav__link:hover,
.data-nav__link:focus-visible,
.data-nav__link--active {
	background: var(--wp--preset--color--ocean-cyan);
	color: var(--wp--preset--color--ocean-indigo);
}

.data-compare,
.data-about,
.data-download {
	padding-block: var(--wp--preset--spacing--2xl);
}

.data-compare__section-heading,
.data-about__section-heading,
.data-download__section-heading {
	margin-block-end: var(--wp--preset--spacing--lg);
}

.data-compare__title,
.data-about__title,
.data-download__title {
	margin: 0 0 var(--wp--preset--spacing--xs);
	font-family: var(--wp--preset--font-family--heading-serif);
	font-size: var(--wp--preset--font-size--2xl);
	line-height: 1.15;
	color: var(--wp--preset--color--gray-900);
}

.data-compare__intro,
.data-about__intro,
.data-download__intro {
	max-width: 48rem;
	margin: 0;
	font-size: var(--wp--preset--font-size--md);
	line-height: 1.7;
	color: var(--wp--preset--color--gray-600);
}

.data-compare__controls {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--wp--preset--spacing--lg);
	margin-block-end: var(--wp--preset--spacing--xl);
}

.data-compare__picker-group,
.data-download__fieldset,
.data-download__card,
.data-compare__chart-cell,
.data-compare__charts-empty,
.data-download__custom {
	border: 1px solid var(--wp--preset--color--gray-200);
	border-radius: 1rem;
	background: var(--wp--preset--color--white);
}

.data-compare__subheading {
	margin: 0 0 var(--wp--preset--spacing--sm);
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 700;
	color: var(--wp--preset--color--gray-900);
}

.data-compare__fieldset,
.data-download__fieldset {
	border: 0;
	margin: 0;
	padding: var(--wp--preset--spacing--md);
}

.data-compare__legend,
.data-download__legend {
	padding: 0;
	font-size: var(--wp--preset--font-size--md);
	font-weight: 700;
	color: var(--wp--preset--color--gray-900);
}

.data-compare__helper {
	margin: var(--wp--preset--spacing--xs) 0 0;
	font-size: var(--wp--preset--font-size--sm);
	line-height: 1.5;
	color: var(--wp--preset--color--gray-600);
}

.data-compare__helper--limit {
	color: var(--wp--preset--color--ocean-orange, var(--wp--preset--color--gray-900));
}

.data-compare__options,
.data-download__options {
	display: flex;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--xs);
	margin-block-start: var(--wp--preset--spacing--sm);
}

.data-download__options--grouped {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.data-download__group-heading {
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	margin: 0 0 0.25rem;
	padding-bottom: 0.25rem;
	border-bottom: 1px solid rgba(128, 128, 128, 0.2);
}

.data-compare__option,
.data-download__option {
	display: inline-flex;
	align-items: center;
	gap: var(--wp--preset--spacing--xs);
	padding: var(--wp--preset--spacing--xs) var(--wp--preset--spacing--sm);
	border: 1px solid var(--wp--preset--color--gray-200);
	border-radius: 999rem;
	background: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--sm);
	line-height: 1.4;
	color: var(--wp--preset--color--gray-900);
	cursor: pointer;
}

.data-compare__option--reference {
	background: var(--wp--preset--color--gray-50, #f8f9fa);
}

.data-compare__option:has(input:disabled) {
	opacity: 0.45;
	cursor: not-allowed;
}

.data-compare__toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--wp--preset--spacing--sm);
	margin-block-end: var(--wp--preset--spacing--sm);
}

.data-compare__chart-types {
	display: inline-flex;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--xs);
}

.data-compare__chart-toggle,
.data-download__toggle-all,
.data-download__submit,
.data-download__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--wp--preset--spacing--xs) var(--wp--preset--spacing--sm);
	border: 1px solid var(--wp--preset--color--gray-200);
	border-radius: 999rem;
	background: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	line-height: 1.2;
	color: var(--wp--preset--color--gray-900);
	text-decoration: none;
	cursor: pointer;
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.data-compare__chart-toggle--active,
.data-compare__chart-toggle:hover,
.data-compare__chart-toggle:focus-visible,
.data-download__toggle-all:hover,
.data-download__toggle-all:focus-visible,
.data-download__submit:hover,
.data-download__submit:focus-visible,
.data-download__button:hover,
.data-download__button:focus-visible {
	border-color: var(--wp--preset--color--ocean-cyan);
	background: var(--wp--preset--color--ocean-cyan);
	color: var(--wp--preset--color--ocean-indigo);
	transform: translateY(-0.0625rem);
	box-shadow: 0 0.5rem 1.25rem rgba(2, 48, 71, 0.08);
}

.data-compare__status {
	margin: 0;
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-600);
}

.data-compare__charts {
	position: relative;
}

.data-compare__charts--loading {
	position: relative;
	min-height: 200px;
	opacity: 0.5;
	pointer-events: none;
}

.data-compare__charts--loading::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 40px;
	height: 40px;
	margin: -20px 0 0 -20px;
	border: 3px solid rgba(128, 128, 128, 0.2);
	border-top-color: currentColor;
	border-radius: 50%;
	animation: sdh-spin 0.8s linear infinite;
	z-index: 5;
}

.data-compare__charts--loading::after {
	content: 'Loading data\2026';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, 24px);
	font-size: 0.85rem;
	color: inherit;
	opacity: 0.6;
	z-index: 5;
}

@keyframes sdh-spin {
	to {
		transform: rotate(360deg);
	}
}

.data-compare__charts-empty {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 18rem;
	padding: var(--wp--preset--spacing--lg);
	text-align: center;
	color: var(--wp--preset--color--gray-600);
}

.data-compare__charts-empty p {
	margin: 0;
	font-size: var(--wp--preset--font-size--md);
	line-height: 1.6;
}

.data-compare__charts-grid {
	display: grid;
	gap: var(--wp--preset--spacing--md);
}

.data-compare__charts-grid--count-1 {
	grid-template-columns: minmax(0, 1fr);
}

.data-compare__charts-grid--count-2,
.data-compare__charts-grid--count-3,
.data-compare__charts-grid--count-4 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.data-compare__chart-cell {
	padding: var(--wp--preset--spacing--sm);
}

.data-compare__chart-head {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	justify-content: space-between;
	gap: var(--wp--preset--spacing--xs);
	margin-block-end: var(--wp--preset--spacing--xs);
}

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

.data-compare__chart-meta {
	margin: 0;
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-600);
}

.data-compare__chart-plot {
	min-height: 17.5rem;
}

.data-compare__shared-legend {
	margin-block-start: var(--wp--preset--spacing--sm);
	padding: var(--wp--preset--spacing--sm);
	border-radius: 1rem;
	background: var(--wp--preset--color--gray-50, #f8f9fa);
}

.data-compare__legend-list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--sm);
	margin: 0;
	padding: 0;
	list-style: none;
}

.data-compare__legend-item {
	display: inline-flex;
	align-items: center;
	gap: var(--wp--preset--spacing--xs);
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--gray-900);
}

.data-compare__legend-swatch {
	display: inline-block;
	inline-size: 1.75rem;
	block-size: 0.25rem;
	border-radius: 999rem;
	background: var(--legend-color);
}

.data-compare__legend-swatch--dashed {
	background:
		repeating-linear-gradient(
			to right,
			var(--legend-color) 0,
			var(--legend-color) 0.5rem,
			transparent 0.5rem,
			transparent 0.75rem
		);
}

.data-download {
	background: var(--wp--preset--color--gray-50, #f8f9fa);
}

.data-download__presets {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--wp--preset--spacing--md);
	margin-block-end: var(--wp--preset--spacing--xl);
}

.data-download__card {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xs);
	padding: var(--wp--preset--spacing--lg);
	color: inherit;
	text-decoration: none;
	box-shadow: 0 0.25rem 0.75rem rgba(2, 48, 71, 0.04);
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.data-download__card:hover,
.data-download__card:focus-within,
.data-download__card:focus-visible {
	transform: translateY(-0.1875rem);
	box-shadow: 0 1rem 2rem rgba(2, 48, 71, 0.08);
	border-color: var(--wp--preset--color--ocean-cyan);
}

.data-download__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	inline-size: 3.25rem;
	block-size: 3.25rem;
	border-radius: 50%;
	background: var(--wp--preset--color--ocean-indigo);
	color: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 700;
	letter-spacing: 0.06em;
}

.data-download__card-title {
	margin: 0;
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 700;
	color: var(--wp--preset--color--gray-900);
}

.data-download__card-meta {
	margin: 0;
	font-size: var(--wp--preset--font-size--sm);
	line-height: 1.6;
	color: var(--wp--preset--color--gray-600);
}

.data-download__label {
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	color: var(--wp--preset--color--gray-900);
}

.data-download__select,
.data-download__input {
	inline-size: 100%;
	padding: var(--wp--preset--spacing--xs) var(--wp--preset--spacing--sm);
	border: 1px solid var(--wp--preset--color--gray-200);
	border-radius: 0.75rem;
	background: var(--wp--preset--color--white);
	font-size: var(--wp--preset--font-size--md);
	color: var(--wp--preset--color--gray-900);
}

.data-download__button {
	margin-block-start: var(--wp--preset--spacing--xs);
	align-self: flex-start;
}

.data-download__custom {
	overflow: hidden;
}

.data-download__summary {
	position: relative;
	padding: var(--wp--preset--spacing--md) var(--wp--preset--spacing--lg);
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 700;
	list-style: none;
	cursor: pointer;
}

.data-download__summary::-webkit-details-marker {
	display: none;
}

.data-download__summary::before {
	content: '\25B8';
	display: inline-block;
	margin-inline-end: var(--wp--preset--spacing--xs);
	color: var(--wp--preset--color--ocean-indigo);
}

.data-download__custom[open] .data-download__summary::before {
	content: '\25BE';
}

.data-download__form {
	padding: 0 var(--wp--preset--spacing--lg) var(--wp--preset--spacing--lg);
}

.data-download__form-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--wp--preset--spacing--md);
}

.data-download__fieldset-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--wp--preset--spacing--sm);
	margin-block-end: var(--wp--preset--spacing--sm);
}

.data-download__fieldset--years {
	margin-block-start: var(--wp--preset--spacing--md);
}

.data-download__years {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--wp--preset--spacing--md);
	margin-block-start: var(--wp--preset--spacing--sm);
}

.data-download__year-field {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xs);
}

.data-download__actions {
	margin-block-start: var(--wp--preset--spacing--md);
}

.data-download__submit {
	border-color: var(--wp--preset--color--ocean-indigo);
	background: var(--wp--preset--color--ocean-indigo);
	color: var(--wp--preset--color--white);
}

.data-download__button[hidden],
.data-compare__shared-legend[hidden],
.data-compare__charts-empty[hidden] {
	display: none;
}

.sr-only {
	position: absolute;
	inline-size: 0.0625rem;
	block-size: 0.0625rem;
	padding: 0;
	margin: -0.0625rem;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

@media (max-width: 48rem) {
	.data-compare__controls,
	.data-download__presets,
	.data-download__form-grid,
	.data-download__years,
	.data-compare__charts-grid--count-2,
	.data-compare__charts-grid--count-3,
	.data-compare__charts-grid--count-4 {
		grid-template-columns: minmax(0, 1fr);
	}

	.data-compare__toolbar,
	.data-download__fieldset-head {
		align-items: flex-start;
		flex-direction: column;
	}
}

/* --- Data Methodology / Compliance Table --- */

.data-methodology {
	padding-block: var(--wp--preset--spacing--2xl);
	background: var(--wp--preset--color--white);
}

.data-methodology__container {
	width: min(100%, 75rem);
	margin-inline: auto;
	padding-inline: var(--wp--preset--spacing--md);
}

.data-methodology__section-heading {
	margin-block-end: var(--wp--preset--spacing--lg);
}

.data-methodology__title {
	margin: 0 0 var(--wp--preset--spacing--xs);
	font-family: var(--wp--preset--font-family--heading-serif);
	font-size: var(--wp--preset--font-size--2xl);
	line-height: 1.15;
	color: var(--wp--preset--color--gray-900);
}

.data-methodology__intro {
	max-width: 48rem;
	margin: 0;
	font-size: var(--wp--preset--font-size--md);
	line-height: 1.7;
	color: var(--wp--preset--color--gray-600);
}

.data-methodology__table-wrap {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	border: 1px solid var(--wp--preset--color--gray-200);
	border-radius: 1rem;
}

.data-methodology__table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--wp--preset--font-size--sm);
	line-height: 1.55;
}

.data-methodology__table thead {
	background: var(--wp--preset--color--ocean-indigo);
	color: var(--wp--preset--color--white);
}

.data-methodology__table th {
	padding: var(--wp--preset--spacing--sm) var(--wp--preset--spacing--md);
	font-weight: 700;
	text-align: left;
	white-space: nowrap;
}

.data-methodology__table td {
	padding: var(--wp--preset--spacing--sm) var(--wp--preset--spacing--md);
	vertical-align: top;
	border-top: 1px solid var(--wp--preset--color--gray-200);
	color: var(--wp--preset--color--gray-900);
}

.data-methodology__table tbody tr:hover {
	background: var(--wp--preset--color--gray-50, #f8f9fa);
}

.data-methodology__table td:first-child {
	font-weight: 600;
	white-space: nowrap;
	min-width: 12rem;
}

.data-methodology__table td:nth-child(2) {
	min-width: 18rem;
}

.data-methodology__table td:nth-child(3) {
	min-width: 14rem;
}

.data-methodology__unit {
	font-weight: 400;
	color: var(--wp--preset--color--gray-600);
}

.data-methodology__table a {
	color: var(--wp--preset--color--ocean-indigo);
	text-decoration: underline;
	text-decoration-color: rgba(2, 48, 71, 0.3);
	text-underline-offset: 0.15em;
}

.data-methodology__table a:hover,
.data-methodology__table a:focus-visible {
	text-decoration-color: currentColor;
}

@media (max-width: 48rem) {
	.data-methodology__table thead {
		display: none;
	}

	.data-methodology__table,
	.data-methodology__table tbody,
	.data-methodology__table tr,
	.data-methodology__table td {
		display: block;
	}

	.data-methodology__table tr {
		padding: var(--wp--preset--spacing--sm) var(--wp--preset--spacing--md);
		border-top: 1px solid var(--wp--preset--color--gray-200);
	}

	.data-methodology__table tr:first-child {
		border-top: 0;
	}

	.data-methodology__table td {
		padding: 0.25rem 0;
		border-top: 0;
		min-width: 0;
		white-space: normal;
	}

	.data-methodology__table td:first-child {
		white-space: normal;
	}

	.data-methodology__table td::before {
		content: attr(data-label);
		display: block;
		font-size: 0.7rem;
		font-weight: 700;
		text-transform: uppercase;
		letter-spacing: 0.06em;
		color: var(--wp--preset--color--gray-600);
		margin-block-end: 0.125rem;
	}

	.data-methodology__table td:empty {
		display: none;
	}
}

.data-methodology__pill {
	display: inline-flex;
	align-items: center;
	padding: 2px 8px;
	border-radius: 999px;
	font-size: var(--wp--preset--font-size--xs, 0.75rem);
	font-weight: 600;
	letter-spacing: 0.01em;
}

.data-methodology__pill--calculated {
	background-color: rgba(33, 158, 188, 0.12);
	color: var(--wp--preset--color--ocean-indigo, #023047);
	border: 1px solid rgba(33, 158, 188, 0.35);
}

.data-methodology__source-detail {
	display: inline;
	margin-left: 0.4em;
	color: var(--wp--preset--color--gray-700, #5a6a78);
}

@media (max-width: 30rem) {
	.data-nav__container {
		flex-direction: column;
	}

	.data-nav__link {
		inline-size: 100%;
	}

	.data-hero,
	.data-compare,
	.data-download,
	.data-methodology {
		padding-block: var(--wp--preset--spacing--xl);
	}
}

/* ---------------------------------------------------------------------------
 * Data About — Singstat-style "Our Data Explained" panel
 * ------------------------------------------------------------------------- */

.data-about {
	margin: 0;
}

.data-about__panel {
	border: 1px solid var(--cc-card-border, #e6e2d6);
	border-radius: 8px;
	background: #fbfaf6;
}

.data-about__toggle {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	padding: 1rem 1.25rem;
	cursor: pointer;
	list-style: none;
}

.data-about__toggle::-webkit-details-marker { display: none; }
.data-about__toggle::marker { content: ''; }

.data-about__toggle-icon {
	font-size: 1.05rem;
	color: var(--cc-card-text-secondary, #5a6a78);
}

.data-about__toggle-label {
	font-weight: 600;
	font-size: 0.95rem;
	color: var(--cc-card-text, #1a2a36);
}

.data-about__panel[open] .data-about__toggle {
	border-bottom: 1px solid var(--cc-card-border, #e6e2d6);
}

.data-about__list {
	margin: 1rem 1.25rem;
	display: grid;
	gap: 0.9rem;
}

.data-about__item {
	display: grid;
	gap: 0.25rem;
}

.data-about__item[hidden] {
	display: none;
}

.data-about__term {
	font-weight: 600;
	font-size: 0.95rem;
	color: var(--cc-card-text, #1a2a36);
}

.data-about__unit {
	margin-left: 0.4rem;
	font-weight: 400;
	font-size: 0.8rem;
	color: var(--cc-card-text-muted, #7a8894);
}

.data-about__desc {
	margin: 0;
	font-size: 0.9rem;
	line-height: 1.5;
	color: var(--cc-card-text-secondary, #5a6a78);
}

.data-about__glossary-link {
	margin: 0 1.25rem 1.25rem;
	font-size: 0.9rem;
}

.data-about__glossary-link a {
	color: var(--cc-link, #1d4e89);
	text-decoration: underline;
}
