/* Redditi 2024 production stylesheet bundle */
/* Base: /Users/apb/Work/03_IP/06_Products/votes-vis/viewer/politiche-2022/styles.css */


/* BEGIN inlined import: /Users/apb/Work/03_IP/06_Products/votes-vis/viewer/torino/styles.css */
@font-face {
  font-family: "Datatype";
  src: url("../fonts/Datatype-VariableFont_wdth,wght.ttf") format("truetype");
  font-display: swap;
}

:root {
  --du-font-brand: "Datatype", "Source Sans 3", sans-serif;
  --du-font-ui: "Source Sans 3", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --du-color-brand-paper: #e5e5e5;
  --du-color-brand-surface: #fbfaf7;
  --du-color-brand-surface-alt: #ece7df;
  --du-color-brand-line: #ced4da;
  --du-color-brand-ink: #1f2328;
  --du-color-brand-ink-muted: #5f6a72;
  --du-color-brand-accent: #8b5738;
  --du-color-brand-accent-cool: #3484bf;
  --du-color-brand-focus: #3484bf;
  --du-color-brand-inverse: #ffffff;
  --page-bg: var(--du-color-brand-paper);
  --panel-line: var(--du-color-brand-line);
  --panel-text: var(--du-color-brand-ink);
  --panel-muted: var(--du-color-brand-ink-muted);
  --panel-faint: #8a929e;
  --stage-border: var(--du-color-brand-line);
  --accent: var(--du-color-brand-accent);
  --accent-hover: #70462d;
  --tile-size: 18px;
  --tile-gap: 6px;
  --swatch-size: 18px;
  --top-strip-bg: #0a0a1a;
  --top-strip-text: var(--du-color-brand-inverse);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
  background: var(--page-bg);
  color: var(--panel-text);
}

body {
  font-family: var(--du-font-ui);
}

button,
select {
  font: inherit;
}

.shell {
  height: calc(100vh - 2rem);
  min-height: calc(100vh - 2rem);
  display: grid;
  grid-template-columns: minmax(150px, 190px) minmax(0, 1fr);
  gap: 16px;
  padding: 24px;
  overflow: hidden;
}

.top-strip {
  height: 2rem;
  background: var(--top-strip-bg);
}

.top-strip-inner {
  height: 100%;
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 0 24px;
}

.top-strip-link,
.top-strip-separator {
  color: var(--top-strip-text);
  font-family: var(--du-font-brand);
  font-size: 0.9rem;
  line-height: 1;
}

.top-strip-link {
  text-decoration: none;
}

.top-strip-link:hover {
  text-decoration: underline;
}

.sidebar {
  display: flex;
  flex-direction: column;
  min-width: 0;
  height: 100%;
  padding-top: 0;
  overflow: hidden;
}

.sidebar-bottom {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-top: 12px;
}

.sidebar-top {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 4px;
}

.reset-all {
  border: 0;
  background: transparent;
  padding: 0;
  color: var(--accent);
  font-family: var(--du-font-brand);
  font-size: 1rem;
  letter-spacing: 0.02em;
  cursor: pointer;
}

.reset-all:hover {
  color: var(--accent-hover);
}

.accordion {
  border-top: 1px solid var(--panel-line);
  padding-top: 6px;
  margin-bottom: 16px;
}

.accordion:last-of-type {
  margin-bottom: 26px;
}

.accordion-title {
  display: flex;
  align-items: center;
  padding: 0 0 8px;
  font-family: var(--du-font-brand);
  font-size: clamp(0.82rem, 1vw, 0.875rem);
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--panel-text);
}

.accordion-body {
  padding: 0 0 6px;
}

.select-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 6px;
}

.select-row select {
  width: 100%;
  min-width: 0;
  appearance: none;
  border: 0;
  border-bottom: 1px solid var(--panel-line);
  background: transparent;
  padding: 0 0 4px;
  color: var(--panel-muted);
  font-weight: 300;
  font-size: 0.93rem;
  outline: none;
}

.select-row select.has-selection {
  color: var(--accent);
}

.select-row select:focus {
  border-bottom-color: var(--du-color-brand-focus);
}

.select-row select:disabled {
  color: var(--panel-faint);
}

.field-reset {
  border: 0;
  background: transparent;
  padding: 0;
  min-width: 12px;
  color: rgba(139, 87, 56, 0.72);
  font-size: 0.88rem;
  line-height: 1.4;
  cursor: pointer;
}

.field-reset:hover {
  color: var(--accent);
}

.field-reset.is-hidden {
  visibility: hidden;
}

.stats-list {
  display: grid;
  gap: 0;
  font-size: 0.98rem;
  line-height: 1.1;
}

.stat-line {
  display: flex;
  gap: 4px;
}

.stat-line .label {
  color: var(--panel-text);
  font-weight: 600;
}

.stat-line .value {
  color: var(--panel-text);
}

.stat-line .value.muted,
.stat-line .label.muted {
  color: var(--panel-muted);
  font-weight: 400;
}

.legend-block {
  margin-top: -24px;
  color: var(--panel-muted);
  font-size: 0.74rem;
  line-height: 1.12;
}

.context-legend {
  margin: 0 0 12px;
}

.context-legend.is-hidden {
  display: none;
}

.source-block {
  color: var(--panel-muted);
  font-size: 0.6rem;
  line-height: 1.25;
}

.source-line {
  margin: 0 0 2px;
  overflow-wrap: anywhere;
}

.source-link {
  color: inherit;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.12em;
}

.source-link:hover {
  color: var(--panel-text);
}

.source-line:empty {
  display: none;
}

.legend-title {
  margin: 0 0 5px;
  color: var(--panel-text);
  font-family: var(--du-font-brand);
  font-weight: 600;
}

.legend-title-secondary {
  margin-bottom: 4px;
}

