.sfi-dashboard {
	--sfi-blue: #2563eb;
	--sfi-blue-light: #dbeafe;
	--sfi-border: #e5e7eb;
	--sfi-text: #111827;
	--sfi-muted: #6b7280;
	--sfi-radius: 12px;
	--sfi-space-8: 8px;
	--sfi-space-12: 12px;
	--sfi-space-16: 16px;
	--sfi-radius-4: 4px;
	--sfi-search-icon: #1a1a1a;
	--sfi-search-text: #4d5f6f;
	--sfi-filter-icon: #3b414b;
	--sfi-filter-bg: #fafafa;
	--sfi-leading: #22c55e;
	--sfi-growing: #2badff;
	--sfi-emerging: #f59e0b;
	--sfi-lagging: #ef4444;
	--sfi-leading-bg: rgba(34, 197, 94, 0.12);
	--sfi-growing-bg: rgba(43, 173, 255, 0.12);
	--sfi-emerging-bg: rgba(245, 158, 11, 0.12);
	--sfi-lagging-bg: rgba(239, 68, 68, 0.12);
	--sfi-dashboard-max-width: 924px;
	font-family: "Open Sans", sans-serif;
	width: 100%;
	max-width: var(--sfi-dashboard-max-width);
	margin-left: auto;
	margin-right: auto;
	padding: 0;
	border: none;
	box-sizing: border-box;
}

.sfi-dashboard .sfi-page-header,
.sfi-dashboard .sfi-table-section,
.sfi-dashboard .sfi-panel,
.sfi-dashboard .sfi-dashboard-footer {
	width: 100%;
	max-width: 100%;
}

.sfi-dashboard *,
.sfi-dashboard *::before,
.sfi-dashboard *::after {
	box-sizing: border-box;
}

/* Do NOT add border to .sfi-dashboard — map tab has no outer border */
.sfi-dashboard.sfi-view-map {
	border: none !important;
}

.sfi-dashboard.sfi-view-table {
	border: none !important;
}

/* Page header & table section: table view only */
.sfi-dashboard.sfi-view-map .sfi-page-header,
.sfi-dashboard.sfi-view-map .sfi-table-section {
	display: none !important;
}

.sfi-table-section {
	display: none;
	border: none;
}

.sfi-dashboard.sfi-view-table .sfi-table-section {
	display: block;
	width: 100%;
	background: #fff;
	border: 1px solid #9ca3af !important;
	border-radius:0px;
	overflow: visible;
}

.sfi-page-header {
	display: none;
}

.sfi-dashboard.sfi-view-table .sfi-page-header {
	display: block;
	background: #E9F6FF;
	padding: 12px 32px;
	border-radius: 0;
	border-top: 1px solid #9CA3AF;
	border-left: 1px solid #9CA3AF;
	border-right: 1px solid #9CA3AF;
}

.sfi-page-title {
	margin: 0 0 4px;
	color: #072C4A;
	font-family: "Open Sans", sans-serif;
	font-size: 18px;
	font-weight: 600;
	line-height: 1.444;
}

.sfi-page-subtitle {
	margin: 0;
	color: #3B414B;
	font-family: "Open Sans", sans-serif;
	font-size: 12px;
	font-weight: 400;
	line-height: 1.5;
}

.sfi-dashboard.sfi-view-table .sfi-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sfi-space-16);
	width: 100%;
	margin-bottom: 0;
	padding: 16px;
	flex-wrap: nowrap;
	overflow: visible;
}

.sfi-toolbar {
	display: none;
}

.sfi-toolbar-actions {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: var(--sfi-space-8);
	flex-shrink: 0;
}

.sfi-search-wrap {
	display: flex;
	padding: var(--sfi-space-8);
	align-items: center;
	gap: var(--sfi-space-16);
	align-self: stretch;
	flex: 0 1 400px;
	width: 100%;
	max-width: 320px;
	min-width: 200px;
	height: 40px;
	border-radius: var(--sfi-radius-4);
	border: 1px solid #e5e7eb;
	background: #fff;
}

.sfi-search-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: var(--sfi-search-icon);
	pointer-events: none;
}

.sfi-search-icon svg {
	display: block;
}

.sfi-dashboard .sfi-search-wrap input.sfi-search[type="search"] {
	flex: 1;
	min-width: 0;
	width: auto;
	padding: 0;
	margin: 0;
	border: none !important;
	border-radius: 0 !important;
	color: #4D5F6F;
    font-family: "Open Sans", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 1.42857em;
	background: transparent;
	box-shadow: none;
	outline: none;
	-webkit-appearance: none;
	appearance: none;
	transition: none;
}

