/*
 * Impairment Calculator — Interactive State Map
 *
 * Geographic SVG map (Albers USA) with click-to-reveal notes panel.
 * Styles inherit the icalc-* design tokens defined in calculator.css; this
 * file only adds map-specific rules. Loaded only on pages that use the
 * [impairment_state_map] shortcode or the matching block.
 */

.icalc-map {
	max-width: 920px;
	margin: 2rem auto;
	font-family: var(--icalc-font-body, system-ui, sans-serif);
	color: var(--icalc-text, #1a1a1a);
}

/* ============ Legend ============ */

.icalc-map__legend {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 18px;
	font-size: 0.8125rem;
	color: var(--icalc-text-muted, #6b6b6b);
	margin-bottom: 0.75rem;
}

.icalc-map__legend-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	line-height: 1.4;
}

.icalc-map__swatch {
	width: 14px;
	height: 14px;
	border-radius: 3px;
	display: inline-block;
	flex-shrink: 0;
	border: 0.5px solid rgba(0, 0, 0, 0.1);
}

/* ============ Stats strip ============ */

.icalc-map__stats {
	display: flex;
	flex-wrap: wrap;
	gap: 4px 16px;
	font-size: 0.75rem;
	color: var(--icalc-text-muted, #6b6b6b);
	margin-bottom: 1rem;
	padding-bottom: 0.75rem;
	border-bottom: 1px solid var(--icalc-border, #e3e0d8);
}

.icalc-map__stat strong {
	font-weight: 600;
	margin-right: 4px;
}

/* ============ SVG canvas ============ */

.icalc-map__canvas-wrap {
	position: relative;
	background: var(--icalc-bg, #fbfaf7);
	border-radius: var(--icalc-radius-lg, 8px);
	padding: 0.5rem;
	border: 1px solid var(--icalc-border, #e3e0d8);
}

.icalc-map__svg {
	width: 100%;
	height: auto;
	display: block;
	aspect-ratio: 975 / 610;
	overflow: visible;
}

.icalc-map__state {
	stroke: #ffffff;
	stroke-width: 0.75;
	stroke-linejoin: round;
	cursor: pointer;
	outline: none;
	transition: opacity 120ms ease, stroke-width 120ms ease;
}

.icalc-map__state:hover,
.icalc-map__state:focus-visible {
	opacity: 0.85;
	stroke-width: 1.5;
	stroke: var(--icalc-accent, #1f3a5f);
}

.icalc-map__state:focus-visible {
	stroke-width: 2;
}

.icalc-map__state.is-active {
	stroke-width: 2;
	stroke: var(--icalc-text, #1a1a1a);
	opacity: 1;
}

/* When something is active, dim the others slightly to draw the eye. */
.icalc-map.has-selection .icalc-map__state:not(.is-active):not(:hover):not(:focus-visible) {
	opacity: 0.55;
}

/* Floating tooltip pinned by JS to mouse / focused state. */
.icalc-map__tooltip {
	position: absolute;
	pointer-events: none;
	background: var(--icalc-text, #1a1a1a);
	color: #ffffff;
	padding: 5px 9px;
	border-radius: 4px;
	font-size: 0.75rem;
	line-height: 1.3;
	white-space: nowrap;
	transform: translate(-50%, -120%);
	z-index: 4;
	opacity: 0;
	transition: opacity 100ms ease;
}

.icalc-map__tooltip.is-visible {
	opacity: 1;
}

.icalc-map__tooltip-name {
	font-weight: 600;
}

.icalc-map__tooltip-edition {
	color: rgba(255, 255, 255, 0.75);
	margin-left: 6px;
}

.icalc-map__hint {
	position: absolute;
	right: 0.75rem;
	bottom: 0.5rem;
	font-size: 0.6875rem;
	color: var(--icalc-text-muted, #6b6b6b);
	background: rgba(255, 255, 255, 0.85);
	padding: 2px 8px;
	border-radius: 10px;
	pointer-events: none;
	transition: opacity 150ms ease;
}

.icalc-map.has-selection .icalc-map__hint {
	opacity: 0;
}

/* ============ Notes panel ============ */

.icalc-map__panel {
	margin-top: 1rem;
	background: var(--icalc-surface, #ffffff);
	border: 1px solid var(--icalc-border, #e3e0d8);
	border-radius: var(--icalc-radius-lg, 8px);
	padding: 1.25rem 1.5rem;
	min-height: 160px;
}

.icalc-map__panel-empty {
	color: var(--icalc-text-muted, #6b6b6b);
	text-align: center;
	padding: 1rem 0;
	font-size: 0.9375rem;
}

.icalc-map__panel-header {
	display: flex;
	align-items: baseline;
	gap: 0.75rem;
	flex-wrap: wrap;
	margin-bottom: 0.5rem;
}

.icalc-map__panel-name {
	font-family: var(--icalc-font-display, Georgia, serif);
	font-size: 1.5rem;
	margin: 0;
	font-weight: 600;
	line-height: 1.2;
}

.icalc-map__panel-badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 12px;
	font-size: 0.75rem;
	font-weight: 600;
	line-height: 1.4;
}

.icalc-map__panel-verify {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	background: var(--icalc-warn-bg, #fef6e4);
	color: #6a4b14;
	font-size: 0.6875rem;
	font-weight: 500;
	padding: 2px 8px;
	border-radius: 10px;
	border: 1px solid var(--icalc-warn-border, #d4a72c);
}

.icalc-map__panel-row {
	display: flex;
	gap: 1rem;
	font-size: 0.875rem;
	margin: 0.5rem 0;
	flex-wrap: wrap;
}

.icalc-map__panel-label {
	color: var(--icalc-text-muted, #6b6b6b);
	font-weight: 500;
	min-width: 64px;
	flex-shrink: 0;
}

.icalc-map__panel-value {
	flex: 1;
	min-width: 0;
}

.icalc-map__panel-value code {
	font-family: var(--icalc-font-mono, monospace);
	background: var(--icalc-accent-soft, #eaf0f7);
	padding: 1px 6px;
	border-radius: 3px;
	font-size: 0.8125rem;
}

.icalc-map__panel-notes {
	font-size: 0.875rem;
	line-height: 1.6;
	margin: 0.75rem 0 0;
	color: var(--icalc-text, #1a1a1a);
}

.icalc-map__panel-formula {
	font-size: 0.8125rem;
	color: var(--icalc-text-muted, #6b6b6b);
	margin: 0.5rem 0 0;
	font-style: italic;
}

.icalc-map__panel-actions {
	margin-top: 1rem;
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
	padding-top: 0.75rem;
	border-top: 1px solid var(--icalc-border, #e3e0d8);
}

.icalc-map__panel-cta {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	background: var(--icalc-accent, #1f3a5f);
	color: #ffffff;
	font-size: 0.8125rem;
	font-weight: 500;
	padding: 7px 14px;
	border-radius: var(--icalc-radius, 4px);
	text-decoration: none;
	transition: background 120ms ease;
}

.icalc-map__panel-cta:hover,
.icalc-map__panel-cta:focus {
	background: #14283f;
	color: #ffffff;
	text-decoration: none;
}

.icalc-map__panel-cta.is-empty {
	background: transparent;
	color: var(--icalc-accent, #1f3a5f);
	border: 1px solid var(--icalc-border, #e3e0d8);
}

.icalc-map__panel-cta.is-empty:hover,
.icalc-map__panel-cta.is-empty:focus {
	background: var(--icalc-accent-soft, #eaf0f7);
	color: var(--icalc-accent, #1f3a5f);
}

.icalc-map__panel-count {
	font-weight: 600;
}

.icalc-map__noscript {
	padding: 1rem;
	background: var(--icalc-warn-bg, #fef6e4);
	border: 1px solid var(--icalc-warn-border, #d4a72c);
	border-radius: var(--icalc-radius, 4px);
	font-size: 0.875rem;
}

/* ============ Responsive ============ */

@media (max-width: 640px) {
	.icalc-map__panel {
		padding: 1rem;
	}
	.icalc-map__panel-name {
		font-size: 1.25rem;
	}
	.icalc-map__legend {
		font-size: 0.75rem;
	}
	.icalc-map__stats {
		font-size: 0.6875rem;
	}
	.icalc-map__hint {
		display: none;
	}
}

/* On very small viewports, stack the row labels above values. */
@media (max-width: 420px) {
	.icalc-map__panel-row {
		flex-direction: column;
		gap: 2px;
	}
	.icalc-map__panel-label {
		min-width: 0;
	}
}

/* Print: hide interactive bits, show panel cleanly. */
@media print {
	.icalc-map__hint,
	.icalc-map__tooltip,
	.icalc-map__panel-actions {
		display: none !important;
	}
}

/* ================= MAP: COMING-SOON BANNER ================= */

.icalc-map__soon {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.5rem 1rem;
	padding: 0.85rem 1.1rem;
	margin: 0 0 1rem 0;
	background: linear-gradient(0deg, #fef9c3, #fef3c7);
	border: 1px solid #facc15;
	border-radius: 8px;
	font-size: 0.9rem;
	color: #422f08;
}

.icalc-map__soon strong {
	font-size: 0.95rem;
	letter-spacing: 0.01em;
}

.icalc-map__soon a {
	margin-left: auto;
	color: #422f08;
	font-weight: 600;
	text-decoration: underline;
	text-decoration-color: rgba(66, 47, 8, 0.45);
	text-underline-offset: 3px;
}

.icalc-map__soon a:hover {
	text-decoration-color: rgba(66, 47, 8, 0.9);
}

@media (max-width: 640px) {
	.icalc-map__soon a {
		margin-left: 0;
	}
}