.legend-note {
  margin: 0 0 8px;
}

.legend-note:empty {
  display: none;
}

.legend-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2px 10px;
}

.legend-column {
  display: grid;
  gap: 2px;
}

.legend-text-group {
  display: grid;
  gap: 3px;
  align-content: start;
}

.legend-text-title {
  margin: 0 0 2px;
  color: var(--panel-text);
  font-family: var(--du-font-brand);
  font-weight: 600;
}

.legend-text-entry {
  color: var(--panel-muted);
  line-height: 1.16;
}

.legend-entry {
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}

.legend-swatch {
  width: 9px;
  height: 9px;
  background: var(--legend-color);
  flex: none;
}

.stage {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 4px;
  min-width: 0;
}

.stage-head {
  min-height: 62px;
  position: relative;
}

.stage-topline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding-right: 0;
  margin-top: 0;
}

.stage-controls {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 1px;
  flex: none;
  margin-top: 0;
}

.language-tabs {
  display: flex;
  align-items: center;
  gap: 5px;
  flex: none;
  line-height: 1.25;
}

.language-tab {
  border: 0;
  background: transparent;
  padding: 0;
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.9rem;
  letter-spacing: 0.02em;
  font-weight: 400;
  cursor: pointer;
}

.language-tab.is-active {
  color: var(--panel-text);
}

.language-separator {
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.9rem;
  line-height: 1.25;
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin: 0;
  font-family: var(--du-font-brand);
  font-size: clamp(1rem, 1.5vw, 1.125rem);
  font-weight: 400;
  letter-spacing: 0.02em;
  color: var(--panel-muted);
  min-width: 0;
  line-height: 1.02;
}

.breadcrumb-separator {
  color: var(--panel-faint);
}

.breadcrumb-link,
.breadcrumb-current {
  border: 0;
  background: transparent;
  padding: 0;
  font: inherit;
  color: inherit;
}

.breadcrumb-link {
  cursor: pointer;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.12em;
}

.breadcrumb-link:hover {
  color: var(--panel-text);
}

.view-tabs {
  display: flex;
  align-items: center;
  gap: 7px;
  padding-top: 0;
  flex: none;
  line-height: 1.25;
}

.subview-tabs {
  display: flex;
  align-items: center;
  gap: 7px;
  justify-content: flex-end;
  flex-wrap: wrap;
  max-width: 360px;
  line-height: 1.25;
}

.subview-tabs.is-hidden {
  display: none;
}

#graph-scope-tabs {
  flex-wrap: nowrap;
  max-width: none;
  white-space: nowrap;
  gap: 6px;
}

.segment-controls {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  flex-wrap: nowrap;
  max-width: none;
  overflow-x: auto;
  overflow-y: hidden;
  white-space: nowrap;
  scrollbar-width: none;
  line-height: 1.25;
}

.segment-controls.is-hidden {
  display: none;
}

.segment-controls::-webkit-scrollbar {
  display: none;
}

.segment-controls select {
  flex: 0 0 auto;
  min-width: 0;
  border: 0;
  border-bottom: 1px solid var(--panel-line);
  background: transparent;
  padding: 0 0 3px;
  color: var(--panel-text);
  font-family: var(--du-font-brand);
  font-size: 0.9rem;
  font-weight: 400;
  letter-spacing: 0.02em;
  outline: none;
}

.segment-controls select.is-hidden {
  display: none;
}

.segment-controls select:focus {
  border-bottom-color: var(--du-color-brand-focus);
}

.segment-toggle {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 5px;
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.9rem;
  letter-spacing: 0.02em;
  cursor: pointer;
}

.segment-toggle input {
  margin: 0;
  accent-color: var(--du-color-brand-focus);
}

.segment-toggle span {
  color: var(--panel-muted);
}

.segment-toggle input:checked + span {
  color: var(--panel-text);
}

.view-tab {
  border: 0;
  background: transparent;
  padding: 0;
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.9rem;
  letter-spacing: 0.02em;
  font-weight: 400;
  cursor: pointer;
}

.view-tab.is-active {
  color: var(--panel-text);
}

.subview-tab {
  border: 0;
  background: transparent;
  padding: 0;
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.9rem;
  letter-spacing: 0.02em;
  font-weight: 400;
  cursor: pointer;
}

.subview-tab.is-active {
  color: var(--panel-text);
}

.control-separator {
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.9rem;
  font-weight: 400;
  line-height: 1.25;
}

.control-separator.is-hidden {
  display: none;
}

.context-line,
.result-line {
  margin: 0;
}

.context-line {
  min-height: 1.1em;
  margin-top: -1px;
  color: var(--panel-faint);
  font-size: 0.98rem;
  line-height: 1.1;
}

.result-line {
  min-height: 1.1em;
  margin-top: 0;
  margin-bottom: 1px;
  padding-bottom: 8px;
  color: var(--panel-text);
  font-family: var(--du-font-brand);
  font-size: clamp(0.82rem, 1.15vw, 0.875rem);
  line-height: 1.1;
}

.result-segment + .result-segment::before {
  content: "·";
  margin: 0 0.35rem;
  color: var(--panel-faint);
}

.result-label {
  color: var(--panel-text);
  font-weight: 500;
}

.result-value {
  color: var(--panel-muted);
  font-weight: 300;
}

.stage-canvas {
  position: relative;
  min-height: 78vh;
  border: 1px solid var(--stage-border);
  background: rgba(255, 255, 255, 0.58);
  overflow: hidden;
}

.stage-panel {
  position: absolute;
  inset: 0;
}

.stage-panel.is-hidden {
  display: none;
}

.graph-panel {
  overflow: auto;
}

.map-panel {
  background: rgba(255, 255, 255, 0.68);
}

.polygon-layout {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
}

.polygon-layout.is-hidden {
  display: none;
}