.sfi-dashboard .sfi-search-wrap input.sfi-search[type="search"]::placeholder {
	color: var(--sfi-search-text);
	opacity: 1;
}

.sfi-dashboard .sfi-search-wrap input.sfi-search[type="search"]:focus,
.sfi-dashboard .sfi-search-wrap input.sfi-search[type="search"]:focus-visible {
	border: none !important;
	outline: none;
	box-shadow: none;
}

.sfi-filters-wrap {
	position: relative;
	flex-shrink: 0;
}

.sfi-all-filters-btn {
	display: flex;
	padding: var(--sfi-space-8) var(--sfi-space-12);
	justify-content: center;
	align-items: center;
	gap: var(--sfi-space-8);
	height: 40px;
	border: none;
	border-radius: var(--sfi-radius-4);
	background: var(--sfi-filter-bg);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.4;
	color: var(--sfi-search-text);
	white-space: nowrap;
	cursor: pointer;
	transition: background 0.15s ease;
}

.sfi-toolbar-icon-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 40px;
	padding: 0;
	border: none;
	border-radius: var(--sfi-radius-4);
	background: transparent;
	color: var(--sfi-filter-icon);
	cursor: pointer;
	flex-shrink: 0;
	transition: color 0.15s ease, background 0.15s ease;
}

.sfi-toolbar-icon-btn:hover {
	color: #1a1a1a;
	background: #f3f4f6;
}

.sfi-toolbar-icon-btn svg {
	display: block;
}

.sfi-all-filters-btn:hover {
	background: #f3f4f6;
}

.sfi-all-filters-btn .sfi-filter-icon {
	flex-shrink: 0;
	color: var(--sfi-filter-icon);
}

.sfi-all-filters-btn .sfi-all-filters-label {
	color: var(--sfi-search-text);
}

.sfi-all-filters-btn .sfi-chevron {
	flex-shrink: 0;
	color: var(--sfi-search-text);
	transition: transform 0.15s ease;
}

.sfi-all-filters-btn.is-open .sfi-chevron {
	transform: rotate(180deg);
}

.sfi-filters-panel {
	position: absolute;
	top: calc(100% + 8px);
	right: 0;
	left: auto;
	z-index: 11;
	width: 320px;
	padding: 16px;
	background: #fff;
	border: 1px solid var(--sfi-border);
	border-radius: 10px;
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
	font-family: "Open Sans", sans-serif;
	font-size: 14px;
	line-height: 1.4;
}

.sfi-filters-section {
	margin-bottom: 16px;
	padding-bottom: 16px;
	border-bottom: 1px solid #f3f4f6;
}

.sfi-filters-section:last-of-type {
	border-bottom: none;
	margin-bottom: 0;
	padding-bottom: 0;
}

.sfi-filters-heading {
	margin: 0 0 10px;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--sfi-muted);
}

.sfi-filter-options {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.sfi-filter-check,
.sfi-filter-radio {
	display: flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	font-size: 14px;
	line-height: 1.4;
}

.sfi-filters-panel .sfi-filter-check > span:not(.sfi-status-pill),
.sfi-filters-panel .sfi-filter-radio > span {
	font-size: 14px;
	line-height: 1.4;
}

.sfi-filter-check input,
.sfi-filter-radio input {
	margin: 0;
	accent-color: var(--sfi-blue);
}

.sfi-filter-check .sfi-status-pill {
	font-size: 11px;
	padding: 3px 8px;
}

.sfi-filter-statuses .sfi-filter-check {
	line-height: 1.2em;
}

.sfi-filter-statuses .sfi-filter-check .sfi-status-pill {
	line-height: 1.2em;
}

.sfi-filter-range {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}

.sfi-range-field {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.sfi-range-label {
	font-size: 12px;
	color: var(--sfi-muted);
}

.sfi-filter-ai-min,
.sfi-filter-ai-max {
	width: 100%;
	padding: 8px 10px;
	border: 1px solid var(--sfi-border);
	border-radius: 6px;
	font-size: 14px;
}

.sfi-filters-actions {
	display: flex;
	justify-content: flex-end;
	gap: 8px;
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px solid #f3f4f6;
}

.sfi-filters-panel .sfi-filters-actions .sfi-btn {
	font-size: 14px;
	line-height: 1.4;
}

.sfi-btn-primary {
	background: var(--sfi-blue);
	border-color: var(--sfi-blue);
	color: #fff;
}

.sfi-btn-primary:hover {
	background: #2badff;
	border-color: #2badff;
}


.sfi-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--sfi-space-8) var(--sfi-space-12);
	border: 1px solid var(--sfi-border);
	border-radius: var(--sfi-radius-4);
	background: #fff;
	color: var(--sfi-text);
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s;
}

