/* Anti-sfarfallio bootstrap: mostra la UI solo dopo il bundle finale. */
@keyframes saBootFallback { to { opacity: 1; } }
html.sa-booting body { opacity: 0; animation: saBootFallback 1ms linear 1.2s forwards; }
html.sa-ready body { opacity: 1; animation: none; }
/* Safe Ability SM 5.83 - CSS bundle ricostruito da 5.74 OK. */

:root {
  --bg: #fffaf2;
  --surface: #ffffff;
  --ink: #14302d;
  --muted: #63716f;
  --teal: #0b625b;
  --teal-dark: #063f3b;
  --coral: #e95845;
  --yellow: #f4bd28;
  --blue: #2c78b8;
  --line: #dce5df;
  --shadow: 0 18px 50px rgba(20, 48, 45, 0.13);
  --radius: 8px;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--bg);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-width: 320px;
  background: var(--bg);
  overflow-x: hidden;
  padding-bottom: env(safe-area-inset-bottom);
}
button, textarea { font: inherit; }
a { color: inherit; }

.skip-link {
  position: absolute;
  left: 16px;
  top: -80px;
  z-index: 10;
  background: var(--ink);
  color: #fff;
  padding: 10px 14px;
  border-radius: var(--radius);
}
.skip-link:focus { top: 16px; }

.app-shell { min-height: 100vh; }
.topbar {
  position: sticky;
  top: 0;
  z-index: 5;
  display: flex;
  align-items: center;
  gap: 24px;
  justify-content: space-between;
  padding: 14px clamp(18px, 4vw, 56px);
  background: rgba(255, 250, 242, 0.92);
  border-bottom: 1px solid rgba(220, 229, 223, 0.9);
  backdrop-filter: blur(16px);
}
.brand { display: flex; align-items: center; gap: 12px; text-decoration: none; min-width: 210px; }
.brand-logo {
  display: none;
}
.brand-mark {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--teal);
  color: #fff;
  font-weight: 900;
}
.brand strong, .brand small { display: block; }
.brand small { color: var(--muted); font-weight: 700; font-size: 0.78rem; }
.nav { display: flex; align-items: center; justify-content: center; gap: 4px; flex-wrap: wrap; }
.nav a {
  min-width: 0;
  text-decoration: none;
  font-weight: 800;
  font-size: 0.9rem;
  padding: 9px 12px;
  border-radius: var(--radius);
  overflow-wrap: anywhere;
  white-space: normal;
}
.nav a:hover, .nav a:focus { background: #e9f4ee; outline: none; }
.top-actions { display: flex; gap: 8px; }
.icon-button {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  color: var(--teal-dark);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  cursor: pointer;
}
.icon-button svg { width: 20px; height: 20px; stroke: currentColor; stroke-width: 2; fill: none; }

main { padding-bottom: 56px; }
.hero {
  width: min(1160px, calc(100% - 36px));
  margin: 0 auto;
  padding: clamp(34px, 6vw, 72px) 0 18px;
}
.hero-copy, .hero-media { min-width: 0; }
.hero-copy { max-width: 860px; }
.hero h1 {
  margin: 0;
  font-size: clamp(2.85rem, 8vw, 6.5rem);
  line-height: 0.94;
  letter-spacing: 0;
}
.hero p {
  margin: 24px 0 0;
  max-width: 780px;
  color: var(--muted);
  font-size: clamp(1.05rem, 1.4vw, 1.3rem);
  line-height: 1.55;
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.primary-action, .secondary-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 12px 18px;
  border-radius: var(--radius);
  font-weight: 900;
  text-decoration: none;
  border: 1px solid transparent;
  cursor: pointer;
}
.primary-action { background: var(--coral); color: #fff; }
.secondary-action { background: #fff; color: var(--teal-dark); border-color: var(--line); }
.primary-action:disabled,
.secondary-action:disabled {
  cursor: not-allowed;
  opacity: 0.58;
  background: #eef2ef;
  color: #66746f;
}
.compact-action {
  width: fit-content;
  min-height: 42px;
  padding: 10px 14px;
}
.inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}
.text-action {
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--teal);
  font: inherit;
  font-weight: 900;
  text-decoration: underline;
  cursor: pointer;
}
.text-action:focus {
  outline: 3px solid rgba(10, 92, 83, 0.22);
  outline-offset: 4px;
}
.hero-media {
  margin: 0;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  background: #dce5df;
}
.hero-media img { display: block; width: 100%; aspect-ratio: 1.18; object-fit: cover; }

.primary-hub {
  width: min(1160px, calc(100% - 36px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  padding: 16px 0 18px;
}
.hub-action {
  display: grid;
  gap: 8px;
  min-height: 124px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--ink);
  text-decoration: none;
  box-shadow: 0 10px 30px rgba(20, 48, 45, 0.06);
}
.hub-action strong {
  font-size: 1.05rem;
  color: var(--teal-dark);
}
.hub-action span {
  color: var(--muted);
  line-height: 1.38;
}
.hub-action.is-primary {
  background: var(--teal);
  border-color: var(--teal);
  color: #fff;
}
.hub-action.is-primary strong,
.hub-action.is-primary span {
  color: #fff;
}

.now-board {
  width: min(1160px, calc(100% - 36px));
  margin: 0 auto 18px;
  display: grid;
  grid-template-columns: 1.15fr 1fr 1fr;
  gap: 12px;
}
.now-tile {
  display: grid;
  gap: 8px;
  align-content: start;
  min-height: 156px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: 0 10px 30px rgba(20, 48, 45, 0.06);
}
.now-tile.is-alert {
  background: #14302d;
  color: #fff;
}
.now-tile h2 {
  margin: 0;
  font-size: clamp(1.35rem, 2vw, 1.9rem);
  line-height: 1.05;
}
.now-tile p {
  margin: 0;
  color: var(--muted);
  line-height: 1.42;
}
.now-tile.is-alert h2,
.now-tile.is-alert .source-link {
  color: #fff;
}
.now-tile.is-alert p {
  color: rgba(255,255,255,0.82);
}
.now-tile.is-alert .card-label {
  color: var(--yellow);
}

.principle-strip {
  width: min(1160px, calc(100% - 36px));
  margin: 10px auto 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding: 0 0 18px;
}
.principle-strip article {
  display: grid;
  gap: 10px;
  align-content: start;
  padding: 20px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: #f7fbf9;
  box-shadow: 0 10px 30px rgba(20, 48, 45, 0.06);
}
.principle-strip h2 {
  margin: 0;
  font-size: clamp(1.35rem, 2.3vw, 2.1rem);
  line-height: 1.08;
}
.principle-strip p {
  margin: 0;
  color: var(--muted);
  line-height: 1.52;
}
.principle-strip .source-link {
  margin-top: 2px;
}
.principle-guide {
  grid-column: 1 / -1;
  background: #14302d !important;
  color: #fff;
}
.principle-guide .card-label {
  color: var(--yellow);
}
.principle-guide h2 {
  max-width: 860px;
  color: #fff;
}
.principle-guide p {
  max-width: 980px;
  color: rgba(255, 255, 255, 0.82);
  font-size: 1.06rem;
}
.principle-guide .guide-kicker {
  color: #ffd15a;
  font-weight: 900;
  font-size: 1.12rem;
}

.action-paths, .section {
  width: min(1160px, calc(100% - 36px));
  margin: 0 auto;
}
.action-paths {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  padding: 20px 0 44px;
}
.action-paths article, .risk-card, .local-risk-card, .easy-card, .phase-grid article, .assistance-grid article, .hub-card, .myth-tool, .barrier-tool, .plan-card, .sendai article {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 10px 30px rgba(20, 48, 45, 0.06);
}
.action-paths article { padding: 22px; }
.role-paths article {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.role-paths .secondary-action {
  margin-top: auto;
}
.role-paths .secondary-action.is-selected,
.role-paths .secondary-action[aria-pressed="true"] {
  background: var(--yellow);
  color: #14302d;
  border-color: var(--yellow);
}
.action-paths span, .risk-icon {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #e9f4ee;
  color: var(--teal);
}
.action-paths svg, .risk-icon svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 2; }
h2, h3, p { overflow-wrap: anywhere; }
.action-paths h2, .risk-card h3, .sendai h3 { margin: 16px 0 8px; }
.action-paths p, .risk-card p, .sendai p { color: var(--muted); line-height: 1.5; margin: 0; }

.section { padding: 44px 0; }
.section-heading { max-width: 760px; margin-bottom: 20px; }
.section-heading h2 {
  margin: 0;
  font-size: clamp(1.8rem, 3vw, 3.1rem);
  line-height: 1.06;
}
.section-heading p { color: var(--muted); line-height: 1.55; font-size: 1.05rem; }
.emergency-mode-section {
  background: #fff;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.emergency-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
  gap: 14px;
}
.emergency-card {
  padding: 22px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: var(--surface);
  box-shadow: 0 10px 30px rgba(20, 48, 45, 0.06);
}
.emergency-card:first-child {
  border-color: rgba(233, 88, 69, 0.35);
}
.emergency-card h3 {
  margin: 10px 0 8px;
  font-size: clamp(1.45rem, 2.5vw, 2.2rem);
  line-height: 1.05;
}
.emergency-checks ul {
  margin: 12px 0 0;
  padding-left: 20px;
  color: var(--muted);
  line-height: 1.55;
}
.filter-row { display: flex; flex-wrap: wrap; gap: 8px; margin: 20px 0; }
.filter {
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  padding: 10px 13px;
  border-radius: var(--radius);
  font-weight: 900;
  cursor: pointer;
}
.filter.is-active { background: var(--teal); color: #fff; border-color: var(--teal); }
.monitor-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin: 0 0 16px;
}
.monitor-strip article {
  padding: 14px;
  border-radius: var(--radius);
  background: #e9f4ee;
  border: 1px solid rgba(11, 98, 91, 0.16);
}
.monitor-strip strong, .monitor-strip span {
  display: block;
}
.monitor-strip strong {
  color: var(--teal-dark);
  margin-bottom: 6px;
}
.monitor-strip span {
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.38;
}
.risk-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.risk-card { padding: 18px; display: flex; flex-direction: column; gap: 12px; }
.risk-card header { display: flex; align-items: flex-start; gap: 12px; }
.risk-card h3 { margin: 0; }
.risk-card strong { color: var(--coral); }
.risk-card ul { margin: 0; padding-left: 18px; color: var(--muted); line-height: 1.48; }

.scenario-lab {
  display: grid;
  grid-template-columns: minmax(280px, 0.72fr) minmax(0, 1.28fr);
  gap: 18px;
  align-items: stretch;
}
.scenario-controls,
.scenario-output {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 10px 30px rgba(20, 48, 45, 0.06);
}
.scenario-controls {
  display: grid;
  gap: 14px;
  padding: 22px;
  align-content: start;
}
.scenario-controls label {
  display: grid;
  gap: 8px;
  color: var(--teal-dark);
  font-weight: 900;
}
.scenario-actions {
  display: grid;
  gap: 10px;
  margin-top: 4px;
}
.scenario-output {
  padding: 24px;
  border-color: rgba(11, 98, 91, 0.22);
}
.scenario-output h3 {
  margin: 8px 0;
  font-size: clamp(1.55rem, 3vw, 2.55rem);
  line-height: 1.05;
}
.scenario-lead {
  margin: 0 0 18px;
  color: var(--muted);
  font-size: 1.05rem;
  line-height: 1.45;
}
.scenario-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.scenario-steps article {
  display: grid;
  gap: 8px;
  padding: 14px;
  border-radius: var(--radius);
  background: #e9f4ee;
}
.scenario-steps strong {
  color: var(--teal-dark);
}
.scenario-steps span,
.scenario-focus p {
  color: var(--muted);
  line-height: 1.45;
}
.scenario-focus {
  display: grid;
  gap: 8px;
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}
.scenario-focus strong {
  color: var(--coral);
}
.scenario-focus p {
  margin: 0;
}

.san-marino-map-shell {
  display: grid;
  grid-template-columns: minmax(320px, 0.95fr) minmax(280px, 0.75fr);
  gap: 18px;
  align-items: stretch;
  margin-bottom: 18px;
}
.physical-map, .castle-panel {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 10px 30px rgba(20, 48, 45, 0.06);
}
.physical-map {
  min-height: 520px;
  padding: 14px;
}
.map-stage {
  position: relative;
  overflow: hidden;
  border-radius: calc(var(--radius) - 4px);
  background: #dfe9dc;
}
.map-stage img {
  display: block;
  width: 100%;
  aspect-ratio: 2242 / 2557;
  object-fit: cover;
}
.map-stage svg {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
}
.map-credit {
  margin: 10px 4px 0;
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.35;
}
.castle-point {
  cursor: pointer;
  outline: none;
}
.castle-point circle {
  fill: rgba(255, 255, 255, 0.94);
  stroke: #0b625b;
  stroke-width: 4;
  filter: drop-shadow(0 8px 10px rgba(20, 48, 45, 0.28));
  transition: fill 0.2s ease, stroke 0.2s ease, transform 0.2s ease;
}
.castle-point text {
  text-anchor: middle;
  pointer-events: none;
  fill: var(--teal-dark);
  paint-order: stroke;
  stroke: rgba(255, 255, 255, 0.9);
  stroke-width: 5px;
  font-size: 13px;
  font-weight: 900;
}
.castle-point:hover circle,
.castle-point:focus circle,
.castle-point.is-selected circle {
  fill: var(--coral);
  stroke: #fff;
}
.castle-point:hover text,
.castle-point:focus text,
.castle-point.is-selected text {
  fill: #fff;
}
.castle-panel {
  padding: 24px;
  align-content: start;
}
.castle-panel h3 {
  margin: 8px 0 8px;
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  line-height: 1.02;
}
.castle-panel p {
  color: var(--muted);
  line-height: 1.55;
}
.castle-panel strong {
  display: block;
  margin-top: 18px;
}
.castle-priority {
  display: grid;
  gap: 6px;
  margin: 18px 0;
  padding: 14px;
  border-left: 5px solid var(--coral);
  background: #fff7df;
}
.castle-priority span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}
.castle-priority strong {
  margin: 0;
  color: var(--ink);
  line-height: 1.35;
}
.castle-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 16px 0;
}
.castle-tags span {
  padding: 8px 10px;
  border-radius: var(--radius);
  background: #e9f4ee;
  color: var(--teal-dark);
  font-weight: 850;
  font-size: 0.88rem;
}
.castle-checklist {
  display: grid;
  gap: 8px;
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
}
.castle-checklist li {
  position: relative;
  padding-left: 24px;
  color: var(--muted);
  line-height: 1.4;
}
.castle-checklist li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.48em;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--teal);
}
.castle-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.san-marino-map-shell {
  display: none;
}