.polygon-layout.has-info-panel {
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 14px;
  padding: 14px;
}

.geo-map {
  width: 100%;
  height: 100%;
  display: block;
}

.geo-map.is-hidden {
  display: none;
}

.map-info-panel {
  display: grid;
  align-content: start;
  gap: 12px;
  overflow: auto;
  padding: 6px 4px 8px 10px;
  color: var(--panel-text);
}

.map-info-panel.is-hidden {
  display: none;
}

.map-info-block {
  display: grid;
  gap: 4px;
}

.map-info-heading {
  margin: 0;
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 1.08rem;
  letter-spacing: 0.02em;
}

.map-info-list {
  display: grid;
  gap: 12px;
}

.map-info-toolbar {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 6px;
  padding-bottom: 8px;
  border-bottom: 0.1rem solid #bdbdbd;
}

.map-info-sort-button {
  border: 0;
  background: transparent;
  padding: 0;
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.88rem;
  letter-spacing: 0.02em;
  cursor: pointer;
}

.map-info-sort-button.is-active {
  color: var(--panel-text);
}

.map-info-sort-separator {
  color: var(--panel-muted);
  font-size: 0.88rem;
  line-height: 1;
}

.map-info-item {
  display: grid;
  gap: 5px;
  padding: 14px 0 12px;
  border-top: 0.055rem solid #bdbdbd;
}

.map-info-item:first-child {
  padding-top: 2px;
  border-top: 0;
}

.map-info-item-title {
  color: var(--panel-text);
  font-family: var(--du-font-brand);
  font-weight: 500;
  font-size: clamp(0.84rem, 0.98vw, 0.9rem);
  line-height: 1.18;
  padding-bottom: 5px;
}

.map-info-subheading {
  margin-top: 5px;
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.92rem;
  letter-spacing: 0.02em;
}

.map-info-line {
  color: var(--panel-muted);
  font-size: 0.82rem;
  line-height: 1.16;
}

.map-info-stat-line {
  display: flex;
  gap: 4px;
  font-size: 0.82rem;
  line-height: 1.16;
}

.map-info-stat-label {
  color: var(--panel-text);
  font-weight: 600;
}

.map-info-stat-value {
  color: var(--panel-muted);
  font-weight: 400;
}

.leaflet-panel {
  position: absolute;
  inset: 0;
}

.leaflet-panel.is-hidden {
  display: none;
}

.leaflet-map {
  width: 100%;
  height: 100%;
}

.geo-shape {
  cursor: pointer;
  transition:
    opacity 120ms ease,
    transform 120ms ease;
}

.geo-shape:hover {
  opacity: 0.92;
}

.geo-shape.is-selected {
  stroke: var(--panel-text);
  stroke-width: 2.4;
}

.square-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--tile-size), var(--tile-size)));
  gap: var(--tile-gap);
  align-content: start;
  justify-content: start;
  padding: 16px 16px 18px;
}

.square-item {
  border: 0;
  background: transparent;
  padding: 0;
  width: var(--tile-size);
  min-height: var(--tile-size);
  color: var(--panel-text);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 7px;
  cursor: pointer;
  text-align: center;
}

.square-grid.is-compact .square-item {
  width: var(--tile-size);
  height: var(--tile-size);
}

.square-item:hover .square-mark,
.square-item:focus-visible .square-mark {
  transform: translateY(-1px);
}

.square-item:focus-visible {
  outline: none;
}

.square-mark {
  width: var(--swatch-size);
  height: var(--swatch-size);
  background: var(--fill);
  transition: transform 120ms ease;
}

.square-grid.is-compact .square-label {
  display: none;
}