.sfi-btn:hover {
	background: #f9fafb;
	border-color: #d1d5db;
}

.sfi-table-section .sfi-panel-table {
	display: block;
	width: 100%;
}

.sfi-table-section .sfi-panel-table .sfi-table-wrap {
	border: none;
	border-radius: 0;
}

.sfi-dashboard-footer {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 16px;
	margin-top: 16px;
	flex-wrap: wrap;
}

.sfi-dashboard.sfi-view-table .sfi-map-legend {
	display: none;
}

.sfi-dashboard.sfi-view-table .sfi-dashboard-footer {
	justify-content: flex-end;
}

.sfi-view-toggle-wrap {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 10px;
}

.sfi-view-label {
   color: #1A1A1A;
   font-family: "Open Sans", sans-serif;
   font-size: 12px;
   font-style: normal;
   font-weight: 400;
  line-height: 1.5em;
}

.sfi-view-toggle {
	display: inline-flex;
	border: 1px solid var(--sfi-border);
	border-radius: 4px;
	overflow: hidden;
	background: #fff;
}

.sfi-view-btn {
	padding: 2px 24px;
	border: none;
	background: transparent;
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
	color: var(--sfi-muted);
	transition: background 0.15s ease, color 0.15s ease;
}

.sfi-view-btn:hover,
.sfi-view-btn.is-active {
	background: #2badff;
	color: #fff;
}

/* Override theme accent (#c36) on dashboard buttons */
.sfi-dashboard .sfi-all-filters-btn:hover,
.sfi-dashboard .sfi-all-filters-btn:active,
.sfi-dashboard .sfi-all-filters-btn:focus,
.sfi-dashboard .sfi-all-filters-btn:focus-visible {
	background: #f3f4f6 !important;
	color: var(--sfi-search-text) !important;
	border-color: transparent !important;
	box-shadow: none !important;
	outline: none;
}

.sfi-dashboard .sfi-toolbar-icon-btn:hover,
.sfi-dashboard .sfi-toolbar-icon-btn:active,
.sfi-dashboard .sfi-toolbar-icon-btn:focus,
.sfi-dashboard .sfi-toolbar-icon-btn:focus-visible {
	background: #f3f4f6 !important;
	color: #1a1a1a !important;
	border-color: transparent !important;
	box-shadow: none !important;
	outline: none;
}

.sfi-dashboard .sfi-btn:not(.sfi-btn-primary):hover,
.sfi-dashboard .sfi-btn:not(.sfi-btn-primary):active,
.sfi-dashboard .sfi-btn:not(.sfi-btn-primary):focus,
.sfi-dashboard .sfi-btn:not(.sfi-btn-primary):focus-visible {
	background: #f9fafb !important;
	border-color: #d1d5db !important;
	color: var(--sfi-text) !important;
	box-shadow: none !important;
	outline: none;
}

.sfi-dashboard .sfi-btn-primary:hover {
	background: #2badff !important;
	border-color: #2badff !important;
	color: #fff !important;
	box-shadow: none !important;
	outline: none;
}

.sfi-dashboard .sfi-btn-primary:active,
.sfi-dashboard .sfi-btn-primary:focus,
.sfi-dashboard .sfi-btn-primary:focus-visible {
	background: #1d4ed8 !important;
	border-color: #1d4ed8 !important;
	color: #fff !important;
	box-shadow: none !important;
	outline: none;
}

.sfi-dashboard .sfi-view-btn:hover,
.sfi-dashboard .sfi-view-btn.is-active,
.sfi-dashboard .sfi-view-btn.is-active:active,
.sfi-dashboard .sfi-view-btn.is-active:focus,
.sfi-dashboard .sfi-view-btn.is-active:focus-visible {
	background: #2badff !important;
	border-color: #2badff !important;
	color: #fff !important;
	box-shadow: none !important;
	outline: none;
}

.sfi-dashboard .sfi-view-btn:active:not(.is-active),
.sfi-dashboard .sfi-view-btn:focus:not(.is-active),
.sfi-dashboard .sfi-view-btn:focus-visible:not(.is-active) {
	background: #f3f4f6 !important;
	border-color: transparent !important;
	color: var(--sfi-muted) !important;
	box-shadow: none !important;
	outline: none;
}