.inclusive-map-area {
  margin: 0 0 18px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: 0 10px 30px rgba(20, 48, 45, 0.06);
}
.inclusive-map-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: end;
}
.inclusive-map-head h3 {
  margin: 8px 0;
  font-size: clamp(1.55rem, 2.7vw, 2.35rem);
  line-height: 1.04;
}
.inclusive-map-head p {
  max-width: 720px;
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}
.inclusive-map-actions,
.dialog-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.inclusive-map-tools {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(170px, 0.4fr) auto auto;
  gap: 10px;
  margin: 18px 0 12px;
}
.inclusive-map-tools input,
.inclusive-map-tools select,
.map-report-dialog input,
.map-report-dialog select,
.map-report-dialog textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  color: var(--ink);
  font: inherit;
  padding: 11px 12px;
}
.inclusive-map-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}
.inclusive-map-legend label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #f7fbf7;
  color: var(--teal-dark);
  font-size: 0.88rem;
  font-weight: 850;
}
.pin-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid #fff;
  box-shadow: 0 0 0 1px rgba(20, 48, 45, 0.2);
}
.pin-dot.safe { background: #0b625b; }
.pin-dot.barrier { background: #d8372a; }
.pin-dot.alert { background: #1f6feb; }
.pin-dot.support { background: #d97706; }
.pin-dot.waiting { background: #0f4c9c; }
.inclusive-map {
  height: min(68vh, 620px);
  min-height: 430px;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 4px);
  overflow: hidden;
  background: #dfe9dc;
  position: relative;
}
.leaflet-container {
  overflow: hidden;
  width: 100%;
  height: 100%;
  background: #dfe9dc;
  outline: 0;
  touch-action: pan-x pan-y;
}
.leaflet-pane,
.leaflet-tile,
.leaflet-marker-icon,
.leaflet-marker-shadow,
.leaflet-tile-container,
.leaflet-pane > svg,
.leaflet-pane > canvas,
.leaflet-zoom-box,
.leaflet-image-layer,
.leaflet-layer {
  position: absolute;
  left: 0;
  top: 0;
}
.leaflet-tile {
  width: 256px;
  height: 256px;
  user-select: none;
  -webkit-user-drag: none;
  max-width: none !important;
  max-height: none !important;
}
.leaflet-marker-icon,
.leaflet-marker-shadow {
  display: block;
}
.leaflet-control-container .leaflet-top,
.leaflet-control-container .leaflet-bottom {
  position: absolute;
  z-index: 1000;
  pointer-events: none;
}
.leaflet-control {
  position: relative;
  z-index: 1000;
  pointer-events: auto;
}
.leaflet-top { top: 10px; }
.leaflet-right { right: 10px; }
.leaflet-bottom { bottom: 10px; }
.leaflet-left { left: 10px; }
.leaflet-control-zoom a {
  display: block;
  width: 30px;
  height: 30px;
  line-height: 30px;
  background: #fff;
  color: var(--teal-dark);
  border-bottom: 1px solid var(--line);
  text-align: center;
  text-decoration: none;
  font-weight: 900;
}
.leaflet-popup {
  position: absolute;
  text-align: center;
}
.leaflet-popup-content-wrapper {
  padding: 1px;
  text-align: left;
  border-radius: var(--radius);
  background: #fff;
  box-shadow: 0 16px 32px rgba(20, 48, 45, 0.18);
}
.leaflet-popup-content {
  margin: 14px;
  min-width: 220px;
}
.leaflet-popup-tip-container {
  display: none;
}
.territory-stage {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: inherit;
  overflow: hidden;
  background:
    radial-gradient(circle at 22% 18%, rgba(255,255,255,0.8), transparent 28%),
    linear-gradient(135deg, #e6f0e4, #f8edd0);
}
.territory-svg {
  position: absolute;
  inset: 2% 8%;
  width: 84%;
  height: 96%;
  filter: drop-shadow(0 18px 24px rgba(20, 48, 45, 0.18));
}
.territory-outline {
  fill: url(#territoryFill);
  stroke: #0b625b;
  stroke-width: 2.4;
}
.territory-ridge {
  fill: none;
  stroke: rgba(11, 98, 91, 0.42);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-dasharray: 5 5;
}
.territory-ridge.secondary {
  stroke: rgba(233, 88, 69, 0.32);
}
.territory-castles span {
  position: absolute;
  transform: translate(-50%, -50%);
  padding: 4px 7px;
  border-radius: 999px;
  background: rgba(255,255,255,0.78);
  color: rgba(6, 63, 59, 0.82);
  font-size: 0.72rem;
  font-weight: 900;
  white-space: nowrap;
  pointer-events: none;
}
.territory-pin-layer {
  position: absolute;
  inset: 0;
}
.territory-marker {
  position: absolute;
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border: 3px solid rgba(255,255,255,0.98);
  border-radius: 50% 50% 50% 12px;
  color: #fff;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(20, 48, 45, 0.28);
  transform: translate(-50%, -88%) rotate(-45deg);
}
.territory-marker span {
  transform: rotate(45deg);
  font-weight: 900;
  line-height: 1;
}
.territory-marker.safe { background: #0b625b; }
.territory-marker.barrier { background: #d8372a; }
.territory-marker.alert { background: #1f6feb; }
.territory-marker.support { background: #d97706; }
.territory-marker:hover,
.territory-marker:focus {
  outline: 3px solid rgba(244, 189, 40, 0.85);
  outline-offset: 2px;
  z-index: 3;
}
.territory-popup {
  position: absolute;
  z-index: 5;
  width: min(320px, calc(100% - 28px));
  max-height: calc(100% - 28px);
  overflow: auto;
  transform: translate(-50%, -105%);
  padding: 14px;
  border: 1px solid rgba(20, 48, 45, 0.14);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.98);
  box-shadow: 0 22px 48px rgba(20, 48, 45, 0.22);
}
.territory-popup[hidden] {
  display: none;
}
.inclusive-map-status {
  margin: 10px 2px 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.4;
}
.inclusive-pin {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50% 50% 50% 12px;
  color: #fff;
  border: 3px solid rgba(255, 255, 255, 0.96);
  box-shadow: 0 8px 18px rgba(20, 48, 45, 0.3);
  transform: rotate(-45deg);
  font-size: 16px;
  font-weight: 900;
}
.inclusive-pin span {
  transform: rotate(45deg);
  line-height: 1;
}
.inclusive-pin.safe { background: #0b625b; }
.inclusive-pin.barrier { background: #d8372a; }
.inclusive-pin.alert { background: #1f6feb; }
.inclusive-pin.support { background: #d97706; }
.inclusive-pin.waiting {
  background: #0f4c9c;
  font-size: 0.72rem;
  letter-spacing: 0;
}
.inclusive-popup {
  min-width: 230px;
  line-height: 1.45;
}
.inclusive-popup strong {
  display: block;
  margin-bottom: 4px;
  color: var(--ink);
  font-size: 0.98rem;
}
.inclusive-popup p {
  margin: 7px 0;
  color: #42514d;
}
.inclusive-popup .popup-type {
  display: inline-flex;
  margin: 6px 0;
  padding: 5px 8px;
  border-radius: 999px;
  background: #e9f4ee;
  color: var(--teal-dark);
  font-size: 0.78rem;
  font-weight: 900;
}
.popup-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 10px;
}
.popup-actions a,
.popup-actions button {
  border: 1px solid rgba(20, 48, 45, 0.18);
  border-radius: 999px;
  background: #fff;
  color: var(--teal-dark);
  cursor: pointer;
  font: inherit;
  font-size: 0.8rem;
  font-weight: 850;
  padding: 7px 9px;
  text-decoration: none;
}
.popup-actions .dark {
  background: var(--teal);
  color: #fff;
}
.map-report-dialog {
  width: min(560px, calc(100vw - 32px));
  border: 0;
  border-radius: var(--radius);
  box-shadow: 0 22px 60px rgba(20, 48, 45, 0.28);
  padding: 0;
}
.map-report-dialog::backdrop {
  background: rgba(8, 22, 21, 0.48);
}
.map-report-dialog form {
  display: grid;
  gap: 14px;
  padding: 22px;
}
.dialog-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}
.dialog-head h3 {
  margin: 6px 0 0;
  font-size: 1.45rem;
}
.map-report-dialog label {
  display: grid;
  gap: 6px;
  color: var(--teal-dark);
  font-size: 0.9rem;
  font-weight: 850;
}
#mapReportCoords {
  margin: 0;
  padding: 10px 12px;
  border-radius: var(--radius);
  background: #fff7df;
  color: var(--teal-dark);
  font-weight: 850;
}

.local-risk-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.local-risk-card { padding: 18px; }
.local-risk-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.risk-level {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 6px 10px;
  border-radius: var(--radius);
  font-size: 0.78rem;
  text-transform: uppercase;
  color: #fff;
}
.risk-level.alto { background: #d8372a; }
.risk-level.medio { background: #d97706; }
.risk-level.medio-alto { background: linear-gradient(135deg, #d97706, #d8372a); }
.risk-level.basso { background: var(--blue); }
.risk-level.molto-basso { background: var(--teal); }
.local-risk-card h3, .easy-card h3, .phase-grid h3, .assistance-grid h3, .hub-card h3, .myth-tool h3, .barrier-tool h3 {
  margin: 14px 0 8px;
  font-size: 1.35rem;
}
.local-risk-card p, .easy-card p, .phase-grid p, .assistance-grid p, .hub-card p, .myth-tool p, .barrier-tool p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}
.official-source-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  margin-top: 18px;
  padding: 22px;
  border-radius: var(--radius);
  background: #14302d;
  color: #fff;
}
.official-source-card h3 {
  margin: 8px 0 8px;
  font-size: clamp(1.35rem, 2.3vw, 2rem);
}
.official-source-card p {
  margin: 0;
  color: rgba(255,255,255,0.78);
  line-height: 1.55;
}
.official-actions {
  display: grid;
  gap: 10px;
  min-width: 230px;
}
.official-actions .secondary-action {
  color: #fff;
  border-color: rgba(255,255,255,0.34);
}

.easy-section {
  background: #fdf2d0;
  width: 100%;
  padding-inline: max(18px, calc((100vw - 1160px) / 2));
}
.easy-layout, .phase-grid, .tools-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.easy-card { padding: 22px; }
.easy-card span, .phase-grid strong {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--teal);
  color: #fff;
  font-weight: 900;
}
.phase-grid article { padding: 20px; }
.phase-grid strong { width: auto; padding: 0 14px; border-radius: 999px; }
.video-guide-section {
  background: #0b625b;
  color: #fff;
  width: 100%;
  padding-inline: max(18px, calc((100vw - 1160px) / 2));
}
.video-guide-section .section-heading p { color: rgba(255,255,255,0.78); }
.video-guide-layout {
  display: grid;
  grid-template-columns: minmax(280px, 0.78fr) minmax(0, 1.22fr);
  gap: 20px;
  align-items: start;
}
.before-card {
  margin: 0;
  padding: 24px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.before-card h3 {
  margin: 8px 0 12px;
  font-size: clamp(1.55rem, 3vw, 2.5rem);
  line-height: 1.04;
}
.before-card p {
  color: rgba(255,255,255,0.8);
  line-height: 1.55;
}
.video-fallback {
  margin-top: 18px;
  border-top: 1px solid rgba(255,255,255,0.22);
  padding-top: 14px;
}
.video-fallback summary {
  cursor: pointer;
  font-weight: 900;
}
.video-fallback video {
  display: block;
  width: 100%;
  margin-top: 12px;
  border-radius: calc(var(--radius) - 4px);
  background: #063f3b;
}
.video-frame {
  margin: 0;
  background: #063f3b;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
}
.video-frame video {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  background: #063f3b;
}
.video-steps {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: step;
}
.video-steps li {
  counter-increment: step;
  position: relative;
  min-height: 112px;
  padding: 16px 16px 16px 54px;
  border-radius: var(--radius);
  background: rgba(255,255,255,0.09);
  border: 1px solid rgba(255,255,255,0.18);
}
.video-steps li::before {
  content: counter(step);
  position: absolute;
  left: 14px;
  top: 16px;
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--yellow);
  color: #14302d;
  font-weight: 900;
}
.video-steps strong, .video-steps span { display: block; }
.video-steps strong { margin-bottom: 6px; }
.video-steps span { color: rgba(255,255,255,0.78); line-height: 1.42; }
.assistance-section {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.assistance-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.assistance-grid article { padding: 20px; }
.source-link {
  display: inline-flex;
  margin-top: 16px;
  color: var(--teal);
  font-weight: 900;
  text-decoration-thickness: 2px;
  text-underline-offset: 4px;
}
.tools-grid { grid-template-columns: 0.8fr 1.2fr; }
.myth-tool, .barrier-tool { padding: 22px; }
.hub-card:has(#feedbackNote) { display: none; }
.tool-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 18px; }
.tool-result {
  margin-top: 14px !important;
  font-weight: 850;
  color: var(--teal-dark) !important;
}
.barrier-tool label {
  display: grid;
  gap: 8px;
  margin-top: 12px;
  color: var(--teal-dark);
  font-weight: 900;
}
select {
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  color: var(--ink);
  padding: 10px 12px;
  font: inherit;
}

.split-section {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 22px;
  align-items: start;
}
.planner {
  background: #0b625b;
  color: #fff;
  border-radius: var(--radius);
  padding: clamp(20px, 4vw, 34px);
}
.planner .section-heading p, .planner .builder-block p { color: rgba(255,255,255,0.78); }
.builder-block + .builder-block { margin-top: 24px; }
.builder-block h3 { margin: 0 0 12px; }
.plan-fields {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.plan-fields h3 {
  grid-column: 1 / -1;
}
.plan-fields label {
  display: grid;
  gap: 8px;
  color: rgba(255,255,255,0.9);
  font-weight: 850;
}
.plan-fields input {
  min-height: 44px;
  border: 1px solid rgba(255,255,255,0.28);
  border-radius: var(--radius);
  padding: 10px 12px;
  color: var(--ink);
  background: #fff;
  font: inherit;
}
.chip-grid { display: flex; flex-wrap: wrap; gap: 9px; }
.need-chip {
  border: 1px solid rgba(255,255,255,0.35);
  background: rgba(255,255,255,0.08);
  color: #fff;
  padding: 10px 12px;
  border-radius: var(--radius);
  cursor: pointer;
  font-weight: 800;
}
.need-chip.is-selected { background: var(--yellow); color: #14302d; border-color: var(--yellow); }
.checklist { display: grid; gap: 10px; }
.check-row {
  display: flex;
  gap: 10px;
  align-items: center;
  min-height: 42px;
  padding: 10px;
  border: 1px solid rgba(255,255,255,0.22);
  border-radius: var(--radius);
}
.check-row input, .pledge-list input { width: 20px; height: 20px; accent-color: var(--coral); }
.plan-card { position: sticky; top: 88px; padding: 22px; }
.role-hint {
  display: block;
  margin-bottom: 10px;
  color: var(--teal-dark);
  font-weight: 850;
  line-height: 1.35;
}
.card-label { font-weight: 900; color: var(--teal); text-transform: uppercase; font-size: 0.78rem; }
.plan-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.plan-card h2 { font-size: 4rem; margin: 6px 0; line-height: 1; color: var(--coral); }
.plan-card p { color: var(--muted); line-height: 1.5; }
textarea {
  width: 100%;
  resize: vertical;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 12px;
  color: var(--ink);
  line-height: 1.45;
  margin: 10px 0 14px;
}

.personal-hub-section {
  border-top: 1px solid var(--line);
}
.hub-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.hub-card {
  padding: 20px;
}
.hub-card label {
  display: grid;
  gap: 8px;
  margin-top: 12px;
  color: var(--teal-dark);
  font-weight: 900;
}
.device-list {
  display: grid;
  gap: 10px;
}
.device-row {
  display: flex !important;
  align-items: center;
  gap: 10px !important;
  min-height: 42px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: var(--ink) !important;
}
.device-row input {
  width: 20px;
  height: 20px;
  accent-color: var(--coral);
}
.civic-sync-card {
  background: #fdf2d0;
}
.api-summary {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 14px 0;
}
.api-summary span, .api-summary strong {
  display: block;
  padding: 8px 10px;
  border-radius: var(--radius);
  background: rgba(255,255,255,0.72);
}
.api-summary span {
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 850;
}
.api-summary strong {
  color: var(--teal-dark);
  font-size: 1.25rem;
}
.civic-dashboard {
  display: grid;
  gap: 12px;
  margin: 14px 0;
}
.civic-dashboard h4 {
  margin: 0 0 8px;
  color: var(--teal-dark);
}
.civic-dashboard ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.civic-dashboard li {
  display: grid;
  gap: 3px;
  padding: 10px;
  border-radius: var(--radius);
  background: rgba(255,255,255,0.7);
}
.civic-dashboard li strong {
  color: var(--ink);
}
.civic-dashboard li span {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.35;
}
.meteo-card {
  background: #f7fbf9;
  grid-column: span 2;
}
.meteo-intro {
  color: var(--muted);
  line-height: 1.45;
}
.meteo-proximity {
  display: grid;
  gap: 12px;
  margin-top: 10px;
}
.meteo-proximity h4 {
  margin: 0;
  color: var(--ink);
  font-size: 1.05rem;
  line-height: 1.25;
}
.meteo-proximity p {
  margin: 0;
}
.meteo-level {
  display: grid;
  gap: 4px;
  padding: 12px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: #fff;
}
.meteo-level span {
  font-size: 0.82rem;
  font-weight: 900;
  text-transform: uppercase;
}
.meteo-level strong {
  color: var(--ink);
}
.meteo-green { border-color: #72b88c; background: #e9f6ee; color: #17633a; }
.meteo-yellow { border-color: #e8b320; background: #fff6d7; color: #6a4a00; }
.meteo-orange { border-color: #e68021; background: #fff0df; color: #783900; }
.meteo-red { border-color: #d33f32; background: #ffe8e4; color: #8d1e16; }
.meteo-impact {
  font-weight: 850;
  color: var(--teal-dark) !important;
}
.meteo-now-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.meteo-now-grid span {
  min-height: 44px;
  display: flex;
  align-items: center;
  padding: 9px 10px;
  border: 1px solid rgba(10, 92, 83, 0.2);
  border-radius: var(--radius);
  background: #fff;
  color: var(--ink);
  font-weight: 850;
  line-height: 1.25;
}
.meteo-timeline {
  display: grid;
  gap: 8px;
}
.meteo-timeline div {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 10px;
  border-left: 4px solid var(--teal);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.78);
}
.meteo-timeline strong {
  color: var(--teal-dark);
}
.meteo-timeline span {
  color: var(--ink);
  line-height: 1.35;
}
.meteo-phenomena {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.meteo-phenomena li {
  display: grid;
  grid-template-columns: 14px minmax(0, 1fr);
  gap: 3px 8px;
  align-items: center;
  padding: 9px;
  border-radius: var(--radius);
  background: rgba(255,255,255,0.74);
}
.meteo-phenomena small {
  grid-column: 2;
  color: var(--muted);
  line-height: 1.3;
}
.meteo-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 1px solid currentColor;
}
.meteo-disclaimer,
.meteo-note,
.meteo-timestamp {
  color: var(--muted) !important;
  font-size: 0.92rem;
  line-height: 1.38;
}
.meteo-timestamp {
  padding: 9px 10px;
  border-left: 4px solid var(--yellow);
  background: rgba(255, 209, 90, 0.16);
  color: var(--ink) !important;
}
.meteo-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}
.health-watch {
  display: grid;
  gap: 10px;
}
.health-level {
  display: grid;
  gap: 4px;
  padding: 11px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
}
.health-level strong {
  color: var(--teal-dark);
  text-transform: uppercase;
}
.health-level span {
  color: var(--muted);
  line-height: 1.35;
}
.health-green { border-left: 5px solid #72b88c; }
.health-yellow { border-left: 5px solid #e8b320; }
.health-orange { border-left: 5px solid #e68021; }
.health-red { border-left: 5px solid #d33f32; }
.health-watch ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.health-watch li {
  display: grid;
  gap: 3px;
  padding: 10px;
  border-radius: var(--radius);
  background: rgba(255,255,255,0.75);
}
.health-watch li strong {
  color: var(--teal-dark);
}
.health-watch li span {
  color: var(--muted);
  line-height: 1.35;
}
.compass-widget {
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  padding: 12px;
  border-radius: var(--radius);
  background: rgba(255,255,255,0.76);
}
.compass-dial {
  position: relative;
  width: 96px;
  height: 96px;
  border: 2px solid var(--teal);
  border-radius: 50%;
  background:
    linear-gradient(90deg, transparent 49%, rgba(10,92,83,0.12) 50%, transparent 51%),
    linear-gradient(0deg, transparent 49%, rgba(10,92,83,0.12) 50%, transparent 51%),
    #fff;
}
.compass-dial span {
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  color: var(--coral);
  font-weight: 900;
}
.compass-needle {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 8px;
  height: 38px;
  transform: translate(-50%, -100%) rotate(0deg);
  transform-origin: 50% 100%;
  border-radius: 999px 999px 2px 2px;
  background: var(--coral);
  transition: transform 0.18s ease;
}
.compass-needle::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -7px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  transform: translateX(-50%);
  background: var(--teal-dark);
}
.compass-readout {
  display: grid;
  gap: 6px;
}
.compass-readout strong {
  color: var(--ink);
  font-size: 1.08rem;
}
.compass-readout span {
  color: var(--muted);
  line-height: 1.35;
}
.capability-status {
  margin: 0;
  padding: 10px 12px;
  border-left: 4px solid var(--yellow);
  border-radius: var(--radius);
  background: rgba(255, 209, 90, 0.16);
  color: var(--ink);
  font-weight: 760;
  line-height: 1.35;
}

.sendai { border-top: 1px solid var(--line); }
.sendai-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.sendai article { padding: 20px; }
.sendai strong {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  background: var(--yellow);
  border-radius: 50%;
}
.resources-section {
  padding-top: 28px;
}
.resource-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
.resource-card {
  min-height: 260px;
  padding: 24px;
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.resource-card h3 {
  margin: 10px 0 8px;
  font-size: clamp(1.6rem, 3vw, 2.45rem);
  line-height: 1.02;
}
.resource-card p {
  margin: 0 0 18px;
  color: var(--muted);
  line-height: 1.5;
}
.resource-card .primary-action,
.resource-card .secondary-action {
  margin-top: auto;
}
.resource-card-wide {
  grid-column: span 2;
}
.pledge-list { display: grid; gap: 10px; }
.pledge-list label {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: var(--radius);
  padding: 12px;
  font-weight: 800;
}
.toast {
  position: fixed;
  right: 20px;
  bottom: 20px;
  max-width: min(360px, calc(100% - 40px));
  background: var(--ink);
  color: #fff;
  padding: 13px 15px;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.toast.is-visible { opacity: 1; transform: translateY(0); }

.pwa-tabbar {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 8;
  display: none;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  padding: 8px 10px calc(8px + env(safe-area-inset-bottom));
  background: rgba(255, 250, 242, 0.96);
  border-top: 1px solid rgba(220, 229, 223, 0.95);
  backdrop-filter: blur(16px);
}
.pwa-tabbar a {
  display: grid;
  place-items: center;
  min-height: 44px;
  border-radius: var(--radius);
  color: var(--teal-dark);
  font-size: 0.82rem;
  font-weight: 900;
  text-decoration: none;
}
.pwa-tabbar a.is-active,
.pwa-tabbar a:focus {
  background: var(--teal);
  color: #fff;
  outline: none;
}

.high-contrast {
  --bg: #050807;
  --surface: #101715;
  --ink: #f8fff9;
  --muted: #c7d8d2;
  --line: #53625e;
  --teal: #67f1d3;
  --teal-dark: #050807;
  --coral: #ff755f;
  --yellow: #ffd84c;
}
.large-text { font-size: 112%; }

@media (max-width: 920px) {
  .topbar { align-items: flex-start; flex-wrap: wrap; }
  .nav { width: 100%; justify-content: flex-start; }
  .split-section { grid-template-columns: 1fr; }
  .scenario-lab { grid-template-columns: 1fr; }
  .san-marino-map-shell { grid-template-columns: 1fr; }
  .inclusive-map-head,
  .inclusive-map-tools { grid-template-columns: 1fr; }
  .inclusive-map-actions { justify-content: flex-start; }
  .hero-media img { aspect-ratio: 1.35; }
  .primary-hub { grid-template-columns: repeat(2, 1fr); }
  .now-board { grid-template-columns: 1fr 1fr; }
  .now-tile.is-alert { grid-column: 1 / -1; }
  .principle-strip { grid-template-columns: 1fr; }
  .risk-grid, .local-risk-grid, .easy-layout, .phase-grid, .assistance-grid, .hub-grid, .tools-grid, .sendai-grid, .monitor-strip, .emergency-grid, .plan-fields { grid-template-columns: repeat(2, 1fr); }
  .meteo-card { grid-column: span 2; }
  .guide-layout { grid-template-columns: 1fr; }
  .guide-media img { aspect-ratio: 1.55; }
  .plan-fields h3 { grid-column: 1 / -1; }
  .video-guide-layout { grid-template-columns: 1fr; }
  .plan-card { position: static; }
}

@media (max-width: 620px) {
  main { padding-bottom: 94px; }
  .pwa-tabbar { display: grid; }
  .topbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
  }
  .brand { min-width: 0; }
  .brand small { font-size: 0.72rem; }
  .top-actions { margin-left: 0; }
  .primary-nav {
    grid-column: 1 / -1;
    display: none;
  }
  .nav {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    width: 100%;
    gap: 6px;
  }
  .nav a {
    padding: 9px 8px;
    font-size: 0.84rem;
    text-align: center;
    background: rgba(255,255,255,0.5);
  }
  .primary-hub, .now-board, .action-paths, .risk-grid, .local-risk-grid, .easy-layout, .phase-grid, .assistance-grid, .hub-grid, .tools-grid, .sendai-grid, .video-steps, .monitor-strip, .resource-grid, .emergency-grid, .plan-fields, .scenario-steps { grid-template-columns: 1fr; }
  .meteo-card { grid-column: auto; }
  .now-tile.is-alert { grid-column: auto; }
  .resource-card-wide { grid-column: auto; }
  .hero { padding-top: 24px; padding-inline: 18px; }
  .hero-copy, .hero-media, .hero-actions { width: 100%; max-width: 430px; }
  .hero h1 { font-size: 2.2rem; line-height: 1.05; overflow-wrap: anywhere; }
  .hero-actions { display: grid; grid-template-columns: 1fr; }
  .primary-action, .secondary-action { width: 100%; }
  .compact-action { width: 100%; }
  .inline-actions { display: grid; grid-template-columns: 1fr; gap: 8px; }
  .guide-media img { aspect-ratio: 1.12; }
.api-summary { grid-template-columns: 1fr; }
  .meteo-now-grid { grid-template-columns: 1fr; }
  .meteo-timeline div { grid-template-columns: 1fr; }
  .compass-widget { grid-template-columns: 1fr; }
  .compass-dial { margin: 0 auto; }
  .physical-map { min-height: 0; padding: 10px; }
  .map-stage img { min-height: 520px; object-fit: cover; }
  .inclusive-map-area { padding: 12px; }
  .inclusive-map { min-height: 380px; height: 62vh; }
  .inclusive-map-tools .secondary-action,
  .inclusive-map-actions .primary-action,
  .inclusive-map-actions .secondary-action { width: 100%; }
  .section { padding: 34px 0; }
}

@media (max-width: 430px) {
  .topbar { padding-inline: 14px; }
  .icon-button { width: 40px; height: 40px; }
  .brand { min-width: 0; }
  .brand-logo { width: 40px; height: 40px; }
  .hero, .primary-hub, .now-board, .principle-strip, .action-paths, .section { width: auto; }
  .hero h1 { font-size: 2.05rem; }
  .primary-hub, .now-board, .principle-strip, .action-paths, .section { margin-inline: 18px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; }
}

.san-marino-map-shell {
  display: none !important;
}


/* Safe Ability SM - livello 2.0: miglioramenti di usabilità, utilità e accessibilità */
:root {
  --focus: 0 0 0 4px rgba(233, 88, 69, 0.22);
  --soft-teal: #e8f5f2;
  --soft-coral: #fff0ed;
  --soft-blue: #eef7ff;
  --soft-yellow: #fff7d8;
}

.topbar { box-shadow: 0 8px 26px rgba(20, 48, 45, 0.07); }
.brand-logo { display: block; width: 46px; height: 46px; object-fit: contain; }
.hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: clamp(22px, 4vw, 56px);
  align-items: center;
}
.hero::after {
  content: "";
  min-height: 330px;
  border-radius: 28px;
  background:
    radial-gradient(circle at 30% 25%, rgba(244,189,40,.45), transparent 28%),
    radial-gradient(circle at 75% 22%, rgba(44,120,184,.30), transparent 28%),
    linear-gradient(145deg, rgba(11,98,91,.93), rgba(6,63,59,.82)),
    url('./assets/emergency-atlas.png') center/cover;
  box-shadow: var(--shadow);
}
.hero h1 { letter-spacing: -0.06em; }
.hero p { color: #425653; }
.primary-action, .secondary-action, .icon-button, .hub-action, .filter, .chip, .check-item, input, textarea, select, summary {
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.primary-action:hover, .secondary-action:hover, .hub-action:hover, .icon-button:hover { transform: translateY(-1px); box-shadow: 0 12px 24px rgba(20, 48, 45, .11); }
:focus-visible { outline: none !important; box-shadow: var(--focus) !important; }

.level2-strip,
.decision-section,
.kit-section,
.data-section,
.protocol-section {
  width: min(1160px, calc(100% - 36px));
  margin: 22px auto;
}
.level2-strip {
  display: grid;
  grid-template-columns: 1.2fr repeat(3, 1fr);
  gap: 12px;
}
.level2-card,
.decision-card,
.kit-card,
.data-card,
.protocol-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: 0 14px 34px rgba(20, 48, 45, .08);
  padding: clamp(18px, 2.5vw, 26px);
}
.level2-card.is-main { background: linear-gradient(135deg, var(--teal), var(--teal-dark)); color: #fff; }
.level2-card.is-main .card-label, .level2-card.is-main p { color: rgba(255,255,255,.86); }
.level2-score { font-size: clamp(3rem, 7vw, 5.5rem); line-height: .88; font-weight: 950; letter-spacing: -.07em; }
.level2-meter { height: 12px; border-radius: 999px; background: rgba(255,255,255,.24); overflow: hidden; margin: 18px 0 10px; }
.level2-meter > span { display:block; height:100%; width:0%; border-radius:999px; background:#fff; }
.level2-card h3, .decision-card h3, .kit-card h3, .data-card h3, .protocol-card h3 { margin: 6px 0 8px; }
.level2-card p, .decision-card p, .kit-card p, .data-card p, .protocol-card p { margin: 0; color: var(--muted); line-height: 1.5; }
.level2-card.is-main p { color: rgba(255,255,255,.88); }
.level2-mini { display:grid; gap:10px; }
.level2-mini span { display:flex; justify-content:space-between; gap:12px; padding:9px 0; border-bottom:1px dashed var(--line); font-weight:800; }
.level2-mini span:last-child { border-bottom:0; }
.status-pill { display:inline-flex; align-items:center; gap:8px; width:fit-content; padding:7px 10px; border-radius:999px; font-size:.82rem; font-weight:900; background:var(--soft-teal); color:var(--teal-dark); }
.status-pill::before { content:""; width:9px; height:9px; border-radius:50%; background:var(--teal); }
.status-pill.warn { background:var(--soft-yellow); color:#755300; }
.status-pill.warn::before { background:var(--yellow); }
.status-pill.danger { background:var(--soft-coral); color:#8b2116; }
.status-pill.danger::before { background:var(--coral); }

.decision-layout { display:grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap:16px; align-items:start; }
.form-grid { display:grid; gap:12px; }
.form-grid label { display:grid; gap:7px; font-weight:850; }
.form-grid select, .form-grid input, .form-grid textarea, .data-card textarea, .kit-card textarea, .map-report-dialog input[type='file'] {
  width:100%; border:1px solid var(--line); border-radius:12px; padding:12px; background:#fff; color:var(--ink);
}
.decision-output { display:grid; gap:12px; }
.decision-output ol { margin:0; padding-left: 1.4rem; display:grid; gap:10px; }
.decision-output li { line-height:1.45; }
.decision-output .what-not { background:var(--soft-coral); padding:14px; border-radius:14px; border:1px solid #ffd1ca; }
.decision-output .what-now { background:var(--soft-teal); padding:14px; border-radius:14px; border:1px solid #cce8e1; }

.kit-grid { display:grid; grid-template-columns: 1.1fr .9fr; gap:16px; }
.kit-list { display:grid; gap:10px; margin-top:12px; }
.kit-item { display:flex; gap:12px; align-items:flex-start; padding:12px; border:1px solid var(--line); border-radius:14px; background:#fff; }
.kit-item input { width:20px; height:20px; flex:0 0 auto; margin-top:2px; }
.kit-item strong { display:block; }
.kit-item small { display:block; color:var(--muted); margin-top:3px; line-height:1.35; }
.kit-toolbar, .data-actions, .decision-actions { display:flex; flex-wrap:wrap; gap:10px; margin-top:14px; }

.data-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:14px; }
.data-card pre { white-space:pre-wrap; overflow:auto; max-height:260px; background:#f7faf8; padding:12px; border-radius:12px; border:1px solid var(--line); }
.protocol-grid { display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap:12px; }
.protocol-card { min-height: 180px; }
.protocol-card strong { display:inline-grid; place-items:center; width:38px; height:38px; border-radius:50%; background:var(--teal); color:#fff; margin-bottom:12px; }

.share-sos-panel { margin-top:12px; display:flex; flex-wrap:wrap; gap:10px; }
.photo-preview { display:none; margin-top:10px; padding:10px; border:1px dashed var(--line); border-radius:12px; background:#f8fbfa; color:var(--muted); font-size:.92rem; }
.photo-preview.is-visible { display:block; }
.print-only { display:none; }

@media (max-width: 980px) {
  .hero { grid-template-columns: 1fr; }
  .hero::after { min-height: 220px; order:-1; }
  .level2-strip, .decision-layout, .kit-grid, .data-grid, .protocol-grid { grid-template-columns: 1fr; }
  .primary-nav { display:none; }
}
@media (max-width: 700px) {
  .topbar { align-items:flex-start; gap:10px; }
  .brand { min-width:0; }
  .brand small { display:none; }
  .level2-strip, .decision-section, .kit-section, .data-section, .protocol-section { width: min(100% - 22px, 1160px); }
  .hero { width:min(100% - 22px, 1160px); }
}

@media print {
  .topbar, .pwa-tabbar, .hero, .primary-hub, .now-board, .principle-strip, .section:not(#piano), .level2-strip, .decision-section, .kit-section, .data-section, .protocol-section, .toast { display:none !important; }
  #piano { display:block !important; width:100% !important; margin:0 !important; }
  .plan-card, .planner { box-shadow:none !important; border:1px solid #222 !important; }
  body { background:#fff !important; color:#000 !important; }
}


/* Safe Ability SM - level up 2.5 */
:root { --safe-blue:#0b4f6c; --safe-green:#0b625b; --safe-light:#f2fbf8; --safe-amber:#ffcf5a; --safe-red:#c93a2b; }
.hero {
  position:relative;
  overflow:hidden;
  min-height: min(68vh, 680px);
  background:
    linear-gradient(90deg, rgba(3,29,42,.96) 0%, rgba(5,54,67,.88) 42%, rgba(5,54,67,.35) 68%, rgba(5,54,67,.08) 100%),
    url('./assets/emergency-atlas-hero.jpg') center/cover no-repeat !important;
  color:#fff;
  border-radius: 0 0 34px 34px;
}
.hero::after { display:none !important; }
.hero-copy { max-width: 760px; padding: clamp(28px, 5vw, 72px); text-shadow: 0 2px 18px rgba(0,0,0,.35); }
.hero h1 { font-size: clamp(3rem, 7vw, 6.6rem); letter-spacing:-.06em; line-height:.88; margin-bottom:18px; }
.hero-copy p { font-size: clamp(1.1rem, 1.65vw, 1.45rem); line-height:1.45; max-width: 690px; }
.hero-actions a { box-shadow:0 12px 30px rgba(0,0,0,.25); }
.hero::before { content:""; position:absolute; inset:auto 0 0 0; height:18px; background:linear-gradient(90deg,#16a085,#ffcf5a,#e76f51); opacity:.95; }
.levelup-section { margin: clamp(24px, 4vw, 54px) auto; max-width:1180px; padding:0 18px; }
.levelup-heading { display:flex; justify-content:space-between; gap:18px; align-items:end; margin-bottom:18px; }
.levelup-heading h2 { margin:0; font-size:clamp(1.8rem,3vw,2.65rem); letter-spacing:-.035em; }
.levelup-heading p { margin:.35rem 0 0; max-width:760px; color:var(--muted, #5c6870); line-height:1.55; }
.levelup-grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:14px; }
.levelup-grid.two { grid-template-columns: repeat(2, minmax(0,1fr)); }
.levelup-grid.four { grid-template-columns: repeat(4, minmax(0,1fr)); }
.levelup-card { background:#fff; border:1px solid var(--line,#dfe7e4); border-radius:24px; padding:20px; box-shadow:0 14px 34px rgba(8,46,61,.08); }
.levelup-card.feature { background:linear-gradient(135deg,#07394b,#0b625b); color:#fff; }
.levelup-card.feature p, .levelup-card.feature small { color:rgba(255,255,255,.86); }
.levelup-card h3 { margin:.35rem 0 .6rem; font-size:1.22rem; }
.levelup-card p, .levelup-card li { line-height:1.48; }
.levelup-card ul, .levelup-card ol { padding-left:1.25rem; display:grid; gap:7px; }
.levelup-pill { display:inline-flex; gap:8px; align-items:center; width:fit-content; border-radius:999px; padding:7px 10px; background:#e8f5f2; color:#075249; font-weight:900; font-size:.82rem; }
.levelup-pill.warn { background:#fff3cd; color:#5a4100; }
.levelup-pill.red { background:#ffe1dc; color:#8b2116; }
.onboarding-steps { display:grid; gap:12px; }
.step-item { display:none; }
.step-item.is-active { display:grid; gap:12px; }
.step-item label { display:grid; gap:7px; font-weight:850; }
.step-item input, .step-item select, .step-item textarea, .sos-select, .qr-card textarea { width:100%; border:1px solid var(--line,#dfe7e4); border-radius:14px; padding:12px; font:inherit; }
.step-progress { height:12px; border-radius:999px; overflow:hidden; background:#e8eeee; margin:8px 0 2px; }
.step-progress span { display:block; height:100%; width:0; background:linear-gradient(90deg,#0b625b,#ffcf5a); transition:.25s ease; }
.inline-actions { display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-top:12px; }
.inline-actions .secondary-action, .inline-actions .primary-action { text-decoration:none; }
.sos-templates { display:grid; gap:12px; }
.sos-preview { min-height:140px; width:100%; border:1px solid var(--line,#dfe7e4); border-radius:16px; padding:14px; font:inherit; }
.easy-mode .complex-only { display:none !important; }
.easy-mode .easy-text { font-size:1.18rem; line-height:1.7; }
.easy-mode body, body.easy-mode { letter-spacing:.01em; }
.easy-mode .hero-copy p { font-size:1.35rem; line-height:1.6; }
.easy-toggle { position:fixed; right:16px; bottom:86px; z-index:30; border:0; border-radius:999px; padding:12px 14px; font-weight:900; background:#07394b; color:#fff; box-shadow:0 12px 28px rgba(0,0,0,.22); }
.qr-wrap { display:grid; grid-template-columns: 220px 1fr; gap:16px; align-items:center; }
.qr-box { min-height:220px; border:1px dashed var(--line,#dfe7e4); border-radius:20px; display:grid; place-items:center; background:#f8fbfa; padding:12px; text-align:center; }
.qr-box img { max-width:200px; border-radius:10px; background:#fff; padding:8px; }
.event-checklist label, .rescuer-checklist label { display:flex; gap:10px; align-items:flex-start; padding:10px 0; border-bottom:1px solid #edf2f0; }
.event-checklist input, .rescuer-checklist input { width:20px; height:20px; flex:0 0 auto; }
.resource-card .source-note { font-size:.9rem; color:var(--muted,#5c6870); border-top:1px solid var(--line,#dfe7e4); margin-top:12px; padding-top:12px; }
@media (max-width: 980px) { .levelup-grid, .levelup-grid.two, .levelup-grid.four, .qr-wrap { grid-template-columns:1fr; } .hero { min-height:auto; } }
@media print { .topbar,.pwa-tabbar,.hero-actions,.inline-actions,.easy-toggle,#toast { display:none !important; } .levelup-card { break-inside:avoid; box-shadow:none; } }


/* Safe Ability SM - pulizia e livello 3.0 */
:root {
  --sa-navy:#062f3f;
  --sa-green:#0b625b;
  --sa-teal:#107f75;
  --sa-cream:#f7fbf8;
  --sa-line:#dbe7e3;
  --sa-red:#bd2f25;
  --sa-amber:#ffcf5a;
}

/* Hero: la carrozzina resta visibile, il testo si sposta a destra */
.hero {
  min-height: min(76vh, 720px) !important;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  background:
    linear-gradient(90deg, rgba(3,29,42,.04) 0%, rgba(3,29,42,.18) 38%, rgba(3,29,42,.78) 61%, rgba(3,29,42,.96) 100%),
    url('./assets/emergency-atlas-hero.jpg') left center/cover no-repeat !important;
}
.hero-copy {
  margin-left:auto;
  width:min(620px, 94vw);
  padding:clamp(22px, 4vw, 56px) !important;
  background:rgba(2,28,40,.72);
  backdrop-filter: blur(8px);
  border:1px solid rgba(255,255,255,.18);
  border-radius:28px 0 0 28px;
  box-shadow:0 24px 70px rgba(0,0,0,.28);
}
.hero h1 { font-size:clamp(2.7rem, 6vw, 5.6rem) !important; }
.hero-copy p { max-width:54ch !important; }
.hero-actions { display:flex; flex-wrap:wrap; gap:10px; }
.hero-actions a { min-height:48px; display:inline-flex; align-items:center; justify-content:center; }

/* Riduzione sovraccarico: questi blocchi ripetevano azioni già presenti nella hero/tabbar/cruscotto. */
.primary-hub, .now-board { display:none !important; }

.topbar .brand small::after { content:" - sicurezza per tutti"; }
.pwa-tabbar a[href="#direttrice"] { display:none; }

.operational-strip {
  width:min(100% - 28px, 1180px);
  margin:clamp(20px, 4vw, 42px) auto;
  display:grid;
  gap:14px;
}
.operational-head {
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:18px;
}
.operational-head h2 { margin:0; font-size:clamp(1.9rem, 3vw, 3rem); letter-spacing:-.045em; }
.operational-head p { margin:.35rem 0 0; color:var(--muted,#58666d); max-width:760px; line-height:1.55; }
.triage-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; }
.triage-button {
  text-align:left;
  border:0;
  border-radius:26px;
  padding:22px;
  background:#fff;
  box-shadow:0 16px 40px rgba(8,46,61,.1);
  cursor:pointer;
  border:1px solid var(--sa-line);
  min-height:160px;
  transition:transform .18s ease, box-shadow .18s ease;
}
.triage-button:hover, .triage-button:focus-visible { transform:translateY(-2px); box-shadow:0 22px 50px rgba(8,46,61,.16); outline:3px solid rgba(11,98,91,.25); }
.triage-button strong { display:block; font-size:1.35rem; margin:.35rem 0; }
.triage-button span { display:block; color:#54616a; line-height:1.45; }
.triage-button .triage-icon { width:48px; height:48px; border-radius:16px; display:grid; place-items:center; font-size:1.6rem; background:#e9f6f3; }
.triage-button.is-danger { background:linear-gradient(135deg,#fff,#ffecea); border-color:#ffc8c0; }
.triage-button.is-danger .triage-icon { background:#bd2f25; color:#fff; }
.triage-button.is-rescuer { background:linear-gradient(135deg,#fff,#f2f7ff); }
.triage-panel {
  display:none;
  background:#062f3f;
  color:#fff;
  border-radius:28px;
  padding:clamp(18px,3vw,30px);
  box-shadow:0 18px 46px rgba(6,47,63,.2);
}
.triage-panel.is-active { display:grid; grid-template-columns:1.1fr .9fr; gap:22px; }
.triage-panel h3 { margin:0 0 10px; font-size:1.55rem; }
.triage-panel ol, .triage-panel ul { display:grid; gap:8px; padding-left:1.2rem; line-height:1.55; }
.triage-panel .panel-box { background:rgba(255,255,255,.09); border:1px solid rgba(255,255,255,.15); border-radius:20px; padding:16px; }
.triage-panel textarea { width:100%; min-height:170px; border-radius:16px; padding:14px; font:inherit; border:0; }

.compact-section {
  width:min(100% - 28px, 1180px);
  margin:clamp(22px,4vw,52px) auto;
}
.compact-heading { margin-bottom:16px; }
.compact-heading h2 { margin:0; font-size:clamp(1.7rem, 2.7vw, 2.55rem); letter-spacing:-.035em; }
.compact-heading p { max-width:760px; color:#58666d; line-height:1.55; }
.compact-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px; }
.compact-grid.three { grid-template-columns:repeat(3,minmax(0,1fr)); }
.compact-card {
  background:#fff;
  border:1px solid var(--sa-line);
  border-radius:24px;
  padding:20px;
  box-shadow:0 14px 34px rgba(8,46,61,.08);
}
.compact-card h3 { margin:.2rem 0 .6rem; }
.compact-card p, .compact-card li { line-height:1.52; }
.compact-card label { display:grid; gap:7px; font-weight:850; margin-bottom:12px; }
.compact-card input, .compact-card textarea, .compact-card select {
  width:100%; border:1px solid var(--sa-line); border-radius:14px; padding:12px; font:inherit; background:#fff;
}
.profile-fields { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; }
.profile-fields label.full { grid-column:1 / -1; }
.profile-preview { min-height:360px; }

.caregiver-tabs, .climate-tabs, .institution-tabs { display:flex; flex-wrap:wrap; gap:8px; margin:8px 0 14px; }
.micro-tab {
  border:1px solid var(--sa-line); background:#fff; border-radius:999px; padding:10px 12px; font-weight:850; cursor:pointer;
}
.micro-tab.is-active { background:var(--sa-green); color:#fff; border-color:var(--sa-green); }
.tab-output { background:#f8fbfa; border:1px solid var(--sa-line); border-radius:20px; padding:18px; min-height:180px; }
.tab-output h3 { margin-top:0; }

.map-upgrade-grid { display:grid; grid-template-columns:repeat(5,minmax(0,1fr)); gap:10px; }
.map-upgrade-item { background:#f8fbfa; border:1px solid var(--sa-line); border-radius:16px; padding:12px; font-weight:850; }
.map-upgrade-item small { display:block; font-weight:500; color:#58666d; margin-top:5px; }

.docs-list label { display:flex; gap:10px; align-items:flex-start; padding:10px 0; border-bottom:1px solid #edf2f0; font-weight:700; }
.docs-list input { width:20px; height:20px; flex:0 0 auto; }
.reminder-grid { display:grid; grid-template-columns:repeat(5,minmax(0,1fr)); gap:12px; }
.reminder-pill {
  background:linear-gradient(135deg,#ffffff,#f3fbf8);
  border:1px solid var(--sa-line);
  border-radius:20px;
  padding:16px;
  font-weight:900;
  line-height:1.35;
  box-shadow:0 10px 24px rgba(8,46,61,.06);
}
.identità-card { background:linear-gradient(135deg,#062f3f,#0b625b); color:#fff; }
.identità-card p { color:rgba(255,255,255,.88); }

body.easy-mode .principle-strip p,
body.easy-mode .section-heading p,
body.easy-mode .levelup-heading p,
body.easy-mode .compact-heading p { font-size:1.18rem; line-height:1.75; }
body.easy-mode .primary-action, body.easy-mode .secondary-action, body.easy-mode button, body.easy-mode input, body.easy-mode textarea, body.easy-mode select { font-size:1.08rem; }

@media (max-width:980px) {
  .hero { justify-content:center; background-position:28% center !important; padding:18px 0; }
  .hero-copy { border-radius:24px; margin:0 14px; }
  .triage-grid, .triage-panel.is-active, .compact-grid, .compact-grid.three, .profile-fields, .map-upgrade-grid, .reminder-grid { grid-template-columns:1fr; }
}

@media print {
  #emergenza-adesso, .compact-section:not(#profilo-completo), .operational-strip, .topbar, .pwa-tabbar, .hero, .easy-toggle, #toast { display:none !important; }
  #profilo-completo { display:block !important; width:100% !important; }
  .compact-card { box-shadow:none; break-inside:avoid; }
}


/* Safe Ability SM - finiture pubblicabili 4.1 */
:root{
  --sa-ink:#082f3f;
  --sa-deep:#073b4c;
  --sa-teal:#0f766e;
  --sa-mint:#e7f7f2;
  --sa-sun:#ffb703;
  --sa-heat:#0f766e;
  --sa-soft:#f8fbfa;
}

body.launch-compact .primary-hub,
body.launch-compact .now-board,
body.launch-compact #direttrice,
body.launch-compact #atlante,
body.launch-compact #scenario,
body.launch-compact #prima,
body.launch-compact #presidio,
body.launch-compact #documenti-essenziali,
body.launch-compact #istituzioni,
body.launch-compact #non-dimenticare{
  display:none !important;
}
body.show-advanced #direttrice,
body.show-advanced #atlante,
body.show-advanced #scenario,
body.show-advanced #prima,
body.show-advanced #presidio,
body.show-advanced #documenti-essenziali,
body.show-advanced #istituzioni,
body.show-advanced #non-dimenticare{
  display:block !important;
}

.topbar{
  border-bottom:1px solid rgba(8,47,63,.08);
  backdrop-filter: blur(16px);
}
.brand-logo{
  width:44px !important;
  height:44px !important;
  border-radius:14px;
  box-shadow:0 8px 22px rgba(7,59,76,.18);
}
.brand strong{ letter-spacing:-.02em; }
.brand small{ color:#42616b !important; }
.primary-nav a[href="#direttrice"],
.primary-nav a[href="#presidio"]{ display:none !important; }

.hero{
  min-height:min(72vh, 690px) !important;
  justify-content:flex-end !important;
  background:
    linear-gradient(90deg, rgba(3,29,42,0) 0%, rgba(3,29,42,.05) 37%, rgba(3,29,42,.48) 58%, rgba(3,29,42,.94) 100%),
    url('./assets/emergency-atlas-hero.jpg') left center/cover no-repeat !important;
  padding:clamp(20px,4vw,52px) 0 !important;
}
.hero-copy{
  width:min(530px, 90vw) !important;
  margin:0 clamp(18px,4vw,64px) 0 auto !important;
  border-radius:30px !important;
  padding:clamp(22px,3.5vw,42px) !important;
  background:rgba(7,59,76,.88) !important;
}
.hero-copy::before{
  content:'Prima versione pubblica';
  display:inline-flex;
  width:max-content;
  max-width:100%;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(231,247,242,.16);
  color:#dffaf2;
  border:1px solid rgba(231,247,242,.36);
  font-weight:900;
  margin-bottom:14px;
}
.hero h1{ font-size:clamp(2.35rem,5vw,4.9rem) !important; line-height:.96 !important; }
.hero-copy p{ font-size:clamp(1rem,1.45vw,1.18rem) !important; }
.hero-actions{ gap:8px !important; }
.hero-actions a{ border-radius:14px !important; }

.launch-spotlight,
.focus-gate{
  width:min(100% - 28px,1180px);
  margin:clamp(18px,3vw,34px) auto;
}
.launch-spotlight{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:16px;
  align-items:stretch;
}
.heat-card,
.focus-card{
  border:1px solid rgba(15,118,110,.18);
  border-radius:28px;
  background:linear-gradient(135deg,#f2fbf8,#ffffff 55%,#eef6fb);
  padding:clamp(20px,3vw,30px);
  box-shadow:0 18px 48px rgba(8,47,63,.10);
}
.heat-card h2,
.focus-card h2{ margin:0 0 8px; font-size:clamp(1.75rem,3vw,2.6rem); letter-spacing:-.04em; color:var(--sa-deep); }
.heat-card p,
.focus-card p{ color:#4e626b; line-height:1.6; }
.heat-actions{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:10px; margin-top:16px; }
.heat-action{
  display:grid;
  gap:6px;
  text-decoration:none;
  background:#fff;
  border:1px solid rgba(8,47,63,.1);
  color:var(--sa-deep);
  border-radius:20px;
  padding:16px;
  font-weight:900;
  min-height:118px;
}
.heat-action small{ color:#5f727a; font-weight:600; line-height:1.35; }
.heat-action.primary{ background:linear-gradient(135deg,#0f766e,#073b4c); color:#fff; }
.heat-action.primary small{ color:rgba(255,255,255,.86); }
.heat-minilist{ background:#fff; border:1px solid rgba(8,47,63,.1); border-radius:24px; padding:18px; }
.heat-minilist h3{ margin:0 0 8px; color:var(--sa-deep); }
.heat-minilist ul{ margin:0; padding-left:1.2rem; display:grid; gap:7px; line-height:1.5; }

.heat-protocol{ width:min(100% - 28px,1180px); margin:clamp(18px,3vw,42px) auto; }
.heat-protocol-header{ display:flex; justify-content:space-between; gap:16px; align-items:flex-end; margin-bottom:14px; }
.heat-protocol-header h2{ margin:0; font-size:clamp(1.8rem,3vw,2.75rem); letter-spacing:-.04em; color:var(--sa-deep); }
.heat-protocol-header p{ margin:.25rem 0 0; color:#566a72; max-width:760px; line-height:1.55; }
.heat-protocol-grid{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; }
.heat-step{
  background:#fff;
  border:1px solid rgba(8,47,63,.1);
  border-radius:24px;
  padding:20px;
  box-shadow:0 14px 34px rgba(8,47,63,.08);
}
.heat-step strong{ display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px; border-radius:14px; background:#e7f7f2; color:#0f766e; }
.heat-step h3{ margin:12px 0 8px; color:var(--sa-deep); }
.heat-step ul{ padding-left:1.1rem; display:grid; gap:8px; line-height:1.5; }

.focus-gate{ display:grid; grid-template-columns:1fr auto; gap:14px; align-items:center; }
.focus-card{ border-color:rgba(15,118,110,.18); background:linear-gradient(135deg,#f2fbf8,#fff); }
.focus-card p{ margin-bottom:0; }
.focus-toggle{
  border:0;
  background:var(--sa-deep);
  color:#fff;
  font-weight:900;
  border-radius:18px;
  padding:16px 20px;
  min-height:58px;
  box-shadow:0 14px 30px rgba(7,59,76,.2);
  cursor:pointer;
}

#emergenza-adesso{ margin-top:22px !important; }
.triage-button{ min-height:132px !important; }
.triage-button strong{ font-size:1.18rem !important; }
.compact-section, .levelup-section, .section{ scroll-margin-top:96px; }

.sticky-emergency{
  position:fixed;
  right:18px;
  bottom:calc(18px + env(safe-area-inset-bottom));
  z-index:70;
  display:inline-flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  border-radius:999px;
  background:#b83214;
  color:#fff;
  padding:14px 18px;
  font-weight:950;
  box-shadow:0 18px 42px rgba(184,50,20,.32);
}
.sticky-emergency::before{ content:'!'; width:26px; height:26px; border-radius:50%; display:grid; place-items:center; background:rgba(255,255,255,.2); }

@media (max-width:980px){
  .hero{
    min-height:auto !important;
    justify-content:center !important;
    background:
      linear-gradient(180deg, rgba(3,29,42,.15) 0%, rgba(3,29,42,.9) 74%),
      url('./assets/emergency-atlas-hero.jpg') 14% center/cover no-repeat !important;
    padding:220px 0 18px !important;
  }
  .hero-copy{ margin:0 14px !important; width:calc(100% - 28px) !important; }
  .launch-spotlight,
  .heat-protocol-grid,
  .focus-gate{ grid-template-columns:1fr; }
  .heat-actions{ grid-template-columns:1fr; }
  .sticky-emergency{ left:14px; right:14px; justify-content:center; bottom:12px; }
  body{ padding-bottom:76px; }
}

@media print{
  .launch-spotlight,.heat-protocol,.focus-gate,.sticky-emergency{ display:none !important; }
}


/* Safe Ability SM 5.0 - pulizia editoriale e identità pubblica Attiva-Mente */
:root{
  --master-ink:#092c3a;
  --master-teal:#08766f;
  --master-blue:#0b5d88;
  --master-soft:#f4faf8;
  --master-line:rgba(9,44,58,.13);
  --master-warm:#f7c948;
}
body.masterpiece{
  background:linear-gradient(180deg,#f7fbfa 0%,#ffffff 38%,#f7fbfa 100%) !important;
  color:var(--master-ink);
}
body.masterpiece .brand-logo{width:46px!important;height:46px!important;border-radius:15px;box-shadow:0 10px 28px rgba(8,118,111,.20)}
body.masterpiece .brand small{font-weight:800;color:#557079!important}
body.masterpiece .topbar{background:rgba(255,255,255,.86)!important;border-bottom:1px solid var(--master-line)!important;backdrop-filter:blur(18px)}
body.masterpiece .primary-nav a{font-weight:900;color:#31545e!important}
body.masterpiece .primary-nav a:hover{color:var(--master-teal)!important}

/* Basta ginepraio: la pagina pubblica mostra il percorso, gli approfondimenti restano apribili. */
body.masterpiece .primary-hub,
body.masterpiece .now-board,
body.masterpiece .launch-spotlight,
body.masterpiece #emergenza,
body.masterpiece #piano,
body.masterpiece #presidio,
body.masterpiece #direttrice,
body.masterpiece #atlante,
body.masterpiece #scenario,
body.masterpiece #prima,
body.masterpiece #documenti-essenziali,
body.masterpiece #non-dimenticare,
body.masterpiece #caregiver-operativo,
body.masterpiece #rischio-momento,
body.masterpiece .focus-gate{display:none!important}
body.masterpiece.show-advanced #direttrice,
body.masterpiece.show-advanced #atlante,
body.masterpiece.show-advanced #scenario,
body.masterpiece.show-advanced #prima,
body.masterpiece.show-advanced #documenti-essenziali,
body.masterpiece.show-advanced #non-dimenticare,
body.masterpiece.show-advanced #caregiver-operativo{display:block!important}

body.masterpiece .hero{
  min-height:min(74vh,720px)!important;
  display:flex!important;
  align-items:stretch!important;
  justify-content:flex-end!important;
  padding:clamp(18px,3.8vw,54px)!important;
  background:
    radial-gradient(circle at 18% 72%, rgba(255,255,255,.0) 0 17%, rgba(255,255,255,.06) 28%, rgba(255,255,255,.0) 40%),
    linear-gradient(90deg, rgba(0,0,0,0) 0%, rgba(2,18,28,.03) 42%, rgba(2,18,28,.54) 67%, rgba(2,18,28,.94) 100%),
    url('./assets/emergency-atlas-hero.jpg') left center/cover no-repeat!important;
  border-radius:0 0 34px 34px!important;
  overflow:hidden;
}
body.masterpiece .hero-copy{
  align-self:center;
  width:min(520px,92vw)!important;
  margin:0!important;
  padding:clamp(22px,3vw,38px)!important;
  border-radius:30px!important;
  background:rgba(255,255,255,.93)!important;
  color:var(--master-ink)!important;
  text-shadow:none!important;
  box-shadow:0 24px 70px rgba(0,0,0,.26)!important;
  border:1px solid rgba(255,255,255,.6)!important;
}
body.masterpiece .hero-copy::before{
  content:'Attiva-Mente · utility civica';
  display:inline-flex;width:max-content;max-width:100%;padding:8px 12px;border-radius:999px;
  background:#e8f7f4;color:#08766f;border:1px solid rgba(8,118,111,.2);font-weight:950;margin-bottom:14px;
}
body.masterpiece .hero h1{font-size:clamp(2.25rem,4.8vw,4.7rem)!important;line-height:.98!important;letter-spacing:-.065em!important;color:#082f3f!important;margin-bottom:14px!important}
body.masterpiece .hero-copy p{color:#425e67!important;font-size:clamp(1rem,1.35vw,1.15rem)!important;line-height:1.62!important;max-width:52ch!important}
body.masterpiece .hero-actions{display:grid!important;grid-template-columns:1fr 1fr;gap:10px!important;margin-top:20px!important}
body.masterpiece .hero-actions .primary-action{grid-column:1/-1;background:linear-gradient(135deg,#08766f,#073b4c)!important;color:#fff!important;border:0!important}
body.masterpiece .hero-actions a{border-radius:16px!important;min-height:52px!important;text-align:center!important;font-weight:950!important}
.master-badge-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.master-badge{display:inline-flex;align-items:center;gap:7px;border-radius:999px;background:#f3f8f7;border:1px solid var(--master-line);padding:8px 10px;font-weight:850;color:#3c5861;font-size:.9rem}

.master-path,.master-launch-note,.master-risks,.master-advanced-gate{width:min(100% - 28px,1180px);margin:clamp(18px,3vw,36px) auto}
.master-path{display:grid;gap:14px}
.master-path-head{display:flex;justify-content:space-between;gap:18px;align-items:end}
.master-path-head h2,.master-risks h2{margin:0;font-size:clamp(1.9rem,3.2vw,3rem);letter-spacing:-.05em;color:var(--master-ink)}
.master-path-head p,.master-risks p{margin:.35rem 0 0;color:#5f737a;line-height:1.55;max-width:760px}
.master-steps{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}
.master-step{position:relative;text-decoration:none;background:#fff;border:1px solid var(--master-line);border-radius:22px;padding:16px;min-height:154px;color:var(--master-ink);box-shadow:0 14px 36px rgba(9,44,58,.07);transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.master-step:hover{transform:translateY(-3px);box-shadow:0 18px 46px rgba(9,44,58,.12);border-color:rgba(8,118,111,.28)}
.master-step b{display:grid;place-items:center;width:36px;height:36px;border-radius:14px;background:#e8f7f4;color:#08766f;font-weight:950;margin-bottom:12px}
.master-step strong{display:block;font-size:1.05rem;line-height:1.1;margin-bottom:8px;color:#082f3f}
.master-step span{display:block;font-size:.9rem;line-height:1.42;color:#61747b;font-weight:650}
.master-step.is-main{background:linear-gradient(135deg,#08766f,#073b4c);color:#fff;border:0}
.master-step.is-main b{background:rgba(255,255,255,.18);color:#fff}.master-step.is-main strong{color:#fff}.master-step.is-main span{color:rgba(255,255,255,.86)}
.master-launch-note{display:grid;grid-template-columns:1.1fr .9fr;gap:14px;align-items:stretch}
.master-note-card{border:1px solid rgba(8,118,111,.18);background:linear-gradient(135deg,#eefaf7,#fff);border-radius:28px;padding:clamp(20px,3vw,30px);box-shadow:0 16px 42px rgba(9,44,58,.08)}
.master-note-card h2{margin:0 0 8px;font-size:clamp(1.55rem,2.5vw,2.25rem);letter-spacing:-.04em;color:#082f3f}.master-note-card p{color:#516872;line-height:1.62}.master-note-card ul{display:grid;gap:8px;margin:.5rem 0 0;padding-left:1.2rem;line-height:1.55;color:#435c65}
.master-note-side{border:1px solid var(--master-line);background:#fff;border-radius:28px;padding:20px}.master-note-side h3{margin:0 0 10px;color:#082f3f}.master-note-side ol{display:grid;gap:9px;margin:0;padding-left:1.2rem;color:#4d646d;line-height:1.5}

body.masterpiece #emergenza-adesso{width:min(100% - 28px,1180px)!important;margin:clamp(18px,3vw,36px) auto!important;border-radius:30px!important;background:#fff!important;border:1px solid var(--master-line)!important;box-shadow:0 18px 52px rgba(9,44,58,.10)!important;padding:clamp(20px,3vw,34px)!important}
body.masterpiece #emergenza-adesso .operational-head h2{font-size:clamp(1.85rem,3vw,2.8rem)!important;color:#082f3f!important;letter-spacing:-.05em!important}
body.masterpiece .triage-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:12px!important}
body.masterpiece .triage-button{border-radius:22px!important;min-height:150px!important;background:#fbfdfd!important;border:1px solid var(--master-line)!important;color:#082f3f!important;text-align:left!important;box-shadow:0 12px 30px rgba(9,44,58,.06)!important}
body.masterpiece .triage-button.is-danger{background:linear-gradient(135deg,#b83214,#87310e)!important;color:#fff!important;border:0!important}.triage-button.is-danger span,.triage-button.is-danger strong{color:#fff!important}
body.masterpiece .triage-button.is-rescuer{background:#edf7ff!important;border-color:rgba(11,93,136,.16)!important}
body.masterpiece .triage-panel{border-radius:24px!important;background:#f8fbfa!important;border:1px solid var(--master-line)!important}

body.masterpiece #profilo-completo,body.masterpiece #sanmarino,body.masterpiece #soccorritori-caregiver,body.masterpiece #crisi-climatica,body.masterpiece #eventi-accessibili,body.masterpiece #istituzioni,body.masterpiece #risorse{width:min(100% - 28px,1180px)!important;margin:clamp(18px,3vw,38px) auto!important;border-radius:30px!important;scroll-margin-top:98px}
body.masterpiece #profilo-completo,body.masterpiece #soccorritori-caregiver,body.masterpiece #crisi-climatica,body.masterpiece #eventi-accessibili,body.masterpiece #istituzioni{background:#fff!important;border:1px solid var(--master-line)!important;box-shadow:0 16px 48px rgba(9,44,58,.08)!important;padding:clamp(20px,3vw,34px)!important}
body.masterpiece .compact-heading h2,body.masterpiece .section-heading h2{font-size:clamp(1.8rem,3vw,2.75rem)!important;letter-spacing:-.05em!important;color:#082f3f!important}
body.masterpiece .compact-heading p,body.masterpiece .section-heading p{color:#5b7179!important;line-height:1.58!important;max-width:800px!important}
body.masterpiece .compact-card,body.masterpiece .resource-card,body.masterpiece .hub-card,body.masterpiece .map-card{border-radius:24px!important;border:1px solid var(--master-line)!important;box-shadow:0 10px 30px rgba(9,44,58,.06)!important}
body.masterpiece .primary-action{background:linear-gradient(135deg,#08766f,#073b4c)!important;color:#fff!important;border:0!important}.secondary-action{border-color:var(--master-line)!important;color:#173d49!important;background:#fff!important}

.master-risks{background:linear-gradient(135deg,#fff,#f2faf8);border:1px solid rgba(8,118,111,.18);border-radius:30px;padding:clamp(20px,3vw,34px);box-shadow:0 16px 48px rgba(9,44,58,.08)}
.master-risk-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:16px}.master-risk{background:#fff;border:1px solid var(--master-line);border-radius:22px;padding:16px;min-height:168px}.master-risk strong{display:block;font-size:1.05rem;margin-bottom:8px;color:#082f3f}.master-risk p{font-size:.94rem;color:#576e76;line-height:1.48}.master-risk small{display:inline-flex;margin-top:10px;border-radius:999px;background:#e8f7f4;color:#08766f;padding:7px 9px;font-weight:900}
.master-advanced-gate{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#082f3f;color:#fff;border-radius:28px;padding:20px 22px;box-shadow:0 18px 46px rgba(9,44,58,.16)}
.master-advanced-gate h2{margin:0 0 4px;font-size:1.45rem}.master-advanced-gate p{margin:0;color:rgba(255,255,255,.82);line-height:1.5}.master-advanced-gate button{border:0;background:#fff;color:#082f3f;border-radius:16px;padding:14px 18px;font-weight:950;cursor:pointer;white-space:nowrap}
.sticky-emergency{background:#b83214!important}

@media(max-width:1080px){.master-steps{grid-template-columns:repeat(3,minmax(0,1fr))}.master-risk-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:760px){body.masterpiece .hero{justify-content:center!important;background:linear-gradient(180deg,rgba(0,0,0,0) 0 42%,rgba(5,33,45,.80) 72%,rgba(5,33,45,.96) 100%),url('./assets/emergency-atlas-hero.jpg') 13% center/cover no-repeat!important;padding:230px 14px 18px!important;border-radius:0 0 24px 24px!important}body.masterpiece .hero-copy{width:100%!important;margin:0!important}.master-steps,.master-launch-note,.master-risk-grid,body.masterpiece .triage-grid{grid-template-columns:1fr!important}.master-path-head,.master-advanced-gate{display:grid}.master-advanced-gate button{width:100%}.master-badge-row{display:grid}.master-badge{justify-content:center}body.masterpiece .hero-actions{grid-template-columns:1fr!important}body.masterpiece .pwa-tabbar{display:grid!important;grid-template-columns:repeat(4,1fr)!important}}
@media print{.topbar,.pwa-tabbar,.hero,.master-path,.master-launch-note,.master-risks,.master-advanced-gate,.sticky-emergency{display:none!important}}

/* Safe Ability SM 5.1 - hero senza testo sopra l'immagine
   La fotografia resta protagonista e leggibile; il testo diventa una fascia editoriale separata. */
body.masterpiece .hero{
  display:block!important;
  min-height:0!important;
  padding:0!important;
  background:#ffffff!important;
  border-radius:0 0 34px 34px!important;
  overflow:hidden!important;
  box-shadow:0 18px 54px rgba(9,44,58,.10)!important;
}
body.masterpiece .hero::before{
  content:'';
  display:block;
  width:100%;
  min-height:clamp(330px,48vw,660px);
  background:url('./assets/emergency-atlas-hero.jpg') center center/cover no-repeat;
}
body.masterpiece .hero-copy{
  width:min(100% - 32px,1180px)!important;
  margin:0 auto!important;
  padding:clamp(22px,3vw,34px) 0 clamp(20px,3vw,32px)!important;
  border-radius:0!important;
  background:transparent!important;
  color:var(--master-ink)!important;
  box-shadow:none!important;
  border:0!important;
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(290px,420px)!important;
  gap:clamp(18px,3vw,36px)!important;
  align-items:end!important;
}
body.masterpiece .hero-copy::before{
  grid-column:1/-1;
  margin:0 0 -6px!important;
  background:#e8f7f4!important;
  color:#08766f!important;
}
body.masterpiece .hero h1{
  margin:0!important;
  font-size:clamp(2.15rem,4.2vw,4.5rem)!important;
  max-width:12ch!important;
}
body.masterpiece .hero-copy p{
  margin:0!important;
  max-width:64ch!important;
  color:#425e67!important;
}
body.masterpiece .hero-actions{
  margin:0!important;
  grid-column:2!important;
  grid-row:2 / span 2!important;
  align-self:stretch!important;
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:10px!important;
}
body.masterpiece .hero-actions .primary-action{grid-column:auto!important;}
body.masterpiece .hero-actions a{min-height:50px!important;}
@media(max-width:760px){
  body.masterpiece .hero{
    padding:0!important;
    background:#fff!important;
    border-radius:0 0 24px 24px!important;
  }
  body.masterpiece .hero::before{
    min-height:clamp(260px,70vw,430px);
    background-position:center center;
  }
  body.masterpiece .hero-copy{
    width:min(100% - 28px,1180px)!important;
    grid-template-columns:1fr!important;
    gap:16px!important;
    padding:20px 0 24px!important;
  }
  body.masterpiece .hero-copy::before{width:max-content;max-width:100%;}
  body.masterpiece .hero-actions{grid-column:auto!important;grid-row:auto!important;}
}


/* Safe Ability SM 5.2 - rifinitura finale: meno landing, più utility */
body.masterpiece.v52{
  --v52-ink:#082f3f;
  --v52-muted:#526b74;
  --v52-teal:#08766f;
  --v52-blue:#0b5d88;
  --v52-red:#b83214;
  --v52-bg:#f6fbfa;
}
body.masterpiece.v52 .brand small{font-weight:850;color:#4c6670!important}
body.masterpiece.v52 .topbar{box-shadow:0 8px 28px rgba(9,44,58,.06)!important}
body.masterpiece.v52 .primary-nav a{font-size:.95rem!important}

/* La fotografia racconta: nessun testo sopra l'immagine. */
body.masterpiece.v52 .hero{
  border-radius:0 0 30px 30px!important;
  background:#fff!important;
  box-shadow:0 16px 44px rgba(9,44,58,.10)!important;
}
body.masterpiece.v52 .hero::before{
  min-height:clamp(320px,46vw,620px)!important;
  background-image:url('./assets/emergency-atlas-hero.jpg')!important;
  background-position:center center!important;
  background-size:cover!important;
}
body.masterpiece.v52 .hero-copy{
  width:min(100% - 32px,1120px)!important;
  grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr)!important;
  gap:clamp(16px,3vw,30px)!important;
  padding:clamp(20px,3vw,30px) 0 clamp(18px,2.6vw,28px)!important;
  align-items:center!important;
}
body.masterpiece.v52 .hero-copy::before{content:'Attiva-Mente · utility civica'!important;grid-column:1/-1!important;margin-bottom:-4px!important}
body.masterpiece.v52 .hero h1{
  max-width:none!important;
  font-size:clamp(2.25rem,4.4vw,4.35rem)!important;
  letter-spacing:-.065em!important;
}
body.masterpiece.v52 .hero-copy p{
  font-size:clamp(1rem,1.35vw,1.12rem)!important;
  line-height:1.58!important;
  color:#415d66!important;
}
body.masterpiece.v52 .hero-actions{
  display:grid!important;
  grid-template-columns:1fr!important;
  grid-column:2!important;
  grid-row:2 / span 2!important;
  align-self:stretch!important;
}
body.masterpiece.v52 .hero-actions a{min-height:56px!important;border-radius:18px!important;font-size:1rem!important}
body.masterpiece.v52 .master-badge-row{display:none!important}

/* Home essenziale: tre scelte e quattro porte, non un ginepraio. */
body.masterpiece.v52 #percorso-maestro,
body.masterpiece.v52 #nota-pubblica-attivamentesm,
body.masterpiece.v52 .master-risks{display:none!important}
.v52-home-actions,
.v52-support-nav{
  width:min(100% - 28px,1120px);
  margin:clamp(18px,3vw,32px) auto;
}
.v52-home-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.v52-action{
  position:relative;
  display:grid;
  gap:8px;
  min-height:150px;
  padding:20px;
  border-radius:26px;
  text-decoration:none;
  background:#fff;
  color:var(--v52-ink);
  border:1px solid rgba(9,44,58,.12);
  box-shadow:0 14px 34px rgba(9,44,58,.07);
}
.v52-action:hover{transform:translateY(-2px);box-shadow:0 18px 44px rgba(9,44,58,.12)}
.v52-action small{font-weight:950;color:var(--v52-teal);text-transform:uppercase;letter-spacing:.06em}
.v52-action strong{font-size:clamp(1.25rem,2vw,1.65rem);line-height:1.08;letter-spacing:-.035em}
.v52-action span{color:#5a7078;line-height:1.42;font-weight:650}
.v52-action.is-emergency{background:linear-gradient(135deg,#b83214,#87310e);color:#fff;border:0}.v52-action.is-emergency small,.v52-action.is-emergency span{color:rgba(255,255,255,.88)}
.v52-support-nav{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.v52-mini{
  display:block;
  text-decoration:none;
  background:#f8fcfb;
  border:1px solid rgba(9,44,58,.11);
  border-radius:22px;
  padding:16px;
  color:var(--v52-ink);
  min-height:118px;
}
.v52-mini strong{display:block;margin-bottom:8px;font-size:1.05rem}.v52-mini span{color:#60747b;line-height:1.38;font-weight:650;font-size:.93rem}

body.masterpiece.v52 #emergenza-adesso{margin-top:clamp(18px,2.8vw,30px)!important}
body.masterpiece.v52 #emergenza-adesso .operational-head{display:grid;gap:6px;margin-bottom:16px!important}
body.masterpiece.v52 #emergenza-adesso .operational-head h2{margin:0!important}
body.masterpiece.v52 #emergenza-adesso .operational-head p{max-width:760px!important}
body.masterpiece.v52 .triage-button strong{font-size:1.12rem!important}
body.masterpiece.v52 .triage-button span:last-child{line-height:1.38!important}
body.masterpiece.v52 .triage-panel{margin-top:14px!important}

/* Mappa: dichiarare che è viva, non incompleta. */
body.masterpiece.v52 #sanmarino .inclusive-map-status{
  background:#effaf7!important;
  border:1px solid rgba(8,118,111,.18)!important;
  color:#244d55!important;
  padding:12px 14px!important;
  border-radius:16px!important;
  font-weight:800!important;
}
body.masterpiece.v52 .meteo-card .meteo-intro::after{
  content:' Servizio informativo di prossimità: non sostituisce gli avvisi ufficiali della Repubblica di San Marino.';
  display:block;
  margin-top:8px;
  color:#6b4b10;
  font-weight:850;
}

body.masterpiece.v52 #master-advanced-gate{
  width:min(100% - 28px,1120px)!important;
  background:linear-gradient(135deg,#082f3f,#0b625b)!important;
}
body.masterpiece.v52.show-advanced #percorso-maestro,
body.masterpiece.v52.show-advanced #nota-pubblica-attivamentesm{display:none!important}

@media(max-width:860px){
  body.masterpiece.v52 .hero-copy{grid-template-columns:1fr!important}
  body.masterpiece.v52 .hero-actions{grid-column:auto!important;grid-row:auto!important}
  .v52-home-actions,.v52-support-nav{grid-template-columns:1fr!important}
}
@media(max-width:560px){
  body.masterpiece.v52 .hero::before{min-height:clamp(250px,72vw,390px)!important;background-position:center center!important}
  .v52-action{min-height:128px;padding:18px}
  body.masterpiece.v52 .primary-nav{display:none!important}
}

/* Safe Ability SM 5.2b - contatti ufficiali e canali chiari */
body.masterpiece.v52 #contatti-ufficiali{
  width:min(100% - 28px,1120px)!important;
  margin:clamp(18px,3vw,38px) auto!important;
  border-radius:30px!important;
  background:#fff!important;
  border:1px solid rgba(9,44,58,.12)!important;
  box-shadow:0 16px 48px rgba(9,44,58,.08)!important;
  padding:clamp(20px,3vw,34px)!important;
  scroll-margin-top:98px;
}
.v52-contact-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:16px}
.v52-contact-card{border:1px solid rgba(9,44,58,.12);background:#f9fcfb;border-radius:24px;padding:18px;box-shadow:0 10px 26px rgba(9,44,58,.05)}
.v52-contact-card.is-emergency{background:linear-gradient(135deg,#b83214,#87310e);color:#fff;border:0}.v52-contact-card.is-emergency .card-label,.v52-contact-card.is-emergency p{color:rgba(255,255,255,.86)!important}
.v52-contact-card h3{margin:.35rem 0 .6rem;color:#082f3f;line-height:1.14}.v52-contact-card.is-emergency h3{color:#fff}
.v52-contact-card p{color:#526b74;line-height:1.45;font-weight:650}.v52-contact-card a{font-weight:950;color:#08766f}.v52-contact-card.is-emergency a{color:#fff}
.v52-call{display:inline-flex;align-items:center;justify-content:center;min-height:52px;border-radius:16px;padding:0 16px;background:#fff;color:#082f3f!important;text-decoration:none;font-size:1.45rem;font-weight:950;box-shadow:0 8px 20px rgba(9,44,58,.08)}
.v52-contact-card.is-emergency .v52-call{color:#b83214!important}.v52-call-row{display:flex;flex-wrap:wrap;gap:8px}.v52-call-row a{display:inline-flex;border-radius:14px;background:#fff;border:1px solid rgba(9,44,58,.12);padding:10px 12px;text-decoration:none}
.v52-contact-note,.v52-warning-line{width:min(100% - 28px,1120px);margin:12px auto 0;border-radius:18px;background:#fff8e6;border:1px solid rgba(247,201,72,.45);color:#5b4210;padding:12px 14px;line-height:1.45;font-weight:750}
.v52-official-contacts .v52-contact-note{width:auto;margin-top:14px}
body.masterpiece.v52 .v52-support-nav{grid-template-columns:repeat(5,minmax(0,1fr))}
@media(max-width:980px){.v52-contact-grid{grid-template-columns:1fr 1fr}body.masterpiece.v52 .v52-support-nav{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.v52-contact-grid{grid-template-columns:1fr}body.masterpiece.v52 .v52-support-nav{grid-template-columns:1fr}.v52-call{width:100%}.v52-call-row{display:grid}.v52-call-row a{justify-content:center}}


/* Safe Ability SM 5.3 - correzione definitiva hero: immagine autonoma, testo separato */
body.masterpiece.v52 .hero.hero-split,
body .hero.hero-split{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:0!important;
  padding:0!important;
  min-height:0!important;
  background:#fff!important;
  background-image:none!important;
  border-radius:0 0 32px 32px!important;
  overflow:hidden!important;
  box-shadow:0 16px 44px rgba(9,44,58,.10)!important;
}
body.masterpiece.v52 .hero.hero-split::before,
body.masterpiece.v52 .hero.hero-split::after,
body .hero.hero-split::before,
body .hero.hero-split::after{
  content:none!important;
  display:none!important;
  background:none!important;
}
.hero-visual{
  display:block!important;
  width:100%!important;
  margin:0!important;
  padding:0!important;
  background:#dfeeea!important;
  line-height:0!important;
}
.hero-visual img{
  display:block!important;
  width:100%!important;
  height:auto!important;
  max-height:min(66vh,680px)!important;
  object-fit:contain!important;
  object-position:center center!important;
  background:#dfeeea!important;
}
body.masterpiece.v52 .hero.hero-split .hero-copy,
body .hero.hero-split .hero-copy{
  width:min(100% - 32px,1120px)!important;
  margin:0 auto!important;
  padding:clamp(20px,3vw,34px) 0 clamp(22px,3vw,34px)!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  color:#082f3f!important;
  display:grid!important;
  grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr)!important;
  gap:clamp(16px,3vw,32px)!important;
  align-items:center!important;
}
body.masterpiece.v52 .hero.hero-split .hero-copy::before,
body .hero.hero-split .hero-copy::before{
  content:'Attiva-Mente · utility civica'!important;
  grid-column:1/-1!important;
  width:max-content!important;
  max-width:100%!important;
  margin:0 0 -6px!important;
  background:#e8f7f4!important;
  color:#08766f!important;
  border:1px solid rgba(8,118,111,.16)!important;
  box-shadow:none!important;
}
body.masterpiece.v52 .hero.hero-split h1,
body .hero.hero-split h1{
  margin:0!important;
  max-width:none!important;
  color:#082f3f!important;
}
body.masterpiece.v52 .hero.hero-split p,
body .hero.hero-split p{
  margin:0!important;
  color:#415d66!important;
}
body.masterpiece.v52 .hero.hero-split .hero-actions,
body .hero.hero-split .hero-actions{
  grid-column:2!important;
  grid-row:2 / span 2!important;
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:10px!important;
  margin:0!important;
  align-self:stretch!important;
}
@media(max-width:860px){
  body.masterpiece.v52 .hero.hero-split .hero-copy,
  body .hero.hero-split .hero-copy{grid-template-columns:1fr!important;width:min(100% - 28px,1120px)!important;}
  body.masterpiece.v52 .hero.hero-split .hero-actions,
  body .hero.hero-split .hero-actions{grid-column:auto!important;grid-row:auto!important;}
  .hero-visual img{max-height:none!important;object-fit:contain!important;}
}


/* Safe Ability SM 5.4 - pulizia logica e sezioni espandibili */
:root{--sa-ink:#102321;--sa-muted:#526461;--sa-border:#dce8e5;--sa-card:#ffffff;--sa-soft:#f3faf8;--sa-accent:#0b625b;--sa-danger:#b42318;}
body.v54-clean .primary-hub,
body.v54-clean .now-board,
body.v54-clean #partenza-rapida,
body.v54-clean #percorso-maestro,
body.v54-clean #nota-pubblica-attivamentesm,
body.v54-clean #v52-support-nav,
body.v54-clean #master-advanced-gate{display:none!important;}
body.v54-clean .hero{margin-bottom:18px!important;}
body.v54-clean .hero-copy p{max-width:760px;font-size:clamp(1rem,2vw,1.18rem);line-height:1.6;}
body.v54-clean .hero-actions{gap:10px;flex-wrap:wrap;}
body.v54-clean .hero-actions a{min-height:48px;display:inline-flex;align-items:center;justify-content:center;}
.v54-flow{max-width:1180px;margin:22px auto 18px;padding:0 18px;}
.v54-flow-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-end;margin-bottom:14px;}
.v54-flow-head h2{margin:0;color:var(--sa-ink);font-size:clamp(1.45rem,3vw,2.15rem);}
.v54-flow-head p{margin:6px 0 0;color:var(--sa-muted);max-width:780px;line-height:1.55;}
.v54-steps{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;counter-reset:step;}
.v54-step{counter-increment:step;text-decoration:none;background:var(--sa-card);border:1px solid var(--sa-border);border-radius:20px;padding:14px;box-shadow:0 12px 32px rgba(16,35,33,.06);color:var(--sa-ink);min-height:116px;display:flex;flex-direction:column;justify-content:space-between;}
.v54-step::before{content:counter(step);width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:#e6f5f2;color:var(--sa-accent);font-weight:800;margin-bottom:12px;}
.v54-step strong{font-size:1rem;line-height:1.2;}
.v54-step span{font-size:.88rem;color:var(--sa-muted);line-height:1.35;margin-top:6px;}
.v54-step.is-emergency{border-color:#ffd0ca;background:#fff7f5;}
.v54-step.is-emergency::before{background:#fee4df;color:var(--sa-danger);}
.v54-essential-grid{max-width:1180px;margin:18px auto 24px;padding:0 18px;display:grid;grid-template-columns:1.2fr 1fr;gap:16px;}
.v54-contact-strip{background:#102321;color:white;border-radius:24px;padding:18px;display:grid;gap:12px;box-shadow:0 18px 42px rgba(0,0,0,.16);}
.v54-contact-strip h2{margin:0;font-size:1.25rem;color:white;}
.v54-contact-strip p{margin:0;color:#d5e5e1;line-height:1.45;}
.v54-call-row{display:flex;gap:10px;flex-wrap:wrap;}
.v54-call-row a{background:white;color:#102321;text-decoration:none;font-weight:800;border-radius:16px;padding:12px 16px;display:inline-flex;align-items:center;gap:6px;}
.v54-warning{background:#fff8e6;border:1px solid #f2d999;color:#4c3b05;border-radius:24px;padding:18px;line-height:1.5;}
.v54-warning strong{display:block;color:#2f2504;margin-bottom:6px;font-size:1.05rem;}
.v54-accordion-wrap{max-width:1180px;margin:28px auto 90px;padding:0 18px;}
.v54-accordion-head{margin-bottom:14px;}
.v54-accordion-head h2{margin:0;color:var(--sa-ink);font-size:clamp(1.35rem,2.5vw,1.9rem);}
.v54-accordion-head p{margin:6px 0 0;color:var(--sa-muted);line-height:1.55;max-width:760px;}
.v54-accordion{display:grid;gap:12px;}
.v54-detail{background:var(--sa-card);border:1px solid var(--sa-border);border-radius:22px;box-shadow:0 12px 30px rgba(16,35,33,.06);overflow:hidden;}
.v54-detail summary{cursor:pointer;list-style:none;padding:18px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;color:var(--sa-ink);font-weight:800;}
.v54-detail summary::-webkit-details-marker{display:none;}
.v54-detail summary::after{content:'+';font-size:1.55rem;color:var(--sa-accent);line-height:1;}
.v54-detail[open] summary::after{content:'-';}
.v54-summary-copy{display:grid;gap:4px;}
.v54-summary-copy span{font-weight:500;color:var(--sa-muted);line-height:1.35;font-size:.95rem;}
.v54-detail-body{border-top:1px solid var(--sa-border);padding:16px;background:#fbfefd;}
.v54-detail-body>.section,
.v54-detail-body>.levelup-section,
.v54-detail-body>.compact-section,
.v54-detail-body>.master-risks,
.v54-detail-body>.heat-protocol,
.v54-detail-body>.personal-hub-section,
.v54-detail-body>.decision-section,
.v54-detail-body>.kit-section,
.v54-detail-body>.data-section,
.v54-detail-body>.protocol-section,
.v54-detail-body>.principle-strip{margin:0 0 14px!important;padding:18px!important;border-radius:18px!important;box-shadow:none!important;}
.v54-detail-body>*:last-child{margin-bottom:0!important;}
body.v54-clean #emergenza-adesso,
body.v54-clean #profilo-completo,
body.v54-clean #sanmarino{max-width:1180px;margin:20px auto!important;}
body.v54-clean #emergenza-adesso{border:2px solid #ffd0ca;}
body.v54-clean #contatti-ufficiali{display:none!important;}
body.v54-clean .sticky-emergency{font-weight:900;letter-spacing:.02em;}
@media (max-width:1050px){.v54-steps{grid-template-columns:repeat(3,minmax(0,1fr));}.v54-essential-grid{grid-template-columns:1fr;}}
@media (max-width:680px){.v54-flow,.v54-essential-grid,.v54-accordion-wrap{padding:0 12px;}.v54-steps{grid-template-columns:1fr 1fr;}.v54-step{min-height:104px;padding:12px;border-radius:16px}.v54-step span{font-size:.82rem}.v54-detail summary{padding:15px 16px}.v54-detail-body{padding:10px}.v54-call-row a{width:100%;justify-content:center}.hero-actions a{width:100%;}.topbar .primary-nav{display:none!important;}}
@media (max-width:420px){.v54-steps{grid-template-columns:1fr;}}


/* Safe Ability SM 5.5 - pulizia home: niente pulsanti sopra/sotto la hero, meno scroll iniziale */
body.v55-lean .hero.hero-split{
  margin-bottom:18px!important;
}
body.v55-lean .hero.hero-split .hero-actions{
  display:none!important;
}
body.v55-lean .hero.hero-split .hero-copy{
  display:block!important;
  width:min(100% - 32px,980px)!important;
  padding:clamp(18px,2.6vw,28px) 0!important;
}
body.v55-lean .hero.hero-split .hero-copy::before{
  margin-bottom:10px!important;
}
body.v55-lean .hero.hero-split h1{
  margin-bottom:8px!important;
}
body.v55-lean .hero.hero-split p{
  max-width:820px!important;
  font-size:clamp(.98rem,1.7vw,1.12rem)!important;
  line-height:1.55!important;
}
body.v55-lean #v54-flow{
  display:none!important;
}
body.v55-lean .v54-essential-grid{
  margin-top:0!important;
  margin-bottom:18px!important;
}
body.v55-lean .v55-index{
  max-width:1180px;
  margin:18px auto;
  padding:0 18px;
}
body.v55-lean .v55-index-card{
  border:1px solid rgba(9,44,58,.10);
  border-radius:22px;
  background:#fff;
  box-shadow:0 14px 34px rgba(9,44,58,.07);
  padding:18px;
}
body.v55-lean .v55-index-card h2{
  margin:0 0 8px;
  color:#083746;
  font-size:clamp(1.25rem,2.4vw,1.65rem);
}
body.v55-lean .v55-index-card p{
  margin:0 0 14px;
  color:#48636b;
  line-height:1.55;
}
body.v55-lean .v55-index-links{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
body.v55-lean .v55-index-links a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:9px 14px;
  border-radius:999px;
  background:#eef8f6;
  color:#075e58;
  text-decoration:none;
  font-weight:900;
  border:1px solid rgba(8,118,111,.13);
}
body.v55-lean .v54-accordion-head p{
  max-width:760px;
}
@media(max-width:700px){
  body.v55-lean .hero.hero-split .hero-copy,
  body.v55-lean .v55-index{width:auto;padding-left:12px!important;padding-right:12px!important;}
  body.v55-lean .v55-index-links a{width:100%;}
}


/* Safe Ability SM 5.6 - niente blocco Eventi e servizi */
body.v56-no-events #eventi-accessibili,
body.v56-no-events #protocollo{
  display:none!important;
}
body.v56-no-events .v54-accordion{
  gap:12px!important;
}
body.v56-no-events .v54-accordion-head h2{
  margin-bottom:6px!important;
}


/* Safe Ability SM 5.8 - rimozione blocchi superflui dalla superficie */
.level2-strip,
.easy-toggle,
.sticky-emergency {
  display: none !important;
  visibility: hidden !important;
}

/* Safe Ability SM 5.9 - fix leggibilità scheda Emergenza adesso su mobile */
#triagePanel.triage-panel,
#triagePanel.triage-panel.is-active {
  background: #ffffff !important;
  color: #082f3f !important;
  border: 1px solid rgba(8,47,63,.14) !important;
  box-shadow: 0 16px 42px rgba(8,47,63,.08) !important;
}
#triagePanel.triage-panel h3,
#triagePanel.triage-panel li,
#triagePanel.triage-panel p,
#triagePanel.triage-panel strong,
#triagePanel.triage-panel label {
  color: #082f3f !important;
}
#triagePanel.triage-panel .panel-box {
  background: #f8fbfa !important;
  border: 1px solid rgba(8,47,63,.12) !important;
  color: #082f3f !important;
}
#triagePanel.triage-panel textarea {
  background: #ffffff !important;
  color: #082f3f !important;
  border: 1px solid rgba(8,47,63,.16) !important;
  box-shadow: inset 0 1px 0 rgba(8,47,63,.04) !important;
}
@media (max-width: 760px) {
  #triagePanel.triage-panel.is-active {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    padding: 16px !important;
    margin-top: 12px !important;
    border-radius: 22px !important;
  }
  #triagePanel.triage-panel h3 {
    font-size: 1.35rem !important;
    line-height: 1.18 !important;
  }
  #triagePanel.triage-panel ol {
    padding-left: 1.1rem !important;
    gap: 7px !important;
  }
  #triagePanel.triage-panel .inline-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }
  #triagePanel.triage-panel .inline-actions button {
    width: 100% !important;
    min-height: 54px !important;
    font-size: 1rem !important;
  }
  #triagePanel.triage-panel textarea {
    min-height: 210px !important;
    font-size: .98rem !important;
  }
}

/* 5.10 - campi più puliti: niente suggerimenti visivi nei form */
.role-hint[hidden], .field-hint, .form-hint { display: none !important; }
input::placeholder, textarea::placeholder { color: transparent !important; }


/* Safe Ability SM 5.11 - command center finale */
body.v511-top {
  --v511-bg: #f4faf7;
  --v511-ink: #062f3d;
  --v511-muted: #53686f;
  --v511-line: rgba(6, 47, 61, 0.14);
  --v511-surface: #ffffff;
  --v511-teal: #08766f;
  --v511-teal-dark: #053f4f;
  --v511-coral: #d93f2f;
  --v511-yellow: #f4c430;
  --v511-blue: #256c9f;
  background:
    linear-gradient(180deg, #f8fcfa 0, #eef8f4 540px, #f8fbfa 100%);
  color: var(--v511-ink);
}

body.v511-top .topbar {
  border-bottom: 1px solid var(--v511-line);
  background: rgba(248, 252, 250, 0.94);
}

body.v511-top .brand-logo {
  display: block;
  width: 42px;
  height: 42px;
}

body.v511-top .primary-nav a,
body.v511-top .pwa-tabbar a {
  border-radius: 8px;
}

body.v511-top .hero.hero-split {
  width: min(1180px, calc(100% - 32px)) !important;
  margin: 18px auto 0 !important;
  padding: 0 !important;
  border: 1px solid var(--v511-line) !important;
  border-radius: 8px !important;
  background: var(--v511-surface) !important;
  box-shadow: 0 16px 44px rgba(6, 47, 61, 0.08) !important;
  overflow: hidden !important;
}

body.v511-top .hero-visual img {
  width: 100% !important;
  min-height: 390px !important;
  max-height: 460px !important;
  aspect-ratio: 16 / 4.3 !important;
  object-fit: cover !important;
  object-position: 42% 54% !important;
  background: #dcebe6 !important;
}

body.v511-top .hero.hero-split .hero-copy {
  width: min(100% - 32px, 1120px) !important;
  margin: 0 auto !important;
  padding: 20px 0 22px !important;
  display: grid !important;
  grid-template-columns: minmax(360px, 0.95fr) minmax(320px, 1.05fr) !important;
  gap: clamp(22px, 4vw, 54px) !important;
  align-items: center !important;
}

body.v511-top .hero.hero-split .hero-copy::before {
  content: none !important;
  display: none !important;
}

body.v511-top .hero h1 {
  color: var(--v511-ink) !important;
  max-width: 720px !important;
  font-size: clamp(2.45rem, 3.35vw, 3.45rem) !important;
  line-height: 1.02 !important;
  letter-spacing: 0 !important;
  text-wrap: balance;
}

body.v511-top .hero p {
  max-width: 760px !important;
  margin: 0 !important;
  color: var(--v511-muted) !important;
  font-size: clamp(1rem, 1.35vw, 1.17rem) !important;
  line-height: 1.55 !important;
}

body.v511-top .hero-actions,
body.v511-top .v52-home-actions,
body.v511-top .v52-support-nav,
body.v511-top .v54-essential-grid,
body.v511-top .v55-index {
  display: none !important;
}

.v511-command {
  width: min(1180px, calc(100% - 32px));
  margin: 14px auto 22px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(290px, 340px);
  gap: 14px;
}

.v511-panel,
.v511-status-card,
.v511-action,
.v511-brief {
  border: 1px solid var(--v511-line);
  border-radius: 8px;
  background: var(--v511-surface);
  box-shadow: 0 12px 30px rgba(6, 47, 61, 0.07);
}

.v511-panel {
  min-width: 0;
  padding: clamp(18px, 2.4vw, 28px);
  display: grid;
  gap: 18px;
}

.v511-panel-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: start;
}

.v511-panel h2,
.v511-status-card h3,
.v511-action strong,
.v511-brief h3 {
  margin: 0;
  color: var(--v511-ink);
}

.v511-panel h2 {
  font-size: clamp(1.65rem, 2.8vw, 2.65rem);
  line-height: 1.02;
}

.v511-panel p,
.v511-status-card p,
.v511-action span,
.v511-brief p,
.v511-status-line span {
  margin: 0;
  color: var(--v511-muted);
  line-height: 1.45;
}

.v511-segmented {
  display: inline-grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  min-width: min(360px, 100%);
  padding: 4px;
  border: 1px solid var(--v511-line);
  border-radius: 8px;
  background: #edf7f3;
}

.v511-segmented button {
  min-height: 42px;
  border: 0;
  border-radius: 6px;
  background: transparent;
  color: var(--v511-teal-dark);
  font: inherit;
  font-size: 0.92rem;
  font-weight: 900;
  cursor: pointer;
}

.v511-segmented button[aria-selected="true"] {
  background: var(--v511-teal);
  color: #fff;
}

.v511-action-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.v511-action {
  position: relative;
  min-height: 148px;
  padding: 16px;
  display: grid;
  align-content: space-between;
  gap: 10px;
  text-decoration: none;
  color: inherit;
}

.v511-action:hover,
.v511-action:focus-visible {
  border-color: rgba(8, 118, 111, 0.34);
  outline: 3px solid rgba(8, 118, 111, 0.16);
  outline-offset: 2px;
}

.v511-action-icon {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #eaf7f4;
  color: var(--v511-teal);
  font-size: 1.2rem;
  font-weight: 950;
}

.v511-action.is-sos {
  background: linear-gradient(135deg, #a72b20, #d94331);
  border-color: transparent;
  color: #fff;
}

.v511-action.is-sos strong,
.v511-action.is-sos span {
  color: #fff;
}

.v511-action.is-sos .v511-action-icon {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

.v511-brief {
  padding: 16px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  background: #f8fcfb;
}

.v511-brief h3 {
  font-size: 1.08rem;
}

.v511-brief button,
.v511-copy-link {
  min-height: 42px;
  border: 1px solid var(--v511-line);
  border-radius: 8px;
  padding: 9px 13px;
  background: #fff;
  color: var(--v511-teal-dark);
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}

.v511-status {
  display: grid;
  gap: 10px;
}

.v511-status-card {
  padding: 16px;
  display: grid;
  gap: 12px;
}

.v511-score {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 14px;
  align-items: center;
}

.v511-score strong {
  width: 74px;
  height: 74px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--v511-yellow);
  color: #173237;
  font-size: 1.45rem;
  line-height: 1;
}

.v511-meter {
  height: 10px;
  overflow: hidden;
  border-radius: 999px;
  background: #e1ece8;
}

.v511-meter span {
  display: block;
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--v511-coral), var(--v511-yellow), var(--v511-teal));
  transition: width 0.25s ease;
}

.v511-status-line {
  display: grid;
  grid-template-columns: 16px minmax(0, 1fr);
  gap: 8px;
  align-items: start;
}

.v511-dot {
  width: 12px;
  height: 12px;
  margin-top: 0.35em;
  border-radius: 50%;
  background: var(--v511-teal);
}

.v511-dot.warn { background: var(--v511-yellow); }
.v511-dot.danger { background: var(--v511-coral); }
.v511-dot.info { background: var(--v511-blue); }

.v511-official {
  background: var(--v511-ink);
  color: #fff;
}

.v511-official h3,
.v511-official p,
.v511-official a {
  color: #fff;
}

.v511-number-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}

.v511-number-row a {
  min-height: 48px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.1);
  text-decoration: none;
  font-weight: 950;
}

.v511-map-fallback {
  height: 100%;
  min-height: inherit;
  padding: 18px;
  display: grid;
  align-content: center;
  gap: 14px;
  background:
    linear-gradient(135deg, rgba(8, 118, 111, 0.12), rgba(244, 196, 48, 0.14)),
    #f8fcfb;
}

.v511-map-fallback h3 {
  margin: 0;
  color: var(--v511-ink);
}

.v511-map-fallback ul {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.v511-map-fallback li {
  padding: 10px;
  border: 1px solid var(--v511-line);
  border-radius: 8px;
  background: #fff;
  color: var(--v511-muted);
  line-height: 1.35;
}

body.v511-top .section,
body.v511-top #emergenza-adesso,
body.v511-top #profilo-completo,
body.v511-top #sanmarino,
body.v511-top #contatti-ufficiali,
body.v511-top .compact-section {
  scroll-margin-top: 92px;
}

body.v511-top input:focus-visible,
body.v511-top select:focus-visible,
body.v511-top textarea:focus-visible,
body.v511-top button:focus-visible,
body.v511-top a:focus-visible {
  outline: 3px solid rgba(8, 118, 111, 0.24);
  outline-offset: 3px;
}

@media (max-width: 980px) {
  body.v511-top .hero.hero-split .hero-copy,
  .v511-panel-head,
  .v511-command,
  .v511-brief {
    grid-template-columns: 1fr !important;
  }

  .v511-action-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .v511-panel-head {
    gap: 12px;
  }
}

@media (max-width: 620px) {
  body.v511-top .hero.hero-split {
    width: auto !important;
    margin: 10px 12px 0 !important;
  }

  body.v511-top .hero-visual img {
    min-height: 260px !important;
    max-height: 320px !important;
    aspect-ratio: 4 / 2.9 !important;
    object-position: 34% 55% !important;
  }

  body.v511-top .hero h1 {
    font-size: 2.22rem !important;
    line-height: 1.03 !important;
  }

  .v511-command {
    width: auto;
    margin: 12px 12px 20px;
  }

  .v511-action-grid,
  .v511-map-fallback ul {
    grid-template-columns: 1fr;
  }

  .v511-action {
    min-height: 112px;
  }

  .v511-segmented {
    width: 100%;
  }

  .v511-number-row {
    grid-template-columns: 1fr;
  }
}

/* v511 hero title final fit: override older high-specificity hero rules */
@media (min-width: 621px) {
  body.masterpiece.v52.v511-top .hero.hero-split .hero-copy h1,
  body.v511-top .hero.hero-split .hero-copy h1 {
    max-width: none !important;
    font-size: clamp(2.5rem, 2.8vw, 3.15rem) !important;
    line-height: 1.02 !important;
    white-space: nowrap !important;
    text-wrap: normal;
  }
}

/* Safe Ability SM 5.12 - PWA and mobile QA polish */
body.v512-polish {
  --v512-ok: #0b7a65;
  --v512-warn: #8a5a00;
  --v512-off: #b7352b;
}

.v512-status-chip {
  min-height: 38px;
  display: inline-flex;
  padding: 0 12px;
  border: 1px solid rgba(6, 47, 61, 0.14);
  border-radius: 8px;
  background: #fff;
  color: #063340;
  font-size: 0.82rem;
  font-weight: 900;
  line-height: 1.15;
  max-width: 100%;
  white-space: normal;
  text-align: center;
  overflow-wrap: anywhere;
}

.v512-status-chip::before {
  content: "";
  width: 0.62em;
  height: 0.62em;
  margin-right: 0.45em;
  display: inline-block;
  border-radius: 50%;
  background: var(--v512-warn);
  vertical-align: 0.04em;
}

.v512-status-chip[data-state="ok"]::before { background: var(--v512-ok); }
.v512-status-chip[data-state="off"]::before,
.v512-status-chip[data-state="offline"]::before { background: var(--v512-off); }

.v512-update-banner {
  width: min(1180px, calc(100% - 32px));
  margin: 10px auto 0;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid rgba(8, 118, 111, 0.22);
  border-radius: 8px;
  background: #e9f8f2;
  color: #053f4f;
  box-shadow: 0 10px 24px rgba(6, 47, 61, 0.08);
  font-weight: 900;
}

.v512-update-banner button {
  min-height: 38px;
  border: 0;
  border-radius: 8px;
  padding: 8px 12px;
  background: #08766f;
  color: #fff;
  font: inherit;
  font-weight: 950;
  cursor: pointer;
}

body.v512-polish .primary-nav a[aria-current="page"],
body.v512-polish .pwa-tabbar a[aria-current="page"] {
  background: #e8f6f2;
  color: #053f4f;
}

body.v512-polish .inclusive-map-tools input,
body.v512-polish .inclusive-map-tools select,
body.v512-polish .plan-fields input,
body.v512-polish textarea {
  scroll-margin-top: 104px;
}

body.v512-polish input::placeholder,
body.v512-polish textarea::placeholder {
  color: #6f8086 !important;
  opacity: 1;
}

body.v512-polish .tool-result {
  overflow-wrap: anywhere;
}

body.v512-polish .v511-action,
body.v512-polish .v511-status-card,
body.v512-polish .hub-card,
body.v512-polish .resource-card,
body.v512-polish .emergency-card {
  overflow-wrap: anywhere;
}

@media (prefers-reduced-motion: reduce) {
  body.v512-polish *,
  body.v512-polish *::before,
  body.v512-polish *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }
}

@media (max-width: 860px) {
  .v512-status-chip {
    order: 2;
    width: 100%;
    min-height: 34px;
  }

  body.v512-polish .topbar {
    align-items: start;
  }
}

@media (max-width: 620px) {
  .v512-update-banner {
    width: auto;
    margin: 8px 12px 0;
    align-items: stretch;
    flex-direction: column;
  }

  .v512-update-banner button {
    width: 100%;
  }

  body.v512-polish .v511-panel,
  body.v512-polish .v511-status-card {
    padding: 14px;
  }

  body.v512-polish .v511-panel h2 {
    font-size: 1.78rem;
  }

  body.v512-polish .v511-segmented {
    grid-template-columns: 1fr;
  }

  body.v512-polish .v511-segmented button {
    min-height: 40px;
  }

  body.v512-polish .pwa-tabbar {
    padding-bottom: max(8px, env(safe-area-inset-bottom));
  }
}
button[data-reading="1"],
.secondary-action[data-reading="1"]{
  border-color:rgba(183,53,43,.42) !important;
  background:#fff1ea !important;
  color:#842515 !important;
}


/* Safe Ability SM 5.13 - remove hidden-tab friction on mobile */
body.v513-mobile-focus .v511-segmented,
body.v513-mobile-focus .v511-brief {
  display: none !important;
}

body.v513-mobile-focus .v511-panel-head {
  grid-template-columns: 1fr !important;
}

body.v513-mobile-focus .v511-command {
  grid-template-columns: 1fr !important;
}

body.v513-mobile-focus .v511-status {
  display: none !important;
}

body.v513-mobile-focus .v511-panel-head p {
  max-width: 760px;
}

.v513-cue {
  width: fit-content;
  min-height: 30px;
  display: inline-grid;
  place-items: center;
  margin-bottom: 10px;
  padding: 5px 9px;
  border-radius: 8px;
  background: #f4c430;
  color: #173237;
  font-size: 0.78rem;
  font-weight: 950;
  text-transform: uppercase;
}

.v513-reveal {
  animation: v513-focus-pulse 1.15s ease-out 1;
}

body.v513-mobile-focus .triage-button.is-selected {
  border-color: rgba(8, 118, 111, 0.62) !important;
  box-shadow: 0 0 0 4px rgba(8, 118, 111, 0.15), 0 18px 42px rgba(8, 46, 61, 0.14) !important;
}

body.v513-mobile-focus .triage-button.is-selected::after {
  content: "Scheda aperta sotto";
  width: fit-content;
  display: block;
  margin-top: 12px;
  padding: 6px 9px;
  border-radius: 8px;
  background: #eaf7f4;
  color: #053f4f;
  font-size: 0.82rem;
  font-weight: 950;
}

body.v513-mobile-focus .triage-panel:focus {
  outline: 0;
}

@keyframes v513-focus-pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(244, 196, 48, 0.86), 0 18px 46px rgba(6, 47, 63, 0.2);
  }
  45% {
    box-shadow: 0 0 0 7px rgba(244, 196, 48, 0.34), 0 18px 46px rgba(6, 47, 63, 0.2);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(244, 196, 48, 0), 0 18px 46px rgba(6, 47, 63, 0.2);
  }
}

@media (max-width: 760px) {
  body.v513-mobile-focus .v511-panel {
    gap: 14px;
  }

  body.v513-mobile-focus .v511-action-grid {
    grid-template-columns: 1fr !important;
  }

  body.v513-mobile-focus .v511-action {
    min-height: 104px;
    grid-template-columns: 46px minmax(0, 1fr);
    align-items: center;
    align-content: center;
    gap: 10px 12px;
  }

  body.v513-mobile-focus .v511-action strong,
  body.v513-mobile-focus .v511-action span:not(.v511-action-icon) {
    grid-column: 2;
  }

  body.v513-mobile-focus .v511-action-icon {
    grid-row: 1 / span 2;
  }

  body.v513-mobile-focus .triage-grid {
    grid-template-columns: 1fr !important;
  }

  body.v513-mobile-focus #triagePanel {
    grid-column: 1 / -1;
    margin: 2px 0 14px;
    border-radius: 18px;
  }

  body.v513-mobile-focus .triage-panel.is-active {
    grid-template-columns: 1fr !important;
  }

  body.v513-mobile-focus .triage-panel textarea {
    min-height: 210px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .v513-reveal {
    animation: none !important;
  }
}


/* Safe Ability SM 5.14 - non-verbal SOS */
.v514-silent-sos {
  padding: clamp(16px, 2.4vw, 22px);
  border: 1px solid rgba(6, 47, 61, 0.14);
  border-radius: 8px;
  background: #ffffff;
  box-shadow: 0 12px 30px rgba(6, 47, 61, 0.07);
  display: grid;
  gap: 14px;
}

.v514-silent-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.v514-silent-head h3,
.v514-output h4 {
  margin: 0;
  color: #062f3d;
}

.v514-silent-head h3 {
  font-size: clamp(1.45rem, 2.4vw, 2.1rem);
  line-height: 1.05;
}

.v514-silent-head p,
.v514-practice-row p,
.v514-output p {
  margin: 0;
  color: #53686f;
  line-height: 1.45;
}

.v514-pill,
.v514-output-label {
  min-height: 32px;
  display: inline-grid;
  place-items: center;
  width: fit-content;
  border-radius: 8px;
  padding: 5px 9px;
  background: #a72b20;
  color: #ffffff;
  font-size: 0.78rem;
  font-weight: 950;
  text-transform: uppercase;
}

.v514-practice-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px;
  border-radius: 8px;
  background: #f4faf7;
  border: 1px solid rgba(6, 47, 61, 0.12);
}

.v514-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 950;
  color: #053f4f;
}

.v514-toggle input {
  width: 22px;
  height: 22px;
  accent-color: #08766f;
}

.v514-silent-sos.is-practice {
  border-color: rgba(244, 196, 48, 0.65);
  background: linear-gradient(180deg, #fffdf2, #ffffff);
}

.v514-scenario-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.v514-scenario {
  min-height: 92px;
  border: 1px solid rgba(6, 47, 61, 0.14);
  border-radius: 8px;
  padding: 12px;
  background: #ffffff;
  color: #062f3d;
  font: inherit;
  text-align: left;
  cursor: pointer;
  display: grid;
  gap: 8px;
}

.v514-scenario span {
  min-height: 30px;
  width: fit-content;
  display: inline-grid;
  place-items: center;
  border-radius: 8px;
  padding: 4px 8px;
  background: #eaf7f4;
  color: #08766f;
  font-weight: 950;
  font-size: 0.82rem;
}

.v514-scenario strong {
  font-size: 1rem;
  line-height: 1.15;
}

.v514-scenario:hover,
.v514-scenario:focus-visible {
  outline: 3px solid rgba(8, 118, 111, 0.18);
  outline-offset: 2px;
  border-color: rgba(8, 118, 111, 0.38);
}

.v514-scenario.is-selected {
  background: #08766f;
  border-color: #08766f;
  color: #ffffff;
}

.v514-scenario.is-selected span {
  background: rgba(255, 255, 255, 0.16);
  color: #ffffff;
}

.v514-output {
  padding: 14px;
  border-radius: 8px;
  border: 1px solid rgba(6, 47, 61, 0.14);
  background: #f8fcfb;
  display: grid;
  gap: 12px;
}

.v514-output:focus {
  outline: 0;
}

.v514-output textarea {
  width: 100%;
  min-height: 220px;
  border: 1px solid rgba(6, 47, 61, 0.16);
  border-radius: 8px;
  padding: 12px;
  color: #062f3d;
  background: #ffffff;
  font: inherit;
  line-height: 1.45;
}

.v514-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.v514-reveal {
  animation: v514-reveal 1.15s ease-out 1;
}

.risk-level.medio-alto {
  background: linear-gradient(135deg, #d97706, #d8372a) !important;
}

@keyframes v514-reveal {
  0% {
    box-shadow: 0 0 0 0 rgba(244, 196, 48, 0.88);
  }
  48% {
    box-shadow: 0 0 0 8px rgba(244, 196, 48, 0.32);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(244, 196, 48, 0);
  }
}

@media (max-width: 760px) {
  .v514-silent-sos {
    padding: 14px;
  }

  .v514-silent-head,
  .v514-practice-row {
    grid-template-columns: 1fr;
    display: grid;
  }

  .v514-scenario-grid {
    grid-template-columns: 1fr;
  }

  .v514-scenario {
    min-height: 76px;
    grid-template-columns: 78px minmax(0, 1fr);
    align-items: center;
  }

  .v514-scenario span {
    width: 66px;
  }

  .v514-output textarea {
    min-height: 260px;
  }

  .v514-actions > * {
    width: 100%;
    justify-content: center;
  }
}

@media (prefers-reduced-motion: reduce) {
  .v514-reveal {
    animation: none !important;
  }
}


/* Safe Ability SM 5.15 - entrance page and purpose guardrail */
body.v515-entry-active {
  min-height: 100vh;
  background: #f6faf7;
}

body.v515-entry-active .skip-link,
body.v515-entry-active .app-shell,
body.v515-entry-active .pwa-tabbar {
  display: none !important;
}

.v515-entry {
  min-height: 100vh;
  color: #062f3f;
  background:
    linear-gradient(90deg, rgba(246, 250, 247, 0.98) 0%, rgba(246, 250, 247, 0.94) 46%, rgba(246, 250, 247, 0.72) 100%),
    #f6faf7;
}

.v515-entry[hidden] {
  display: none !important;
}

.v515-entry-shell {
  width: min(1180px, calc(100% - 32px));
  min-height: 100vh;
  margin: 0 auto;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 24px;
  padding: 24px 0 28px;
}

.v515-entry-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 56px;
}

.v515-entry-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: #062f3f;
  text-decoration: none;
}

.v515-entry-brand img {
  width: 54px;
  height: 54px;
  border-radius: 8px;
  background: #fff;
  object-fit: contain;
  box-shadow: 0 10px 28px rgba(5, 49, 56, 0.08);
}

.v515-entry-brand strong,
.v515-entry-brand span {
  display: block;
}

.v515-entry-brand strong {
  font-size: 1.12rem;
  line-height: 1.05;
}

.v515-entry-brand span {
  margin-top: 3px;
  color: #466368;
  font-size: 0.9rem;
  font-weight: 800;
}

.v515-entry-main {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(420px, 1.08fr);
  gap: clamp(24px, 4vw, 54px);
  align-items: center;
}

.v515-entry-copy {
  min-width: 0;
}

.v515-entry-copy h1 {
  margin: 0;
  max-width: 690px;
  color: #052f3e;
  font-size: clamp(2.35rem, 5.8vw, 5.45rem);
  line-height: 0.95;
  letter-spacing: 0;
}

.v515-entry-lead {
  margin: 24px 0 0;
  max-width: 680px;
  color: #35575e;
  font-size: clamp(1.08rem, 1.5vw, 1.36rem);
  line-height: 1.52;
}

.v515-entry-alert {
  margin: 24px 0 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  max-width: 680px;
  padding: 16px;
  border: 1px solid rgba(193, 57, 34, 0.24);
  border-left: 6px solid #c13922;
  border-radius: 8px;
  background: #fff7f3;
  color: #6d2016;
  box-shadow: 0 16px 34px rgba(77, 30, 18, 0.08);
}

.v515-entry-alert strong {
  color: #802515;
}

.v515-entry-alert p {
  margin: 4px 0 0;
  color: #6d453c;
  line-height: 1.45;
}

.v515-alert-mark {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #c13922;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 950;
}

.v515-entry-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

.v515-entry-button,
.v515-entry-link,
.v515-reopen {
  min-height: 48px;
  border-radius: 8px;
  font: inherit;
  font-weight: 950;
  cursor: pointer;
}

.v515-entry-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 13px 20px;
  border: 1px solid #08766f;
  background: #08766f;
  color: #fff;
  text-decoration: none;
  box-shadow: 0 14px 30px rgba(8, 118, 111, 0.22);
}

.v515-entry-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 13px 18px;
  border: 1px solid #bed8d1;
  background: #fff;
  color: #063f3b;
  text-decoration: none;
}

.v515-entry-button:hover,
.v515-entry-button:focus-visible,
.v515-entry-link:hover,
.v515-entry-link:focus-visible,
.v515-reopen:hover,
.v515-reopen:focus-visible {
  outline: 3px solid rgba(8, 118, 111, 0.22);
  outline-offset: 3px;
}

.v515-entry-media {
  position: relative;
  min-width: 0;
  margin: 0;
  border-radius: 8px;
  overflow: hidden;
  background: #dfece9;
  box-shadow: 0 28px 70px rgba(5, 47, 62, 0.16);
}

.v515-entry-media img {
  display: block;
  width: 100%;
  min-height: clamp(460px, 62vh, 680px);
  object-fit: cover;
  object-position: center;
}

.v515-image-note {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  display: grid;
  gap: 7px;
  max-width: 520px;
  padding: 14px 16px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.92);
  color: #062f3f;
  box-shadow: 0 16px 34px rgba(5, 47, 62, 0.16);
  backdrop-filter: blur(10px);
}

.v515-image-note strong {
  font-size: 1.02rem;
}

.v515-image-note span {
  color: #466368;
  line-height: 1.38;
}

.v515-entry-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.v515-entry-card {
  min-height: 142px;
  display: grid;
  gap: 8px;
  align-content: start;
  padding: 18px;
  border: 1px solid #d7e5df;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(5, 47, 62, 0.06);
}

.v515-entry-card h2 {
  margin: 0;
  color: #052f3e;
  font-size: 1.12rem;
  line-height: 1.15;
}

.v515-entry-card p {
  margin: 0;
  color: #466368;
  line-height: 1.42;
}

.v515-entry-card.is-limit {
  border-color: rgba(193, 57, 34, 0.2);
  background: #fff9f5;
}

.v515-entry-criteria {
  display: grid;
  grid-template-columns: 0.72fr 1.28fr;
  gap: 18px;
  align-items: start;
  padding: 20px;
  border: 1px solid #d7e5df;
  border-radius: 8px;
  background: #ffffff;
}

.v515-entry-criteria h2 {
  margin: 0;
  color: #052f3e;
  font-size: clamp(1.45rem, 2.4vw, 2.15rem);
  line-height: 1.05;
}

.v515-entry-criteria ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.v515-entry-criteria li {
  position: relative;
  padding-left: 24px;
  color: #35575e;
  line-height: 1.45;
}

.v515-entry-criteria li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.58em;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #08766f;
}

.v515-entry-source {
  margin-top: 16px;
  color: #5f7477;
  font-size: 0.92rem;
  line-height: 1.45;
}

.v515-entry-source a {
  color: #075f59;
  font-weight: 900;
}

.v515-reopen {
  min-height: 40px;
  padding: 9px 12px;
  border: 1px solid #d7e5df;
  background: #fff;
  color: #063f3b;
}

@media (max-width: 980px) {
  .v515-entry-main {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .v515-entry-media {
    order: -1;
  }

  .v515-entry-media img {
    min-height: 360px;
    max-height: 480px;
  }

  .v515-entry-cards,
  .v515-entry-criteria {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .v515-entry-shell {
    width: min(100% - 24px, 540px);
    gap: 18px;
    padding: 16px 0 22px;
  }

  .v515-entry-top {
    align-items: flex-start;
  }

  .v515-entry-brand img {
    width: 46px;
    height: 46px;
  }

  .v515-entry-media img {
    min-height: 310px;
    max-height: 360px;
  }

  .v515-image-note {
    position: static;
    max-width: none;
    border-radius: 0;
    box-shadow: none;
    background: #fff;
  }

  .v515-entry-copy h1 {
    font-size: clamp(2.1rem, 12vw, 3.2rem);
  }

  .v515-entry-alert {
    grid-template-columns: 1fr;
  }

  .v515-entry-actions,
  .v515-entry-actions > * {
    width: 100%;
  }
}


/* Safe Ability SM 5.16 - autonomous project homepage */
body.v516-home-ready.v515-entry-active {
  background: #f7faf8;
}

body.v516-home-ready .v515-entry {
  background: #f7faf8;
}

body.v516-home-ready .v515-entry-shell {
  width: min(1240px, calc(100% - 32px));
  gap: 26px;
}

.v516-home {
  display: grid;
  gap: 26px;
}

.v516-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  min-height: 58px;
}

.v516-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  color: #052f3e;
  text-decoration: none;
}

.v516-brand img {
  width: 54px;
  height: 54px;
  border-radius: 8px;
  background: #fff;
  object-fit: contain;
  box-shadow: 0 10px 26px rgba(5, 47, 62, 0.08);
}

.v516-brand strong,
.v516-brand span {
  display: block;
}

.v516-brand strong {
  font-size: 1.14rem;
  line-height: 1.05;
}

.v516-brand span {
  margin-top: 3px;
  color: #4b6469;
  font-size: 0.9rem;
  font-weight: 800;
}

.v516-top-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.v516-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(460px, 1.12fr);
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
}

.v516-hero-copy h1 {
  margin: 0;
  color: #052f3e;
  font-size: clamp(2.5rem, 5.6vw, 5.35rem);
  line-height: 0.95;
  letter-spacing: 0;
}

.v516-lead {
  margin: 24px 0 0;
  max-width: 680px;
  color: #375a61;
  font-size: clamp(1.08rem, 1.45vw, 1.35rem);
  line-height: 1.52;
}

.v516-alert {
  margin-top: 22px;
  max-width: 720px;
  padding: 16px 18px;
  border: 1px solid rgba(193, 57, 34, 0.22);
  border-left: 6px solid #c13922;
  border-radius: 8px;
  background: #fff8f3;
  color: #6d2016;
  line-height: 1.45;
  box-shadow: 0 16px 36px rgba(75, 34, 20, 0.08);
}

.v516-alert strong {
  color: #842515;
}

.v516-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

.v516-primary,
.v516-secondary,
.v516-112 {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  padding: 13px 18px;
  border: 1px solid transparent;
  font: inherit;
  font-weight: 950;
  text-decoration: none;
  cursor: pointer;
}

.v516-primary {
  background: #08766f;
  border-color: #08766f;
  color: #fff;
  box-shadow: 0 14px 30px rgba(8, 118, 111, 0.22);
}

.v516-secondary {
  background: #fff;
  border-color: #bed8d1;
  color: #063f3b;
}

.v516-112 {
  background: #fff1ea;
  border-color: rgba(193, 57, 34, 0.24);
  color: #842515;
}

.v516-primary:hover,
.v516-primary:focus-visible,
.v516-secondary:hover,
.v516-secondary:focus-visible,
.v516-112:hover,
.v516-112:focus-visible {
  outline: 3px solid rgba(8, 118, 111, 0.22);
  outline-offset: 3px;
}

.v516-media {
  position: relative;
  min-width: 0;
  margin: 0;
  border-radius: 8px;
  overflow: hidden;
  background: #dce9e7;
  box-shadow: 0 28px 72px rgba(5, 47, 62, 0.16);
}

.v516-media img {
  display: block;
  width: 100%;
  min-height: clamp(430px, 58vh, 640px);
  object-fit: cover;
  object-position: center;
}

.v516-media-caption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  max-width: 560px;
  display: grid;
  gap: 7px;
  padding: 14px 16px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  color: #052f3e;
  box-shadow: 0 16px 34px rgba(5, 47, 62, 0.16);
  backdrop-filter: blur(10px);
}

.v516-media-caption strong {
  font-size: 1.03rem;
}

.v516-media-caption span {
  color: #466368;
  line-height: 1.38;
}

.v516-band {
  display: grid;
  gap: 16px;
  padding: clamp(20px, 3vw, 28px);
  border: 1px solid #d7e5df;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(5, 47, 62, 0.06);
}

.v516-band-head {
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) minmax(0, 1.28fr);
  gap: 18px;
  align-items: start;
}

.v516-band h2 {
  margin: 0;
  color: #052f3e;
  font-size: clamp(1.55rem, 2.5vw, 2.3rem);
  line-height: 1.05;
  letter-spacing: 0;
}

.v516-band-head p,
.v516-card p,
.v516-pill li,
.v516-flow p {
  margin: 0;
  color: #466368;
  line-height: 1.45;
}

.v516-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.v516-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.v516-card {
  display: grid;
  gap: 10px;
  align-content: start;
  min-height: 166px;
  padding: 18px;
  border: 1px solid #d7e5df;
  border-radius: 8px;
  background: #fbfefd;
}

.v516-card.is-limit {
  background: #fff8f3;
  border-color: rgba(193, 57, 34, 0.18);
}

.v516-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #e7f4f1;
  color: #08766f;
  font-size: 1.2rem;
  font-weight: 950;
}

.v516-card h3 {
  margin: 0;
  color: #052f3e;
  font-size: 1.15rem;
  line-height: 1.15;
}

.v516-pill {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.v516-pill li {
  position: relative;
  padding-left: 24px;
}

.v516-pill li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.58em;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #08766f;
}

.v516-flow {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.v516-flow article {
  min-height: 134px;
  padding: 18px;
  border-radius: 8px;
  background: #052f3e;
  color: #fff;
}

.v516-flow strong {
  display: block;
  margin-bottom: 8px;
  font-size: 1.05rem;
}

.v516-flow p {
  color: rgba(255, 255, 255, 0.82);
}

@media (max-width: 1000px) {
  .v516-hero,
  .v516-band-head {
    grid-template-columns: 1fr;
  }
.v516-grid-4,
  .v516-flow {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .v516-grid-3 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  body.v516-home-ready .v515-entry-shell {
    width: min(100% - 24px, 540px);
    gap: 18px;
    padding-top: 16px;
  }

  .v516-top {
    align-items: flex-start;
  }

  .v516-brand img {
    width: 46px;
    height: 46px;
  }

  .v516-112 {
    min-height: 42px;
    padding: 9px 12px;
  }

  .v516-media img {
    min-height: 310px;
    max-height: 390px;
  }

  .v516-media-caption {
    position: static;
    max-width: none;
    border-radius: 0;
    box-shadow: none;
    background: #fff;
  }

  .v516-hero-copy h1 {
    font-size: clamp(2.15rem, 12vw, 3.25rem);
  }

  .v516-actions,
  .v516-actions > *,
  .v516-grid-4,
  .v516-flow {
    grid-template-columns: 1fr;
  }

  .v516-actions {
    display: grid;
  }
}


/* Safe Ability SM 5.17 - compact responsive app-like homepage */
body.v517-home-ready.v515-entry-active,
body.v517-home-ready .v515-entry {
  background:
    linear-gradient(135deg, rgba(8, 118, 111, 0.09), rgba(247, 250, 248, 0) 38%),
    #f7faf8;
}

body.v517-home-ready .v515-entry-shell {
  width: min(1180px, calc(100% - 32px));
  gap: 18px;
}

.v517-home {
  display: grid;
  gap: 18px;
}

.v517-top {
  min-height: 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.v517-brand {
  display: flex;
  align-items: center;
  gap: 11px;
  color: #052f3e;
  text-decoration: none;
}

.v517-brand img {
  width: 52px;
  height: 52px;
  border-radius: 8px;
  background: #fff;
  object-fit: contain;
  box-shadow: 0 12px 26px rgba(5, 47, 62, 0.08);
}

.v517-brand strong,
.v517-brand span {
  display: block;
}

.v517-brand strong {
  font-size: 1.12rem;
  line-height: 1.05;
}

.v517-brand span {
  margin-top: 3px;
  color: #4b6469;
  font-size: 0.9rem;
  font-weight: 850;
}

.v517-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(420px, 1.08fr);
  gap: clamp(20px, 3.8vw, 48px);
  align-items: center;
  min-height: min(690px, calc(100svh - 112px));
}

.v517-copy {
  min-width: 0;
}

.v517-copy h1 {
  margin: 0;
  color: #052f3e;
  font-size: clamp(2.55rem, 5.2vw, 5rem);
  line-height: 0.96;
  letter-spacing: 0;
  max-width: 780px;
}

.v517-lead {
  max-width: 680px;
  margin: 22px 0 0;
  color: #35595f;
  font-size: clamp(1.08rem, 1.42vw, 1.28rem);
  line-height: 1.45;
}

.v517-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.v517-primary,
.v517-secondary,
.v517-112,
.v517-dock button,
.v517-dock a {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  padding: 13px 18px;
  border: 1px solid transparent;
  font: inherit;
  font-weight: 950;
  text-decoration: none;
  cursor: pointer;
}

.v517-primary {
  background: #08766f;
  border-color: #08766f;
  color: #fff;
  box-shadow: 0 16px 32px rgba(8, 118, 111, 0.24);
}

.v517-secondary {
  background: #fff;
  border-color: #bed8d1;
  color: #063f3b;
}

.v517-112 {
  background: #fff1ea;
  border-color: rgba(193, 57, 34, 0.24);
  color: #842515;
  white-space: nowrap;
}

.v517-primary:hover,
.v517-primary:focus-visible,
.v517-secondary:hover,
.v517-secondary:focus-visible,
.v517-112:hover,
.v517-112:focus-visible,
.v517-dock button:hover,
.v517-dock button:focus-visible,
.v517-dock a:hover,
.v517-dock a:focus-visible {
  outline: 3px solid rgba(8, 118, 111, 0.22);
  outline-offset: 3px;
}

.v517-for {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}

.v517-for span {
  padding: 8px 11px;
  border: 1px solid #d7e5df;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.78);
  color: #35595f;
  font-weight: 850;
  font-size: 0.9rem;
}

.v517-media {
  position: relative;
  min-width: 0;
  margin: 0;
  overflow: hidden;
  border-radius: 8px;
  background: #dce9e7;
  box-shadow: 0 28px 72px rgba(5, 47, 62, 0.16);
}

.v517-media::after {
  content: "Prima chiedi. Poi agisci.";
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  width: fit-content;
  max-width: calc(100% - 36px);
  padding: 12px 14px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  color: #052f3e;
  font-weight: 950;
  box-shadow: 0 16px 34px rgba(5, 47, 62, 0.16);
  backdrop-filter: blur(10px);
}

.v517-media img {
  display: block;
  width: 100%;
  min-height: clamp(390px, 55vh, 610px);
  object-fit: cover;
  object-position: center;
}

.v517-panel,
.v517-split,
.v517-bottom-cta {
  border: 1px solid #d7e5df;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 14px 34px rgba(5, 47, 62, 0.06);
}

.v517-panel {
  display: grid;
  gap: 16px;
  padding: clamp(18px, 2.8vw, 26px);
}

.v517-panel-head,
.v517-split {
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) minmax(0, 1.28fr);
  gap: 18px;
  align-items: start;
}

.v517-panel h2,
.v517-split h2 {
  margin: 0;
  color: #052f3e;
  font-size: clamp(1.55rem, 2.4vw, 2.2rem);
  line-height: 1.05;
  letter-spacing: 0;
}

.v517-panel-head p,
.v517-actions-grid p,
.v517-split p,
.v517-rules span,
.v517-bottom-cta p {
  margin: 0;
  color: #466368;
  line-height: 1.4;
}

.v517-actions-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.v517-actions-grid article {
  min-height: 138px;
  display: grid;
  gap: 8px;
  align-content: start;
  padding: 18px;
  border: 1px solid #d7e5df;
  border-radius: 8px;
  background: #fbfefd;
}

.v517-actions-grid span {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #08766f;
  color: #fff;
  font-weight: 950;
}

.v517-actions-grid h3 {
  margin: 0;
  color: #052f3e;
  font-size: 1.18rem;
  line-height: 1.1;
}

.v517-split {
  padding: clamp(18px, 2.8vw, 26px);
}

.v517-rules {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.v517-rules li {
  display: grid;
  grid-template-columns: minmax(128px, 0.4fr) minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 13px 0;
  border-bottom: 1px solid #d7e5df;
}

.v517-rules li:first-child {
  padding-top: 0;
}

.v517-rules li:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.v517-rules strong {
  color: #052f3e;
}

.v517-bottom-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: clamp(18px, 2.8vw, 26px);
  background: #052f3e;
}

.v517-bottom-cta p {
  color: rgba(255, 255, 255, 0.86);
  font-size: clamp(1.05rem, 1.45vw, 1.22rem);
  font-weight: 850;
}

.v517-dock {
  display: none;
}

@media (max-width: 980px) {
  .v517-hero,
  .v517-panel-head,
  .v517-split {
    grid-template-columns: 1fr;
  }

  .v517-hero {
    min-height: auto;
  }

  .v517-actions-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  body.v517-home-ready.v515-entry-active {
    padding-bottom: calc(86px + env(safe-area-inset-bottom, 0px));
  }

  body.v517-home-ready .v515-entry-shell {
    width: min(100% - 22px, 540px);
    gap: 14px;
    padding-top: 14px;
  }

  .v517-home {
    gap: 14px;
  }

  .v517-top {
    align-items: flex-start;
  }

  .v517-brand img {
    width: 46px;
    height: 46px;
  }

  .v517-brand strong {
    font-size: 1rem;
  }

  .v517-brand span {
    font-size: 0.82rem;
  }

  .v517-112 {
    min-height: 40px;
    padding: 9px 11px;
    font-size: 0.86rem;
  }

  .v517-copy h1 {
    font-size: clamp(2.12rem, 12vw, 3.22rem);
    line-height: 0.98;
  }

  .v517-lead {
    margin-top: 16px;
    font-size: 1.03rem;
  }

  .v517-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 9px;
    margin-top: 18px;
  }

  .v517-actions > * {
    width: 100%;
    padding-inline: 12px;
  }

  .v517-for {
    gap: 7px;
    margin-top: 13px;
  }

  .v517-for span {
    font-size: 0.82rem;
    padding: 7px 9px;
  }

  .v517-media img {
    min-height: 260px;
    max-height: 330px;
  }

  .v517-media::after {
    left: 12px;
    right: 12px;
    bottom: 12px;
    max-width: calc(100% - 24px);
    padding: 10px 12px;
    font-size: 0.95rem;
  }

  .v517-panel,
  .v517-split,
  .v517-bottom-cta {
    padding: 16px;
  }

  .v517-panel h2,
  .v517-split h2 {
    font-size: 1.48rem;
  }

  .v517-actions-grid {
    grid-template-columns: 1fr;
    gap: 9px;
  }

  .v517-actions-grid article {
    min-height: 0;
    grid-template-columns: 42px minmax(0, 1fr);
    column-gap: 12px;
  }

  .v517-actions-grid article p {
    grid-column: 2;
  }

  .v517-rules li {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .v517-bottom-cta {
    display: none;
  }

  .v517-dock {
    position: fixed;
    left: 12px;
    right: 12px;
    bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    z-index: 80;
    display: grid;
    grid-template-columns: 1fr 84px;
    gap: 8px;
    padding: 8px;
    border: 1px solid rgba(215, 229, 223, 0.92);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 18px 46px rgba(5, 47, 62, 0.22);
    backdrop-filter: blur(14px);
  }

  .v517-dock button {
    background: #08766f;
    color: #fff;
  }

  .v517-dock a {
    background: #fff1ea;
    color: #842515;
    border-color: rgba(193, 57, 34, 0.24);
  }
}

@media (max-width: 390px) {
  .v517-actions {
    grid-template-columns: 1fr;
  }

  .v517-112 {
    max-width: 118px;
    white-space: normal;
    line-height: 1.08;
  }
}


/* Safe Ability SM 5.18 - visual-only launch homepage */
body.v518-home-ready.v515-entry-active,
body.v518-home-ready .v515-entry {
  min-height: 100svh;
  background: #eaf2ef;
}

body.v518-home-ready .v515-entry {
  padding: 0;
}

body.v518-home-ready .v515-entry-shell {
  width: 100%;
  max-width: none;
  min-height: 100svh;
  padding: clamp(12px, 2.2vw, 24px);
  gap: 0;
}

.v518-home {
  min-height: calc(100svh - clamp(24px, 4.4vw, 48px));
  display: grid;
}

.v518-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.v518-hero {
  position: relative;
  min-height: inherit;
  margin: 0;
  overflow: hidden;
  border-radius: 8px;
  background: #dce9e7;
  box-shadow: 0 30px 80px rgba(5, 47, 62, 0.2);
  isolation: isolate;
}

.v518-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(5, 47, 62, 0.08), rgba(5, 47, 62, 0.02) 38%, rgba(5, 47, 62, 0.58)),
    radial-gradient(circle at 50% 86%, rgba(5, 47, 62, 0.36), rgba(5, 47, 62, 0) 34%);
  pointer-events: none;
}

.v518-hero img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
  object-position: center;
}

.v518-risk-panel {
  position: absolute;
  top: clamp(14px, 2.4vw, 28px);
  right: clamp(14px, 2.4vw, 28px);
  z-index: 2;
  display: flex;
  gap: 10px;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 18px 42px rgba(5, 47, 62, 0.18);
  backdrop-filter: blur(16px);
}

.v518-risk {
  width: clamp(48px, 5vw, 64px);
  height: clamp(48px, 5vw, 64px);
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #f8fcfb;
  color: #064a45;
  box-shadow: inset 0 0 0 1px rgba(8, 118, 111, 0.12);
}

.v518-risk:nth-child(1) {
  color: #c56c00;
}

.v518-risk:nth-child(2) {
  color: #1e6f9f;
}

.v518-risk:nth-child(3) {
  color: #6a4a2f;
}

.v518-risk:nth-child(4) {
  color: #c13922;
}

.v518-risk:nth-child(5) {
  color: #062f3d;
}

.v518-risk svg {
  width: 68%;
  height: 68%;
  fill: none;
  stroke: currentColor;
  stroke-width: 3.1;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.v518-enter {
  position: absolute;
  left: 50%;
  bottom: clamp(22px, 4vw, 48px);
  z-index: 2;
  transform: translateX(-50%);
  min-width: min(340px, calc(100% - 48px));
  min-height: 62px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 255, 255, 0.32);
  border-radius: 8px;
  padding: 16px 28px;
  background: #08766f;
  color: #fff;
  box-shadow: 0 20px 44px rgba(5, 47, 62, 0.32);
  font: inherit;
  font-size: clamp(1.08rem, 1.6vw, 1.28rem);
  font-weight: 950;
  letter-spacing: 0;
  cursor: pointer;
}

.v518-enter:hover,
.v518-enter:focus-visible {
  outline: 4px solid rgba(255, 255, 255, 0.72);
  outline-offset: 4px;
}

@media (max-width: 760px) {
  body.v518-home-ready .v515-entry-shell {
    padding: 10px;
  }

  .v518-home {
    min-height: calc(100svh - 20px);
  }

  .v518-hero {
    min-height: calc(100svh - 20px);
  }

  .v518-hero img {
    object-position: center top;
  }

  .v518-risk-panel {
    top: auto;
    left: 50%;
    right: auto;
    bottom: calc(92px + env(safe-area-inset-bottom, 0px));
    transform: translateX(-50%);
    width: min(360px, calc(100% - 24px));
    justify-content: center;
    gap: 7px;
    padding: 8px;
  }

  .v518-risk {
    width: clamp(44px, 13vw, 56px);
    height: clamp(44px, 13vw, 56px);
  }

  .v518-enter {
    bottom: calc(18px + env(safe-area-inset-bottom, 0px));
    width: min(330px, calc(100% - 34px));
    min-height: 60px;
  }
}

@media (max-width: 420px) {
  .v518-risk-panel {
    width: calc(100% - 20px);
    gap: 6px;
  }

  .v518-risk {
    width: 48px;
    height: 48px;
  }
}

@media (prefers-reduced-motion: no-preference) {
  .v518-risk {
    transition: transform 180ms ease, box-shadow 180ms ease;
  }

  .v518-risk:hover {
    transform: translateY(-2px);
    box-shadow: inset 0 0 0 1px rgba(8, 118, 111, 0.18), 0 8px 16px rgba(5, 47, 62, 0.12);
  }
}


/* Safe Ability SM 5.19 - number alignment, references and personal share */
body.v519-official-numbers .v519-call-row,
body.v519-official-numbers .v54-call-row,
body.v519-official-numbers .v511-number-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

body.v519-official-numbers #whatsappSosTemplate.v519-personal-share,
body.v519-official-numbers #whatsappSosTemplate{
  border-color:#bad7d1;
  color:#073f3a;
  background:#f8fffd;
}

body.v519-official-numbers .v52-contact-note{
  border-color:#bad7d1;
  background:#f8fffd;
}

body.v519-official-numbers .v519-framework{
  max-width:1180px;
  margin:22px auto 26px;
  padding:0 18px;
}

body.v519-official-numbers .v519-framework .section-heading{
  max-width:780px;
}

body.v519-official-numbers .v519-framework-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:14px;
}

body.v519-official-numbers .v519-framework-grid article{
  border:1px solid #d5e1df;
  background:#ffffff;
  border-radius:18px;
  padding:18px;
  box-shadow:0 14px 34px rgba(7,63,58,.08);
}

body.v519-official-numbers .v519-framework-grid h3{
  margin:0 0 8px;
  color:#052f3f;
}

body.v519-official-numbers .v519-framework-grid p{
  margin:0 0 14px;
  color:#44616a;
  line-height:1.55;
}

body.v519-official-numbers .v519-framework-grid a{
  display:inline-flex;
  align-items:center;
  min-height:40px;
  font-weight:800;
  color:#006c67;
}

@media (max-width:680px){
  body.v519-official-numbers .v519-call-row a,
  body.v519-official-numbers .v54-call-row a,
  body.v519-official-numbers .v511-number-row a{
    flex:1 1 100%;
    justify-content:center;
    min-height:44px;
  }
  body.v519-official-numbers .v519-framework{
    padding:0 12px;
  }
  body.v519-official-numbers .v519-framework-grid{
    grid-template-columns:1fr;
  }
}


/* Safe Ability SM 5.20 - number alignment, references and personal share */
body.v519-official-numbers .v519-call-row,
body.v519-official-numbers .v54-call-row,
body.v519-official-numbers .v511-number-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

body.v519-official-numbers #whatsappSosTemplate.v519-personal-share,
body.v519-official-numbers #whatsappSosTemplate{
  border-color:#bad7d1;
  color:#073f3a;
  background:#f8fffd;
}

body.v519-official-numbers .v52-contact-note{
  border-color:#bad7d1;
  background:#f8fffd;
}

body.v519-official-numbers .v519-framework{
  max-width:1180px;
  margin:22px auto 26px;
  padding:0 18px;
}

body.v519-official-numbers .v519-framework .section-heading{
  max-width:780px;
}

body.v519-official-numbers .v519-framework-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:14px;
}

body.v519-official-numbers .v519-framework-grid article{
  border:1px solid #d5e1df;
  background:#ffffff;
  border-radius:18px;
  padding:18px;
  box-shadow:0 14px 34px rgba(7,63,58,.08);
}

body.v519-official-numbers .v519-framework-grid h3{
  margin:0 0 8px;
  color:#052f3f;
}

body.v519-official-numbers .v519-framework-grid p{
  margin:0 0 14px;
  color:#44616a;
  line-height:1.55;
}

body.v519-official-numbers .v519-framework-grid a{
  display:inline-flex;
  align-items:center;
  min-height:40px;
  font-weight:800;
  color:#006c67;
}

@media (max-width:680px){
  body.v519-official-numbers .v519-call-row a,
  body.v519-official-numbers .v54-call-row a,
  body.v519-official-numbers .v511-number-row a{
    flex:1 1 100%;
    justify-content:center;
    min-height:44px;
  }
  body.v519-official-numbers .v519-framework{
    padding:0 12px;
  }
  body.v519-official-numbers .v519-framework-grid{
    grid-template-columns:1fr;
  }
}



/* Safe Ability SM 5.29 - practical risk atlas */
html{
  scroll-padding-top:108px;
}

body.v529-risk-atlas #v529-risk-playbook,
body.v529-risk-atlas #v529-plan-kit{
  scroll-margin-top:132px;
}

.v529-risk-playbook{
  width:min(1180px, calc(100% - 32px));
  margin:22px auto;
}

.v529-shell{
  border:1px solid #d5e2df;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,252,251,.98)),
    linear-gradient(90deg, rgba(205,48,35,.08), rgba(245,185,35,.08), rgba(40,116,180,.08));
  border-radius:18px;
  padding:clamp(18px, 3vw, 28px);
  box-shadow:0 20px 54px rgba(6,43,54,.10);
}

.v529-heading{
  display:grid;
  grid-template-columns:minmax(0, .9fr) minmax(260px, .68fr);
  align-items:end;
  gap:18px;
  margin-bottom:18px;
}

.v529-mini-label{
  margin:0 0 6px;
  color:#08766f;
  font-weight:900;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:0;
}

.v529-heading h2{
  margin:0;
  color:#062f3d;
  font-size:clamp(1.55rem, 3vw, 2.45rem);
  line-height:1.04;
}

.v529-heading p:not(.v529-mini-label){
  margin:0;
  color:#48626a;
  line-height:1.55;
  font-size:1rem;
}

.v529-frameworks{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(210px, 1fr));
  gap:10px;
  margin:0 0 16px;
}

.v529-frameworks a,
.v529-frameworks div{
  min-height:92px;
  border:1px solid #d7e4e1;
  background:rgba(255,255,255,.78);
  color:#3f5b64;
  border-radius:12px;
  padding:13px 14px;
  text-decoration:none;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:6px;
}

.v529-frameworks a:hover,
.v529-frameworks a:focus-visible{
  border-color:#8dbbb3;
  box-shadow:0 0 0 3px rgba(8,118,111,.14);
  outline:none;
}

.v529-frameworks strong{
  color:#073f3a;
  font-size:.94rem;
  line-height:1.15;
}

.v529-frameworks span{
  color:#48626a;
  font-size:.88rem;
  line-height:1.35;
}

.v529-tabs{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:10px;
  margin-bottom:16px;
}

.v529-tabs button{
  appearance:none;
  border:1px solid #d5e2df;
  background:#fff;
  color:#063242;
  border-radius:12px;
  min-height:76px;
  padding:12px;
  display:flex;
  align-items:center;
  gap:10px;
  text-align:left;
  font:inherit;
  cursor:pointer;
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.v529-tabs button:hover,
.v529-tabs button:focus-visible{
  border-color:#8dbbb3;
  box-shadow:0 0 0 3px rgba(8,118,111,.14);
  outline:none;
}

.v529-tabs button.is-selected{
  background:#073f3a;
  color:#fff;
  border-color:#073f3a;
  box-shadow:0 12px 28px rgba(7,63,58,.18);
}

.v529-tab-icon{
  width:42px;
  height:42px;
  border-radius:12px;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  background:#eef6f5;
  color:#08766f;
}

.v529-tabs button.is-selected .v529-tab-icon{
  background:rgba(255,255,255,.16);
  color:#fff;
}

.v529-tab-icon svg,
.v529-scenario-icon svg{
  width:26px;
  height:26px;
  fill:none;
  stroke:currentColor;
  stroke-width:3;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.v529-tabs strong{
  display:block;
  font-size:.96rem;
  line-height:1.15;
}

.v529-tabs small{
  display:block;
  margin-top:4px;
  color:inherit;
  opacity:.74;
  line-height:1.25;
}

.v529-detail{
  display:grid;
  grid-template-columns:minmax(230px, .72fr) minmax(0, 1.5fr);
  gap:14px;
}

.v529-scenario-card,
.v529-step,
.v529-inclusive-note{
  border:1px solid #d8e4e1;
  background:#fff;
  border-radius:14px;
}

.v529-scenario-card{
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:14px;
  min-height:100%;
}

.v529-scenario-icon{
  width:62px;
  height:62px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:#eef6f5;
  color:#08766f;
}

.v529-scenario-icon svg{
  width:34px;
  height:34px;
}

.v529-scenario-card h3{
  margin:0 0 8px;
  color:#052f3f;
  font-size:1.45rem;
  line-height:1.08;
}

.v529-scenario-card p:not(.v529-mini-label){
  margin:0;
  color:#435f68;
  line-height:1.5;
}

.v529-call-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:auto;
}

.v529-call-list span{
  min-height:34px;
  display:inline-flex;
  align-items:center;
  border:1px solid #d8e4e1;
  border-radius:999px;
  padding:7px 10px;
  color:#083442;
  background:#f7fbfa;
  font-weight:800;
  font-size:.86rem;
}

.v529-action-area{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.v529-steps{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(210px, 1fr));
  gap:10px;
}

.v529-step{
  padding:14px;
}

.v529-step h4{
  margin:0 0 10px;
  color:#052f3f;
  font-size:1rem;
}

.v529-step ul{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:9px;
}

.v529-step li{
  position:relative;
  padding-left:16px;
  color:#435f68;
  line-height:1.45;
  font-size:.96rem;
}

.v529-step li::before{
  content:"";
  position:absolute;
  left:0;
  top:.58em;
  width:6px;
  height:6px;
  border-radius:50%;
  background:#08766f;
}

.v529-inclusive-note{
  padding:14px 16px;
  display:grid;
  grid-template-columns:150px minmax(0,1fr);
  gap:10px;
  align-items:center;
  background:#f8fffd;
}

.v529-inclusive-note strong{
  color:#073f3a;
}

.v529-inclusive-note span{
  color:#435f68;
  line-height:1.45;
}

.v529-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.v529-actions button,
.v529-actions a{
  min-height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  padding:10px 14px;
  font-weight:900;
  text-decoration:none;
}

.v529-actions button{
  border:0;
  background:#08766f;
  color:#fff;
  cursor:pointer;
}

.v529-actions a{
  border:1px solid #b9d1cc;
  background:#fff;
  color:#073f3a;
}

.v529-detail.is-fire .v529-scenario-icon,
.v529-tab-icon.fire{color:#cf3b2f;background:#fff0ec;}
.v529-detail.is-fire .v529-step li::before{background:#cf3b2f;}
.v529-detail.is-quake .v529-scenario-icon,
.v529-tab-icon.quake{color:#c77900;background:#fff7df;}
.v529-detail.is-quake .v529-step li::before{background:#c77900;}
.v529-detail.is-snow .v529-scenario-icon,
.v529-tab-icon.snow{color:#2c78b8;background:#edf7ff;}
.v529-detail.is-snow .v529-step li::before{background:#2c78b8;}
.v529-detail.is-heat .v529-scenario-icon,
.v529-tab-icon.heat{color:#d93a32;background:#fff3d8;}
.v529-detail.is-heat .v529-step li::before{background:#d93a32;}

.v529-plan-kit{
  width:min(1180px, calc(100% - 32px));
  margin:22px auto;
}

.v529-plan-shell{
  border:1px solid #d5e2df;
  border-radius:18px;
  padding:clamp(18px, 3vw, 28px);
  background:linear-gradient(180deg, rgba(255,255,255,.97), rgba(247,251,250,.98));
  box-shadow:0 16px 42px rgba(6,43,54,.08);
}

.v529-plan-heading{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(250px,.72fr);
  gap:18px;
  align-items:end;
  margin-bottom:16px;
}

.v529-plan-heading h2{
  margin:0;
  color:#062f3d;
  font-size:clamp(1.35rem, 2.5vw, 2rem);
  line-height:1.08;
}

.v529-plan-heading p:not(.v529-mini-label){
  margin:0;
  color:#48626a;
  line-height:1.5;
}

.v529-plan-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:10px;
}

.v529-plan-grid article{
  border:1px solid #d8e4e1;
  background:#fff;
  border-radius:14px;
  padding:15px;
}

.v529-plan-grid span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
  height:28px;
  border-radius:999px;
  background:#eef6f5;
  color:#08766f;
  font-size:.78rem;
  font-weight:900;
  margin-bottom:10px;
}

.v529-plan-grid h3{
  margin:0 0 8px;
  color:#052f3f;
  font-size:1.05rem;
  line-height:1.18;
}

.v529-plan-grid p{
  margin:0;
  color:#435f68;
  line-height:1.45;
  font-size:.94rem;
}

.v529-plan-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}

.v529-plan-actions a,
.v529-plan-actions button{
  min-height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  padding:10px 14px;
  font-weight:900;
  text-decoration:none;
}

.v529-plan-actions a{
  border:1px solid #b9d1cc;
  background:#fff;
  color:#073f3a;
}

.v529-plan-actions button{
  border:0;
  background:#08766f;
  color:#fff;
  cursor:pointer;
}

@media (max-width:980px){
  .v529-heading,
  .v529-plan-heading,
  .v529-detail{
    grid-template-columns:1fr;
  }
  .v529-tabs,
  .v529-plan-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width:680px){
  .v529-risk-playbook,
  .v529-plan-kit{
    width:calc(100% - 24px);
    margin:16px auto;
  }
  .v529-shell,
  .v529-plan-shell{
    border-radius:14px;
    padding:14px;
  }
  .v529-frameworks,
  .v529-tabs,
  .v529-plan-grid{
    grid-template-columns:1fr;
  }
  .v529-tabs button{
    min-height:64px;
    border-radius:10px;
  }
  .v529-steps{
    grid-template-columns:1fr;
  }
  .v529-inclusive-note{
    grid-template-columns:1fr;
  }
  .v529-actions button,
  .v529-actions a,
  .v529-plan-actions a,
  .v529-plan-actions button{
    width:100%;
  }
}


@media (max-width:760px){
  body.v529-risk-atlas .pwa-tabbar{
    display:grid!important;
    grid-template-columns:repeat(5,minmax(0,1fr))!important;
    gap:4px;
    padding:6px 8px calc(6px + env(safe-area-inset-bottom));
  }

  body.v529-risk-atlas .pwa-tabbar a{
    min-width:0;
    min-height:42px;
    padding:8px 2px;
    border-radius:10px;
    font-size:.72rem;
    line-height:1.05;
    white-space:nowrap;
    text-align:center;
  }
}


/* Safe Ability SM 5.29 - compact accessible map legend */
body.v529-risk-atlas .inclusive-map-legend{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
  margin:12px 0;
}

body.v529-risk-atlas .inclusive-map-legend label{
  min-width:0;
  border-radius:10px;
  padding:8px 9px;
  font-size:.82rem;
  line-height:1.15;
}

.pin-dot.restroom,.inclusive-pin.restroom,.v529-pin-sample.restroom{background:#167f91;}
.pin-dot.power,.inclusive-pin.power,.v529-pin-sample.power{background:#9a6b00;}
.pin-dot.health,.inclusive-pin.health,.v529-pin-sample.health{background:#0f7a4f;}
.pin-dot.transport,.inclusive-pin.transport,.v529-pin-sample.transport{background:#6c5ce7;}
.pin-dot.elevator,.inclusive-pin.elevator,.v529-pin-sample.elevator{background:#58707a;}
.pin-dot.road,.inclusive-pin.road,.v529-pin-sample.road{background:#8f3c16;}
.pin-dot.inaccessible,.inclusive-pin.inaccessible,.v529-pin-sample.inaccessible{background:#c7352d;}
.pin-dot.volunteers,.inclusive-pin.volunteers,.v529-pin-sample.volunteers{background:#d97706;}
.pin-dot.calm,.inclusive-pin.calm,.v529-pin-sample.calm{background:#2c78b8;}
.pin-dot.alert,.inclusive-pin.alert,.v529-pin-sample.alert{background:#1f6feb;}
.pin-dot.waiting,.inclusive-pin.waiting,.v529-pin-sample.waiting{background:#0f4c9c;}

.inclusive-pin.power,.inclusive-pin.transport,.inclusive-pin.elevator,.inclusive-pin.calm,.inclusive-pin.waiting{
  font-size:.62rem;
  letter-spacing:0;
}

.v529-map-legend{
  margin:14px 0;
  box-shadow:none!important;
  padding:0!important;
  overflow:hidden;
}

.v529-map-legend summary{
  min-height:58px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 16px;
  cursor:pointer;
  color:#052f3f;
  list-style:none;
}

.v529-map-legend summary::-webkit-details-marker{display:none;}
.v529-summary-copy{display:grid;gap:3px;}
.v529-summary-copy strong{font-size:1.02rem;}
.v529-summary-copy small{color:#536b72;font-weight:700;}
.v529-summary-action{
  min-width:72px;
  min-height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid #bad7d1;
  border-radius:10px;
  background:#f8fffd;
  color:#073f3a;
  font-weight:900;
}
.v529-map-legend[open] .v529-summary-action{font-size:0;}
.v529-map-legend[open] .v529-summary-action::before{content:"Chiudi";font-size:.88rem;}

.v529-pin-legend-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  padding:0 16px 16px;
}

.v529-pin-row{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:10px;
  align-items:center;
  border:1px solid #d7e5e1;
  border-radius:12px;
  background:#f8fbfa;
  padding:10px;
}

.v529-pin-sample{
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  border:3px solid #fff;
  border-radius:50% 50% 50% 10px;
  color:#fff;
  box-shadow:0 7px 16px rgba(20,48,45,.22);
  transform:rotate(-45deg);
  font-size:.72rem;
  font-weight:950;
  line-height:1;
}
.v529-pin-sample span{transform:rotate(45deg);}
.v529-pin-row strong{display:block;color:#052f3f;font-size:.95rem;}
.v529-pin-row small{display:block;color:#536b72;line-height:1.35;margin-top:2px;}

@media (max-width:900px){
  body.v529-risk-atlas .inclusive-map-legend,
  .v529-pin-legend-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media (max-width:560px){
  body.v529-risk-atlas .inclusive-map-legend,
  .v529-pin-legend-grid{grid-template-columns:1fr;}
  .v529-map-legend summary{align-items:flex-start;}
}


/* Safe Ability SM 5.30 - branded home and PWA identità */
:root{
  --safe-blue:#123A5A;
  --safe-teal:#00A6A6;
  --safe-coral:#FF6B5E;
  --safe-aqua:#68D8D3;
  --safe-ice:#EDF8F7;
  --safe-line:#CDE2E0;
}

body.v530-brand-system{
  background:linear-gradient(180deg, var(--safe-ice) 0%, #f8fcfb 42%, #ffffff 100%);
}

body.v530-brand-system .topbar{
  border-bottom:1px solid rgba(18,58,90,.12);
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(14px);
}

body.v530-brand-system .brand{
  min-width:0;
  gap:12px;
}

body.v530-brand-system .brand-logo{
  display:block;
  width:46px;
  height:46px;
  object-fit:contain;
  flex:0 0 auto;
}

body.v530-brand-system .brand strong{
  color:var(--safe-blue);
  letter-spacing:0;
}

body.v530-brand-system .brand small{
  color:#526575;
  font-weight:800;
}


body.v530-brand-system.v515-entry-active .pwa-tabbar{
  display:none !important;
}

body.v530-brand-system .primary-nav a,
body.v530-brand-system .pwa-tabbar a{
  color:var(--safe-blue);
}

body.v530-brand-system .primary-nav a:hover,
body.v530-brand-system .primary-nav a:focus-visible,
body.v530-brand-system .pwa-tabbar a:hover,
body.v530-brand-system .pwa-tabbar a:focus-visible{
  color:var(--safe-teal);
}

.v530-entry-home{
  width:min(1180px, calc(100% - 28px));
  min-height:min(780px, calc(100dvh - 44px));
  margin:auto;
  display:grid;
  grid-template-columns:minmax(0, 1.02fr) minmax(330px, .78fr);
  align-items:stretch;
  gap:clamp(14px, 2.4vw, 24px);
  color:var(--safe-blue);
}

.v530-entry-hero{
  margin:0;
  min-height:100%;
  border-radius:24px;
  overflow:hidden;
  background:#dcefee;
  box-shadow:0 26px 70px rgba(18,58,90,.18);
  position:relative;
}

.v530-entry-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(18,58,90,.06), rgba(0,166,166,.05));
  pointer-events:none;
}

.v530-entry-hero img{
  width:100%;
  height:100%;
  min-height:520px;
  object-fit:cover;
  object-position:center;
  display:block;
}

.v530-entry-panel{
  min-height:100%;
  border:1px solid rgba(18,58,90,.13);
  border-radius:24px;
  background:rgba(255,255,255,.92);
  box-shadow:0 26px 70px rgba(18,58,90,.14);
  padding:clamp(22px, 4vw, 44px);
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:clamp(16px, 2.5vw, 24px);
}

.v530-entry-logo{
  width:min(100%, 520px);
  max-height:164px;
  object-fit:contain;
  object-position:left center;
  display:block;
}

.v530-entry-line{
  margin:0;
  color:#526575;
  font-size:clamp(1.02rem, 1.7vw, 1.35rem);
  line-height:1.45;
  max-width:34rem;
}

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

.v530-risk{
  min-height:58px;
  border:1px solid rgba(0,166,166,.2);
  background:linear-gradient(180deg, rgba(237,248,247,.94), rgba(255,255,255,.92));
  border-radius:14px;
  padding:10px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--safe-blue);
  font-weight:900;
}

.v530-risk-icon{
  width:36px;
  height:36px;
  border-radius:12px;
  display:grid;
  place-items:center;
  background:#fff;
  color:var(--safe-teal);
  box-shadow:inset 0 0 0 1px rgba(0,166,166,.16);
  flex:0 0 auto;
}

.v530-risk-icon svg{
  width:23px;
  height:23px;
  fill:none;
  stroke:currentColor;
  stroke-width:2.4;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.v530-enter{
  appearance:none;
  border:0;
  border-radius:16px;
  background:linear-gradient(135deg, var(--safe-blue), #0a8786);
  color:#fff;
  min-height:62px;
  width:100%;
  padding:16px 18px;
  font:inherit;
  font-weight:1000;
  font-size:1.2rem;
  cursor:pointer;
  box-shadow:0 18px 36px rgba(18,58,90,.22);
}

.v530-enter:hover,
.v530-enter:focus-visible{
  outline:3px solid rgba(255,107,94,.36);
  outline-offset:3px;
}.v530-entry-actions{
  display:grid;
  grid-template-columns:minmax(0, 1.3fr) minmax(130px, .7fr);
  gap:10px;
  align-items:stretch;
}

.v530-install{
  appearance:none;
  border:1px solid rgba(18,58,90,.18);
  border-radius:16px;
  background:#fff;
  color:var(--safe-blue);
  min-height:62px;
  padding:14px 16px;
  font:inherit;
  font-weight:1000;
  font-size:1.02rem;
  cursor:pointer;
  box-shadow:0 12px 28px rgba(18,58,90,.10);
}

.v530-install:hover,
.v530-install:focus-visible{
  outline:3px solid rgba(0,166,166,.28);
  outline-offset:3px;
  border-color:rgba(0,166,166,.45);
}


.v530-home-hero{
  border:1px solid rgba(18,58,90,.12);
  background:#fff;
  box-shadow:0 26px 70px rgba(18,58,90,.10);
}

.v530-home-hero .hero-visual img{
  object-position:center;
}

.v530-hero-logo{
  width:min(100%, 420px);
  margin:0 0 14px;
}

.v530-hero-logo img{
  width:100%;
  height:auto;
  display:block;
}

.v530-home-hero .hero-copy h1{
  color:var(--safe-blue);
  letter-spacing:0;
}

.v530-home-hero .hero-copy p{
  color:#526575;
}

body.v530-brand-system .primary-action{
  background:linear-gradient(135deg, var(--safe-blue), #087f7d);
  border-color:transparent;
}

body.v530-brand-system .secondary-action{
  border-color:rgba(18,58,90,.2);
  color:var(--safe-blue);
  background:#fff;
}

body.v530-brand-system .secondary-action:hover,
body.v530-brand-system .secondary-action:focus-visible{
  border-color:rgba(0,166,166,.45);
  color:#007f7e;
}

@media (max-width: 900px){
  .v530-entry-home{
    grid-template-columns:1fr;
    min-height:calc(100dvh - 28px);
  }
  .v530-entry-hero{
    min-height:45dvh;
  }
  .v530-entry-hero img{
    min-height:45dvh;
    max-height:54dvh;
  }
  .v530-entry-panel{
    min-height:auto;
    justify-content:flex-start;
  }
}

@media (max-width: 640px){
  body.v530-brand-system .topbar{
    gap:8px;
  }
  body.v530-brand-system .brand-logo{
    width:40px;
    height:40px;
  }
  body.v530-brand-system .brand > span{
    display:none;
  }
  body.v530-brand-system .brand small{
    display:none;
  }
  .v530-entry-home{
    width:calc(100% - 20px);
    max-width:480px;
    gap:10px;
  }
  .v530-entry-hero,
  .v530-entry-panel{
    border-radius:18px;
  }
  .v530-entry-hero{
    min-height:42dvh;
  }
  .v530-entry-hero img{
    min-height:42dvh;
    max-height:46dvh;
  }
  .v530-entry-panel{
    padding:18px;
    gap:13px;
  }
  .v530-entry-logo{
    max-height:108px;
  }
  .v530-entry-line{
    font-size:.98rem;
    line-height:1.38;
  }
  .v530-risk-strip{
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:7px;
  }
  .v530-risk{
    min-height:62px;
    padding:8px 6px;
    flex-direction:column;
    justify-content:center;
    gap:4px;
    text-align:center;
    font-size:.74rem;
    line-height:1.05;
  }
  .v530-risk-icon{
    width:30px;
    height:30px;
    border-radius:10px;
  }
  .v530-risk-icon svg{
    width:19px;
    height:19px;
  }
  .v530-enter{
    min-height:56px;
    border-radius:14px;
    font-size:1.05rem;
  }
  .v530-hero-logo{
    max-width:300px;
    margin-bottom:10px;
  }
}

@media (max-width: 420px){
  .v530-risk-strip{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .v530-entry-hero{
    min-height:36dvh;
  }
  .v530-entry-hero img{
    min-height:36dvh;
  }
}


/* Safe Ability SM 5.31 - remove redundant internal hero */
body.v531-no-internal-hero:not(.v515-entry-active) #home.hero{
  display:none !important;
}

body.v531-no-internal-hero:not(.v515-entry-active) main{
  padding-top:clamp(14px, 2vw, 24px);
}

body.v531-no-internal-hero:not(.v515-entry-active) .primary-hub{
  margin-top:0;
}

@media (max-width: 620px){
  body.v531-no-internal-hero:not(.v515-entry-active) main{
    padding-top:12px;
  }
}


/* Temporarily hide the risk playbook and its navigation entry. */
body.v531-no-internal-hero #v529-risk-playbook,
body.v531-no-internal-hero .primary-nav a[href="#v529-risk-playbook"],
body.v531-no-internal-hero .pwa-tabbar a[href="#v529-risk-playbook"],
body.v531-no-internal-hero .hero-actions a[href="#v529-risk-playbook"]{
  display:none !important;
}

/* More compact and distinct emergency triage cards. */
body.v531-no-internal-hero .triage-grid{
  gap:12px;
}

body.v531-no-internal-hero .triage-button{
  min-height:128px;
  display:grid;
  grid-template-columns:44px minmax(0, 1fr);
  align-items:center;
  align-content:center;
  gap:5px 14px;
  padding:16px 18px;
  border-radius:18px;
  border:1px solid #b9ddd5;
  background:linear-gradient(135deg, #f8fffd 0%, #eaf8f4 100%);
  box-shadow:0 10px 24px rgba(8,46,61,.08);
}

body.v531-no-internal-hero .triage-button .triage-icon{
  grid-row:1 / span 2;
  width:44px;
  height:44px;
  border-radius:14px;
  color:#0b625b;
  background:#dff5ee;
}

body.v531-no-internal-hero .triage-button strong{
  margin:0;
  font-size:clamp(1.08rem, 1.35vw, 1.24rem);
  line-height:1.12;
}

body.v531-no-internal-hero .triage-button span:not(.triage-icon){
  line-height:1.32;
  color:#34545d;
}

body.v531-no-internal-hero .triage-button.is-danger{
  border-color:#9d2a16;
  background:linear-gradient(135deg, #b52c13 0%, #8e230f 100%);
  color:#fff;
  box-shadow:0 14px 30px rgba(142,35,15,.18);
}

body.v531-no-internal-hero .triage-button.is-danger .triage-icon{
  background:rgba(255,255,255,.14);
  color:#fff;
}

body.v531-no-internal-hero .triage-button.is-danger strong,
body.v531-no-internal-hero .triage-button.is-danger span:not(.triage-icon){
  color:#fff;
}

body.v531-no-internal-hero .triage-button.is-rescuer{
  border-color:#9dcad7;
  background:linear-gradient(135deg, #f5fcff 0%, #e1f2f8 100%);
  box-shadow:0 10px 24px rgba(32,104,132,.11);
}

body.v531-no-internal-hero .triage-button.is-rescuer .triage-icon{
  background:#d9f0f6;
  color:#1e6f86;
}

body.v531-no-internal-hero .triage-button.is-selected{
  transform:none;
  border-width:2px;
  box-shadow:0 0 0 4px rgba(0,166,166,.13), 0 12px 28px rgba(8,46,61,.12) !important;
}

body.v531-no-internal-hero .triage-button.is-selected::after{
  display:none !important;
  content:none !important;
}

@media (max-width: 760px){
  body.v531-no-internal-hero .triage-grid{
    gap:10px;
  }

  body.v531-no-internal-hero .triage-button{
    min-height:94px;
    padding:13px 14px;
    border-radius:16px;
    grid-template-columns:40px minmax(0, 1fr);
    gap:3px 12px;
  }

  body.v531-no-internal-hero .triage-button .triage-icon{
    width:40px;
    height:40px;
    border-radius:12px;
    font-size:1.25rem;
  }

  body.v531-no-internal-hero .triage-button strong{
    font-size:1.04rem;
  }

  body.v531-no-internal-hero .triage-button span:not(.triage-icon){
    font-size:.94rem;
  }
}


/* Temporarily hide the kit summary block. */
body.v531-no-internal-hero #v529-plan-kit{
  display:none !important;
}


/* Safe Ability SM 5.33 - compact approfondimenti, numbers, pins and SOS wording */
body.v533-compact-approfondimenti #v54-essential{
  display:grid !important;
  scroll-margin-top:104px;
}

body.v533-compact-approfondimenti .primary-nav a.is-active,
body.v533-compact-approfondimenti .pwa-tabbar a.is-active{
  background:#e7f4f1;
  color:#123a5a;
}

body.v533-compact-approfondimenti #v529-risk-playbook,
body.v533-compact-approfondimenti .primary-nav a[href="#v529-risk-playbook"],
body.v533-compact-approfondimenti .pwa-tabbar a[href="#v529-risk-playbook"],
body.v533-compact-approfondimenti .hero-actions a[href="#v529-risk-playbook"]{
  display:none !important;
}

.v533-risk-compact{
  display:grid;
  gap:14px;
  margin:0 0 14px;
  padding:14px;
  border:1px solid #cfe2de;
  border-radius:18px;
  background:linear-gradient(180deg,#ffffff 0%,#f6fbfa 100%);
}

.v533-risk-compact-head{display:grid;gap:4px;}
.v533-risk-compact-head span{color:#007f78;font-size:.78rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase;}
.v533-risk-compact-head strong{color:#062d3c;font-size:clamp(1.24rem,2.2vw,1.72rem);line-height:1.04;}
.v533-risk-compact-head p{max-width:820px;margin:0;color:#425f67;line-height:1.45;}

.v533-risk-mini-grid,.v533-sm-risk-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;}
.v533-risk-mini-card,.v533-sm-risk-card{border:1px solid #d5e3df;border-radius:14px;background:#fff;padding:12px;min-width:0;}
.v533-risk-mini-card{display:grid;gap:9px;}
.v533-risk-mini-card.is-fire,.v533-sm-risk-card.is-fire{background:#fff5f1;border-color:#efc7bb;}
.v533-risk-mini-card.is-quake,.v533-sm-risk-card.is-quake{background:#fffaf0;border-color:#efd9a8;}
.v533-risk-mini-card.is-snow{background:#f2f9ff;border-color:#c5ddf2;}
.v533-risk-mini-card.is-heat,.v533-sm-risk-card.is-heat{background:#fff7ed;border-color:#e9c69d;}
.v533-sm-risk-card.is-land{background:#f4fbf8;border-color:#bfded0;}
.v533-sm-risk-card.is-water{background:#f1f8ff;border-color:#c5dcf3;}
.v533-sm-risk-card.is-flood{background:#f0fbfa;border-color:#b9dfdc;}

.v533-risk-mini-top{display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;align-items:center;}
.v533-risk-dot{width:34px;height:34px;border-radius:12px;background:#e4f3ef;position:relative;}
.v533-risk-dot::after{content:'';position:absolute;inset:10px;border-radius:50%;background:#007f78;}
.v533-risk-mini-card.is-fire .v533-risk-dot{background:#fee6de;}
.v533-risk-mini-card.is-fire .v533-risk-dot::after{background:#d43b2c;}
.v533-risk-mini-card.is-quake .v533-risk-dot{background:#fff0c9;}
.v533-risk-mini-card.is-quake .v533-risk-dot::after{background:#c86a00;}
.v533-risk-mini-card.is-snow .v533-risk-dot{background:#dff0ff;}
.v533-risk-mini-card.is-snow .v533-risk-dot::after{background:#2b7dbd;}
.v533-risk-mini-card.is-heat .v533-risk-dot{background:#ffe6ce;}
.v533-risk-mini-card.is-heat .v533-risk-dot::after{background:#dc6803;}

.v533-risk-mini-card h4,.v533-sm-risk-card h4{margin:0;color:#062d3c;font-size:1rem;line-height:1.14;}
.v533-risk-mini-card p,.v533-sm-risk-card p{margin:0;color:#425f67;line-height:1.36;}
.v533-risk-mini-card ul{margin:0;padding-left:18px;color:#244a54;line-height:1.35;}
.v533-risk-mini-card li + li{margin-top:5px;}
.v533-risk-mini-card small{color:#003848;font-weight:900;}

.v533-sm-risk{display:grid;gap:10px;padding:12px;border-radius:16px;background:#f8fcfb;border:1px solid #d6e7e3;}
.v533-sm-risk-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-end;}
.v533-sm-risk-head strong{color:#062d3c;font-size:1.08rem;}
.v533-sm-risk-head span{max-width:660px;color:#526872;font-size:.92rem;line-height:1.35;text-align:right;}
.v533-sm-risk-card{display:grid;gap:8px;min-height:124px;}
.v533-sm-risk-card div{display:flex;justify-content:space-between;gap:8px;align-items:flex-start;}
.v533-sm-risk-card span{flex:0 0 auto;border-radius:999px;padding:6px 9px;background:#0a746b;color:#fff;font-size:.76rem;font-weight:900;text-transform:uppercase;}
.v533-sm-risk-card.is-fire span,.v533-sm-risk-card.is-heat span{background:linear-gradient(90deg,#d97706,#e43d30);}
.v533-sm-risk-card.is-quake span,.v533-sm-risk-card.is-land span{background:#d97706;}
.v533-sm-risk-card.is-water span{background:#2d7fbd;}
.v533-sm-risk-card.is-flood span{background:#096b63;}

.v533-risk-inclusive-note{display:grid;grid-template-columns:minmax(120px,180px) minmax(0,1fr);gap:14px;align-items:center;padding:12px 14px;border-radius:14px;border:1px solid #c9e4de;background:#f3fbf9;color:#244a54;}
.v533-risk-inclusive-note strong{color:#06433f;}
body.v533-compact-approfondimenti #v529-plan-kit{display:none !important;}

body.v533-compact-approfondimenti .pin-dot,
body.v533-compact-approfondimenti .v529-pin-sample,
body.v533-compact-approfondimenti .inclusive-pin{
  --pin-color:#0b625b;
  background:var(--pin-color) !important;
  box-shadow:0 0 0 2px #fff,0 0 0 3px rgba(6,47,61,.28),0 9px 18px rgba(6,47,61,.22);
}

body.v533-compact-approfondimenti .pin-dot.safe,
body.v533-compact-approfondimenti .inclusive-pin.safe,
body.v533-compact-approfondimenti .v529-pin-sample.safe{--pin-color:#006a6a;border-radius:50%;}
body.v533-compact-approfondimenti .pin-dot.restroom,
body.v533-compact-approfondimenti .inclusive-pin.restroom,
body.v533-compact-approfondimenti .v529-pin-sample.restroom{--pin-color:#008aa3;border-radius:5px;}
body.v533-compact-approfondimenti .pin-dot.power,
body.v533-compact-approfondimenti .inclusive-pin.power,
body.v533-compact-approfondimenti .v529-pin-sample.power{--pin-color:#b45309;border-radius:4px;}
body.v533-compact-approfondimenti .pin-dot.health,
body.v533-compact-approfondimenti .inclusive-pin.health,
body.v533-compact-approfondimenti .v529-pin-sample.health{--pin-color:#15803d;border-radius:50%;}
body.v533-compact-approfondimenti .pin-dot.transport,
body.v533-compact-approfondimenti .inclusive-pin.transport,
body.v533-compact-approfondimenti .v529-pin-sample.transport{--pin-color:#6d28d9;border-radius:5px 50% 50% 50%;}
body.v533-compact-approfondimenti .pin-dot.elevator,
body.v533-compact-approfondimenti .inclusive-pin.elevator,
body.v533-compact-approfondimenti .v529-pin-sample.elevator{--pin-color:#475569;border-radius:4px;}
body.v533-compact-approfondimenti .pin-dot.road,
body.v533-compact-approfondimenti .inclusive-pin.road,
body.v533-compact-approfondimenti .v529-pin-sample.road{--pin-color:#92400e;border-radius:2px;}
body.v533-compact-approfondimenti .pin-dot.inaccessible,
body.v533-compact-approfondimenti .inclusive-pin.inaccessible,
body.v533-compact-approfondimenti .v529-pin-sample.inaccessible{--pin-color:#dc2626;border-radius:50% 50% 50% 4px;}
body.v533-compact-approfondimenti .pin-dot.volunteers,
body.v533-compact-approfondimenti .inclusive-pin.volunteers,
body.v533-compact-approfondimenti .v529-pin-sample.volunteers{--pin-color:#be185d;border-radius:50% 4px 50% 50%;}
body.v533-compact-approfondimenti .pin-dot.calm,
body.v533-compact-approfondimenti .inclusive-pin.calm,
body.v533-compact-approfondimenti .v529-pin-sample.calm{--pin-color:#0ea5e9;border-radius:999px;}
body.v533-compact-approfondimenti .pin-dot.waiting,
body.v533-compact-approfondimenti .inclusive-pin.waiting,
body.v533-compact-approfondimenti .v529-pin-sample.waiting{--pin-color:#1e3a8a;border-radius:5px 5px 50% 50%;}
body.v533-compact-approfondimenti .pin-dot.alert,
body.v533-compact-approfondimenti .inclusive-pin.alert,
body.v533-compact-approfondimenti .v529-pin-sample.alert{--pin-color:#2563eb;border-radius:50% 50% 4px 50%;}

body.v533-compact-approfondimenti .inclusive-pin.power,
body.v533-compact-approfondimenti .inclusive-pin.transport,
body.v533-compact-approfondimenti .inclusive-pin.elevator,
body.v533-compact-approfondimenti .inclusive-pin.road,
body.v533-compact-approfondimenti .inclusive-pin.calm,
body.v533-compact-approfondimenti .inclusive-pin.waiting{
  font-size:.58rem;
  letter-spacing:0;
}

body.v533-compact-approfondimenti .inclusive-map-legend label{
  gap:9px;
  background:#fbfefd;
}

body.v533-compact-approfondimenti .v514-toggle span{font-size:0;}
body.v533-compact-approfondimenti .v514-toggle span::before{content:'Anteprima SOS';font-size:1rem;}

@media (max-width:980px){
  .v533-risk-mini-grid,.v533-sm-risk-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .v533-sm-risk-head{display:grid;align-items:start;}
  .v533-sm-risk-head span{text-align:left;}
}

@media (max-width:640px){
  body.v533-compact-approfondimenti #v54-essential{grid-template-columns:1fr !important;}
  .v533-risk-compact{padding:11px;border-radius:16px;}
  .v533-risk-mini-grid,.v533-sm-risk-grid{grid-template-columns:1fr;}
  .v533-risk-inclusive-note{grid-template-columns:1fr;gap:5px;}
  .v533-sm-risk-card{min-height:0;}
}
body.v533-compact-approfondimenti #sanmarino > .section-heading{
  display:none !important;
}

body.v533-compact-approfondimenti #sanmarino.local-risk-section{
  padding-top:clamp(12px,2vw,20px);
}

body.v533-compact-approfondimenti .v511-action-grid .v511-action[href="#contatti-ufficiali"],
body.v533-compact-approfondimenti .v511-action-grid .v511-action[href="#v54-essential"]{
  display:none !important;
}
body.v533-compact-approfondimenti #localRiskGrid{
  display:none !important;
}
body.v533-compact-approfondimenti #v54-comunità-crpd-e-istituzioni,
body.v533-compact-approfondimenti #v54-comunità-crpd-e-istituzioni{
  display:none !important;
}
#prepara.levelup-section{
  display:none !important;
}

/* Safe Ability SM 5.37 - cruscotto operativo di partenza */
body.v537-start-dashboard #v511-command.v537-start-dashboard{
  width:min(1180px, calc(100% - 32px));
  margin:14px auto 24px;
  display:block;
}

.v537-shell{
  display:grid;
  gap:14px;
  padding:clamp(16px, 2.4vw, 28px);
  border:1px solid rgba(6,47,61,.14);
  border-radius:18px;
  background:linear-gradient(180deg,#ffffff 0%,#f5fbf9 100%);
  box-shadow:0 16px 42px rgba(6,47,61,.08);
}

.v537-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:16px;
  align-items:start;
}

.v537-head h2{
  margin:0;
  color:#062f3d;
  font-size:clamp(2rem, 4vw, 3.6rem);
  line-height:1;
  letter-spacing:0;
}

.v537-head p{
  max-width:860px;
  margin:8px 0 0;
  color:#4b646b;
  font-size:clamp(1rem, 1.4vw, 1.18rem);
  line-height:1.42;
}

.v537-connectivity{
  min-height:42px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid #b9ddd5;
  background:#edf8f4;
  color:#064c47;
  font-size:.92rem;
  font-weight:900;
  text-align:center;
}

.v537-connectivity[data-state="offline"]{
  border-color:#e7c36b;
  background:#fff7df;
  color:#714900;
}

.v537-resilience{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:10px;
}

.v537-resilience div{
  min-height:86px;
  padding:13px 14px;
  border:1px solid rgba(6,47,61,.12);
  border-radius:14px;
  background:#fbfefd;
}

.v537-resilience strong,
.v537-resilience span{
  display:block;
}

.v537-resilience strong{
  color:#062f3d;
  font-size:.98rem;
  line-height:1.18;
}

.v537-resilience span{
  margin-top:5px;
  color:#4e676f;
  line-height:1.34;
}

.v537-primary-actions,
.v537-situation{
  display:grid;
  gap:12px;
}

.v537-primary-actions{
  grid-template-columns:repeat(4, minmax(0,1fr));
}

.v537-situation{
  grid-template-columns:repeat(3, minmax(0,1fr));
}

.v537-primary-card,
.v537-situation-card{
  min-width:0;
  text-align:left;
  text-decoration:none;
  color:#062f3d;
  border:1px solid rgba(6,47,61,.14);
  border-radius:18px;
  background:#fff;
  box-shadow:0 10px 24px rgba(6,47,61,.06);
}

.v537-primary-card{
  min-height:148px;
  display:grid;
  align-content:space-between;
  gap:12px;
  padding:18px;
}

.v537-primary-card > span,
.v537-situation-card > span{
  display:grid;
  place-items:center;
  width:44px;
  height:44px;
  border-radius:14px;
  background:#e7f6f2;
  color:#08766f;
  font-size:1.28rem;
  font-weight:950;
}

.v537-primary-card strong,
.v537-situation-card strong{
  display:block;
  color:inherit;
  font-size:clamp(1.18rem, 1.8vw, 1.5rem);
  line-height:1.08;
}

.v537-primary-card small,
.v537-situation-card small{
  display:block;
  margin-top:6px;
  color:#4e676f;
  font-size:1rem;
  line-height:1.34;
}

.v537-primary-card.is-sos,
.v537-situation-card.is-danger{
  color:#fff;
  border-color:#9d2a16;
  background:linear-gradient(135deg,#bd321e 0%,#8f250f 100%);
  box-shadow:0 14px 30px rgba(143,37,15,.17);
}

.v537-primary-card.is-sos > span,
.v537-situation-card.is-danger > span{
  background:rgba(255,255,255,.16);
  color:#fff;
}

.v537-primary-card.is-sos small,
.v537-situation-card.is-danger small{
  color:rgba(255,255,255,.9);
}

.v537-primary-card.is-plan{
  background:linear-gradient(135deg,#ffffff 0%,#effaf6 100%);
}

.v537-primary-card.is-map,
.v537-primary-card.is-rescuer,
.v537-situation-card.is-rescuer{
  border-color:#a6cfda;
  background:linear-gradient(135deg,#f8fdff 0%,#e7f5fb 100%);
}

.v537-situation-card{
  min-height:124px;
  display:grid;
  grid-template-columns:46px minmax(0,1fr);
  align-items:center;
  gap:6px 14px;
  padding:16px 18px;
  cursor:pointer;
  font:inherit;
}

.v537-situation-card > span{
  grid-row:1 / span 2;
}

.v537-primary-card.is-rescuer > span,
.v537-situation-card.is-rescuer > span{
  background:#d9f0f6;
  color:#1e6f86;
}

.v537-primary-card:hover,
.v537-primary-card:focus-visible,
.v537-situation-card:hover,
.v537-situation-card:focus-visible{
  transform:translateY(-1px);
  border-color:rgba(8,118,111,.34);
  outline:3px solid rgba(8,118,111,.16);
  outline-offset:2px;
}

body.v537-start-dashboard #emergenza-adesso > .operational-head,
body.v537-start-dashboard #emergenza-adesso > .triage-grid{
  display:none !important;
}


@media (min-width:901px) and (max-width:1120px){
  .v537-primary-actions{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }
}
@media (max-width:900px){
  .v537-head,
  .v537-resilience,
  .v537-primary-actions,
  .v537-situation{
    grid-template-columns:1fr;
  }
  .v537-connectivity{
    justify-content:flex-start;
    border-radius:14px;
  }
  .v537-primary-card{
    min-height:118px;
  }
}

@media (max-width:620px){
  body.v537-start-dashboard #v511-command.v537-start-dashboard{
    width:min(100% - 20px, 1180px);
    margin-top:10px;
  }
  .v537-shell{
    padding:13px;
    border-radius:16px;
    gap:11px;
  }
  .v537-head h2{
    font-size:clamp(2rem, 10vw, 3rem);
  }
  .v537-resilience div{
    min-height:0;
  }
  .v537-primary-card,
  .v537-situation-card{
    border-radius:16px;
  }
  .v537-primary-card{
    min-height:104px;
    padding:15px;
  }
  .v537-situation-card{
    min-height:92px;
    grid-template-columns:40px minmax(0,1fr);
    padding:13px 14px;
    gap:4px 12px;
  }
  .v537-primary-card > span,
  .v537-situation-card > span{
    width:40px;
    height:40px;
    border-radius:12px;
  }
  .v537-primary-card small,
  .v537-situation-card small{
    font-size:.94rem;
  }
}
/* Safe Ability SM 5.38 - filtri mappa più puliti */
body.v537-start-dashboard .inclusive-map-legend label .pin-dot{
  display:none !important;
}

body.v537-start-dashboard .inclusive-map-legend label{
  grid-template-columns:auto minmax(0,1fr);
  gap:10px;
}
/* Safe Ability SM 5.40 - credito progetto */
.project-credit{
  max-width:1120px;
  margin:18px auto 88px;
  padding:0 18px;
  color:#5c7380;
  font-size:0.82rem;
  line-height:1.45;
  text-align:center;
}

@media (min-width:760px){
  .project-credit{
    margin-bottom:32px;
  }
}


/* Safe Ability SM 5.74 - aiutare pulito */
body[data-static-page]:not(.safe-pages-ready) #main > section {
  display: none !important;
}

body[data-static-page="aiutare"]:not(.safe-pages-ready) #soccorritori-caregiver,
body[data-static-page="aiutare"]:not(.safe-pages-ready) #caregiver-operativo,
body[data-static-page="aiutare"]:not(.safe-pages-ready) #eventi-accessibili,
body[data-static-page="piano"]:not(.safe-pages-ready) #profilo-completo,
body[data-static-page="piano"]:not(.safe-pages-ready) #piano,
body[data-static-page="piano"]:not(.safe-pages-ready) #qr-emergenza,
body[data-static-page="piano"]:not(.safe-pages-ready) #documenti-essenziali,
body[data-static-page="piano"]:not(.safe-pages-ready) #presidio,
body[data-static-page="sos"]:not(.safe-pages-ready) #v54-essential,
body[data-static-page="sos"]:not(.safe-pages-ready) #emergenza-adesso,
body[data-static-page="sos"]:not(.safe-pages-ready) #contatti-ufficiali,
body[data-static-page="sos"]:not(.safe-pages-ready) #emergenza,
body[data-static-page="sos"]:not(.safe-pages-ready) #sos-guidati,
body[data-static-page="mappa"]:not(.safe-pages-ready) #sanmarino,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #direttrice,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #atlante,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #scenario,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #prima,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #sa-bussola,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #v54-approfondimenti,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #v529-risk-playbook,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #v533-risk-compact,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #rischio-momento,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #crisi-climatica,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #v519-framework,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #risorse,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #master-advanced-gate,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #focus-gate,
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #istituzioni {
  display: block !important;
}

/* 5.60: la schermata ingresso vive solo nella home, non nelle pagine interne. */
body[data-static-page] #v515-entry {
  display: none !important;
}
.physical-page-hero {
  width: min(1180px, calc(100% - 28px));
  margin: clamp(18px, 3vw, 34px) auto 10px;
  padding: clamp(18px, 3vw, 30px);
  border: 1px solid rgba(0, 166, 166, .22);
  border-radius: 24px;
  background: linear-gradient(135deg, #ffffff 0%, #f2fbfa 100%);
  box-shadow: 0 18px 54px rgba(9, 44, 58, .08);
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(260px, .7fr);
  gap: clamp(18px, 3vw, 30px);
  align-items: center;
}

.physical-page-kicker {
  margin: 0 0 8px;
  color: #007a72;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .82rem;
}

.physical-page-copy h1 {
  margin: 0;
  color: #062f3e;
  font-size: clamp(2rem, 5vw, 4.1rem);
  line-height: .98;
}

.physical-page-copy p {
  margin: 14px 0 0;
  max-width: 760px;
  color: #405c69;
  font-size: clamp(1.02rem, 1.7vw, 1.28rem);
  line-height: 1.42;
}

.physical-page-panel {
  display: grid;
  gap: 10px;
}

.physical-page-panel span {
  min-height: 46px;
  display: flex;
  align-items: center;
  padding: 10px 13px;
  border: 1px solid rgba(18, 58, 90, .14);
  border-radius: 14px;
  background: rgba(255, 255, 255, .82);
  color: #063243;
  font-weight: 900;
  box-shadow: 0 8px 24px rgba(9, 44, 58, .06);
}

.physical-page-hero--sos {
  border-color: rgba(255, 107, 94, .32);
  background: linear-gradient(135deg, #fff8f6 0%, #ffffff 72%);
}

.physical-page-hero--piano {
  border-color: rgba(247, 197, 45, .42);
  background: linear-gradient(135deg, #fffaf0 0%, #ffffff 72%);
}

.physical-page-hero--mappa {
  border-color: rgba(42, 119, 181, .30);
  background: linear-gradient(135deg, #f3f9ff 0%, #ffffff 74%);
}

.physical-page-hero--altro {
  border-color: rgba(104, 216, 211, .38);
  background: linear-gradient(135deg, #f4fffd 0%, #ffffff 74%);
}

.physical-page-panel--numbers span {
  border-color: rgba(255, 107, 94, .28);
}

@media (max-width: 760px) {
  .physical-page-hero {
    grid-template-columns: 1fr;
    border-radius: 18px;
    padding: 18px;
  }

  .physical-page-copy h1 {
    font-size: clamp(1.9rem, 10vw, 3rem);
  }
}
body.v545-remake [data-safe-page-hidden],
body.v545-remake [data-sa-page-hidden] {
  display: none !important;
}

body.v545-remake.safe-pages-ready:not(.v515-entry-active) #main {
  min-height: calc(100vh - 170px);
  padding-bottom: clamp(82px, 12vh, 130px);
}

body.v545-remake.safe-pages-ready:not(.v515-entry-active) #home.hero,
body.v545-remake.safe-pages-ready:not(.v515-entry-active) .primary-hub,
body.v545-remake.safe-pages-ready:not(.v515-entry-active) .now-board {
  display: none !important;
}

body.v545-remake .primary-nav,
body.v545-remake .pwa-tabbar {
  align-items: center;
}

body.v545-remake .primary-nav a,
body.v545-remake .pwa-tabbar a {
  border-radius: 12px;
  transition: background .18s ease, color .18s ease, box-shadow .18s ease;
}

/* 5.64: stato attivo basato sulla pagina, stabile anche dopo navigazione mobile. */
body.v545-remake[data-sa-active-view="aiutare"] [data-sa-page-link="aiutare"],
body.v545-remake[data-safe-page="aiutare"] [data-sa-page-link="aiutare"],
body.v545-remake[data-sa-active-view="piano"] [data-sa-page-link="piano"],
body.v545-remake[data-safe-page="piano"] [data-sa-page-link="piano"],
body.v545-remake[data-sa-active-view="sos"] [data-sa-page-link="sos"],
body.v545-remake[data-safe-page="sos"] [data-sa-page-link="sos"],
body.v545-remake[data-sa-active-view="mappa"] [data-sa-page-link="mappa"],
body.v545-remake[data-safe-page="mappa"] [data-sa-page-link="mappa"],
body.v545-remake[data-sa-active-view="approfondimenti"] [data-sa-page-link="approfondimenti"],
body.v545-remake[data-safe-page="approfondimenti"] [data-sa-page-link="approfondimenti"],
body.v545-remake .primary-nav a.is-active,
body.v545-remake .pwa-tabbar a.is-active {
  background: rgba(0, 166, 166, .13);
  color: #0b3f4b;
  box-shadow: inset 0 0 0 1px rgba(0, 166, 166, .18);
}

body.v545-remake .topbar .primary-nav {
  gap: clamp(8px, 1.3vw, 18px);
}

body.v545-remake .topbar .primary-nav a {
  padding: 10px 12px;
  white-space: nowrap;
}

body.v545-remake main > section[data-safe-view]:not([data-safe-view="hidden"]) {
  scroll-margin-top: 112px;
}

body.v545-remake #emergenza-adesso,
body.v545-remake #profilo-completo,
body.v545-remake #sanmarino,
body.v545-remake #soccorritori-caregiver,
body.v545-remake #v54-approfondimenti,
body.v545-remake #emergenza,
body.v545-remake #piano,
body.v545-remake #presidio,
body.v545-remake #risorse {
  margin-top: clamp(16px, 2.5vw, 28px) !important;
}

body.v545-remake #v54-essential {
  width: min(100% - 28px, 1180px) !important;
  margin: 18px auto clamp(22px, 3vw, 38px) !important;
}

body.v545-remake[data-safe-page="sos"] #emergenza-adesso,
body.v545-remake[data-sa-active-view="sos"] #emergenza-adesso {
  border-color: rgba(255, 107, 94, .32) !important;
}

body.v545-remake[data-safe-page="mappa"] #sanmarino .section-heading,
body.v545-remake[data-sa-active-view="mappa"] #sanmarino .section-heading {
  max-width: min(1180px, calc(100% - 28px));
  margin-left: auto;
  margin-right: auto;
}

body.v545-remake .sticky-emergency {
  display: none !important;
}

body.v545-remake .project-credit {
  margin-bottom: clamp(70px, 10vh, 96px);
}

@media (max-width: 820px) {
  body.v545-remake .topbar .primary-nav {
    display: none !important;
  }

  body.v545-remake .pwa-tabbar {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  body.v545-remake .pwa-tabbar a {
    min-width: 0;
    padding: 9px 4px;
    font-size: .84rem;
    line-height: 1.05;
  }
}

@media (max-width: 390px) {
  body.v545-remake .pwa-tabbar a {
    font-size: .76rem;
  }
}
body.v545-remake[data-safe-page="aiutare"] #soccorritori-caregiver,
body.v545-remake[data-sa-active-view="aiutare"] #soccorritori-caregiver {
  border-color: rgba(0, 166, 166, .24) !important;
}

body.v545-remake .sa-compass-section {
  width: min(100% - 28px, 1180px) !important;
  margin: clamp(16px, 2.5vw, 28px) auto !important;
}

body.v545-remake .sa-compass-card {
  margin-top: 14px;
  border: 1px solid rgba(0, 166, 166, .20);
  box-shadow: 0 16px 42px rgba(9,44,58,.08);
}

body.v545-remake .sa-compass-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 8px;
}

body.v545-remake .sa-compass-actions .primary-action,
body.v545-remake .sa-compass-actions .secondary-action {
  min-height: 44px;
  padding: 10px 14px;
}

@media (max-width: 520px) {
  body.v545-remake .sa-compass-actions .primary-action,
  body.v545-remake .sa-compass-actions .secondary-action {
    width: 100%;
  }
}
/* 5.50: la navigazione usa bottoni reali, non link/ancore. */
body.v545-remake .primary-nav button,
body.v545-remake .pwa-tabbar button {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--safe-blue, #123A5A);
  font: inherit;
  font-weight: 900;
  cursor: pointer;
  border-radius: 12px;
  transition: background .18s ease, color .18s ease, box-shadow .18s ease;
}

body.v545-remake .primary-nav button.is-active,
body.v545-remake .pwa-tabbar button.is-active {
  background: rgba(0, 166, 166, .13);
  color: #0b3f4b;
  box-shadow: inset 0 0 0 1px rgba(0, 166, 166, .18);
}

body.v545-remake .topbar .primary-nav button {
  padding: 10px 12px;
  white-space: nowrap;
}

@media (max-width: 680px) {
  body.v545-remake .pwa-tabbar button {
    min-width: 0;
    padding: 9px 4px;
    font-size: .84rem;
    line-height: 1.05;
  }
}

@media (max-width: 380px) {
  body.v545-remake .pwa-tabbar button {
    font-size: .76rem;
  }
}

/* 5.54: pagine fisiche pulite, senza indici legacy ripetuti. */
body.v545-remake #v55-index,
body.v545-remake #v52-home-actions,
body.v545-remake #v52-support-nav {
  display: none !important;
}

/* 5.55: rimuove il toggle ambiguo Prova SOS. */
body.v545-remake .v514-practice-row {
  display: none !important;
}

body.v545-remake[data-safe-page="sos"] #v54-essential,
body.v545-remake[data-sa-active-view="sos"] #v54-essential {
  display: grid !important;
  margin-top: clamp(12px, 2vw, 22px) !important;
}
/* 5.55: regola finale, vince sui vecchi display important. */
body.v545-remake.safe-pages-ready main > section[data-safe-page-hidden],
body.v545-remake.safe-pages-ready main > section[data-sa-page-hidden] {
  display: none !important;
}
/* 5.55: nasconde anche blocchi dinamici non figli diretti del main. */
body.v545-remake.safe-pages-ready [data-safe-page-hidden],
body.v545-remake.safe-pages-ready [data-sa-page-hidden] {
  display: none !important;
}
/* 5.65: le pagine interne entrano subito nel contenuto, senza fasce ripetitive. */
body[data-static-page] .physical-page-hero {
  display: none !important;
}

body[data-static-page].v545-remake.safe-pages-ready:not(.v515-entry-active) #main {
  padding-top: clamp(14px, 2.5vw, 28px);
}

/* 5.65: la guida inclusiva lunga resta sostituita da una nota compatta in Aiutare. */
body.v545-remake #guida.principle-guide {
  display: none !important;
}

.inclusive-question-note {
  margin: clamp(12px, 2vw, 18px) 0 clamp(16px, 2.5vw, 24px);
  padding: clamp(16px, 2.4vw, 22px);
  border: 1px solid rgba(0, 166, 166, .18);
  border-left: 6px solid #00a6a6;
  border-radius: 16px;
  background: #f7fffe;
  color: #123a5a;
  box-shadow: 0 12px 34px rgba(9, 44, 58, .06);
}

.inclusive-question-note p {
  margin: 0;
  max-width: 980px;
  font-size: clamp(.98rem, 1.25vw, 1.08rem);
  line-height: 1.48;
}

.inclusive-question-note p + p {
  margin-top: 10px;
}

.inclusive-question-note strong {
  color: #063243;
}
/* 5.65: SOS senza generatore doppio. */
body.v545-remake #sos-guidati {
  display: none !important;
}
/* 5.65: Mappa solo operativa AA, senza doppioni introduttivi. */
body.v545-remake[data-safe-page="mappa"] #sanmarino > .section-heading,
body.v545-remake[data-sa-active-view="mappa"] #sanmarino > .section-heading,
body.v545-remake[data-safe-page="mappa"] #sanmarino .san-marino-map-shell,
body.v545-remake[data-sa-active-view="mappa"] #sanmarino .san-marino-map-shell {
  display: none !important;
}

body.v545-remake[data-safe-page="mappa"] #sanmarino,
body.v545-remake[data-sa-active-view="mappa"] #sanmarino {
  padding-top: 0;
}

body.v545-remake[data-safe-page="mappa"] .inclusive-map-area,
body.v545-remake[data-sa-active-view="mappa"] .inclusive-map-area {
  margin-top: 0;
}

body.v545-remake[data-safe-page="mappa"] .inclusive-map-legend label:not(:has([data-map-type="waiting"])),
body.v545-remake[data-sa-active-view="mappa"] .inclusive-map-legend label:not(:has([data-map-type="waiting"])) {
  display: none !important;
}

body.v545-remake[data-safe-page="mappa"] .inclusive-map-legend,
body.v545-remake[data-sa-active-view="mappa"] .inclusive-map-legend {
  grid-template-columns: minmax(220px, 1fr);
}
/* 5.66: kit 72 ore accessibile integrato nel Piano personale. */
body.v545-remake .sa-kit-accessible {
  padding: clamp(20px, 3vw, 32px) !important;
}

body.v545-remake .sa-kit-head {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(260px, .65fr);
  gap: clamp(14px, 2vw, 24px);
  align-items: start;
  margin-bottom: clamp(16px, 2.2vw, 24px);
}

body.v545-remake .sa-kit-head h2 {
  margin: 6px 0 8px;
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: .98;
  letter-spacing: 0;
}

body.v545-remake .sa-kit-head p {
  margin: 0;
  max-width: 760px;
}

body.v545-remake .sa-kit-reminder {
  padding: 16px;
  border: 1px solid rgba(0, 166, 166, .18);
  border-radius: 16px;
  background: #f7fffe;
}

body.v545-remake .sa-kit-reminder span,
body.v545-remake .sa-kit-notes span {
  display: block;
  margin-bottom: 6px;
  color: #007a78;
  font-size: .82rem;
  font-weight: 900;
  text-transform: uppercase;
}

body.v545-remake .sa-kit-reminder strong {
  display: block;
  margin-bottom: 6px;
  color: #063243;
  font-size: 1.08rem;
}

body.v545-remake .sa-kit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

body.v545-remake .sa-kit-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  min-height: 82px;
  padding: 14px;
  border: 1px solid rgba(18, 58, 90, .14);
  border-radius: 14px;
  background: #fff;
}

body.v545-remake .sa-kit-item input {
  width: 22px;
  height: 22px;
  margin-top: 2px;
}

body.v545-remake .sa-kit-item strong {
  display: block;
  color: #063243;
  font-size: 1rem;
  line-height: 1.2;
}

body.v545-remake .sa-kit-item small {
  display: block;
  margin-top: 4px;
  color: #3f5f6c;
  font-size: .92rem;
  line-height: 1.32;
}

body.v545-remake .sa-kit-notes {
  display: block;
  margin-top: 14px;
}

body.v545-remake .sa-kit-notes textarea {
  width: 100%;
  min-height: 108px;
  resize: vertical;
  border: 1px solid rgba(18, 58, 90, .14);
  border-radius: 14px;
  padding: 14px;
  font: inherit;
  color: #063243;
  background: #fff;
}

body.v545-remake .sa-kit-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

body.v545-remake .sa-kit-actions .primary-action,
body.v545-remake .sa-kit-actions .secondary-action {
  min-height: 48px;
  padding: 11px 16px;
}

@media (max-width: 760px) {
  body.v545-remake .sa-kit-head,
  body.v545-remake .sa-kit-grid {
    grid-template-columns: 1fr;
  }

  body.v545-remake .sa-kit-head h2 {
    font-size: clamp(2rem, 11vw, 3rem);
  }
}

@media (max-width: 520px) {
  body.v545-remake .sa-kit-accessible {
    padding: 16px !important;
  }

  body.v545-remake .sa-kit-actions .primary-action,
  body.v545-remake .sa-kit-actions .secondary-action {
    width: 100%;
  }
}
/* 5.68: numeri ufficiali compatti nella pagina SOS. */
body.v545-remake .sa-sos-numbers {
  width: min(1180px, calc(100% - 28px));
  margin: clamp(12px, 2vw, 22px) auto clamp(16px, 2.5vw, 28px);
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(280px, .95fr);
  gap: 16px;
}

body.v545-remake .sa-sos-number-card {
  border-radius: 20px;
  padding: clamp(18px, 2.4vw, 26px);
  border: 1px solid rgba(18, 58, 90, .12);
  box-shadow: 0 18px 44px rgba(9, 44, 58, .08);
}

body.v545-remake .sa-sos-number-card h2 {
  margin: 0 0 10px;
  font-size: clamp(1.35rem, 2.2vw, 1.9rem);
  line-height: 1.1;
}

body.v545-remake .sa-sos-number-card p {
  margin: 0;
  line-height: 1.42;
}

body.v545-remake .sa-sos-number-card--dark {
  background: #082923;
  color: #fff;
}

body.v545-remake .sa-sos-number-card--note {
  background: #fff7e8;
  border-color: rgba(230, 148, 35, .32);
  color: #2d2100;
}

body.v545-remake .sa-sos-number-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

body.v545-remake .sa-sos-number-links a {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 9px 14px;
  border-radius: 999px;
  background: #fff;
  color: #063243;
  font-weight: 900;
  text-decoration: none;
}

@media (max-width: 760px) {
  body.v545-remake .sa-sos-numbers {
    grid-template-columns: 1fr;
  }

  body.v545-remake .sa-sos-number-links a {
    width: 100%;
    justify-content: center;
  }
}
/* 5.72: elimina duplicazioni e riposiziona i contenuti operativi in Aiutare. */
body.v545-remake #prepara {
  display: none !important;
}

body.v545-remake #soccorritori-caregiver .levelup-grid,
body.v545-remake #soccorritori-caregiver .compact-grid {
  display: none !important;
}

body.v545-remake[data-safe-page="aiutare"] #v533-risk-compact,
body.v545-remake[data-sa-active-view="aiutare"] #v533-risk-compact {
  display: block !important;
  width: min(100% - 28px, 1180px) !important;
  margin: clamp(16px, 2.5vw, 28px) auto !important;
}

body.v545-remake #v533-risk-compact .v533-risk-compact-head span {
  display: none !important;
}

body.v545-remake #v513-triage-cue {
  background: #e7f7f6;
  color: #06484b;
}
body[data-static-page="approfondimenti"]:not(.safe-pages-ready) #v533-risk-compact {
  display: none !important;
}
body.v545-remake[data-safe-page="piano"] #prepara,
body.v545-remake[data-sa-active-view="piano"] #prepara,
body.v545-remake.safe-pages-ready #prepara {
  display: none !important;
}

/* 5.83: Kit 72 ore spostato nella pagina Piano personale. */
body.v545-remake[data-safe-page="piano"] #v529-plan-kit,
body.v545-remake[data-sa-active-view="piano"] #v529-plan-kit {
  display: block !important;
}
body.v545-remake[data-safe-page="approfondimenti"] #v529-plan-kit,
body.v545-remake[data-sa-active-view="approfondimenti"] #v529-plan-kit {
  display: none !important;
}
/* 5.84: quadro rischi unico e scheda operativa in Aiutare. */
body.v545-remake .v533-risk-unified-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
body.v545-remake .v533-risk-unified-card{
  padding:15px;
  gap:10px;
  min-height:0;
}
body.v545-remake .v533-risk-unified-card .v533-risk-mini-top{
  grid-template-columns:34px minmax(0,1fr) auto;
}
body.v545-remake .v533-risk-level{
  align-self:start;
  border-radius:999px;
  padding:6px 9px;
  background:#0a746b;
  color:#fff;
  font-size:.72rem;
  font-weight:900;
  line-height:1;
  text-transform:uppercase;
  white-space:nowrap;
}
body.v545-remake .v533-risk-unified-card.is-fire .v533-risk-level,
body.v545-remake .v533-risk-unified-card.is-heat .v533-risk-level{background:linear-gradient(90deg,#d97706,#e43d30);}
body.v545-remake .v533-risk-unified-card.is-quake .v533-risk-level,
body.v545-remake .v533-risk-unified-card.is-land .v533-risk-level,
body.v545-remake .v533-risk-unified-card.is-snow .v533-risk-level{background:#d97706;}
body.v545-remake .v533-risk-unified-card.is-water .v533-risk-level{background:#2d7fbd;}
body.v545-remake .v533-risk-action,
body.v545-remake .v533-risk-inclusive{
  margin:0;
  color:#244a54;
  line-height:1.42;
}
body.v545-remake .v533-risk-inclusive{
  padding-top:8px;
  border-top:1px solid rgba(6,47,61,.1);
}
body.v545-remake .v533-risk-unified-card.is-land{background:#f4fbf8;border-color:#bfded0;}
body.v545-remake .v533-risk-unified-card.is-land .v533-risk-dot{background:#e3f3ec;}
body.v545-remake .v533-risk-unified-card.is-land .v533-risk-dot::after{background:#0a746b;}
body.v545-remake .v533-risk-unified-card.is-water{background:#f1f8ff;border-color:#c5dcf3;}
body.v545-remake .v533-risk-unified-card.is-water .v533-risk-dot{background:#dbeeff;}
body.v545-remake .v533-risk-unified-card.is-water .v533-risk-dot::after{background:#2d7fbd;}
body.v545-remake #cosa-fare{
  margin-top:clamp(16px,2.4vw,28px);
}
@media (max-width:980px){
  body.v545-remake .v533-risk-unified-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:640px){
  body.v545-remake .v533-risk-unified-grid{grid-template-columns:1fr;}
  body.v545-remake .v533-risk-unified-card .v533-risk-mini-top{grid-template-columns:34px minmax(0,1fr);}
  body.v545-remake .v533-risk-level{grid-column:2;justify-self:start;margin-top:2px;}
}
/* Safe Ability SM 5.88 - nasconde solo il testo introduttivo ritagliato negli approfondimenti */
body.v545-remake #v54-approfondimenti .v54-accordion-head p{
  display:none !important;
}

/* Safe Ability SM 5.88 - pill Approfondimenti rimosse e scheda operativa stabile in Aiutare */
body[data-static-page="aiutare"]:not(.safe-pages-ready) #v533-risk-compact,
body[data-static-page="aiutare"]:not(.safe-pages-ready) #cosa-fare {
  display: block !important;
}

body.v545-remake[data-safe-page="aiutare"] #cosa-fare,
body.v545-remake[data-sa-active-view="aiutare"] #cosa-fare {
  display: block !important;
  width: min(100% - 28px, 1180px) !important;
  margin: clamp(16px, 2.5vw, 28px) auto clamp(32px, 5vw, 64px) !important;
}



/* Safe Ability SM 5.90 - blocchi rimossi su richiesta: niente lampi visuali */
#rischi-accessibili,
#dati-locali,
#crisi-climatica {
  display: none !important;
}

/* Safe Ability SM 5.91 - Home stabile su mobile: niente stati intermedi visibili */
html.sa-home-stabilizing body {
  opacity: 0 !important;
  animation: none !important;
}

html.sa-home-stable body {
  opacity: 1 !important;
  animation: none !important;
}

body.sa-home-entry-locked.v515-entry-active {
  min-height: 100svh;
  overflow-x: hidden;
  background: #f6faf7;
}

body.sa-home-entry-locked.v515-entry-active .skip-link,
body.sa-home-entry-locked.v515-entry-active .app-shell,
body.sa-home-entry-locked.v515-entry-active .pwa-tabbar {
  display: none !important;
}

body.sa-home-entry-locked #v515-entry {
  display: block !important;
  min-height: 100svh;
  visibility: visible !important;
  opacity: 1 !important;
}

body.sa-home-entry-locked #v515-entry[hidden] {
  display: block !important;
}

body.sa-home-entry-locked .v515-entry-shell {
  min-height: 100svh !important;
  width: 100% !important;
  padding: 0 !important;
}

body.sa-home-entry-locked .v530-entry-home {
  min-height: min(780px, calc(100svh - 44px)) !important;
}

@media (max-width: 700px) {
  body.sa-home-entry-locked .v530-entry-home {
    width: 100% !important;
    min-height: 100svh !important;
    max-width: none !important;
    padding: 10px !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(32svh, 40svh) auto !important;
    gap: 10px !important;
  }

  body.sa-home-entry-locked .v530-entry-hero {
    min-height: 32svh !important;
    max-height: 40svh !important;
    border-radius: 18px !important;
  }

  body.sa-home-entry-locked .v530-entry-hero img {
    min-height: 32svh !important;
    max-height: 40svh !important;
    height: 40svh !important;
    object-fit: cover !important;
    object-position: center !important;
  }

  body.sa-home-entry-locked .v530-entry-panel {
    min-height: auto !important;
    padding: 16px !important;
    border-radius: 18px !important;
    gap: 12px !important;
  }

  body.sa-home-entry-locked .v530-entry-logo {
    max-height: 96px !important;
  }

  body.sa-home-entry-locked .v530-entry-line {
    font-size: 0.98rem !important;
    line-height: 1.36 !important;
  }

  body.sa-home-entry-locked .v530-risk {
    min-height: 54px !important;
  }
}
/* Safe Ability SM 5.92 - consolidamento stabilita, mobile e strumenti */
html.sa-v592-stable body,
html.sa-v592-stable .topbar,
html.sa-v592-stable .brand,
html.sa-v592-stable main {
  animation: none !important;
}

body.safe-pages-ready main > section[data-safe-page-hidden],
body.safe-pages-ready main > section[data-sa-page-hidden],
body.sa-v592-page main > section[data-safe-page-hidden],
body.sa-v592-page main > section[data-sa-page-hidden] {
  display: none !important;
  visibility: hidden !important;
}

.topbar {
  min-height: 88px;
  contain: layout paint;
}

.topbar .brand {
  min-width: min(420px, 46vw);
  min-height: 64px;
}

.topbar .brand img,
.brand-logo {
  width: 58px;
  height: 58px;
  flex: 0 0 58px;
}

.primary-nav a,
.pwa-tabbar a,
[data-sa-page-link] {
  touch-action: manipulation;
}

html.sa-home-stabilizing body {
  opacity: 0 !important;
  pointer-events: none !important;
}

html.sa-home-stable body {
  opacity: 1 !important;
  pointer-events: auto !important;
}

body.sa-home-entry-locked .app-shell,
body.sa-home-entry-locked .pwa-tabbar,
body.sa-home-entry-locked .skip-link {
  display: none !important;
}

body.sa-home-entry-locked #v515-entry {
  display: block !important;
  min-height: 100svh;
}

.v530-entry-actions [data-install-app][hidden],
.install-hint[hidden] {
  display: none !important;
}

.sa-compass-card {
  display: grid;
  grid-template-columns: minmax(180px, 260px) 1fr;
  gap: clamp(18px, 4vw, 36px);
  align-items: center;
  border: 1px solid rgba(0, 166, 166, 0.22);
  border-radius: 22px;
  padding: clamp(18px, 4vw, 34px);
  background: linear-gradient(135deg, #f7fffd, #ffffff);
  box-shadow: 0 24px 70px rgba(18, 58, 90, 0.08);
}

.compass-dial {
  position: relative;
  aspect-ratio: 1;
  border-radius: 999px;
  border: 12px solid #123a5a;
  background: radial-gradient(circle at 50% 50%, #ffffff 0 28%, #e8f7f6 29% 100%);
  display: grid;
  place-items: start center;
  padding-top: 16px;
  color: #123a5a;
  font-weight: 900;
  box-shadow: inset 0 0 0 2px rgba(0, 166, 166, 0.22);
}

.compass-needle {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 16px;
  height: 42%;
  transform-origin: 50% 100%;
  transform: translate(-50%, -100%) rotate(0deg);
  border-radius: 999px 999px 4px 4px;
  background: linear-gradient(#ff6b5e 0 50%, #123a5a 50% 100%);
  transition: transform 180ms ease;
}

.compass-needle::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -10px;
  width: 22px;
  height: 22px;
  transform: translateX(-50%);
  border-radius: 999px;
  background: #ffffff;
  border: 5px solid #123a5a;
}

.compass-readout {
  display: grid;
  gap: 12px;
}

.compass-readout strong {
  font-size: clamp(1.6rem, 4vw, 2.8rem);
  line-height: 1.05;
  color: #073040;
}

.sa-compass-actions,
.sa-kit-actions,
.sa-admin-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}

.sa-admin-note,
.install-hint,
.sa-update-banner {
  border: 1px solid rgba(0, 166, 166, 0.22);
  border-radius: 18px;
  padding: 16px 18px;
  background: #f4fbfa;
  color: #073040;
}

.sa-update-banner {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: calc(16px + env(safe-area-inset-bottom, 0px));
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  max-width: 780px;
  margin: 0 auto;
  box-shadow: 0 20px 60px rgba(18, 58, 90, 0.18);
}

.sa-update-banner button {
  min-height: 44px;
}

.sa-kit-accessible {
  display: block !important;
}

.sa-kit-head {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(260px, 0.8fr);
  gap: clamp(18px, 4vw, 34px);
  align-items: stretch;
}

.sa-kit-reminder {
  border: 1px solid rgba(245, 193, 48, 0.55);
  border-radius: 18px;
  padding: 18px;
  background: #fff8e6;
}

.sa-kit-reminder span,
.sa-admin-note span {
  color: #007f79;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 0.8rem;
}

.sa-kit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 22px;
}

.sa-kit-item {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 12px;
  align-items: start;
  border: 1px solid rgba(18, 58, 90, 0.16);
  border-radius: 16px;
  padding: 16px;
  background: #fff;
}

.sa-kit-item input {
  width: 24px;
  height: 24px;
  margin-top: 3px;
}

.sa-kit-item span {
  display: grid;
  gap: 4px;
}

.sa-kit-item small {
  color: #45606b;
  font-size: 0.95rem;
  line-height: 1.35;
}

.sa-kit-notes {
  display: grid;
  gap: 8px;
  margin-top: 18px;
  font-weight: 800;
}

.sa-kit-notes textarea {
  width: 100%;
  border: 1px solid rgba(18, 58, 90, 0.16);
  border-radius: 16px;
  padding: 14px;
  font: inherit;
  resize: vertical;
}

.speaking-now {
  box-shadow: 0 0 0 4px rgba(0, 166, 166, 0.2) !important;
}

@media (max-width: 760px) {
  .topbar {
    min-height: 78px;
    padding-inline: 12px;
  }

  .topbar .brand {
    min-width: 0;
    min-height: 58px;
  }

  .topbar .brand img,
  .brand-logo {
    width: 52px;
    height: 52px;
    flex-basis: 52px;
  }

  .topbar .brand small {
    max-width: 230px;
    white-space: normal;
    line-height: 1.15;
  }

  body.sa-home-entry-locked .v530-entry-home {
    min-height: 100svh !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(260px, 42svh) 1fr !important;
    gap: 0 !important;
    padding: 0 !important;
  }

  body.sa-home-entry-locked .v530-entry-hero {
    min-height: 260px !important;
    height: 42svh !important;
    border-radius: 0 !important;
  }

  body.sa-home-entry-locked .v530-entry-panel {
    border-radius: 22px 22px 0 0 !important;
    padding: 20px !important;
    min-height: auto !important;
  }

  body.sa-home-entry-locked .v530-risk-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  body.sa-home-entry-locked .v530-entry-actions {
    grid-template-columns: 1fr !important;
  }

  .sa-compass-card,
  .sa-kit-head {
    grid-template-columns: 1fr;
  }

  .compass-dial {
    width: min(240px, 74vw);
    justify-self: center;
  }

  .sa-kit-grid {
    grid-template-columns: 1fr;
  }

  .sa-update-banner {
    align-items: stretch;
    flex-direction: column;
  }
}

/* Safe Ability SM 5.92 - leggibilita legenda mappa */
.inclusive-map-legend .pin-dot,
.v529-pin-row .pin-dot {
  display: none !important;
}

/* Safe Ability SM 5.92 - mappa: tutti i filtri restano disponibili, senza colori ridondanti */
body.v545-remake[data-safe-page="mappa"] .inclusive-map-legend label,
body.v545-remake[data-sa-active-view="mappa"] .inclusive-map-legend label {
  display: flex !important;
}

/* Safe Ability SM 5.92 - legenda: nasconde colori solo nei filtri, non nei pin descrittivi */
.v529-pin-row .pin-dot { display: inline-flex !important; }

/* 5.92: home di ingresso isolata, nessun contenuto app sotto la piega. */
body.sa-home-entry-locked #main,
body.sa-home-entry-locked main#main,
body.sa-home-entry-locked .physical-page-hero,
body.sa-home-entry-locked .site-footer,
body.sa-home-entry-locked footer {
  display: none !important;
}

/* Safe Ability SM 5.93 - distinzione tra prevenzione e intervento */
.sa-phase-bridge {
  width: min(1180px, calc(100% - 28px));
  margin: clamp(12px, 2vw, 22px) auto clamp(16px, 2.4vw, 28px);
  padding: clamp(16px, 2.6vw, 26px);
  border: 1px solid rgba(18, 58, 90, 0.13);
  border-radius: 22px;
  background:
    linear-gradient(90deg, rgba(0, 166, 166, 0.08), transparent 46%, rgba(255, 107, 94, 0.08)),
    #ffffff;
  box-shadow: 0 18px 48px rgba(9, 44, 58, 0.08);
  display: grid;
  gap: clamp(14px, 2.2vw, 22px);
}

.sa-phase-head {
  display: grid;
  gap: 8px;
  max-width: 920px;
}

.sa-phase-overline,
.sa-phase-label,
.sa-phase-route span {
  color: #007a72;
  font-size: 0.78rem;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sa-phase-head h2 {
  margin: 0;
  color: #062f3e;
  font-size: clamp(1.55rem, 3vw, 2.7rem);
  line-height: 1.04;
}

.sa-phase-head p,
.sa-phase-lane p,
.sa-phase-lane li,
.sa-phase-route p {
  margin: 0;
  color: #405c69;
  line-height: 1.45;
}

.sa-phase-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.sa-phase-lane {
  display: grid;
  gap: 12px;
  align-content: start;
  min-width: 0;
  padding: clamp(15px, 2.2vw, 22px);
  border: 1px solid rgba(18, 58, 90, 0.12);
  border-left: 7px solid #00a6a6;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 10px 28px rgba(9, 44, 58, 0.05);
}

.sa-phase-lane--intervento {
  border-left-color: #ff6b5e;
}

.sa-phase-lane--prevenzione {
  background: linear-gradient(180deg, #f3fffd, #ffffff);
}

.sa-phase-lane--intervento {
  background: linear-gradient(180deg, #fff8f6, #ffffff);
}

.sa-phase-lane h3 {
  margin: 0;
  color: #063243;
  font-size: clamp(1.22rem, 2.2vw, 1.7rem);
  line-height: 1.08;
}

.sa-phase-lane ul {
  display: grid;
  gap: 7px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.sa-phase-lane li {
  position: relative;
  padding-left: 20px;
}

.sa-phase-lane li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.56em;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #00a6a6;
}

.sa-phase-lane--intervento li::before {
  background: #ff6b5e;
}

.sa-phase-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 2px;
}

.sa-phase-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 13px;
  border: 1px solid rgba(18, 58, 90, 0.14);
  border-radius: 12px;
  background: #ffffff;
  color: #063243;
  font-size: 0.92rem;
  font-weight: 900;
  text-decoration: none;
}

.sa-phase-lane--prevenzione .sa-phase-action:first-child {
  background: #007a72;
  border-color: #007a72;
  color: #ffffff;
}

.sa-phase-lane--intervento .sa-phase-action:first-child {
  background: #d94b3d;
  border-color: #d94b3d;
  color: #ffffff;
}

.sa-phase-route {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border: 1px solid rgba(18, 58, 90, 0.12);
  border-radius: 14px;
  background: #f7fbfa;
}

.sa-phase-route strong {
  color: #063243;
  font-size: clamp(1rem, 1.5vw, 1.15rem);
  line-height: 1.2;
}

body[data-sa-phase="prevenzione"] .sa-phase-lane--prevenzione,
body[data-sa-phase="intervento"] .sa-phase-lane--intervento,
body[data-sa-phase="both"] .sa-phase-lane {
  border-color: rgba(18, 58, 90, 0.2);
  box-shadow: 0 18px 42px rgba(9, 44, 58, 0.1);
}

body[data-sa-phase="prevenzione"] .sa-phase-lane--intervento,
body[data-sa-phase="intervento"] .sa-phase-lane--prevenzione {
  opacity: 0.82;
}

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

.v593-entry-lane {
  min-width: 0;
  min-height: 92px;
  padding: 12px;
  border: 1px solid rgba(18, 58, 90, 0.14);
  border-left: 6px solid #00a6a6;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.88);
  display: grid;
  gap: 5px;
  align-content: start;
}

.v593-entry-lane--intervento {
  border-left-color: #ff6b5e;
}

.v593-entry-lane strong {
  color: #063243;
  font-size: 1rem;
  line-height: 1.12;
}

.v593-entry-lane small {
  color: #526575;
  font-size: 0.86rem;
  font-weight: 800;
  line-height: 1.28;
}

@media (max-width: 820px) {
  .sa-phase-grid {
    grid-template-columns: 1fr;
  }

  .sa-phase-bridge {
    border-radius: 18px;
  }
}

@media (max-width: 560px) {
  .sa-phase-actions .sa-phase-action {
    width: 100%;
  }

  .v593-entry-lanes {
    grid-template-columns: 1fr;
  }

  .v593-entry-lane {
    min-height: 0;
  }
}
/* 5.93: mantiene chiaro il colore della fase attiva. */
body[data-sa-phase="prevenzione"] .sa-phase-lane--prevenzione {
  border-left-color: #00a6a6;
}

body[data-sa-phase="intervento"] .sa-phase-lane--intervento {
  border-left-color: #ff6b5e;
}

body[data-sa-phase="both"] .sa-phase-lane--prevenzione {
  border-left-color: #00a6a6;
}

body[data-sa-phase="both"] .sa-phase-lane--intervento {
  border-left-color: #ff6b5e;
}
/* Safe Ability SM 5.94 - ARRSM e comunicazioni resilienti */
.sa-comms-note {
  display: grid;
  gap: 7px;
  padding: 14px 16px;
  border: 1px solid rgba(42, 119, 181, 0.18);
  border-left: 6px solid #2a77b5;
  border-radius: 14px;
  background: linear-gradient(135deg, #f3f9ff, #ffffff);
}

.sa-phase-bridge + .sa-comms-note {
  width: min(1180px, calc(100% - 28px));
  margin: 0 auto clamp(16px, 2.4vw, 28px);
}

.sa-comms-note span {
  color: #1c669e;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.1;
  text-transform: uppercase;
}

.sa-comms-note strong {
  color: #063243;
  font-size: clamp(1rem, 1.5vw, 1.14rem);
  line-height: 1.2;
}

.sa-comms-note p {
  margin: 0;
  color: #405c69;
  line-height: 1.45;
}

.sa-comms-note a {
  width: fit-content;
  color: #0a527f;
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.sa-arrsm-resource {
  border-left: 6px solid #2a77b5;
  background: linear-gradient(180deg, #f3f9ff, #ffffff);
}

@media (max-width: 560px) {
  .sa-comms-note a {
    width: 100%;
  }
}