.square-label {
  max-width: 100%;
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.72rem;
  line-height: 0.98;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.square-item.is-active .square-mark {
  outline: 2px solid var(--panel-text);
  outline-offset: 2px;
}

.square-item.is-active .square-label {
  color: var(--panel-text);
  font-weight: 600;
}

.loading-overlay {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  background: rgba(229, 229, 229, 0.86);
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 1.3rem;
  letter-spacing: 0.03em;
  z-index: 500;
}

.loading-overlay.is-hidden {
  display: none;
}

@media (max-width: 980px) {
  .shell {
    height: auto;
    min-height: calc(100vh - 2rem);
    grid-template-columns: 1fr;
    gap: 28px;
    padding: 24px;
    overflow: visible;
  }

  .sidebar {
    height: auto;
    padding-top: 0;
    overflow: visible;
  }

  .legend-block {
    margin-top: 8px;
  }

  .stage-topline {
    flex-direction: column;
    gap: 6px;
  }

  .stage-controls {
    align-items: flex-start;
    margin-top: 0;
  }

  .view-tabs {
    padding-top: 0;
  }

  .stage-canvas {
    min-height: 56vh;
  }

  .polygon-layout.has-info-panel {
    grid-template-columns: 1fr;
  }
}

/* END inlined import: /Users/apb/Work/03_IP/06_Products/votes-vis/viewer/torino/styles.css */


.stage-head {
  min-height: 86px;
}

.stage-heading {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.stage-secondaryline {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 14px;
  min-height: 1.15rem;
}

.stage-heading .context-line {
  margin: 0;
  text-align: left;
  min-width: 0;
}

.chart-empty {
  padding: 18px 0;
  color: var(--panel-muted);
  font-size: 0.92rem;
}

.graph-panel {
  overflow: auto;
}

.square-grid {
  padding: 18px 18px 22px;
}

.square-item {
  gap: 10px;
  justify-content: flex-start;
}

.square-mark {
  display: block;
  flex: none;
}

.square-value {
  color: var(--panel-text);
  font-family: var(--du-font-brand);
  font-size: 0.84rem;
  font-weight: 500;
  line-height: 1.06;
  white-space: nowrap;
}

.square-title {
  max-width: 100%;
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.72rem;
  line-height: 1.12;
  text-transform: uppercase;
  letter-spacing: 0.015em;
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
  min-height: 2.24em;
}

.square-grid.is-compact .square-title {
  display: none;
}

.square-grid.is-medium .square-title {
  font-size: 0.68rem;
}

.square-grid.is-tight .square-title {
  font-size: 0.63rem;
  min-height: 2.12em;
}

.square-grid.is-compact .square-item {
  gap: 6px;
}

.square-grid.is-dense .square-value {
  display: none;
}

.square-item.is-active .square-mark {
  outline: 2px solid #3182bd;
}

.square-item.is-active .square-value,
.square-item.is-active .square-title {
  color: #3182bd;
  font-weight: 500;
}

.stat-line.color-chip {
  align-items: center;
}

.stat-swatch {
  width: 9px;
  height: 9px;
  flex: none;
  background: var(--swatch-color, var(--panel-faint));
}

.leaflet-container {
  background: rgba(255, 255, 255, 0.08);
  font-family: var(--du-font-ui);
}

.leaflet-map {
  min-height: 100%;
}

.map-info-panel {
  border-left: 1px solid var(--panel-line);
}

.map-info-panel .chart-empty {
  padding-top: 2px;
}

.map-info-title {
  margin: 0;
  color: var(--panel-text);
  font-family: var(--du-font-brand);
  font-size: 1.08rem;
  font-weight: 500;
  line-height: 1.08;
}

.map-info-subtitle {
  margin: 0;
  color: var(--panel-muted);
  font-size: 0.8rem;
  line-height: 1.12;
}

.map-info-item-button {
  border: 0;
  background: transparent;
  padding: 0;
  color: inherit;
  text-align: left;
  cursor: pointer;
}

.map-info-item-button:hover .map-info-item-title,
.map-info-item-button:focus-visible .map-info-item-title {
  color: var(--du-color-brand-focus);
}

.map-info-item-button:focus-visible {
  outline: none;
}

@media (max-width: 980px) {
  .stage-head {
    min-height: auto;
  }

  .stage-secondaryline {
    align-items: flex-start;
  }

  .map-info-panel {
    border-left: 0;
    border-top: 1px solid var(--panel-line);
  }
}

/* Redditi 2024 overrides */

/* BEGIN inlined import: /Users/apb/Work/03_IP/06_Products/votes-vis/viewer/politiche-2022/styles.css */

/* skipped repeated import: /Users/apb/Work/03_IP/06_Products/votes-vis/viewer/politiche-2022/styles.css */

/* END inlined import: /Users/apb/Work/03_IP/06_Products/votes-vis/viewer/politiche-2022/styles.css */


.stage-head {
  min-height: 86px;
}

.metric-controls {
  max-width: 420px;
}

.metric-controls select {
  max-width: 420px;
}

.square-grid.is-band-view {
  grid-template-columns: repeat(auto-fill, minmax(96px, 96px));
}

.square-grid.is-band-view .square-item {
  width: 96px;
}

.square-grid.is-band-view .square-title {
  min-height: 1.2em;
}

.map-info-value {
  color: var(--panel-text);
  font-family: var(--du-font-brand);
  font-size: 0.96rem;
  font-weight: 500;
  line-height: 1.08;
}

.map-info-muted {
  color: var(--panel-muted);
}

.square-mark {
  border: 1px solid var(--stroke, rgba(31, 35, 40, 0.22));
}

.legend-swatch {
  border: 1px solid var(--legend-stroke, rgba(31, 35, 40, 0.22));
}

@media (max-width: 980px) {
  .metric-controls,
  .metric-controls select {
    max-width: 100%;
  }
}

/* Map mode toggle: CONFINI / STRADARIO */
.map-mode-tabs {
  justify-content: flex-end;
  max-width: none;
  white-space: nowrap;
}

.map-mode-tabs.is-hidden {
  display: none;
}

/* Boundary mode: current analytical surface, no tile substrate. */
.leaflet-map.is-boundary-mode {
  background: rgba(255, 255, 255, 0.42);
}

/* Street mode: quiet basemap below the analytical overlay. */
.leaflet-map.is-street-mode {
  background: #f3f0eb;
}

.leaflet-map.is-street-mode .leaflet-tile-pane {
  filter: saturate(0.45) contrast(0.92) brightness(1.04);
}

.leaflet-map.is-street-mode .leaflet-overlay-pane {
  mix-blend-mode: multiply;
}

/* Keep Leaflet attribution visually compatible with the Data Urbs frame. */
.leaflet-control-attribution {
  background: rgba(251, 250, 247, 0.78) !important;
  color: var(--panel-muted, #5f6a72) !important;
  font-family: var(--du-font-ui, "Source Sans 3", sans-serif) !important;
  font-size: 0.62rem !important;
  line-height: 1.2 !important;
}

.leaflet-control-attribution a {
  color: inherit !important;
}

/* Map controls hierarchy:
   view mode first, map substrate second, metric/value selection third. */
#map-mode-tabs {
  order: 3;
  margin-top: 1px;
}

#metric-controls {
  order: 4;
  margin-top: 4px;
}

#metric-controls select {
  text-align: left;
}

.stage-controls {
  row-gap: 2px;
}

/* Street map visibility tuning */
.leaflet-map.is-street-mode .leaflet-tile-pane {
  opacity: 1;
  filter: saturate(0.72) contrast(1.02) brightness(1.01);
}

.leaflet-map.is-street-mode img.leaflet-tile {
  mix-blend-mode: normal !important;
}

.leaflet-map.is-street-mode .leaflet-overlay-pane {
  mix-blend-mode: normal;
}

.leaflet-map.is-street-mode .leaflet-interactive {
  transition:
    fill-opacity 120ms ease,
    stroke-width 120ms ease;
}