.sfi-panel {
	display: none;
}

.sfi-panel.is-active {
	display: block;
}

/* Map */
.sfi-map-container {
	position: relative;
	padding: 16px;
	min-height: 420px;
}

.sfi-map-svg {
	width: 100%;
	height: auto;
	display: block;
}

.sfi-map-svg path.state {
	fill: #e5e7eb;
	stroke: #121212;
	stroke-width: 1;
	cursor: pointer;
	transition: fill 0.2s, stroke-width 0.15s;
}

.sfi-map-svg path.state.has-data {
	fill: var(--sfi-map-fill, #e5e7eb);
}

.sfi-map-svg path.state.has-data:hover,
.sfi-map-svg path.state.is-hovered {
	stroke: #1e3a8a;
	stroke-width: 2;
}

.sfi-map-tooltip {
	position: absolute;
	z-index: 10;
	min-width: 220px;
	max-width: 280px;
	padding: 16px 18px;
	background: #fff;
	border: none;
	border-radius: 8px;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1), 0 2px 6px rgba(0, 0, 0, 0.06);
	pointer-events: none;
	font-family: "Open Sans", sans-serif;
	box-sizing: border-box;
}

.sfi-map-tooltip .sfi-tooltip-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 0;
}

.sfi-map-tooltip .sfi-tooltip-state-name {
	font-size: 14px;
	font-weight: 700;
	color: #072c4a;
	line-height: 1.3;
	flex: 1;
	min-width: 0;
}

.sfi-map-tooltip .sfi-abbr-badge {
	flex-shrink: 0;
}

.sfi-map-tooltip .sfi-tooltip-divider {
	height: 1px;
	background: var(--sfi-border);
	margin: 10px 0;
}

.sfi-map-tooltip .sfi-tooltip-stations {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 0;
}

.sfi-map-tooltip .sfi-tooltip-icon {
	width: 12px;
	height: 12px;
	flex-shrink: 0;
	border-radius: 2px;
}

.sfi-map-tooltip .sfi-tooltip-stations-value {
	font-size: 18px;
	font-weight: 700;
	color: #1a1a1a;
	line-height: 1.2;
}

.sfi-map-tooltip .sfi-tooltip-stations-label {
	font-size: 14px;
	font-weight: 400;
	color: var(--sfi-muted);
	line-height: 1.4;
}

.sfi-map-tooltip .sfi-tooltip-bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.sfi-map-tooltip .sfi-tooltip-ai {
	display: inline-flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 4px;
	font-size: 14px;
	line-height: 1.4;
	min-width: 0;
}

.sfi-map-tooltip .sfi-tooltip-ai-value {
	font-weight: 700;
}

.sfi-map-tooltip .sfi-tooltip-ai-label {
	font-weight: 400;
	color: var(--sfi-muted);
}

.sfi-map-tooltip .sfi-tooltip-ai.sfi-ai-leading .sfi-tooltip-ai-value  { color: var(--sfi-leading); }
.sfi-map-tooltip .sfi-tooltip-ai.sfi-ai-growing .sfi-tooltip-ai-value  { color: var(--sfi-growing); }
.sfi-map-tooltip .sfi-tooltip-ai.sfi-ai-emerging .sfi-tooltip-ai-value { color: var(--sfi-emerging); }
.sfi-map-tooltip .sfi-tooltip-ai.sfi-ai-lagging .sfi-tooltip-ai-value  { color: var(--sfi-lagging); }

.sfi-map-tooltip .sfi-status-pill {
	flex-shrink: 0;
	white-space: nowrap;
}

.sfi-map-legend {
	display: flex;
	align-items: center;
	gap: 16px;
	flex: 1;
	min-width: 280px;
	max-width: 400px;
	padding: 8px 0px;
	border-radius: 6px;
}