/* STRADARIO visibility fix: keep street tiles clearly visible below polygons. */
.leaflet-map.is-street-mode {
  background: #f4f1ea;
}

.leaflet-map.is-street-mode .leaflet-tile-pane,
.leaflet-map.is-street-mode .leaflet-pane.leaflet-street-pane {
  opacity: 1 !important;
  filter: none !important;
  mix-blend-mode: normal !important;
}

.leaflet-map.is-street-mode img.leaflet-tile {
  opacity: 1 !important;
  filter: none !important;
  mix-blend-mode: normal !important;
}

.leaflet-map.is-street-mode .leaflet-overlay-pane {
  mix-blend-mode: normal !important;
}

.leaflet-map.is-street-mode path.leaflet-interactive {
  fill-opacity: 0.28;
}

/* Classification scope controls */
.classification-controls {
  order: 3;
  justify-content: flex-end;
  max-width: none;
  white-space: nowrap;
}

.classification-controls.is-hidden {
  display: none;
}

.classification-controls select {
  max-width: 260px;
}

/* When map modes are visible, keep them above the metric selector. */
#map-mode-tabs {
  order: 3;
}

#classification-controls + #map-mode-tabs {
  margin-top: 1px;
}

/* Classification controls: primary | combine | secondary | value | metric */
.classification-controls {
  order: 3;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  max-width: min(920px, 72vw);
  white-space: nowrap;
}

.classification-controls.is-hidden {
  display: none;
}

.classification-controls select,
.classification-controls #metric-controls select {
  flex: 0 1 auto;
  max-width: 260px;
}

.classification-controls #classification-group-select {
  max-width: 340px;
}

.classification-controls #metric-controls {
  display: flex;
  align-items: center;
  flex: 0 1 auto;
  margin-top: 0;
  max-width: 320px;
  order: 20;
}

.classification-controls #metric-controls select {
  max-width: 320px;
}

.classification-toggle {
  flex: 0 0 auto;
}

.classification-toggle input {
  margin: 0;
  accent-color: var(--du-color-brand-focus, #3484bf);
}

.classification-controls .is-hidden {
  display: none;
}

@media (max-width: 1180px) {
  .classification-controls {
    max-width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .classification-controls select,
  .classification-controls #metric-controls,
  .classification-controls #metric-controls select,
  .classification-controls #classification-group-select {
    max-width: 100%;
  }
}

/* Metro + classification analytical controls */
#graph-scope-tabs {
  flex-wrap: nowrap;
  max-width: none;
  white-space: nowrap;
}

.classification-controls {
  order: 3;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  max-width: min(960px, 76vw);
  white-space: nowrap;
}

.classification-controls.is-hidden {
  display: none;
}

.classification-controls select,
.classification-controls #metric-controls select {
  flex: 0 1 auto;
  max-width: 260px;
}

.classification-controls #classification-group-select {
  max-width: 340px;
}

.classification-controls #metric-controls {
  display: flex;
  align-items: center;
  flex: 0 1 auto;
  margin-top: 0;
  max-width: 320px;
  order: 20;
}

.classification-controls #metric-controls select {
  max-width: 320px;
}

.classification-toggle {
  flex: 0 0 auto;
}

.classification-toggle input {
  margin: 0;
  accent-color: var(--du-color-brand-focus, #3484bf);
}

.classification-controls .is-hidden {
  display: none;
}

@media (max-width: 1180px) {
  .classification-controls {
    max-width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .classification-controls select,
  .classification-controls #metric-controls,
  .classification-controls #metric-controls select,
  .classification-controls #classification-group-select {
    max-width: 100%;
  }
}

/* Metro + classification final layout */
#graph-scope-tabs {
  flex-wrap: nowrap;
  max-width: none;
  white-space: nowrap;
}

.classification-controls {
  order: 3;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  max-width: min(980px, 78vw);
  white-space: nowrap;
}

.classification-controls.is-hidden {
  display: none;
}

.classification-controls select,
.classification-controls #metric-controls select {
  flex: 0 1 auto;
  max-width: 260px;
}

.classification-controls #classification-group-select {
  max-width: 360px;
}

.classification-controls #metric-controls {
  display: flex;
  align-items: center;
  flex: 0 1 auto;
  margin-top: 0;
  max-width: 320px;
  order: 20;
}

.classification-controls #metric-controls select {
  max-width: 320px;
}

.classification-toggle {
  flex: 0 0 auto;
}

.classification-toggle input {
  margin: 0;
  accent-color: var(--du-color-brand-focus, #3484bf);
}

.classification-controls .is-hidden {
  display: none;
}

@media (max-width: 1180px) {
  .classification-controls {
    max-width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .classification-controls select,
  .classification-controls #metric-controls,
  .classification-controls #metric-controls select,
  .classification-controls #classification-group-select {
    max-width: 100%;
  }
}

/* Metro + classification scope correction */
#graph-scope-tabs {
  flex-wrap: nowrap;
  max-width: none;
  white-space: nowrap;
}

.classification-controls {
  order: 3;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  max-width: min(980px, 78vw);
  white-space: nowrap;
}

.classification-controls.is-hidden {
  display: none;
}

.classification-controls select,
.classification-controls #metric-controls select {
  flex: 0 1 auto;
  max-width: 260px;
}

.classification-controls #classification-group-select {
  max-width: 360px;
}

.classification-controls #metric-controls {
  display: flex;
  align-items: center;
  flex: 0 1 auto;
  margin-top: 0;
  max-width: 320px;
  order: 20;
}

.classification-controls #metric-controls select {
  max-width: 320px;
}

.classification-toggle {
  flex: 0 0 auto;
}

.classification-toggle input {
  margin: 0;
  accent-color: var(--du-color-brand-focus, #3484bf);
}

.classification-controls .is-hidden {
  display: none;
}

@media (max-width: 1180px) {
  .classification-controls {
    max-width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .classification-controls select,
  .classification-controls #metric-controls,
  .classification-controls #metric-controls select,
  .classification-controls #classification-group-select {
    max-width: 100%;
  }
}

/* Boundaries mode: hide Leaflet attribution/logo when no street basemap is active. */
.leaflet-map.is-boundary-mode .leaflet-control-attribution {
  display: none !important;
}

/* Street mode: keep attribution visible because external map tiles are active. */
.leaflet-map.is-street-mode .leaflet-control-attribution {
  display: block !important;
}

/* Classification map keeps categorical areas readable over both substrates. */
.leaflet-map.is-boundary-mode path.leaflet-interactive {
  stroke-linejoin: round;
  stroke-linecap: round;
}

/* Metro independent scope + classification controls */
#graph-scope-tabs {
  flex-wrap: nowrap;
  max-width: none;
  white-space: nowrap;
}

.classification-controls {
  order: 3;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  max-width: min(980px, 78vw);
  white-space: nowrap;
}

.classification-controls.is-hidden {
  display: none;
}

.classification-controls select,
.classification-controls #metric-controls select {
  flex: 0 1 auto;
  max-width: 260px;
}

.classification-controls #classification-group-select {
  max-width: 360px;
}

.classification-controls #metric-controls {
  display: flex;
  align-items: center;
  flex: 0 1 auto;
  margin-top: 0;
  max-width: 320px;
  order: 20;
}

.classification-controls #metric-controls select {
  max-width: 320px;
}

.classification-toggle {
  flex: 0 0 auto;
}