.sfi-legend-title {
	display: block;
	color: var(--Texts-Text-Primary, #1A1A1A);
    font-family: "Open Sans", sans-serif;
    font-size: 10px;
   font-style: normal;
   font-weight: 400;
   line-height: 14px;
   margin-bottom: 0;
	white-space: nowrap;
	flex-shrink: 0;
}

.sfi-legend-segments {
	display: flex;
	flex: 1;
	min-width: 0;
	border-radius: 6px;
	overflow: hidden;
}

.sfi-legend-segment {
	flex: 1;
	min-width: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 4px 7.5px;
	color: var(--Texts-Text-Primary, #1A1A1A);
    font-family: "Open Sans", sans-serif;
    font-size: 10px;
    font-style: normal;
    font-weight: 400;
    line-height: 14px;
	text-align: center;
	white-space: nowrap;
}

.sfi-legend-segment.is-dark {
	color: #e5e7eb;
}

/* Table */
.sfi-table-wrap {
	width: 100%;
	border-radius: 0;
	background: #fff;
	max-height: min(560px, 65vh);
	overflow: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
	isolation: isolate;
	padding: 0 16px 0 12px;
}

.sfi-table-wrap::-webkit-scrollbar {
	width: 8px;
	height: 8px;
}

.sfi-table-wrap::-webkit-scrollbar-track {
	background: #f1f5f9;
	border-radius: 0 var(--sfi-radius) var(--sfi-radius) 0;
}

.sfi-table-wrap::-webkit-scrollbar-thumb {
	background: #cbd5e1;
	border-radius: 999px;
}

.sfi-table-wrap::-webkit-scrollbar-thumb:hover {
	background: #94a3b8;
}

.sfi-table {
	width: 100%;
	border: none;
	border-collapse: separate;
	border-spacing: 0;
	font-size: 14px;
	table-layout: fixed;
}

.sfi-table thead {
	background-color: #fafafa;
}

.sfi-table thead th {
	position: sticky;
	top: 0;
	z-index: 10;
	background-color: #fafafa !important;
	background-clip: padding-box;
	box-shadow: 0 1px 0 #9ca3af;
	border: none;
	border-bottom: 1px solid #9ca3af !important;
	border-top: none !important;
	font-family: "Open Sans", sans-serif;
	color: #1a1a1a;
	font-weight: 400;
	font-size: 12px;
	vertical-align: middle;
}

.sfi-table thead th.sfi-sortable {
	padding: 0;
	border-right: 1px solid #4fb8ff !important;
}

.sfi-table thead th.sfi-sortable:last-child {
	border-right: none !important;
}

.sfi-table th,
.sfi-table td {
	padding: 8px 16px;
	text-align: left;
	border: none;
	border-left: none !important;
	border-right: none !important;
	border-top: none;
	vertical-align: middle;
}

.sfi-table tbody td {
	border-bottom: 1px solid #e5e7eb;
}

.sfi-table tbody tr:last-child td {
	border-bottom: none;
}

.sfi-table th:nth-child(1),
.sfi-table td.sfi-col-state {
	width: 28%;
	padding-left: 12px;
}

.sfi-table tbody td.sfi-col-state {
	font-size: 12px;
	font-weight: 600;
	line-height: 1.5;
	color: #1a1a1a;
}

.sfi-table th:nth-child(1) .sfi-th-label {
	padding-left: 12px;
}

.sfi-table th:nth-child(2),
.sfi-table td.sfi-col-abbr {
	width: 16%;
	text-align: center;
	padding-left: 12px;
	padding-right: 12px;
}

.sfi-table th:nth-child(2) {
	text-align: center;
}

.sfi-table th:nth-child(2) .sfi-th-label {
	padding-left: 12px;
	padding-right: 12px;
}

.sfi-table th:nth-child(2) .sfi-th-sort {
	padding-right: 12px;
}

.sfi-table th.sfi-col-numeric,
.sfi-table td.sfi-col-numeric {
	width: 16%;
	text-align: right;
}

.sfi-table tbody td.sfi-col-numeric {
	font-size: 12px;
	font-weight: 600;
	line-height: 1.5;
	color: #072c4a;
}

.sfi-table th.sfi-col-adoption,
.sfi-table td.sfi-col-adoption {
	width: 26%;
}

.sfi-table th.sfi-col-status,
.sfi-table td.sfi-col-status {
	width: 14%;
	text-align: left;
}

.sfi-table tbody td.sfi-col-status .sfi-status-pill {
	font-size: 10px;
	font-weight: 700;
	line-height: 1.4em;
}

.sfi-dashboard .sfi-table tbody tr,
.sfi-dashboard .sfi-table tbody tr:nth-child(odd),
.sfi-dashboard .sfi-table tbody tr:nth-child(even) {
	background-color: #fff !important;
}

.sfi-dashboard .sfi-table tbody td,
.sfi-dashboard .sfi-table tbody tr:nth-child(odd) td,
.sfi-dashboard .sfi-table tbody tr:nth-child(even) td {
	background-color: #fff !important;
}

.sfi-dashboard .sfi-table tbody tr:hover,
.sfi-dashboard .sfi-table tbody tr:hover td {
	background-color: #fff !important;
}

.sfi-table th.sfi-sortable {
	cursor: pointer;
	user-select: none;
	white-space: nowrap;
}

.sfi-table th.sfi-sortable .sfi-th-inner {
	display: flex;
	align-items: stretch;
	width: 100%;
	min-height: 36px;
}

.sfi-table th.sfi-sortable .sfi-th-label {
	flex: 1;
	display: flex;
	align-items: center;
	padding: 8px 12px;
	min-width: 0;
	white-space: nowrap;
}

.sfi-table th.sfi-sortable .sfi-th-sort {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 40px;
	padding: 8px 10px;
	border-left: none;
	box-sizing: border-box;
}

.sfi-table th.sfi-th-no-icon .sfi-th-sort {
	display: none;
}

.sfi-table th.sfi-th-no-icon .sfi-th-label {
	padding: 8px 16px;
}

.sfi-table th.sfi-sortable .sfi-sort-icon {
	display: block;
	width: 20px;
	height: 20px;
	margin: 0;
	opacity: 0.45;
	object-fit: contain;
}

.sfi-table th.sfi-col-numeric .sfi-th-label,
.sfi-table th:nth-child(2).sfi-sortable .sfi-th-label {
	justify-content: center;
	text-align: center;
}

.sfi-table th.sfi-sort-asc .sfi-sort-icon,
.sfi-table th.sfi-sort-desc .sfi-sort-icon {
	opacity: 1;
}

.sfi-table th.sfi-sort-desc .sfi-sort-icon {
	transform: rotate(180deg);
}

.sfi-abbr-badge {
	display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    padding: 2px 6px;
    background: #CFEFFF;
    color: #072C4A;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.5em;
}

.sfi-adoption-cell {
	display: flex;
	align-items: center;
	gap: 12px;
	width: 100%;
	max-width: 220px;
}

.sfi-progress {
	flex: 1;
	height: 8px;
	min-width: 60px;
	background: #f3f4f6;
	border-radius: 33554400px;
	overflow: hidden;
}

.sfi-adoption-pct {
	flex-shrink: 0;
	min-width: 44px;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.5em;
	text-align: right;
}

.sfi-pct-leading  { color: var(--sfi-leading); }
.sfi-pct-growing  { color: var(--sfi-growing); }
.sfi-pct-emerging { color: var(--sfi-emerging); }
.sfi-pct-lagging  { color: var(--sfi-lagging); }

.sfi-progress-bar {
	height: 100%;
	border-radius: 33554400px;
}

.sfi-bar-leading  { background: var(--sfi-leading); }
.sfi-bar-growing  { background: var(--sfi-growing); }
.sfi-bar-emerging { background: var(--sfi-emerging); }
.sfi-bar-lagging  { background: var(--sfi-lagging); }

.sfi-status-pill {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 3px 8px;
	border-radius: 4px;
	font-size: 12px;
	font-weight: 600;
}

.sfi-status-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: currentColor;
}

.sfi-status-pill.sfi-status-emerging {
	background: #fff7e5;
	color: #d97706;
	border-radius: 4px;
	padding: 3px 8px;
}

.sfi-status-pill.sfi-status-leading {
	background: #e8f7ee;
	color: #22c55e;
	border-radius: 4px;
	padding: 3px 8px;
}

.sfi-status-pill.sfi-status-lagging {
	background: #fdecec;
	color: #dc2626;
	border-radius: 4px;
	padding: 3px 8px;
}

.sfi-status-pill.sfi-status-growing {
	background: #cfefff;
	color: var(--sfi-growing);
	border-radius: 4px;
	padding: 3px 8px;
}

.sfi-no-results {
	padding: 32px;
	text-align: center;
	color: var(--sfi-muted);
	margin: 0;
}

/* Below dashboard max width — edge padding on narrow viewports */
@media (max-width: 968px) {
	.sfi-dashboard {
		max-width: 100%;
		padding-left: 16px;
		padding-right: 16px;
	}
}

/* Tablet */
@media (max-width: 1024px) {
	.sfi-dashboard.sfi-view-table .sfi-page-header {
		padding: 12px 20px;
	}

	.sfi-dashboard.sfi-view-table .sfi-toolbar {
		flex-wrap: wrap;
		gap: 12px;
		padding: 12px 16px;
	}

	.sfi-dashboard.sfi-view-table .sfi-search-wrap {
		flex: 1 1 100%;
		max-width: 100%;
		min-width: 0;
	}

	.sfi-dashboard.sfi-view-table .sfi-toolbar-actions {
		flex: 1 1 100%;
		justify-content: flex-end;
		width: 100%;
	}

	.sfi-map-legend {
		max-width: 100%;
		min-width: 0;
	}
}

/* Mobile */
@media (max-width: 768px) {
	.sfi-dashboard {
		overflow-x: hidden;
		min-width: 0;
		padding-left: 12px;
		padding-right: 12px;
	}

	.sfi-dashboard.sfi-view-table .sfi-page-header {
		padding: 12px 16px;
		border-left: 1px solid #9ca3af;
		border-right: 1px solid #9ca3af;
	}

	.sfi-dashboard.sfi-view-table .sfi-table-section {
		border-left: 1px solid #9ca3af;
		border-right: 1px solid #9ca3af;
		border-bottom: 1px solid #9ca3af;
	}

	.sfi-dashboard.sfi-view-table .sfi-toolbar {
		flex-wrap: wrap;
		gap: 10px;
		padding: 12px;
	}

	/* Hide search/filters when Elementor mobile off-canvas menu is open */
	body.sfi-site-menu-open .sfi-dashboard .sfi-toolbar,
	body:has(.e-off-canvas[aria-hidden="false"]) .sfi-dashboard .sfi-toolbar {
		visibility: hidden;
		pointer-events: none;
	}

	.sfi-dashboard.sfi-view-table .sfi-search-wrap {
		flex: 1 1 100%;
		max-width: 100%;
		min-width: 0;
		height: 40px;
	}

	.sfi-dashboard.sfi-view-table .sfi-toolbar-actions {
		flex: 1 1 100%;
		justify-content: space-between;
		width: 100%;
		gap: 6px;
	}

	.sfi-dashboard.sfi-view-table .sfi-filters-wrap {
		flex: 1;
		min-width: 0;
	}

	.sfi-dashboard.sfi-view-table .sfi-all-filters-btn {
		width: 100%;
		max-width: none;
		justify-content: flex-start;
	}

	.sfi-filters-panel {
		position: absolute;
		top: calc(100% + 8px);
		left: 0;
		right: 0;
		width: auto;
		max-width: none;
		max-height: min(70vh, 520px);
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
	}

	.sfi-filters-actions {
		flex-wrap: wrap;
	}

	.sfi-filters-actions .sfi-btn {
		flex: 1;
		min-width: 120px;
	}

	.sfi-map-container {
		padding: 8px 4px;
		min-height: min(300px, 50vh);
	}

	.sfi-map-tooltip {
		min-width: 0;
		max-width: calc(100% - 24px);
		padding: 14px 16px;
	}

	.sfi-map-tooltip .sfi-tooltip-stations-value {
		font-size: 16px;
	}

	.sfi-map-tooltip .sfi-tooltip-state-name,
	.sfi-map-tooltip .sfi-tooltip-stations-label,
	.sfi-map-tooltip .sfi-tooltip-ai {
		font-size: 13px;
	}

	.sfi-dashboard-footer {
		flex-direction: column;
		align-items: stretch;
		gap: 12px;
		margin-top: 12px;
		padding: 0 4px;
	}

	.sfi-dashboard.sfi-view-table .sfi-dashboard-footer {
		justify-content: stretch;
	}

	.sfi-map-legend {
		flex-direction: column;
		align-items: stretch;
		gap: 8px;
		width: 100%;
		max-width: 100%;
		padding: 0;
	}

	.sfi-legend-title {
		white-space: normal;
	}

	.sfi-legend-segments {
		width: 100%;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	.sfi-legend-segment {
		flex: 0 0 auto;
		min-width: 56px;
		font-size: 9px;
		padding: 6px 6px;
	}

	.sfi-view-toggle-wrap {
		width: 100%;
		justify-content: space-between;
	}

	.sfi-view-toggle {
		flex: 1;
		max-width: 240px;
	}

	.sfi-view-btn {
		flex: 1;
		padding: 2px 12px;
		text-align: center;
	}

	.sfi-table-section .sfi-table-wrap {
		max-height: min(420px, 55vh);
		padding: 0 8px 0 12px;
		-webkit-overflow-scrolling: touch;
	}

	.sfi-table {
		min-width: 600px;
		table-layout: auto;
		font-size: 13px;
	}

	.sfi-table th,
	.sfi-table td {
		padding: 8px 12px;
	}

	.sfi-table th:nth-child(1),
	.sfi-table td.sfi-col-state {
		padding-left: 12px;
	}

	.sfi-table th:nth-child(1) .sfi-th-label {
		padding-left: 12px;
	}

	.sfi-table th:nth-child(2),
	.sfi-table td.sfi-col-abbr {
		padding-left: 12px;
		padding-right: 12px;
	}

	.sfi-table th:nth-child(2) .sfi-th-label {
		padding-left: 12px;
		padding-right: 12px;
	}

	.sfi-table th:nth-child(2) .sfi-th-sort {
		padding-right: 12px;
	}

	.sfi-table thead th {
		font-size: 11px;
	}

	.sfi-table th.sfi-sortable .sfi-th-sort {
		width: 36px;
		padding: 8px 6px;
	}

	.sfi-table th:nth-child(2) .sfi-th-sort {
		padding-right: 12px;
	}

	.sfi-table th.sfi-sortable .sfi-sort-icon {
		width: 16px;
		height: 16px;
	}

	.sfi-adoption-cell {
		max-width: none;
		gap: 8px;
	}

	.sfi-adoption-pct {
		font-size: 12px;
		line-height: 1.5em;
		min-width: 36px;
	}

	.sfi-table tbody td.sfi-col-status .sfi-status-pill {
		font-size: 10px;
		font-weight: 700;
		line-height: 1.4em;
		padding: 3px 8px;
	}

	.sfi-abbr-badge {
		min-width: 28px;
		font-size: 11px;
		padding: 3px 6px;
	}
}

/* Small phones */
@media (max-width: 480px) {
	.sfi-dashboard {
		padding-left: 8px;
		padding-right: 8px;
	}

	.sfi-dashboard.sfi-view-table .sfi-page-header {
		padding: 10px 12px;
	}

	.sfi-page-title {
		font-size: 16px;
		line-height: 1.35;
	}

	.sfi-page-subtitle {
		font-size: 11px;
	}

	.sfi-dashboard.sfi-view-table .sfi-toolbar {
		padding: 10px;
	}

	.sfi-search-wrap {
		height: 40px;
		gap: 10px;
		padding: 6px 8px;
	}

	.sfi-all-filters-label {
		font-size: 14px;
	}

	.sfi-toolbar-icon-btn {
		width: 36px;
		height: 36px;
	}

	.sfi-filter-range {
		grid-template-columns: 1fr;
	}

	.sfi-filters-panel {
		padding: 12px;
	}

	.sfi-map-container {
		min-height: min(240px, 45vh);
	}

	.sfi-legend-segment {
		min-width: 44px;
		font-size: 8px;
	}

	.sfi-view-label {
		font-size: 11px;
	}

	.sfi-view-toggle {
		max-width: none;
		width: 100%;
	}

	.sfi-table {
		min-width: 520px;
		font-size: 12px;
	}

	.sfi-table-section .sfi-table-wrap {
		max-height: min(360px, 50vh);
		padding: 0 4px 0 12px;
	}

	.sfi-table th,
	.sfi-table td {
		padding: 8px 10px;
	}

	.sfi-table th:nth-child(1),
	.sfi-table td.sfi-col-state {
		padding-left: 12px;
	}

	.sfi-table th:nth-child(1) .sfi-th-label {
		padding-left: 12px;
	}

	.sfi-table th:nth-child(2),
	.sfi-table td.sfi-col-abbr {
		padding-left: 12px;
		padding-right: 12px;
	}

	.sfi-table th:nth-child(2) .sfi-th-label {
		padding-left: 12px;
		padding-right: 12px;
	}

	.sfi-table th:nth-child(2) .sfi-th-sort {
		padding-right: 12px;
	}

	.sfi-table th.sfi-sortable .sfi-th-sort {
		width: 32px;
		padding: 8px 4px;
	}

	.sfi-table th:nth-child(2) .sfi-th-sort {
		padding-right: 12px;
	}

	.sfi-table th.sfi-sortable .sfi-th-label {
		padding: 8px 8px;
	}

	.sfi-table th:nth-child(2) .sfi-th-label {
		padding-left: 12px;
		padding-right: 12px;
	}

	.sfi-table th.sfi-sortable .sfi-sort-icon {
		width: 14px;
		height: 14px;
	}

	.sfi-no-results {
		padding: 24px 12px;
		font-size: 13px;
	}
}