.classification-toggle input {
  margin: 0;
  accent-color: var(--du-color-brand-focus, #3484bf);
}

.classification-controls .is-hidden {
  display: none;
}

@media (max-width: 1180px) {
  .classification-controls {
    max-width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .classification-controls select,
  .classification-controls #metric-controls,
  .classification-controls #metric-controls select,
  .classification-controls #classification-group-select {
    max-width: 100%;
  }
}

/* Classification map legend: categorical hue + metric shade ramp */
.classification-shade-legend {
  grid-column: 1 / -1;
}

.classification-shade-entry {
  align-items: center;
}

.legend-ramp {
  width: 22px;
  height: 9px;
  flex: none;
  border: 1px solid var(--legend-stroke, rgba(31, 35, 40, 0.22));
  background: linear-gradient(90deg, var(--legend-low), var(--legend-high));
}

/* Classification shade-bin legend */
.classification-bin-legend {
  grid-column: 1 / -1;
  display: grid;
  gap: 2px 10px;
}

.classification-bin-legend.is-two-column {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.classification-bin-entry {
  min-width: 0;
  white-space: normal;
}

.classification-bin-swatch {
  border: 1px solid var(--legend-stroke, rgba(31, 35, 40, 0.22));
}

/* Region map municipality list: all entries, alphabetical */
.map-info-list-all-municipalities {
  gap: 0;
}

.map-info-list-all-municipalities .map-info-item {
  padding: 8px 0 7px;
}

.map-info-item-button {
  width: 100%;
  border: 0;
  background: transparent;
  padding: 0;
  color: inherit;
  text-align: left;
  font: inherit;
  cursor: pointer;
}

.map-info-item-button:hover .map-info-item-title {
  color: var(--accent);
}

/* Consistent typographic air between stat labels and values */
.stat-line,
.map-info-stat-line {
  column-gap: 0.38em;
}

.stat-line .label,
.map-info-stat-label {
  margin-right: 0.08em;
}

.stat-line .value,
.map-info-stat-value {
  font-variant-numeric: tabular-nums;
}

/* Plain map-info lines may contain label/value text in a single node. */
.map-info-line {
  letter-spacing: 0.002em;
}

/* Map info sorting controls */
.map-info-toolbar {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 2px 0 8px;
  padding-bottom: 8px;
  border-bottom: 0.055rem solid #bdbdbd;
}

.map-info-sort-button {
  border: 0;
  background: transparent;
  padding: 0;
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.88rem;
  letter-spacing: 0.02em;
  cursor: pointer;
}

.map-info-sort-button.is-active {
  color: var(--panel-text);
}

.map-info-sort-button:hover {
  color: var(--accent);
}

.map-info-sort-separator {
  color: var(--panel-muted);
  font-size: 0.88rem;
  line-height: 1;
}

/* Slightly more readable municipality list rhythm */
.map-info-item .map-info-line,
.map-info-item .map-info-stat-line {
  line-height: 1.22;
}

/* Municipality selected from the map-side list */
.map-info-item.is-map-selected {
  border-left: 3px solid #e31a1c;
  padding-left: 7px;
}

.map-info-item.is-map-selected .map-info-item-title {
  color: #e31a1c;
}

.map-info-item.is-map-selected .map-info-item-button {
  color: inherit;
}

/* Compact two-control map info sorter */
.compact-map-info-toolbar {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 2px 0 8px;
  padding-bottom: 8px;
  border-bottom: 0.055rem solid #bdbdbd;
  white-space: nowrap;
}

.compact-map-sort-button {
  border: 0;
  background: transparent;
  padding: 0;
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.88rem;
  letter-spacing: 0.02em;
  line-height: 1;
  cursor: pointer;
}

.compact-map-sort-button.is-active {
  color: var(--panel-text);
}

.compact-map-sort-button:hover {
  color: var(--accent);
}

.compact-map-info-toolbar .map-info-sort-separator {
  color: var(--panel-muted);
  font-size: 0.88rem;
  line-height: 1;
}

/* Clear selected municipality control */
.redditi-map-clear-selection {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 1001;
  display: none;
  border: 0.055rem solid rgba(31, 35, 40, 0.28);
  background: rgba(251, 250, 247, 0.92);
  color: #e31a1c;
  padding: 5px 8px 4px;
  font-family: var(--du-font-brand);
  font-size: 0.72rem;
  line-height: 1;
  letter-spacing: 0.08em;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(31, 35, 40, 0.12);
}

.redditi-map-clear-selection.is-visible {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.redditi-map-clear-selection:hover,
.redditi-map-clear-selection:focus-visible {
  background: #e31a1c;
  color: #ffffff;
  outline: none;
}

/* Compact classification legend labels: range + count only */
.classification-bin-entry span:last-child {
  font-variant-numeric: tabular-nums;
}

/* Left-column stats: stable label/value formatting */
.stats-list {
  display: grid;
  gap: 2px;
}

.stats-list .stat-line,
.stats-list > .stat-line {
  display: flex;
  align-items: baseline;
  gap: 0.42em;
  min-width: 0;
  line-height: 1.24;
  white-space: nowrap;
}

.stats-list .stat-label {
  flex: 0 0 auto;
  color: var(--panel-muted);
}

.stats-list .stat-label::after {
  content: ":";
}

.stats-list .stat-value {
  flex: 0 1 auto;
  min-width: 0;
  color: var(--panel-text);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

/* Prevent accidental colon/value collapse in legacy text-rendered lines. */
.stats-list .stat-line-normalised {
  letter-spacing: 0.002em;
}

/* Classification legend: compact range/count rows */
.classification-bin-entry span:last-child,
.classification-bin-legend .legend-entry span:last-child {
  font-variant-numeric: tabular-nums;
}

/* Classification chart swatches: larger, less collision-prone blocks */
.is-classification-swatch-view .redditi-classification-swatch {
  min-width: 34px !important;
  width: 34px !important;
  min-height: 24px !important;
  height: 24px !important;
  margin: 0 5px 6px 0 !important;
  flex: 0 0 auto !important;
}

/* Numeric labels remain readable when the chart is not dense. */
.is-classification-swatch-view [data-classification-value-label="true"] {
  display: inline-block;
  max-width: 72px;
  line-height: 1.08;
  white-space: nowrap;
  text-align: center;
  font-variant-numeric: tabular-nums;
}

/* Dense classification charts: keep values as tooltips only. */
.is-dense-classification-swatch-view [data-classification-value-label="true"] {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
}

/* Extra air around dense swatch arrays */
.is-dense-classification-swatch-view .redditi-classification-swatch {
  margin-bottom: 8px !important;
}



/* Redditi production UI/performance patch */
.leaflet-map,
.map-panel,
.graph-panel,
.map-info-panel {
  contain: layout style;
}

.leaflet-map.is-boundary-mode .leaflet-control-attribution {
  display: none !important;
}

.leaflet-map.is-street-mode .leaflet-control-attribution {
  display: block !important;
}

.stats-list {
  display: grid;
  gap: 2px;
}

.stats-list .stat-line,
.map-info-line.stat-line {
  display: flex;
  align-items: baseline;
  gap: 0.42em;
  min-width: 0;
  line-height: 1.24;
  white-space: nowrap;
}

.stats-list .stat-label,
.map-info-line .stat-label {
  flex: 0 0 auto;
  color: var(--panel-muted);
}

.stats-list .stat-label::after,
.map-info-line .stat-label::after {
  content: ":";
}

.stats-list .stat-value,
.map-info-line .stat-value {
  flex: 0 1 auto;
  min-width: 0;
  color: var(--panel-text);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.map-info-list-all-municipalities {
  gap: 0;
  content-visibility: auto;
  contain-intrinsic-size: 1px 900px;
}

.map-info-list-all-municipalities .map-info-item {
  padding: 8px 0 7px;
  contain: content;
}

.map-info-item-button {
  width: 100%;
  border: 0;
  background: transparent;
  padding: 0;
  color: inherit;
  text-align: left;
  font: inherit;
  cursor: pointer;
}

.map-info-item-button:hover .map-info-item-title {
  color: var(--accent);
}

.map-info-item.is-map-selected {
  border-left: 3px solid #e31a1c;
  padding-left: 7px;
}

.map-info-item.is-map-selected .map-info-item-title {
  color: #e31a1c;
}

.compact-map-info-toolbar {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 2px 0 8px;
  padding-bottom: 8px;
  border-bottom: 0.055rem solid #bdbdbd;
  white-space: nowrap;
}

.compact-map-sort-button {
  border: 0;
  background: transparent;
  padding: 0;
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.88rem;
  letter-spacing: 0.02em;
  line-height: 1;
  cursor: pointer;
}

.compact-map-sort-button.is-active {
  color: var(--panel-text);
}

.compact-map-sort-button:hover {
  color: var(--accent);
}

.map-info-sort-separator {
  color: var(--panel-muted);
  font-size: 0.88rem;
  line-height: 1;
}

.redditi-map-clear-selection {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 1001;
  display: none;
  border: 0.055rem solid rgba(31, 35, 40, 0.28);
  background: rgba(251, 250, 247, 0.92);
  color: #e31a1c;
  padding: 5px 8px 4px;
  font-family: var(--du-font-brand);
  font-size: 0.72rem;
  line-height: 1;
  letter-spacing: 0.08em;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(31, 35, 40, 0.12);
}

.redditi-map-clear-selection.is-visible {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.redditi-map-clear-selection:hover,
.redditi-map-clear-selection:focus-visible {
  background: #e31a1c;
  color: #ffffff;
  outline: none;
}

.classification-bin-legend {
  grid-column: 1 / -1;
  display: grid;
  gap: 2px 10px;
}

.classification-bin-legend.is-two-column {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.classification-bin-entry {
  min-width: 0;
  white-space: normal;
}

.classification-bin-swatch {
  border: 1px solid var(--legend-stroke, rgba(31, 35, 40, 0.22));
}

.classification-bin-entry span:last-child {
  font-variant-numeric: tabular-nums;
}

.is-dense-classification-swatch-view [data-classification-value-label="true"] {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
}

/* Context/dense classification-chart correction */
.is-classification-chart .redditi-classification-chart-swatch {
  min-width: 32px !important;
  width: 32px !important;
  min-height: 24px !important;
  height: 24px !important;
  margin: 0 5px 7px 0 !important;
  flex: 0 0 auto !important;
}

.is-classification-chart [data-redditi-dense-value="true"] {
  display: inline-block;
  max-width: 72px;
  line-height: 1.08;
  white-space: nowrap;
  text-align: center;
  font-variant-numeric: tabular-nums;
}

/* When there are too many swatches, values are available as tooltips only. */
.is-classification-chart-dense [data-redditi-dense-value="true"] {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
}

.is-classification-chart-dense .redditi-classification-chart-swatch {
  margin-bottom: 9px !important;
}

/* Final classification graph: production swatch-only rendering */
.redditi-clean-classification-graph {
  min-height: 160px;
  overflow: auto;
  contain: layout style paint;
}

.redditi-clean-classification-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(34px, 34px));
  grid-auto-rows: 24px;
  gap: 10px 8px;
  align-content: start;
  justify-content: start;
  padding: 24px 28px;
}

.redditi-clean-classification-swatch {
  width: 34px;
  height: 24px;
  border: 1px solid var(--swatch-stroke, #ffffff);
  background: var(--swatch-fill, #9db9d8);
  padding: 0;
  margin: 0;
  cursor: pointer;
  box-shadow: none;
  appearance: none;
}

.redditi-clean-classification-swatch:hover,
.redditi-clean-classification-swatch:focus-visible {
  outline: 2px solid #e31a1c;
  outline-offset: 2px;
}

/* Prevent legacy numeric text from appearing if the old chart survives in any nested renderer. */
.redditi-clean-classification-graph svg text,
.redditi-clean-classification-graph text {
  display: none !important;
}

/* Stable final classification graph/map behaviour */
.redditi-classification-swatch-only {
  overflow: visible !important;
  contain: layout style paint;
}

/* Hide numeric labels inside detected classification chart roots. */
.redditi-classification-swatch-only [data-redditi-hidden-classification-value="true"],
.redditi-classification-swatch-only svg text[data-redditi-hidden-classification-value="true"],
.redditi-classification-swatch-only text[data-redditi-hidden-classification-value="true"] {
  opacity: 0 !important;
  fill-opacity: 0 !important;
  color: transparent !important;
  pointer-events: none !important;
}

/*
  Fallback: in classification graph mode, SVG text inside the detected chart
  root must never be visible. Values remain on title/tooltips.
*/
.redditi-classification-graph-active .redditi-classification-swatch-only svg text,
.redditi-classification-graph-active .redditi-classification-swatch-only text {
  opacity: 0 !important;
  fill-opacity: 0 !important;
  color: transparent !important;
  pointer-events: none !important;
}

/* Preserve and regularise the visible swatches. */
.redditi-classification-graph-active .redditi-classification-swatch-block {
  min-width: 34px !important;
  width: 34px !important;
  min-height: 24px !important;
  height: 24px !important;
  margin: 0 7px 11px 0 !important;
  flex: 0 0 auto !important;
}

/* Give classification graph views enough vertical rhythm after labels vanish. */
.redditi-classification-graph-active .redditi-classification-swatch-only {
  padding-bottom: 18px;
}

/* Final deterministic classification remediation */
.square-grid.is-tooltip-only {
  align-content: start;
  justify-content: start;
}

.square-grid.is-tooltip-only .square-item {
  width: var(--tile-size) !important;
  min-width: var(--tile-size) !important;
  height: var(--tile-size) !important;
  min-height: var(--tile-size) !important;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
}

.square-grid.is-tooltip-only .square-mark {
  width: var(--swatch-size) !important;
  height: var(--swatch-size) !important;
  min-width: var(--swatch-size) !important;
  min-height: var(--swatch-size) !important;
  margin: 0 !important;
}

.square-grid.is-tooltip-only .square-value,
.square-grid.is-tooltip-only .square-title {
  display: none !important;
}

.square-grid.is-classification-analysis.is-tooltip-only {
  gap: var(--tile-gap) !important;
}

.redditi-classification-graph-active .square-grid.is-tooltip-only .square-item::after {
  content: none !important;
}

/* Classification controls must remain visible in map mode when classification analysis is active. */
body.redditi-classification-map-active .classification-controls {
  display: flex;
}

/* Classification map path and side panel: avoid geography pollution. */
body.redditi-classification-map-active #context-line {
  color: var(--panel-muted);
}

body.redditi-classification-map-active .map-info-subtitle {
  color: var(--panel-muted);
  line-height: 1.12;
}

/* Keep legacy dense-chart hacks inert if they remain in cached CSS. */
.redditi-clean-classification-graph,
.redditi-classification-swatch-only {
  all: unset;
}

/* Universal sorter for every "Valori in evidenza" map-side panel */
.redditi-valori-sort-toolbar {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 3px 0 9px;
  padding-bottom: 8px;
  border-bottom: 0.055rem solid #bdbdbd;
  white-space: nowrap;
}

.redditi-valori-sort-button {
  border: 0;
  background: transparent;
  padding: 0;
  color: var(--panel-muted);
  font-family: var(--du-font-brand);
  font-size: 0.88rem;
  letter-spacing: 0.02em;
  line-height: 1;
  cursor: pointer;
}

.redditi-valori-sort-button.is-active {
  color: var(--panel-text);
}

.redditi-valori-sort-button:hover,
.redditi-valori-sort-button:focus-visible {
  color: var(--accent);
  outline: none;
}

.redditi-valori-sort-separator {
  color: var(--panel-muted);
  font-size: 0.88rem;
  line-height: 1;
}

