:root {
  --app-vh: 100vh;
  --bg: #e7edf3;
  --card: rgba(255, 255, 255, 0.88);
  --line: rgba(20, 39, 60, 0.12);
  --text: #122033;
  --muted: #5f7288;
  --base: #1c8f5f;
  --exit: #f28f3b;
  --route: #0f766e;
  --corridor: #2fb344;
  --hazard: #d94841;
  --boat: #6f42c1;
  --warn: #f08c00;
  --danger: #c92a2a;
  --stale: #7f8c9a;
}

* {
  box-sizing: border-box;
}

html,
body {
  min-height: 100%;
  min-height: -webkit-fill-available;
}

body {
  margin: 0;
  font-family: "Segoe UI", Tahoma, sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(24, 100, 171, 0.18), transparent 24%),
    linear-gradient(180deg, #f4f7fb, var(--bg));
}

.app-shell {
  display: grid;
  grid-template-columns: 360px minmax(0, 1fr);
  min-height: 100vh;
}

.sidebar {
  padding: 20px;
  border-right: 1px solid var(--line);
  background: rgba(244, 247, 251, 0.92);
  backdrop-filter: blur(12px);
  overflow-y: auto;
}

.brand h1,
.panel h2 {
  margin: 0;
}

.eyebrow {
  margin: 0 0 8px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--route);
}

.subtle,
.meta {
  color: var(--muted);
}

.panel {
  margin-top: 16px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--card);
  box-shadow: 0 14px 30px rgba(12, 24, 38, 0.06);
}

.panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

button {
  border: 0;
  border-radius: 8px;
  padding: 10px 14px;
  font: inherit;
  color: white;
  background: #0f766e;
  cursor: pointer;
}

button:disabled {
  cursor: not-allowed;
  opacity: 0.5;
}

.danger-button {
  color: white;
  background: #c92a2a;
}

a {
  color: #0f766e;
  font-weight: 600;
}

.nav-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 14px;
  min-height: 40px;
  padding: 10px 14px;
  border-radius: 8px;
  color: white;
  background: #0f766e;
  text-decoration: none;
}

.secondary-link {
  color: #0f766e;
  background: rgba(15, 118, 110, 0.12);
}

.client-shell {
  grid-template-columns: 340px minmax(0, 1fr);
}

.monitor-shell {
  grid-template-columns: 420px minmax(0, 1fr);
}

.client-sidebar {
  background: rgba(247, 250, 252, 0.96);
}

.monitor-sidebar {
  background: rgba(247, 250, 252, 0.97);
}

.client-device-list .device-card {
  border-color: rgba(15, 118, 110, 0.12);
}

.monitor-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 12px;
}

.monitor-stats span {
  display: grid;
  gap: 2px;
  min-width: 0;
  padding: 10px;
  border-radius: 8px;
  background: rgba(15, 118, 110, 0.08);
}

.monitor-stats b {
  overflow: hidden;
  color: var(--text);
  font-size: 17px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.monitor-stats small {
  color: var(--muted);
  font-size: 11px;
}

.qr-box {
  display: grid;
  justify-items: center;
  gap: 10px;
  margin-top: 12px;
}

.qr-box img {
  width: 180px;
  height: 180px;
  border-radius: 8px;
  background: white;
  box-shadow: 0 10px 24px rgba(12, 24, 38, 0.12);
}

.qr-box a {
  max-width: 100%;
  overflow-wrap: anywhere;
  font-size: 13px;
}

.qr-list {
  display: grid;
  gap: 10px;
  max-height: 420px;
  margin-top: 12px;
  overflow-y: auto;
}

.qr-card {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: white;
}

.qr-card img {
  width: 88px;
  height: 88px;
  border-radius: 6px;
  background: white;
}

.qr-card strong,
.qr-card span,
.qr-card a {
  display: block;
  min-width: 0;
  overflow-wrap: anywhere;
}

.qr-card span {
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
}

.qr-card a {
  margin-top: 6px;
  font-size: 12px;
}

.monitor-alert-list {
  display: grid;
  gap: 8px;
  max-height: 260px;
  margin-top: 12px;
  overflow-y: auto;
}

.monitor-alert-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 4px 10px;
  padding: 10px;
  border: 1px solid rgba(240, 140, 0, 0.22);
  border-radius: 8px;
  background: rgba(240, 140, 0, 0.08);
}

.monitor-alert-card.danger {
  border-color: rgba(201, 42, 42, 0.24);
  background: rgba(201, 42, 42, 0.08);
}

.monitor-alert-card span {
  color: var(--muted);
  font-size: 12px;
}

.monitor-alert-card b {
  grid-column: 2;
  grid-row: 1 / span 2;
  align-self: center;
  color: #c92a2a;
}

.hidden-control {
  display: none;
}

.quick-actions,
.segmented-controls {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 12px;
}

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

.active-toggle {
  color: white;
  background: #0f766e;
}

.toggle-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.toggle-row {
  display: flex;
  align-items: center;
  gap: 9px;
  min-height: 34px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: white;
  font-size: 13px;
  font-weight: 600;
}

.toggle-row input {
  width: 17px;
  height: 17px;
  accent-color: #0f766e;
}

.legend,
.device-list {
  margin: 12px 0 0;
  padding: 0;
}

.legend li {
  display: flex;
  align-items: center;
  gap: 10px;
  list-style: none;
  margin-bottom: 10px;
}

.swatch {
  width: 14px;
  height: 14px;
  border-radius: 50%;
}

.swatch-base { background: var(--base); }
.swatch-exit { background: var(--exit); }
.swatch-route { background: var(--route); }
.swatch-corridor { background: var(--corridor); opacity: 0.7; }
.swatch-speed { background: #7048e8; }
.swatch-hazard { background: var(--hazard); }
.swatch-boat { background: var(--boat); }

.device-card {
  padding: 14px;
  border-radius: 8px;
  border: 1px solid rgba(20, 39, 60, 0.08);
  background: rgba(255, 255, 255, 0.95);
}

.device-card.alert-state {
  border-color: rgba(201, 42, 42, 0.2);
  background: rgba(255, 250, 250, 0.98);
}

.device-card + .device-card {
  margin-top: 12px;
}

.device-card h3,
.device-card p {
  margin: 0;
}

.device-card .muted {
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
}

.device-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
  margin: 10px 0;
}

.device-stats span {
  display: grid;
  min-width: 0;
  padding: 8px;
  border-radius: 8px;
  background: rgba(15, 118, 110, 0.08);
}

.device-stats b {
  overflow: hidden;
  color: var(--text);
  font-size: 14px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.device-stats small {
  color: var(--muted);
  font-size: 10px;
}

.badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
}

.badge-ok { background: rgba(28, 143, 95, 0.12); color: var(--base); }
.badge-warning { background: rgba(240, 140, 0, 0.13); color: var(--warn); }
.badge-danger { background: rgba(201, 42, 42, 0.12); color: var(--danger); }
.badge-stale { background: rgba(127, 140, 154, 0.16); color: var(--stale); }

.map-area {
  position: relative;
  padding: 20px;
}

#map {
  width: 100%;
  height: calc(var(--app-vh, 100vh) - 40px);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 25px 50px rgba(12, 24, 38, 0.12);
}

#map.navigation-rotating::after {
  content: "по курсу";
  position: absolute;
  top: 14px;
  left: 54px;
  z-index: 700;
  padding: 7px 10px;
  border-radius: 8px;
  color: #0f766e;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 8px 20px rgba(12, 24, 38, 0.14);
  font-size: 12px;
  font-weight: 800;
}

.nav-boat-overlay {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 740;
  display: none;
  width: 58px;
  height: 58px;
  pointer-events: none;
  transform: translate(-50%, -50%);
}

.nav-boat-overlay.visible {
  display: block;
}

.nav-boat-overlay svg {
  display: block;
  width: 100%;
  height: 100%;
  filter: drop-shadow(0 8px 14px rgba(12, 24, 38, 0.36));
}

.map-fullscreen-button {
  position: absolute;
  right: 32px;
  bottom: 32px;
  z-index: 720;
  min-height: 42px;
  padding: 10px 14px;
  color: white;
  background: #0f766e;
  box-shadow: 0 12px 30px rgba(12, 24, 38, 0.2);
}

.map-toolbar {
  position: absolute;
  left: 32px;
  bottom: 32px;
  z-index: 720;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-width: calc(100% - 210px);
}

.map-toolbar button {
  min-height: 40px;
  box-shadow: 0 10px 24px rgba(12, 24, 38, 0.18);
}

.map-toolbar .removed-toggle-button {
  min-width: 96px;
}

.map-toolbar .removed-toggle-button:disabled {
  opacity: .58;
  cursor: not-allowed;
}

.map-toolbar .removed-toggle-button.control-removed {
  opacity: .64;
  cursor: not-allowed;
}

.map-status-overlay {
  position: absolute;
  top: 32px;
  left: 32px;
  z-index: 720;
  display: grid;
  gap: 2px;
  width: min(360px, calc(100% - 220px));
  padding: 12px 14px;
  border: 1px solid rgba(15, 118, 110, 0.16);
  border-radius: 8px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 12px 30px rgba(12, 24, 38, 0.18);
}

.map-status-overlay span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.map-status-overlay strong {
  font-size: 20px;
  line-height: 1.18;
}

.map-status-overlay small {
  color: var(--muted);
  font-size: 12px;
}

.map-fine-overlay {
  position: absolute;
  top: 32px;
  right: 32px;
  z-index: 720;
  display: grid;
  gap: 2px;
  min-width: 132px;
  padding: 10px 12px;
  border: 1px solid rgba(201, 42, 42, 0.16);
  border-radius: 8px;
  color: #c92a2a;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 12px 30px rgba(12, 24, 38, 0.18);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-6px);
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.map-fine-overlay.visible {
  opacity: 1;
  transform: translateY(0);
}

.map-fine-overlay span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.map-fine-overlay strong {
  font-size: 24px;
  line-height: 1.1;
}

.map-fine-overlay small {
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
}

body.ride-time-expired .map-fine-overlay small,
body.ride-time-expired #client-ride-timer {
  color: #c92a2a;
}

.map-area:fullscreen {
  padding: 0;
  background: #dbe8ef;
}

.navigation-page-lock {
  overflow: hidden;
}

.map-area.navigation-fullscreen-fallback {
  position: fixed;
  inset: 0;
  z-index: 3000;
  padding: 0;
  background: #dbe8ef;
}

.map-area:fullscreen #map,
.map-area.navigation-fullscreen-fallback #map {
  height: var(--app-vh, 100vh);
  min-height: var(--app-vh, 100vh);
  border-radius: 0;
  box-shadow: none;
}

.map-area:fullscreen .map-fine-overlay,
.map-area.navigation-fullscreen-fallback .map-fine-overlay {
  top: 18px;
  right: 18px;
}

.map-area:fullscreen .map-fullscreen-button,
.map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  right: 18px;
  bottom: 18px;
}

.map-area:fullscreen .map-status-overlay,
.map-area.navigation-fullscreen-fallback .map-status-overlay {
  top: 18px;
  left: 18px;
}

.map-area:fullscreen .map-toolbar,
.map-area.navigation-fullscreen-fallback .map-toolbar {
  left: 18px;
  bottom: 18px;
}

.map-area:fullscreen #map-follow-button,
.map-area.navigation-fullscreen-fallback #map-follow-button,
.map-area:fullscreen #map-course-button,
.map-area.navigation-fullscreen-fallback #map-course-button {
  position: fixed;
  right: 18px;
  bottom: 76px;
  z-index: 760;
  min-width: 118px;
  min-height: 44px;
  color: white;
  background: #0f766e;
  box-shadow: 0 12px 30px rgba(12, 24, 38, 0.24);
}


.map-area:fullscreen #map-course-button,
.map-area.navigation-fullscreen-fallback #map-course-button {
  bottom: 128px;
}

.map-area:fullscreen #map-follow-button:not(.active-toggle),
.map-area.navigation-fullscreen-fallback #map-follow-button:not(.active-toggle),
.map-area:fullscreen #map-course-button:not(.active-toggle),
.map-area.navigation-fullscreen-fallback #map-course-button:not(.active-toggle) {
  color: #0f766e;
  background: rgba(255, 255, 255, 0.96);
}

.map-area:fullscreen #map.navigation-rotating::after,
.map-area.navigation-fullscreen-fallback #map.navigation-rotating::after {
  top: 18px;
  left: 18px;
}

.runtime-warning {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 1200;
  max-width: 360px;
  padding: 12px 14px;
  border: 1px solid rgba(201, 42, 42, 0.18);
  border-radius: 8px;
  color: #7a1f1f;
  background: rgba(255, 245, 245, 0.96);
  box-shadow: 0 14px 34px rgba(12, 24, 38, 0.2);
  font-size: 14px;
}

.runtime-warning strong {
  display: block;
  margin-bottom: 4px;
}

.boat-icon {
  position: relative;
  width: 44px;
  height: 58px;
  background: transparent;
  border: 0;
}

.boat-icon svg {
  display: block;
  width: 44px;
  height: 58px;
  overflow: visible;
  filter: drop-shadow(0 3px 8px rgba(12, 24, 38, 0.34));
}

.boat-marker-svg .boat-alert-ring {
  display: none;
}

.native-boat-shape.alert .boat-marker-svg .boat-alert-ring {
  display: block;
}

.native-boat-shape.alert .boat-marker-svg .boat-hull {
  stroke: #c92a2a;
  stroke-width: 4.8px;
}

.native-boat-marker {
  will-change: transform, opacity;
  transition: opacity 0.18s ease;
}

.native-boat-shape.alert svg {
  filter: drop-shadow(0 4px 10px rgba(201, 42, 42, 0.55));
}

.native-boat-label {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 5px);
  transform: translateX(-50%);
  white-space: nowrap;
  pointer-events: none;
}

.native-map-pin {
  width: 24px;
  height: 24px;
}

.native-map-pin span {
  display: grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border: 3px solid white;
  border-radius: 999px;
  color: white;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
  font-size: 10px;
  font-weight: 800;
}

.boat-label {
  padding: 4px 7px;
  border: 1px solid rgba(15, 118, 110, 0.18);
  border-radius: 8px;
  color: #0f766e;
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 6px 16px rgba(12, 24, 38, 0.16);
  font-size: 12px;
  font-weight: 800;
}

.leaflet-popup-content,
.maplibregl-popup-content {
  min-width: 220px;
}

.leaflet-compat-tooltip {
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translate(-50%, 5px);
  white-space: nowrap;
  pointer-events: none;
}

.caution {
  margin-top: 10px;
  color: #8a5a00;
}

.corridor-tooltip {
  color: #0b5d1e;
  border: 1px solid rgba(47, 179, 68, 0.35);
  box-shadow: 0 8px 24px rgba(10, 76, 32, 0.14);
  font-weight: 700;
}

.editor-shell {
  grid-template-columns: 390px minmax(0, 1fr);
  height: 100vh;
  min-height: 0;
  overflow: hidden;
}

.editor-sidebar {
  height: 100vh;
  padding-bottom: 32px;
  overscroll-behavior: contain;
}

.editor-shell .map-area {
  height: 100vh;
  min-height: 0;
  overflow: hidden;
}

.editor-shell #map {
  height: calc(100vh - 40px);
}

.field-label {
  display: block;
  margin-top: 14px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.field-control {
  width: 100%;
  min-height: 40px;
  margin-top: 6px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  background: white;
  font: inherit;
}

.coord-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 10px;
}

.editor-meta {
  margin-top: 12px;
}

.tool-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 12px;
}

.wide-button {
  width: 100%;
  margin-top: 10px;
}

.secondary-button {
  color: #0f766e;
  background: rgba(15, 118, 110, 0.12);
}

a.secondary-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 10px 14px;
  border-radius: 8px;
  text-decoration: none;
}

.active-tool {
  background: #8a5a00;
}

.status-error {
  color: #c92a2a;
}

.small-counter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 28px;
  border-radius: 8px;
  color: #0f766e;
  background: rgba(15, 118, 110, 0.12);
  font-weight: 700;
}

.point-list {
  display: grid;
  gap: 8px;
  max-height: 300px;
  margin: 12px 0 0;
  padding: 0;
  overflow-y: auto;
}

.point-list li {
  list-style-position: inside;
}

.point-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}

.point-list button {
  display: grid;
  width: 100%;
  gap: 3px;
  padding: 10px;
  border: 1px solid var(--line);
  color: var(--text);
  background: white;
  text-align: left;
}

.point-list .point-delete {
  width: auto;
  min-width: 78px;
  justify-content: center;
  color: #c92a2a;
  background: rgba(201, 42, 42, 0.08);
  text-align: center;
}

.point-list .point-delete:hover {
  color: white;
  background: #c92a2a;
}

.point-list span {
  color: var(--muted);
  font-size: 12px;
}

.point-list .selected button {
  border-color: rgba(15, 118, 110, 0.55);
  background: rgba(15, 118, 110, 0.08);
}

.fine-total {
  color: #c92a2a;
  font-size: 20px;
}

.fine-rules {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.fine-row {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr) 96px;
  align-items: center;
  gap: 8px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: white;
}

.fine-row span {
  font-size: 13px;
}

.fine-row input[type="number"] {
  width: 100%;
  min-height: 34px;
  padding: 6px 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  font: inherit;
}

.fine-live-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.fine-live-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 3px 10px;
  padding: 10px;
  border-radius: 8px;
  background: rgba(201, 42, 42, 0.08);
}

.fine-live-card span {
  color: var(--muted);
  font-size: 12px;
}

.fine-live-card b {
  grid-row: 1 / span 2;
  grid-column: 2;
  align-self: center;
  color: #c92a2a;
}

.fine-summary {
  margin-top: 10px;
  color: #c92a2a;
  font-weight: 700;
}

.navigator-panel {
  background: rgba(255, 255, 255, 0.96);
}

.navigator-panel .field-label {
  display: block;
  margin-top: 14px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.navigator-panel .field-control {
  width: 100%;
  min-height: 40px;
  margin-top: 6px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  background: white;
  font: inherit;
}

.navigator-card {
  display: grid;
  gap: 6px;
  margin-top: 14px;
  padding: 14px;
  border-radius: 8px;
  color: white;
  background: #0f766e;
}

.navigator-card strong {
  font-size: 18px;
  line-height: 1.25;
}

.navigator-card span {
  color: rgba(255, 255, 255, 0.86);
  font-size: 13px;
}

.navigator-progress {
  height: 8px;
  margin-top: 12px;
  overflow: hidden;
  border-radius: 8px;
  background: rgba(15, 118, 110, 0.14);
}

.navigator-progress span {
  display: block;
  width: 0%;
  height: 100%;
  border-radius: 8px;
  background: #0f766e;
  transition: width 0.25s ease;
}

.navigator-metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 12px;
}

.navigator-metrics span {
  display: grid;
  gap: 2px;
  padding: 8px;
  border-radius: 8px;
  background: rgba(15, 118, 110, 0.08);
}

.navigator-metrics b {
  color: var(--text);
  font-size: 16px;
}

.navigator-metrics small {
  color: var(--muted);
  font-size: 11px;
}

.device-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.editor-point-icon span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 3px solid white;
  border-radius: 50%;
  color: white;
  background: #0f766e;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.24);
  font-size: 13px;
  font-weight: 800;
}

.editor-point-icon span.selected {
  background: #f28f3b;
}

.editor-insert-icon {
  background: transparent;
  border: 0;
}

.editor-insert-icon button {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  padding: 0;
  border: 3px solid white;
  border-radius: 50%;
  color: white;
  background: #0f766e;
  box-shadow: 0 4px 14px rgba(12, 24, 38, 0.28);
  font-size: 20px;
  font-weight: 900;
  line-height: 1;
}

.editor-insert-icon button:hover {
  background: #8a5a00;
}

.editor-buoy-icon span {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border: 3px solid white;
  border-radius: 50%;
  color: white;
  background: #1864ab;
  box-shadow: 0 3px 12px rgba(12, 24, 38, 0.28);
  font-size: 11px;
  font-weight: 900;
}

.editor-buoy-icon span.selected {
  background: #0f766e;
}

.editor-buoy-icon.buoy-green span {
  background: #2f9e44;
}

.editor-buoy-icon.buoy-red span {
  background: #e03131;
}

.editor-buoy-icon.buoy-green span.selected {
  background: #2b8a3e;
}

.editor-buoy-icon.buoy-red span.selected {
  background: #c92a2a;
}

.editor-two-way-icon span {
  display: grid;
  place-items: center;
  min-width: 34px;
  height: 24px;
  border: 2px solid rgba(24, 100, 171, 0.24);
  border-radius: 8px;
  color: #1864ab;
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 4px 14px rgba(12, 24, 38, 0.18);
  font-size: 18px;
  font-weight: 900;
}

.editor-two-way-icon span.selected {
  color: #0f766e;
  border-color: rgba(15, 118, 110, 0.28);
}

.editor-resize-icon {
  background: transparent;
  border: 0;
}

.editor-resize-icon span {
  display: block;
  width: 20px;
  height: 20px;
  border: 3px solid white;
  border-radius: 6px;
  background: #1f2937;
  box-shadow: 0 4px 14px rgba(12, 24, 38, 0.32);
  cursor: nwse-resize;
}


.editor-zone-vertex-icon,
.editor-zone-insert-icon {
  background: transparent;
  border: 0;
  touch-action: none;
}

.editor-zone-vertex-icon span {
  display: block;
  width: 22px;
  height: 22px;
  border: 3px solid white;
  border-radius: 7px;
  background: #1f2937;
  box-shadow: 0 4px 14px rgba(12, 24, 38, 0.34);
  cursor: grab;
}

.editor-zone-vertex-icon span:active {
  cursor: grabbing;
}

.editor-zone-insert-icon button {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  padding: 0;
  border: 3px solid white;
  border-radius: 50%;
  color: white;
  background: #7048e8;
  box-shadow: 0 4px 14px rgba(12, 24, 38, 0.26);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.editor-zone-insert-icon button:hover {
  background: #8a5a00;
}

@media (max-width: 980px) {
  .app-shell {
    grid-template-columns: 1fr;
  }

  .editor-shell {
    height: auto;
    min-height: 100vh;
    overflow: visible;
  }

  .sidebar {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .editor-sidebar {
    height: auto;
    max-height: none;
  }

  .editor-shell .map-area {
    height: auto;
    min-height: 70vh;
    overflow: visible;
  }

  #map {
    height: 70vh;
    border-radius: 8px;
  }

  .map-status-overlay {
    top: 14px;
    left: 14px;
    right: 14px;
    width: auto;
  }

  .map-fine-overlay {
    top: auto;
    right: 14px;
    bottom: 70px;
  }

  .map-toolbar {
    left: 14px;
    right: 14px;
    bottom: 14px;
    max-width: none;
  }

  .map-fullscreen-button {
    right: 14px;
    bottom: 14px;
  }

  .editor-map-toolbar {
    right: 14px;
    bottom: 64px;
  }
}

/* v2: tracking/navigation disabled */
.disabled-tracking-block {
  display: none !important;
}
.map-toolbar a.secondary-button {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* v3: мобильная плашка штрафов + плавное следование за катером */
.active-device-card {
  border-color: rgba(15, 118, 110, 0.45);
  box-shadow: inset 0 0 0 1px rgba(15, 118, 110, 0.18);
}

.map-fine-overlay {
  z-index: 745;
  min-width: 118px;
  max-width: min(220px, calc(100vw - 28px));
  text-align: left;
}

.map-fine-overlay strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.native-boat-shape {
  transform-origin: center center;
  transition: transform 0.25s ease;
}

.native-boat-shape .boat-marker-svg {
  pointer-events: none;
}

.device-card.active-device-card .device-actions button {
  background: #0f766e;
}


.editor-zone-vertex-icon,
.editor-zone-insert-icon {
  background: transparent;
  border: 0;
  touch-action: none;
}

.editor-zone-vertex-icon span {
  display: block;
  width: 22px;
  height: 22px;
  border: 3px solid white;
  border-radius: 7px;
  background: #1f2937;
  box-shadow: 0 4px 14px rgba(12, 24, 38, 0.34);
  cursor: grab;
}

.editor-zone-vertex-icon span:active {
  cursor: grabbing;
}

.editor-zone-insert-icon button {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  padding: 0;
  border: 3px solid white;
  border-radius: 50%;
  color: white;
  background: #7048e8;
  box-shadow: 0 4px 14px rgba(12, 24, 38, 0.26);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.editor-zone-insert-icon button:hover {
  background: #8a5a00;
}

@media (max-width: 980px) {
  .map-status-overlay {
    max-height: 96px;
    overflow: hidden;
    padding: 10px 12px;
  }

  .map-status-overlay strong {
    font-size: 17px;
  }

  .map-status-overlay small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .map-fine-overlay,
  .map-area:fullscreen .map-fine-overlay,
  .map-area.navigation-fullscreen-fallback .map-fine-overlay {
    top: 92px;
    right: 14px;
    bottom: auto;
    left: auto;
    display: inline-grid;
    min-width: 112px;
    max-width: 150px;
    padding: 8px 10px;
    border-radius: 8px;
  }

  .map-fine-overlay span {
    font-size: 10px;
  }

  .map-fine-overlay strong {
    font-size: 18px;
  }

  .map-toolbar {
    right: 136px;
    bottom: 14px;
    max-width: none;
  }

  .map-toolbar button,
  .map-toolbar a.secondary-button {
    min-height: 38px;
    padding: 8px 10px;
    font-size: 13px;
  }
}

@media (max-width: 520px) {
  .map-fine-overlay,
  .map-area:fullscreen .map-fine-overlay,
  .map-area.navigation-fullscreen-fallback .map-fine-overlay {
    top: 104px;
    right: 10px;
    max-width: 138px;
  }

  .map-toolbar {
    left: 10px;
    right: 116px;
    bottom: 10px;
    gap: 6px;
  }

  .map-fullscreen-button {
    right: 10px;
    bottom: 10px;
    min-height: 38px;
    padding: 8px 10px;
    font-size: 13px;
  }
}


/* v5: удобное клиентское приложение и стабилизированный GPS */
.client-gps-panel {
  border-color: rgba(24, 100, 171, 0.18);
  background: rgba(255, 255, 255, 0.94);
}

.gps-pill {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 8px;
  border-radius: 999px;
  color: #1864ab;
  background: rgba(24, 100, 171, 0.1);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.client-gps-grid {
  display: grid;
  grid-template-columns: 90px minmax(0, 1fr);
  gap: 8px 10px;
  margin-top: 12px;
  align-items: center;
}

.client-gps-grid span {
  color: var(--muted);
  font-size: 12px;
}

.client-gps-grid strong {
  overflow: hidden;
  padding: 8px 10px;
  border-radius: 8px;
  color: var(--text);
  background: rgba(24, 100, 171, 0.08);
  font-size: 13px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.client-hint {
  margin: 12px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.client-shell .device-stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.client-shell .device-stats b {
  font-size: 13px;
}

.client-map-status {
  border-color: rgba(24, 100, 171, 0.18);
}


.editor-zone-vertex-icon,
.editor-zone-insert-icon {
  background: transparent;
  border: 0;
  touch-action: none;
}

.editor-zone-vertex-icon span {
  display: block;
  width: 22px;
  height: 22px;
  border: 3px solid white;
  border-radius: 7px;
  background: #1f2937;
  box-shadow: 0 4px 14px rgba(12, 24, 38, 0.34);
  cursor: grab;
}

.editor-zone-vertex-icon span:active {
  cursor: grabbing;
}

.editor-zone-insert-icon button {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  padding: 0;
  border: 3px solid white;
  border-radius: 50%;
  color: white;
  background: #7048e8;
  box-shadow: 0 4px 14px rgba(12, 24, 38, 0.26);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.editor-zone-insert-icon button:hover {
  background: #8a5a00;
}

@media (max-width: 980px) {
  .client-shell {
    display: flex;
    flex-direction: column-reverse;
    min-height: 100vh;
  }

  .client-shell .sidebar {
    height: auto;
    max-height: none;
    padding: 12px;
    border-right: 0;
    border-top: 1px solid var(--line);
  }

  .client-shell .map-area {
    min-height: 72vh;
  }

  .client-shell #map {
    height: 72vh;
  }

  .client-gps-grid {
    grid-template-columns: 78px minmax(0, 1fr);
  }
}

@media (max-width: 520px) {
  .client-shell .brand h1 {
    font-size: 24px;
  }

  .client-shell .panel {
    margin-top: 10px;
    padding: 12px;
  }

  .client-shell .map-area {
    min-height: 78vh;
  }

  .client-shell #map {
    height: 78vh;
  }

  .client-gps-grid strong {
    font-size: 12px;
  }
}


/* v7: главная страница выбора приложений */
.home-page {
  min-height: 100vh;
  padding: clamp(18px, 4vw, 42px);
  background:
    radial-gradient(circle at top left, rgba(15, 118, 110, 0.18), transparent 28%),
    radial-gradient(circle at bottom right, rgba(24, 100, 171, 0.16), transparent 30%),
    linear-gradient(180deg, #f7fbff, #e7edf3);
}

.home-hero {
  width: min(1050px, 100%);
  margin: 0 auto 22px;
  padding: clamp(20px, 4vw, 34px);
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 22px 60px rgba(12, 24, 38, 0.08);
}

.home-hero h1 {
  margin: 0 0 10px;
  font-size: clamp(34px, 7vw, 72px);
  line-height: 0.95;
  letter-spacing: -0.055em;
}

.home-hero .subtle {
  max-width: 760px;
  margin: 0;
  font-size: clamp(15px, 2vw, 18px);
  line-height: 1.5;
}

.home-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  width: min(1050px, 100%);
  margin: 0 auto;
}

.home-card {
  display: flex;
  min-height: 360px;
  flex-direction: column;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 18px 44px rgba(12, 24, 38, 0.08);
}

.home-card-icon {
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  margin-bottom: 16px;
  border-radius: 18px;
  background: rgba(15, 118, 110, 0.1);
  font-size: 30px;
}

.home-card h2 {
  margin: 0 0 10px;
  font-size: 28px;
  line-height: 1.08;
}

.home-card p:not(.eyebrow) {
  margin: 0;
  color: var(--muted);
  line-height: 1.48;
}

.home-actions {
  display: grid;
  gap: 8px;
  margin-top: auto;
}

.home-primary,
.home-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  margin-top: auto;
  padding: 12px 14px;
  border-radius: 14px;
  font-weight: 800;
  text-align: center;
  text-decoration: none;
}

.home-actions .home-primary,
.home-actions .home-secondary {
  margin-top: 0;
}

.home-primary {
  color: white;
  background: #0f766e;
  box-shadow: 0 10px 24px rgba(15, 118, 110, 0.18);
}

.home-secondary {
  color: #0f766e;
  background: rgba(15, 118, 110, 0.1);
}

.home-note {
  width: min(1050px, 100%);
  margin: 16px auto 0;
  padding: 14px 18px;
  border: 1px solid rgba(24, 100, 171, 0.14);
  border-radius: 18px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.82);
  line-height: 1.45;
}

@media (max-width: 980px) {
  .home-grid {
    grid-template-columns: 1fr;
  }

  .home-card {
    min-height: 0;
  }
}

@media (max-width: 560px) {
  .home-page {
    padding: 12px;
  }

  .home-hero,
  .home-card {
    border-radius: 18px;
  }

  .home-card {
    padding: 18px;
  }

  .home-card h2 {
    font-size: 24px;
  }
}

/* v8: зоны редактируются произвольно, ссылки между приложениями скрыты */
.app-private-note a {
  display: none !important;
}

.editor-zone-move-icon {
  background: transparent;
  border: 0;
  touch-action: none;
}

.editor-zone-move-icon span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 3px solid white;
  border-radius: 999px;
  background: #0f766e;
  color: #fff;
  box-shadow: 0 6px 18px rgba(12, 24, 38, 0.32);
  cursor: move;
  font-size: 18px;
  font-weight: 900;
  transform: rotate(45deg);
}

/* v9: клиенты по QR отображаются на карте контроля отдельно от маркера катера */
.client-dot-marker {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px 4px 5px;
  border: 2px solid #fff;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 8px 22px rgba(12, 24, 38, 0.24);
  color: #0b7285;
  font-size: 12px;
  font-weight: 850;
  white-space: nowrap;
  pointer-events: auto;
}

.client-dot-marker .client-dot {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: #0ca678;
  box-shadow: 0 0 0 5px rgba(12, 166, 120, 0.18);
}


/* v11: убрана постоянная подпись "Дудка: Клиент" возле клиентских GPS-точек */
.client-dot-marker.client-dot-only {
  padding: 0;
  width: 22px;
  height: 22px;
  justify-content: center;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
}

.client-dot-marker.client-dot-only .client-dot {
  width: 14px;
  height: 14px;
}

.client-dot-marker.stale {
  opacity: 0.55;
  filter: grayscale(0.5);
}

.client-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 10px 0 0;
}

.client-chip {
  min-height: 30px;
  padding: 6px 9px;
  border: 1px solid rgba(12, 166, 120, 0.24);
  border-radius: 999px;
  background: rgba(12, 166, 120, 0.1);
  color: #087f5b;
  font-size: 12px;
  font-weight: 750;
}

.client-chip.stale {
  color: #6c757d;
  background: rgba(108, 117, 125, 0.1);
  border-color: rgba(108, 117, 125, 0.2);
}

.device-clients-empty {
  margin: 8px 0 0;
}

@media (max-width: 760px) {
  .client-dot-marker strong {
    max-width: 116px;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

/* v12: журнал контроля и явный редактор слоёв */
.layer-edit-panel .tool-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.layer-edit-panel select {
  min-width: 0;
}

.mini-button {
  min-height: 30px;
  padding: 6px 10px;
  font-size: 12px;
}

.control-log-list {
  display: grid;
  gap: 8px;
  max-height: 260px;
  overflow: auto;
  padding-right: 4px;
}

.control-log-row {
  display: grid;
  gap: 2px;
  padding: 9px 10px;
  border: 1px solid rgba(15, 118, 110, 0.13);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.72);
}

.control-log-row time {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.control-log-row strong {
  color: var(--text);
  font-size: 13px;
}

.control-log-row span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.control-log-row.error {
  border-color: rgba(201, 42, 42, 0.24);
  background: rgba(255, 245, 245, 0.82);
}

.control-log-row.sync {
  border-color: rgba(12, 166, 120, 0.22);
  background: rgba(235, 251, 238, 0.72);
}

.control-log-row.camera {
  border-color: rgba(24, 100, 171, 0.2);
  background: rgba(231, 245, 255, 0.7);
}

@media (max-width: 760px) {
  .control-log-list {
    max-height: 190px;
  }

  .layer-edit-panel .tool-grid {
    grid-template-columns: 1fr;
  }
}

/* v13: в клиентском приложении на карте оставляем только значок катера без отдельной GPS-точки клиента и без лишней подписи */
body[data-app-mode="client"] .native-boat-label {
  display: none;
}

/* v14: режим следования по курсу — отдельная кнопка, карта поворачивается по направлению движения */
#map-course-button.active-toggle { background: #7048e8; color: #fff; border-color: #7048e8; }
#map.navigation-rotating::after { content: "по курсу"; }


/* v15: iPhone/Safari — ручной запуск GPS и облегчение мобильной карты */
html {
  -webkit-text-size-adjust: 100%;
}

.gps-start-button,
.status-action-button {
  width: 100%;
  min-height: 44px;
  margin-top: 10px;
  color: white;
  background: #1864ab;
  font-weight: 800;
}

.gps-start-button.gps-running,
.status-action-button.gps-running {
  background: #0f766e;
}

.status-action-button {
  display: none;
  width: auto;
  justify-self: start;
  padding: 9px 12px;
  font-size: 13px;
}

body[data-app-mode="client"] .status-action-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.client-gps-actions {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

@supports (-webkit-touch-callout: none) {
  .sidebar,
  .map-status-overlay,
  .map-fine-overlay,
  .panel {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .panel,
  .map-status-overlay,
  .map-fine-overlay,
  .map-fullscreen-button,
  .map-toolbar button {
    box-shadow: 0 6px 18px rgba(12, 24, 38, 0.12);
  }

  .native-boat-shape {
    transition: transform 0.12s linear;
  }
}

@media (max-width: 760px) {
  body[data-app-mode="client"] .map-status-overlay {
    top: calc(10px + env(safe-area-inset-top));
    left: calc(10px + env(safe-area-inset-left));
    right: calc(10px + env(safe-area-inset-right));
    gap: 4px;
    max-height: none;
  }

  body[data-app-mode="client"] .map-status-overlay strong {
    font-size: 16px;
  }

  body[data-app-mode="client"] .map-status-overlay small {
    white-space: normal;
  }

  body[data-app-mode="client"] .map-toolbar {
    left: calc(10px + env(safe-area-inset-left));
    right: calc(106px + env(safe-area-inset-right));
    bottom: calc(10px + env(safe-area-inset-bottom));
  }

  body[data-app-mode="client"] .map-fullscreen-button {
    right: calc(10px + env(safe-area-inset-right));
    bottom: calc(10px + env(safe-area-inset-bottom));
  }

  body[data-app-mode="client"] .map-fine-overlay {
    top: calc(128px + env(safe-area-inset-top));
    right: calc(10px + env(safe-area-inset-right));
  }
}


/* v16: iPhone/Safari fullscreen fallback. Safari on iPhone does not always expose true Fullscreen API for pages, so the app uses a fixed full-screen map container. */
body.navigation-page-lock {
  width: 100%;
  height: var(--app-vh, 100vh);
  overscroll-behavior: none;
}

body.ios-navigation-lock {
  position: fixed;
  inset: 0;
  overflow: hidden;
  -webkit-overflow-scrolling: auto;
}

.map-area.navigation-fullscreen-fallback {
  width: 100vw;
  height: var(--app-vh, 100vh);
  min-height: var(--app-vh, 100vh);
  padding: 0;
  overflow: hidden;
  border-radius: 0;
}

.map-area.navigation-fullscreen-fallback #map {
  width: 100vw;
  height: var(--app-vh, 100vh);
  min-height: var(--app-vh, 100vh);
  border-radius: 0;
  box-shadow: none;
}

.map-area.ios-fullscreen-fallback .map-fullscreen-button,
.map-area.ios-fullscreen-fallback .map-toolbar,
.map-area.ios-fullscreen-fallback .map-status-overlay,
.map-area.ios-fullscreen-fallback .map-fine-overlay {
  transform: translateZ(0);
}

.map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  right: calc(14px + env(safe-area-inset-right));
  bottom: calc(14px + env(safe-area-inset-bottom));
}

.map-area.navigation-fullscreen-fallback .map-toolbar {
  left: calc(14px + env(safe-area-inset-left));
  bottom: calc(14px + env(safe-area-inset-bottom));
}

.map-area.navigation-fullscreen-fallback .map-status-overlay {
  top: calc(14px + env(safe-area-inset-top));
  left: calc(14px + env(safe-area-inset-left));
}

.map-area.navigation-fullscreen-fallback .map-fine-overlay {
  top: calc(14px + env(safe-area-inset-top));
  right: calc(14px + env(safe-area-inset-right));
}

@supports (height: 100dvh) {
  :root { --app-vh: 100dvh; }
  .map-area.navigation-fullscreen-fallback,
  .map-area.navigation-fullscreen-fallback #map {
    height: 100dvh;
    min-height: 100dvh;
  }
}

/* v18: контурный редактор зон и красное предупреждение опасной зоны */
.zone-redraw-box {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(201, 42, 42, 0.22);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255, 245, 245, 0.96), rgba(255, 250, 250, 0.9));
}

.zone-redraw-box strong {
  display: block;
  font-size: 14px;
  color: #9b1c1c;
  margin-bottom: 4px;
}

.zone-redraw-box p {
  margin: 0 0 10px;
  font-size: 12px;
  line-height: 1.45;
  color: #7a2e2e;
}

.zone-redraw-box .active-tool {
  background: #c92a2a;
  color: #fff;
  border-color: #c92a2a;
}

.map-danger-alert {
  position: absolute;
  left: 50%;
  bottom: 86px;
  z-index: 8;
  min-width: 160px;
  max-width: min(320px, calc(100% - 28px));
  transform: translate(-50%, 10px) scale(0.96);
  opacity: 0;
  pointer-events: none;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(201, 42, 42, 0.94);
  color: #fff;
  box-shadow: 0 12px 28px rgba(92, 0, 0, 0.28);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: opacity 0.18s ease, transform 0.18s ease;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.map-danger-alert.visible {
  opacity: 1;
  transform: translate(-50%, 0) scale(1);
}

.map-danger-alert strong {
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.map-danger-alert span {
  font-size: 12px;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.client-dot-marker.danger .client-dot {
  background: #c92a2a;
  box-shadow: 0 0 0 4px rgba(201, 42, 42, 0.18), 0 8px 18px rgba(201, 42, 42, 0.28);
}

.map-area.navigation-fullscreen-fallback .map-danger-alert,
.map-area:fullscreen .map-danger-alert {
  bottom: calc(82px + env(safe-area-inset-bottom));
}

.map-area.ios-fullscreen-fallback .map-danger-alert {
  transform: translateZ(0) translate(-50%, 0) scale(1);
}

@media (max-width: 760px) {
  .map-danger-alert {
    bottom: calc(70px + env(safe-area-inset-bottom));
    padding: 7px 10px;
    max-width: calc(100% - 20px);
  }

  .map-danger-alert strong,
  .map-danger-alert span {
    font-size: 11px;
  }
}

/* v18: основной редактор зон через контур */
.editor-sketch-point {
  width: 30px;
  height: 30px;
  transform: translate(-50%, -50%);
  cursor: grab;
  touch-action: none;
}

.editor-sketch-point span {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  border: 3px solid #fff;
  background: #e03131;
  color: #fff;
  font-size: 11px;
  font-weight: 900;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.28);
}

.editor-sketch-point.first span {
  background: #2f9e44;
}

.editor-sketch-point.last span {
  outline: 3px solid rgba(224, 49, 49, 0.22);
}

.editor-sketch-point:active,
.editor-sketch-point.maplibregl-marker-dragging {
  cursor: grabbing;
}

.zone-redraw-box .tool-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 760px) {
  .editor-sketch-point {
    width: 36px;
    height: 36px;
  }
  .editor-sketch-point span {
    width: 30px;
    height: 30px;
    font-size: 12px;
  }
  .editor-map-toolbar button#editor-map-add-speed,
  .editor-map-toolbar button#editor-map-add-area {
    min-width: 124px;
  }
}
.zone-size-hidden { display: none !important; }

/* v21 simplified server map editor */
.simple-editor-shell .brand h1 { margin-bottom: 8px; }
.simple-editor-sidebar { gap: 12px; }
.simple-editor-sidebar .panel { margin-bottom: 10px; }
.editor-mode-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.save-all-button { font-size: 16px; font-weight: 800; padding: 13px 16px; }
.hidden-panel { display: none !important; }
.simple-map-toolbar { gap: 8px; flex-wrap: wrap; }
.simple-object-list { max-height: 220px; overflow: auto; padding-right: 4px; }
.simple-object-list li { margin-bottom: 8px; }
.object-row { width: 100%; text-align: left; display: grid; gap: 4px; padding: 10px 12px; border: 1px solid rgba(31, 41, 55, .14); border-radius: 14px; background: rgba(255,255,255,.94); color: #1f2937; cursor: pointer; }
.object-row:hover, .object-row.selected { border-color: #1864ab; box-shadow: 0 0 0 2px rgba(24, 100, 171, .14); }
.object-row strong { font-size: 14px; }
.object-row span { color: #667085; font-size: 12px; }
.empty-list-item { color: #667085; font-size: 13px; padding: 8px 2px; }
.buoy-dot { display: inline-block; width: 10px; height: 10px; border-radius: 999px; margin-right: 3px; vertical-align: -1px; border: 1px solid #fff; box-shadow: 0 0 0 1px rgba(31,41,55,.12); }
.buoy-dot.green { background: #2f9e44; }
.buoy-dot.red { background: #e03131; }
.simple-buoy-marker { width: 22px; height: 22px; border-radius: 999px; border: 3px solid #fff; box-shadow: 0 4px 14px rgba(0,0,0,.25); cursor: grab; }
.simple-buoy-marker:active { cursor: grabbing; }
.simple-buoy-marker.green { background: #2f9e44; }
.simple-buoy-marker.red { background: #e03131; }
.simple-buoy-marker.pending { animation: simplePulse 1s infinite alternate; }
.simple-vertex-marker { width: 24px; height: 24px; border-radius: 999px; border: 3px solid #fff; background: #f76707; box-shadow: 0 4px 14px rgba(0,0,0,.28); cursor: grab; padding: 0; }
.simple-vertex-marker.first { background: #2f9e44; }
.simple-vertex-marker:active { cursor: grabbing; }
.editor-toast { position: absolute; left: 50%; bottom: calc(18px + env(safe-area-inset-bottom)); transform: translate(-50%, 20px); z-index: 15; pointer-events: none; max-width: min(520px, calc(100vw - 24px)); padding: 12px 16px; border-radius: 16px; font-weight: 800; color: #fff; opacity: 0; transition: opacity .2s ease, transform .2s ease; box-shadow: 0 12px 35px rgba(0,0,0,.22); }
.editor-toast.show { opacity: 1; transform: translate(-50%, 0); }
.editor-toast.ok { background: #2f9e44; }
.editor-toast.warn { background: #f08c00; }
.editor-toast.error { background: #e03131; }
.editor-action-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 10px; }
.editor-action-row button { min-height: 42px; font-weight: 800; }
.simple-map-toolbar .danger-button { box-shadow: 0 8px 22px rgba(201, 42, 42, .22); }
.simple-map-toolbar button { min-height: 40px; font-weight: 800; }
@media (max-width: 820px) {
  .editor-action-row { grid-template-columns: 1fr; }
  .simple-map-toolbar { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .simple-map-toolbar button { padding: 9px 10px; }
}

@keyframes simplePulse { from { transform: scale(1); } to { transform: scale(1.18); } }
@media (max-width: 820px) {
  .simple-editor-shell { grid-template-rows: minmax(52vh, 1fr) auto; }
  .simple-editor-shell .editor-sidebar { order: 2; max-height: 48vh; overflow: auto; padding-bottom: calc(14px + env(safe-area-inset-bottom)); }
  .simple-editor-shell .map-stage { order: 1; min-height: 52vh; }
  .editor-mode-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .simple-object-list { max-height: 150px; }
  .simple-map-toolbar { top: calc(10px + env(safe-area-inset-top)); left: 10px; right: 58px; }
  .simple-vertex-marker, .simple-buoy-marker { width: 28px; height: 28px; }
}

/* v23: fixed simple editor map container height */
.editor-shell .map-stage,
.simple-editor-shell .map-stage {
  position: relative;
  height: 100vh;
  min-height: 0;
  overflow: hidden;
  background: #dce8f3;
}

.editor-shell #editor-map,
.simple-editor-shell #editor-map,
#editor-map.map {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 420px;
}

.simple-editor-shell .maplibregl-canvas-container,
.simple-editor-shell .maplibregl-canvas {
  min-height: 100%;
}


@media (max-width: 820px) {
  .simple-editor-shell .map-stage {
    height: 52vh;
    min-height: 52vh;
  }
  .simple-editor-shell #editor-map,
  #editor-map.map {
    height: 100%;
    min-height: 52vh;
  }
}

/* v26: более заметная плашка штрафов при активном нарушении */
.map-fine-overlay.danger {
  border-color: rgba(201, 42, 42, 0.55);
  background: rgba(255, 245, 245, 0.96);
  box-shadow: 0 14px 34px rgba(201, 42, 42, 0.24);
}
.map-fine-overlay span {
  white-space: normal;
  line-height: 1.15;
}
.map-fine-overlay.danger span {
  color: #c92a2a;
}

/* v26: SOS button and alert */
.client-sos-panel {
  border-color: rgba(201, 42, 42, 0.22);
  background: linear-gradient(180deg, rgba(255, 245, 245, 0.96), rgba(255, 255, 255, 0.94));
}
.danger-pill {
  color: #c92a2a;
  background: rgba(201, 42, 42, 0.12);
}
.sos-button,
.map-sos-button {
  color: #fff;
  background: #c92a2a;
  border-color: #c92a2a;
  box-shadow: 0 14px 34px rgba(201, 42, 42, 0.28);
  font-weight: 1000;
  letter-spacing: .08em;
}
.sos-button {
  width: 100%;
  min-height: 58px;
  margin-top: 12px;
  border-radius: 12px;
  font-size: 22px;
}
.sos-button.sending,
.map-sos-button.sending {
  opacity: .75;
  filter: saturate(.8);
}
.map-sos-button {
  position: absolute;
  right: 32px;
  bottom: 88px;
  z-index: 735;
  width: 72px;
  min-height: 52px;
  border-radius: 999px;
  font-size: 17px;
}
.map-sos-alert {
  position: absolute;
  left: 50%;
  top: 112px;
  z-index: 780;
  display: none;
  width: min(520px, calc(100% - 28px));
  transform: translateX(-50%);
  padding: 12px 14px;
  border: 1px solid rgba(201, 42, 42, 0.45);
  border-radius: 14px;
  color: #fff;
  background: rgba(201, 42, 42, 0.96);
  box-shadow: 0 18px 42px rgba(92, 0, 0, 0.32);
  align-items: center;
  gap: 10px;
}
.map-sos-alert.visible {
  display: flex;
}
.map-sos-alert.sent {
  background: rgba(15, 118, 110, 0.96);
  border-color: rgba(15, 118, 110, 0.45);
}
.map-sos-alert strong {
  flex: 0 0 auto;
  font-size: 16px;
  font-weight: 1000;
}
.map-sos-alert span {
  flex: 1 1 auto;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.25;
}
.map-sos-alert button {
  flex: 0 0 auto;
  min-height: 34px;
  padding: 7px 11px;
  color: #c92a2a;
  background: #fff;
  box-shadow: none;
}
.map-area:fullscreen .map-sos-button,
.map-area.navigation-fullscreen-fallback .map-sos-button {
  right: 18px;
  bottom: 132px;
}
.map-area:fullscreen .map-sos-alert,
.map-area.navigation-fullscreen-fallback .map-sos-alert {
  top: calc(82px + env(safe-area-inset-top));
}
@media (max-width: 760px) {
  .map-sos-button {
    right: 14px;
    bottom: calc(120px + env(safe-area-inset-bottom));
    width: 66px;
    min-height: 50px;
  }
  .map-sos-alert {
    top: calc(86px + env(safe-area-inset-top));
    padding: 10px 11px;
  }
  .map-sos-alert strong { font-size: 14px; }
  .map-sos-alert span { font-size: 12px; }
}
.sos-map-marker {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border: 3px solid #fff;
  border-radius: 999px;
  background: #c92a2a;
  box-shadow: 0 0 0 8px rgba(201, 42, 42, .18), 0 18px 34px rgba(92, 0, 0, .34);
  animation: sosPulse 1.1s ease-in-out infinite;
}
.sos-map-marker span {
  font-size: 20px;
  line-height: 1;
}
@keyframes sosPulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.12); }
}

/* v27: стартовая форма клиента, сообщения и чистая карта контроля */
.client-start-gate {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: max(18px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(18px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));
  background: radial-gradient(circle at top, rgba(2, 132, 199, 0.22), transparent 42%), rgba(6, 18, 34, 0.86);
  backdrop-filter: blur(12px);
}
.client-start-gate.hidden,
body[data-demo="true"] .client-start-gate {
  display: none;
}
.client-start-card {
  width: min(420px, 100%);
  border-radius: 24px;
  padding: 22px;
  background: #ffffff;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.28);
  display: grid;
  gap: 14px;
}
.client-start-card h1 {
  margin: 0;
  font-size: 24px;
}
.client-start-card label,
.control-message-label {
  display: grid;
  gap: 6px;
  color: #475569;
  font-size: 13px;
  font-weight: 700;
}
.client-start-card input,
.client-start-card select,
.control-message-label select,
.control-message-label textarea {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #cbd5e1;
  border-radius: 14px;
  padding: 12px 13px;
  background: #fff;
  color: #0f172a;
  font: inherit;
}
.control-message-label textarea {
  resize: vertical;
  min-height: 76px;
}
.form-error {
  min-height: 18px;
  margin: 0;
  color: #dc2626;
  font-size: 13px;
  font-weight: 700;
}
.client-message-alert {
  position: absolute;
  left: max(14px, env(safe-area-inset-left));
  right: max(14px, env(safe-area-inset-right));
  top: calc(74px + env(safe-area-inset-top));
  z-index: 12;
  display: none;
  gap: 8px;
  border-radius: 18px;
  padding: 12px 14px;
  background: rgba(15, 23, 42, 0.92);
  color: #fff;
  box-shadow: 0 16px 50px rgba(0, 0, 0, 0.3);
  backdrop-filter: blur(10px);
}
.client-message-alert.visible {
  display: grid;
}
.client-message-alert strong {
  font-size: 13px;
  color: #bfdbfe;
}
.client-message-alert span {
  font-size: 16px;
  font-weight: 800;
}
.client-message-alert button {
  justify-self: start;
  border: none;
  border-radius: 999px;
  padding: 8px 14px;
  background: #2563eb;
  color: #fff;
  font-weight: 800;
}
.control-message-panel {
  display: grid;
  gap: 12px;
}
body.control-clean-mode .map-status-overlay,
body.control-clean-mode .map-fine-overlay {
  display: none !important;
}
body.control-clean-mode .native-boat-label,
body.control-clean-mode .client-dot-marker:not(.danger) {
  opacity: 0.45;
}
body[data-demo="true"] .client-sos-panel,
body[data-demo="true"] .client-start-gate {
  display: none !important;
}
body[data-demo="true"] .client-gps-panel .client-hint::after {
  content: "";
  font-weight: 800;
}
.home-card-demo {
  border-color: rgba(234, 88, 12, 0.25);
}

@media (max-width: 720px) {
  .client-start-card {
    border-radius: 22px;
    padding: 18px;
  }
  .client-message-alert {
    top: calc(92px + env(safe-area-inset-top));
  }
}

/* v30: клиентский fullscreen — SOS выше, штрафы ниже, чтобы элементы не перекрывались на телефоне */
.map-area:fullscreen .map-sos-button,
.map-area.navigation-fullscreen-fallback .map-sos-button {
  bottom: calc(190px + env(safe-area-inset-bottom));
  right: calc(18px + env(safe-area-inset-right));
}

.map-area:fullscreen .map-fine-overlay,
.map-area.navigation-fullscreen-fallback .map-fine-overlay {
  top: calc(78px + env(safe-area-inset-top));
  right: calc(18px + env(safe-area-inset-right));
}

@media (max-width: 760px) {
  .map-area:fullscreen .map-sos-button,
  .map-area.navigation-fullscreen-fallback .map-sos-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
    bottom: calc(178px + env(safe-area-inset-bottom));
    right: calc(12px + env(safe-area-inset-right));
  }

  .map-area:fullscreen .map-fine-overlay,
  .map-area.navigation-fullscreen-fallback .map-fine-overlay,
  body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
    top: calc(150px + env(safe-area-inset-top));
    right: calc(10px + env(safe-area-inset-right));
  }
}

/* v31: safe corridor editor points */
.corridor-dot { display: inline-block; width: 10px; height: 10px; border-radius: 999px; margin-right: 3px; vertical-align: -1px; background: #0f766e; border: 1px solid #fff; box-shadow: 0 0 0 1px rgba(31,41,55,.12); }
.simple-corridor-marker { width: 24px; height: 24px; border-radius: 999px; border: 3px solid #fff; background: #0f766e; box-shadow: 0 4px 14px rgba(0,0,0,.28); cursor: grab; }
.simple-corridor-marker::after { content: ''; position: absolute; inset: 6px; border-radius: 999px; background: rgba(255,255,255,.9); }
.simple-corridor-marker:active { cursor: grabbing; }
@media (max-width: 820px) { .simple-corridor-marker { width: 30px; height: 30px; } }


/* v32: сообщение диспетчера в клиентской карте снизу слева, рядом с кнопками Следить/Курс */
body[data-app-mode="client"] .client-message-alert,
body[data-demo="true"] .client-message-alert {
  top: auto !important;
  left: calc(14px + env(safe-area-inset-left)) !important;
  right: calc(14px + env(safe-area-inset-right)) !important;
  bottom: calc(86px + env(safe-area-inset-bottom)) !important;
  z-index: 755;
  max-width: min(430px, calc(100vw - 28px - env(safe-area-inset-left) - env(safe-area-inset-right)));
  border-radius: 16px;
  padding: 10px 12px;
}

body[data-app-mode="client"] .client-message-alert strong,
body[data-demo="true"] .client-message-alert strong {
  font-size: 12px;
}

body[data-app-mode="client"] .client-message-alert span,
body[data-demo="true"] .client-message-alert span {
  font-size: 14px;
  line-height: 1.25;
}

body[data-app-mode="client"] .client-message-alert button,
body[data-demo="true"] .client-message-alert button {
  min-height: 32px;
  padding: 7px 12px;
}

body[data-app-mode="client"] .map-area:fullscreen .client-message-alert,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .client-message-alert,
body[data-demo="true"] .map-area:fullscreen .client-message-alert,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .client-message-alert {
  bottom: calc(76px + env(safe-area-inset-bottom)) !important;
  left: calc(12px + env(safe-area-inset-left)) !important;
  right: calc(152px + env(safe-area-inset-right)) !important;
  max-width: none;
}

@media (max-width: 760px) {
  body[data-app-mode="client"] .client-message-alert,
  body[data-demo="true"] .client-message-alert {
    bottom: calc(72px + env(safe-area-inset-bottom)) !important;
    left: calc(10px + env(safe-area-inset-left)) !important;
    right: calc(10px + env(safe-area-inset-right)) !important;
    padding: 9px 10px;
  }

  body[data-app-mode="client"] .map-area:fullscreen .client-message-alert,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .client-message-alert,
  body[data-demo="true"] .map-area:fullscreen .client-message-alert,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .client-message-alert {
    bottom: calc(76px + env(safe-area-inset-bottom)) !important;
    left: calc(10px + env(safe-area-inset-left)) !important;
    right: calc(142px + env(safe-area-inset-right)) !important;
  }
}

/* v33: trip stop/reset controls */
.trip-stop-button,
.danger-outline-button,
.map-stop-button {
  border: 1px solid rgba(224, 49, 49, .35) !important;
  background: linear-gradient(135deg, #fff5f5, #ffe3e3) !important;
  color: #c92a2a !important;
  font-weight: 900;
}
.trip-stop-button:hover,
.danger-outline-button:hover,
.map-stop-button:hover { filter: brightness(.98); }
.trip-stop-button.wide { width: 100%; margin-top: 10px; }
.client-gps-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.client-gps-actions .gps-start-button { flex: 1 1 160px; }
.client-gps-actions .trip-stop-button { flex: 0 0 auto; padding-left: 16px; padding-right: 16px; }
.map-toolbar .map-stop-button { min-width: 62px; }
@media (max-width: 720px) {
  .map-toolbar .map-stop-button { min-width: 54px; padding-left: 10px; padding-right: 10px; }
  .client-gps-actions .trip-stop-button { flex: 1 1 96px; }
}

/* v36 modern navigator: iPhone-safe layout, GPS help, offline status */
:root {
  color-scheme: light;
  --glass: rgba(255,255,255,.86);
  --glass-strong: rgba(255,255,255,.94);
  --nav-shadow: 0 18px 48px rgba(8,22,38,.18);
}

html {
  height: 100%;
  height: 100dvh;
  overscroll-behavior: none;
  -webkit-text-size-adjust: 100%;
}

body[data-app-mode="client"],
body[data-app-mode="monitor"] {
  min-height: var(--app-vh);
  overflow: hidden;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

button,
a,
input,
select,
textarea {
  touch-action: manipulation;
}

input,
select,
textarea {
  font-size: 16px;
}

.map-area {
  min-height: min(100vh, var(--app-vh));
  min-height: 100dvh;
}

body[data-app-mode="client"] .sidebar,
body[data-app-mode="monitor"] .sidebar {
  scrollbar-width: thin;
}

body[data-app-mode="client"] .panel,
body[data-app-mode="monitor"] .panel,
.map-status-overlay,
.map-fine-overlay,
.map-toolbar,
.client-message-alert,
.map-danger-alert,
.map-sos-alert {
  backdrop-filter: blur(18px) saturate(1.25);
  -webkit-backdrop-filter: blur(18px) saturate(1.25);
}

.map-toolbar button,
.map-fullscreen-button,
.map-sos-button,
.gps-start-button,
.status-action-button {
  min-height: 44px;
  border-radius: 14px;
  font-weight: 800;
  box-shadow: 0 10px 24px rgba(12,24,38,.16);
}

.gps-start-button.gps-needs-help,
.status-action-button.gps-needs-help {
  color: #111827;
  background: #ffd43b;
  box-shadow: 0 12px 28px rgba(240,140,0,.28);
}

.app-system-status {
  position: fixed;
  z-index: 80;
  left: 50%;
  top: calc(10px + env(safe-area-inset-top));
  transform: translate(-50%, -12px);
  max-width: min(560px, calc(100vw - 24px - env(safe-area-inset-left) - env(safe-area-inset-right)));
  padding: 10px 14px;
  border: 1px solid rgba(255,255,255,.55);
  border-radius: 999px;
  color: #102033;
  background: var(--glass-strong);
  box-shadow: var(--nav-shadow);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.25;
  text-align: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
}

.app-system-status.visible {
  opacity: 1;
  transform: translate(-50%, 0);
}

.app-system-status.ok { border-color: rgba(47,179,68,.34); }
.app-system-status.warn { border-color: rgba(240,140,0,.45); background: rgba(255,248,225,.95); }
.app-system-status.danger { border-color: rgba(201,42,42,.45); background: rgba(255,235,238,.96); }

.gps-help-overlay {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: grid;
  place-items: center;
  padding: calc(18px + env(safe-area-inset-top)) calc(14px + env(safe-area-inset-right)) calc(18px + env(safe-area-inset-bottom)) calc(14px + env(safe-area-inset-left));
  background: rgba(8, 20, 34, .42);
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
}

.gps-help-overlay.visible {
  opacity: 1;
  pointer-events: auto;
}

.gps-help-card {
  position: relative;
  width: min(560px, 100%);
  max-height: min(86vh, calc(var(--app-vh) - 32px));
  overflow: auto;
  padding: 22px;
  border: 1px solid rgba(255,255,255,.65);
  border-radius: 24px;
  background: var(--glass-strong);
  box-shadow: 0 28px 80px rgba(0,0,0,.28);
}

.gps-help-card h2 {
  margin: 0 44px 10px 0;
  font-size: clamp(22px, 5vw, 30px);
  line-height: 1.08;
}

.gps-help-card ol {
  display: grid;
  gap: 10px;
  margin: 16px 0 0;
  padding-left: 22px;
}

.gps-help-card li {
  padding-left: 4px;
  font-weight: 700;
  line-height: 1.35;
}

.gps-help-close {
  position: absolute;
  top: 12px;
  right: 12px;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  padding: 0;
  border-radius: 50%;
  color: #102033;
  background: rgba(16,32,51,.08);
  box-shadow: none;
  font-size: 28px;
  line-height: 1;
}

.gps-help-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 18px;
}

.gps-help-actions button {
  min-height: 46px;
  border-radius: 14px;
  font-weight: 900;
}

.gps-help-actions .secondary-button {
  color: #0f766e;
  background: rgba(15,118,110,.12);
}

body.gps-help-open .app-system-status {
  opacity: 0;
}

@supports (height: 100dvh) {
  .client-shell,
  .monitor-shell,
  .map-area,
  .map-area.navigation-fullscreen-fallback,
  .map-area.navigation-fullscreen-fallback #map {
    min-height: 100dvh;
    height: 100dvh;
  }
}

@media (max-width: 980px) {
  body[data-app-mode="client"],
  body[data-app-mode="monitor"] {
    overflow: auto;
  }
  .client-shell,
  .monitor-shell {
    min-height: var(--app-vh);
  }
  .client-shell .sidebar,
  .monitor-shell .sidebar {
    max-height: 38vh;
    max-height: 38dvh;
    overflow: auto;
    padding-bottom: calc(16px + env(safe-area-inset-bottom));
  }
  .client-shell .map-area,
  .monitor-shell .map-area {
    min-height: 62vh;
    min-height: 62dvh;
  }
}

@media (max-width: 760px) {
  body[data-app-mode="client"] .map-status-overlay {
    top: calc(10px + env(safe-area-inset-top));
    left: calc(10px + env(safe-area-inset-left));
    right: calc(10px + env(safe-area-inset-right));
    max-width: none;
    padding: 12px;
    border-radius: 18px;
  }

  body[data-app-mode="client"] .map-toolbar {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7px;
    left: calc(10px + env(safe-area-inset-left));
    right: calc(96px + env(safe-area-inset-right));
    bottom: calc(10px + env(safe-area-inset-bottom));
    padding: 7px;
    border-radius: 18px;
    background: rgba(255,255,255,.72);
  }

  body[data-app-mode="client"] .map-toolbar button {
    min-width: 0;
    min-height: 42px;
    padding: 8px 6px;
    border-radius: 12px;
    font-size: 12px;
  }

  body[data-app-mode="client"] .map-fullscreen-button {
    right: calc(10px + env(safe-area-inset-right));
    bottom: calc(10px + env(safe-area-inset-bottom));
    width: 78px;
    min-height: 54px;
    padding: 8px 10px;
    border-radius: 18px;
    font-size: 12px;
  }

  body[data-app-mode="client"] .map-sos-button {
    right: calc(12px + env(safe-area-inset-right));
    bottom: calc(146px + env(safe-area-inset-bottom));
    width: 62px;
    height: 62px;
  }

  .gps-help-card {
    padding: 18px;
    border-radius: 22px;
  }
  .gps-help-actions {
    grid-template-columns: 1fr;
  }
}

@media (display-mode: standalone) {
  body[data-app-mode="client"] .map-status-overlay,
  body[data-app-mode="monitor"] .map-status-overlay {
    top: calc(14px + env(safe-area-inset-top));
  }
}

/* v36: boat templates and one-active-session lock */
.boat-session-status {
  display: grid;
  gap: 4px;
  padding: 11px 12px;
  border-radius: 16px;
  border: 1px solid rgba(15, 118, 110, 0.18);
  background: rgba(15, 118, 110, 0.08);
  color: #0f172a;
  font-size: 13px;
  line-height: 1.35;
}
.boat-session-status strong {
  font-size: 14px;
}
.boat-session-status span {
  color: #475569;
}
.boat-session-status.ok {
  border-color: rgba(22, 163, 74, 0.26);
  background: rgba(22, 163, 74, 0.10);
}
.boat-session-status.warn,
.boat-session-status.checking {
  border-color: rgba(245, 158, 11, 0.28);
  background: rgba(245, 158, 11, 0.11);
}
.boat-session-status.danger {
  border-color: rgba(220, 38, 38, 0.30);
  background: rgba(220, 38, 38, 0.10);
}
.boat-session-status.danger strong,
.boat-session-status.danger span {
  color: #991b1b;
}
.qr-template-actions {
  margin: 10px 0 4px;
}


/* v38/v39: красивая клиентская шапка навигатора без штрафов + отдельная синяя кнопка GPS в панели кнопок */
.navigator-header.map-status-overlay {
  width: min(520px, calc(100% - 240px));
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(37, 99, 235, 0.16);
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(255,255,255,.94), rgba(239,246,255,.88));
  box-shadow: 0 18px 48px rgba(15, 23, 42, 0.18);
}
.navigator-header-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.navigator-header-title-row span,
.navigator-header #map-status-title {
  color: #2563eb;
  letter-spacing: .08em;
}
.navigator-header-title-row strong,
.navigator-header #map-status-main {
  max-width: 72%;
  color: #0f172a;
  font-size: 20px;
  text-align: right;
}
.navigator-status-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}
.navigator-status-chip {
  display: grid;
  gap: 3px;
  min-width: 0;
  padding: 9px 10px;
  border: 1px solid rgba(37, 99, 235, 0.12);
  border-radius: 16px;
  background: rgba(255,255,255,.72);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.65);
}
.navigator-status-chip small {
  color: #64748b;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
  white-space: nowrap;
}
.navigator-status-chip b {
  overflow: hidden;
  color: #0f172a;
  font-size: 13px;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.navigator-header #map-status-detail {
  color: #475569;
  font-size: 12px;
  line-height: 1.25;
}
.toolbar-gps-button {
  color: #fff !important;
  border-color: #1d4ed8 !important;
  background: linear-gradient(135deg, #2563eb, #1d4ed8) !important;
}
.toolbar-gps-button.gps-running {
  border-color: #0f766e !important;
  background: linear-gradient(135deg, #10b981, #0f766e) !important;
}
.toolbar-gps-button.gps-needs-help {
  color: #111827 !important;
  border-color: #f59e0b !important;
  background: linear-gradient(135deg, #fde68a, #f59e0b) !important;
}
.map-fine-overlay {
  border-radius: 18px;
  border-color: rgba(220, 38, 38, .18);
  background: rgba(255,255,255,.96);
}
.map-fine-overlay.danger {
  background: linear-gradient(135deg, rgba(254, 242, 242, .98), rgba(255,255,255,.96));
}
.map-area:fullscreen .navigator-header.map-status-overlay,
.map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
  top: calc(14px + env(safe-area-inset-top));
  left: calc(14px + env(safe-area-inset-left));
}
.map-area:fullscreen .map-fine-overlay,
.map-area.navigation-fullscreen-fallback .map-fine-overlay {
  top: calc(116px + env(safe-area-inset-top));
  right: calc(14px + env(safe-area-inset-right));
}
@media (max-width: 760px) {
  body[data-app-mode="client"] .navigator-header.map-status-overlay,
  body[data-demo="true"] .navigator-header.map-status-overlay {
    top: calc(8px + env(safe-area-inset-top));
    left: calc(8px + env(safe-area-inset-left));
    right: calc(8px + env(safe-area-inset-right));
    width: auto;
    padding: 10px;
    gap: 8px;
    border-radius: 18px;
  }
  .navigator-header-title-row strong,
  .navigator-header #map-status-main {
    max-width: 64%;
    font-size: 16px;
  }
  .navigator-status-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 5px;
  }
  .navigator-status-chip {
    padding: 7px 6px;
    border-radius: 12px;
  }
  .navigator-status-chip small { font-size: 8.5px; }
  .navigator-status-chip b { font-size: 11px; }
  .navigator-header #map-status-detail {
    display: block;
    font-size: 11px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  body[data-app-mode="client"] .map-toolbar,
  body[data-demo="true"] .map-toolbar {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    right: calc(88px + env(safe-area-inset-right));
  }
  body[data-app-mode="client"] .map-toolbar button,
  body[data-demo="true"] .map-toolbar button {
    font-size: 11px;
    min-height: 40px;
    padding: 7px 5px;
  }
  body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay,
  body[data-demo="true"] .map-area:fullscreen .map-fine-overlay,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
    top: calc(118px + env(safe-area-inset-top));
    right: calc(8px + env(safe-area-inset-right));
  }
}
@media (max-width: 390px) {
  .navigator-status-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  body[data-app-mode="client"] .map-toolbar,
  body[data-demo="true"] .map-toolbar { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

/* v39: предупреждение о нарушении крупнее и читаемее на iPhone */
.map-danger-alert {
  min-width: 240px;
  max-width: min(520px, calc(100% - 24px));
  padding: 12px 18px;
  border-radius: 22px;
  gap: 10px;
  bottom: calc(104px + env(safe-area-inset-bottom));
  box-shadow: 0 18px 44px rgba(92, 0, 0, 0.34);
}
.map-danger-alert strong {
  font-size: 15px;
  letter-spacing: .01em;
}
.map-danger-alert span {
  font-size: 14px;
  line-height: 1.25;
  max-width: 380px;
}
.map-area.navigation-fullscreen-fallback .map-danger-alert,
.map-area:fullscreen .map-danger-alert,
.map-area.ios-fullscreen-fallback .map-danger-alert {
  bottom: calc(122px + env(safe-area-inset-bottom));
}
@media (max-width: 760px) {
  .map-danger-alert {
    min-width: min(300px, calc(100% - 28px));
    padding: 11px 14px;
    border-radius: 20px;
    bottom: calc(98px + env(safe-area-inset-bottom));
  }
  .map-danger-alert strong {
    font-size: 14px;
  }
  .map-danger-alert span {
    font-size: 13px;
    max-width: 100%;
  }
  .map-area.navigation-fullscreen-fallback .map-danger-alert,
  .map-area:fullscreen .map-danger-alert,
  .map-area.ios-fullscreen-fallback .map-danger-alert {
    bottom: calc(118px + env(safe-area-inset-bottom));
  }
}

/* v40: старт маршрута, иконка катера вместо текстовой кнопки, ровные элементы в fullscreen */
.route-start-button,
.route-start-map-button {
  border: 1px solid rgba(15, 118, 110, .35) !important;
  background: linear-gradient(135deg, #ecfdf5, #ccfbf1) !important;
  color: #0f766e !important;
  font-weight: 900;
}
.route-start-button.route-running,
.route-start-map-button.route-running,
.route-start-button:disabled,
.route-start-map-button:disabled {
  opacity: .72;
}
.client-gps-actions .route-start-button { flex: 1 1 160px; }
.boat-icon-button {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-width: 46px;
  width: 46px;
  padding-left: 8px !important;
  padding-right: 8px !important;
  line-height: 1;
}
.boat-icon-button img {
  display: block;
  width: 24px;
  height: 24px;
  object-fit: contain;
  object-position: center;
  transform-origin: center;
}
.compact-icon-actions { align-items: center; }
.map-area:fullscreen .boat-icon-button,
.map-area.navigation-fullscreen-fallback .boat-icon-button {
  width: 48px;
  min-width: 48px;
  height: 44px;
}
.map-area:fullscreen .boat-icon-button img,
.map-area.navigation-fullscreen-fallback .boat-icon-button img {
  width: 26px;
  height: 26px;
}
.map-area:fullscreen .map-toolbar,
.map-area.navigation-fullscreen-fallback .map-toolbar {
  align-items: center;
}
@media (max-width: 760px) {
  body[data-app-mode="client"] .map-toolbar,
  body[data-demo="true"] .map-toolbar {
    align-items: center;
  }
  body[data-app-mode="client"] .map-toolbar .boat-icon-button,
  body[data-demo="true"] .map-toolbar .boat-icon-button {
    min-width: 42px;
    width: 42px;
    padding: 6px !important;
  }
  body[data-app-mode="client"] .map-toolbar .route-start-map-button {
    min-width: 92px;
  }
}


/* v41: Android layout fix — no overlapping buttons, boat-return button above SOS */
.map-locate-boat-button {
  position: absolute;
  right: 32px;
  bottom: 148px;
  z-index: 736;
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  padding: 0 !important;
  border: 1px solid rgba(15, 118, 110, .22);
  border-radius: 18px;
  background: rgba(255, 255, 255, .94);
  box-shadow: 0 14px 34px rgba(12, 24, 38, .20);
}
.map-locate-boat-button img {
  display: block;
  width: 32px;
  height: 32px;
  object-fit: contain;
}
.map-area:fullscreen .map-locate-boat-button,
.map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  right: calc(18px + env(safe-area-inset-right));
  bottom: calc(256px + env(safe-area-inset-bottom));
}

@media (max-width: 760px) {
  body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button,
  body[data-demo="true"] .map-area:fullscreen #map-follow-button,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback #map-follow-button,
  body[data-demo="true"] .map-area:fullscreen #map-course-button,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback #map-course-button {
    position: static !important;
    right: auto !important;
    bottom: auto !important;
    min-width: 0 !important;
    min-height: 44px !important;
    color: #0f766e !important;
    background: rgba(15, 118, 110, .12) !important;
    box-shadow: 0 8px 20px rgba(12, 24, 38, .14) !important;
  }
  body[data-app-mode="client"] .map-area:fullscreen #map-follow-button.active-toggle,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button.active-toggle,
  body[data-app-mode="client"] .map-area:fullscreen #map-course-button.active-toggle,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button.active-toggle,
  body[data-demo="true"] .map-area:fullscreen #map-follow-button.active-toggle,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback #map-follow-button.active-toggle,
  body[data-demo="true"] .map-area:fullscreen #map-course-button.active-toggle,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback #map-course-button.active-toggle {
    color: #fff !important;
    background: #0f766e !important;
  }
  body[data-app-mode="client"] .map-toolbar,
  body[data-demo="true"] .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar,
  body[data-demo="true"] .map-area:fullscreen .map-toolbar,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 7px !important;
    left: calc(10px + env(safe-area-inset-left)) !important;
    right: calc(92px + env(safe-area-inset-right)) !important;
    bottom: calc(10px + env(safe-area-inset-bottom)) !important;
    max-width: none !important;
    padding: 7px !important;
    border-radius: 18px !important;
    background: rgba(255, 255, 255, .78) !important;
  }
  body[data-app-mode="client"] .map-toolbar button,
  body[data-demo="true"] .map-toolbar button {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 44px !important;
    padding: 8px 6px !important;
    border-radius: 13px !important;
    font-size: 11.5px !important;
    line-height: 1.05 !important;
    white-space: nowrap !important;
  }
  body[data-app-mode="client"] #map-gps-start-button,
  body[data-demo="true"] #map-gps-start-button {
    grid-column: span 2;
  }
  body[data-app-mode="client"] .map-fullscreen-button,
  body[data-demo="true"] .map-fullscreen-button {
    right: calc(10px + env(safe-area-inset-right)) !important;
    bottom: calc(10px + env(safe-area-inset-bottom)) !important;
    width: 78px !important;
    min-height: 58px !important;
    padding: 8px 8px !important;
    border-radius: 18px !important;
    font-size: 11.5px !important;
    line-height: 1.05 !important;
  }
  body[data-app-mode="client"] .map-sos-button,
  body[data-demo="true"] .map-sos-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button,
  body[data-demo="true"] .map-area:fullscreen .map-sos-button,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-sos-button {
    right: calc(12px + env(safe-area-inset-right)) !important;
    bottom: calc(156px + env(safe-area-inset-bottom)) !important;
    width: 62px !important;
    height: 62px !important;
    min-height: 62px !important;
  }
  body[data-app-mode="client"] .map-locate-boat-button,
  body[data-demo="true"] .map-locate-boat-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button,
  body[data-demo="true"] .map-area:fullscreen .map-locate-boat-button,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
    right: calc(12px + env(safe-area-inset-right)) !important;
    bottom: calc(224px + env(safe-area-inset-bottom)) !important;
    width: 62px !important;
    height: 58px !important;
    min-width: 62px !important;
  }
  body[data-app-mode="client"] .map-locate-boat-button img,
  body[data-demo="true"] .map-locate-boat-button img {
    width: 31px !important;
    height: 31px !important;
  }
  body[data-app-mode="client"] .client-message-alert,
  body[data-demo="true"] .client-message-alert {
    bottom: calc(112px + env(safe-area-inset-bottom)) !important;
  }
  body[data-app-mode="client"] .map-area:fullscreen .client-message-alert,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .client-message-alert,
  body[data-demo="true"] .map-area:fullscreen .client-message-alert,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .client-message-alert {
    bottom: calc(112px + env(safe-area-inset-bottom)) !important;
    right: calc(92px + env(safe-area-inset-right)) !important;
  }
}

@media (max-width: 390px) {
  body[data-app-mode="client"] .map-toolbar,
  body[data-demo="true"] .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar,
  body[data-demo="true"] .map-area:fullscreen .map-toolbar,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    right: calc(88px + env(safe-area-inset-right)) !important;
  }
  body[data-app-mode="client"] #map-route-start-button,
  body[data-demo="true"] #map-route-start-button,
  body[data-app-mode="client"] #map-gps-start-button,
  body[data-demo="true"] #map-gps-start-button {
    grid-column: auto;
  }
  body[data-app-mode="client"] .map-toolbar button,
  body[data-demo="true"] .map-toolbar button {
    min-height: 42px !important;
    font-size: 11px !important;
  }
}

/* v42: Android/non-fullscreen button alignment + Stop above spare */
body[data-app-mode="client"] .map-toolbar,
body[data-demo="true"] .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar,
body[data-demo="true"] .map-area:fullscreen .map-toolbar,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  display: grid !important;
  grid-template-columns: minmax(70px, .9fr) minmax(64px, .8fr) minmax(88px, 1fr) !important;
  grid-template-areas:
    "follow course stop"
    "start gps spare" !important;
  align-items: stretch !important;
  justify-items: stretch !important;
  gap: 8px !important;
  left: calc(10px + env(safe-area-inset-left)) !important;
  right: calc(96px + env(safe-area-inset-right)) !important;
  bottom: calc(10px + env(safe-area-inset-bottom)) !important;
  max-width: none !important;
  width: auto !important;
  padding: 8px !important;
  border-radius: 20px !important;
  box-sizing: border-box !important;
  background: rgba(255,255,255,.84) !important;
  box-shadow: 0 16px 40px rgba(12,24,38,.18) !important;
}
body[data-app-mode="client"] #map-follow-button,
body[data-demo="true"] #map-follow-button { grid-area: follow !important; }
body[data-app-mode="client"] #map-course-button,
body[data-demo="true"] #map-course-button { grid-area: course !important; }
body[data-app-mode="client"] #map-route-start-button,
body[data-demo="true"] #map-route-start-button { grid-area: start !important; }
body[data-app-mode="client"] #map-gps-start-button,
body[data-demo="true"] #map-gps-start-button { grid-area: gps !important; grid-column: auto !important; }
body[data-app-mode="client"] #map-trip-stop-button,
body[data-demo="true"] #map-trip-stop-button { grid-area: stop !important; }
body[data-app-mode="client"] #navigator-removed-button,
body[data-demo="true"] #navigator-removed-button { grid-area: spare !important; }
body[data-app-mode="client"] .map-toolbar button,
body[data-demo="true"] .map-toolbar button {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 46px !important;
  padding: 9px 7px !important;
  border-radius: 14px !important;
  font-size: 12px !important;
  line-height: 1.05 !important;
  white-space: normal !important;
  text-align: center !important;
}
body[data-app-mode="client"] #map-trip-stop-button,
body[data-demo="true"] #map-trip-stop-button {
  font-size: 12.5px !important;
}
body[data-app-mode="client"] .map-fullscreen-button,
body[data-demo="true"] .map-fullscreen-button,
body[data-app-mode="client"] .map-area:fullscreen .map-fullscreen-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button,
body[data-demo="true"] .map-area:fullscreen .map-fullscreen-button,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  right: calc(10px + env(safe-area-inset-right)) !important;
  bottom: calc(10px + env(safe-area-inset-bottom)) !important;
  width: 84px !important;
  min-height: 64px !important;
  padding: 8px !important;
  border-radius: 20px !important;
  font-size: 11px !important;
  line-height: 1.08 !important;
  text-align: center !important;
}
body[data-app-mode="client"] .map-sos-button,
body[data-demo="true"] .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button,
body[data-demo="true"] .map-area:fullscreen .map-sos-button,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  right: calc(15px + env(safe-area-inset-right)) !important;
  bottom: calc(164px + env(safe-area-inset-bottom)) !important;
  width: 62px !important;
  height: 62px !important;
  min-height: 62px !important;
}
body[data-app-mode="client"] .map-locate-boat-button,
body[data-demo="true"] .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button,
body[data-demo="true"] .map-area:fullscreen .map-locate-boat-button,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  right: calc(15px + env(safe-area-inset-right)) !important;
  bottom: calc(234px + env(safe-area-inset-bottom)) !important;
  width: 62px !important;
  height: 58px !important;
  min-width: 62px !important;
}
body[data-app-mode="client"] .map-fine-overlay,
body[data-demo="true"] .map-fine-overlay {
  z-index: 742 !important;
}

@media (max-width: 390px) {
  body[data-app-mode="client"] .map-toolbar,
  body[data-demo="true"] .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar,
  body[data-demo="true"] .map-area:fullscreen .map-toolbar,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    grid-template-areas:
      "follow stop"
      "course spare"
      "gps gps" !important;
    right: calc(92px + env(safe-area-inset-right)) !important;
    gap: 7px !important;
    padding: 7px !important;
  }
  body[data-app-mode="client"] .map-toolbar button,
  body[data-demo="true"] .map-toolbar button {
    min-height: 42px !important;
    padding: 7px 5px !important;
    font-size: 11px !important;
  }
  body[data-app-mode="client"] .map-fullscreen-button,
  body[data-demo="true"] .map-fullscreen-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-fullscreen-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button,
  body[data-demo="true"] .map-area:fullscreen .map-fullscreen-button,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button {
    width: 78px !important;
    min-height: 60px !important;
    font-size: 10.5px !important;
  }
}


/* v43: в обычном режиме оставляем только кнопку «Полный экран», все остальные кнопки показываем после fullscreen */
body[data-app-mode="client"] .map-area:not(:fullscreen):not(.navigation-fullscreen-fallback) .map-toolbar,
body[data-app-mode="client"] .map-area:not(:fullscreen):not(.navigation-fullscreen-fallback) .map-sos-button,
body[data-app-mode="client"] .map-area:not(:fullscreen):not(.navigation-fullscreen-fallback) .map-locate-boat-button,
body[data-demo="true"] .map-area:not(:fullscreen):not(.navigation-fullscreen-fallback) .map-toolbar,
body[data-demo="true"] .map-area:not(:fullscreen):not(.navigation-fullscreen-fallback) .map-sos-button,
body[data-demo="true"] .map-area:not(:fullscreen):not(.navigation-fullscreen-fallback) .map-locate-boat-button {
  display: none !important;
  pointer-events: none !important;
}

body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar,
body[data-demo="true"] .map-area:fullscreen .map-toolbar,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  display: grid !important;
  grid-template-columns: minmax(72px, .95fr) minmax(70px, .9fr) minmax(96px, 1fr) !important;
  grid-template-areas:
    "follow course stop"
    "start gps spare" !important;
  left: calc(10px + env(safe-area-inset-left)) !important;
  right: calc(100px + env(safe-area-inset-right)) !important;
  bottom: calc(10px + env(safe-area-inset-bottom)) !important;
  gap: 8px !important;
  padding: 8px !important;
  border-radius: 20px !important;
  background: rgba(255, 255, 255, .88) !important;
  box-shadow: 0 16px 40px rgba(12, 24, 38, .18) !important;
}

body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button,
body[data-demo="true"] .map-area:fullscreen .map-sos-button,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  display: grid !important;
  pointer-events: auto !important;
  right: calc(15px + env(safe-area-inset-right)) !important;
  bottom: calc(164px + env(safe-area-inset-bottom)) !important;
}

body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button,
body[data-demo="true"] .map-area:fullscreen .map-locate-boat-button,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  display: grid !important;
  pointer-events: auto !important;
  right: calc(15px + env(safe-area-inset-right)) !important;
  bottom: calc(234px + env(safe-area-inset-bottom)) !important;
}

body[data-app-mode="client"] .map-area:not(:fullscreen):not(.navigation-fullscreen-fallback) .map-fullscreen-button,
body[data-demo="true"] .map-area:not(:fullscreen):not(.navigation-fullscreen-fallback) .map-fullscreen-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  pointer-events: auto !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(12px + env(safe-area-inset-bottom)) !important;
  width: min(164px, calc(100vw - 24px)) !important;
  min-height: 52px !important;
  border-radius: 18px !important;
  font-size: 14px !important;
  font-weight: 900 !important;
}

@media (max-width: 390px) {
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar,
  body[data-demo="true"] .map-area:fullscreen .map-toolbar,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    grid-template-areas:
      "follow stop"
      "course spare"
      "start gps" !important;
    right: calc(94px + env(safe-area-inset-right)) !important;
  }
}


/* v43 class fallback: тот же режим через JS-класс для Android/iPhone, если :fullscreen работает нестабильно */
body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active) .map-toolbar,
body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active) .map-sos-button,
body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active) .map-locate-boat-button,
body[data-demo="true"] .map-area:not(.navigation-fullscreen-active) .map-toolbar,
body[data-demo="true"] .map-area:not(.navigation-fullscreen-active) .map-sos-button,
body[data-demo="true"] .map-area:not(.navigation-fullscreen-active) .map-locate-boat-button {
  display: none !important;
  pointer-events: none !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-demo="true"] .map-area.navigation-fullscreen-active .map-toolbar {
  display: grid !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-demo="true"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-demo="true"] .map-area.navigation-fullscreen-active .map-locate-boat-button {
  display: grid !important;
  pointer-events: auto !important;
}


/* v44: исправление входа на сайт — карта не должна занимать весь экран до нажатия «Полный экран» */
body[data-app-mode="client"]:not(.navigation-fullscreen-active),
body[data-demo="true"]:not(.navigation-fullscreen-active) {
  overflow: auto !important;
  height: auto !important;
  min-height: 100vh !important;
  min-height: 100dvh !important;
}

body[data-app-mode="client"]:not(.navigation-fullscreen-active) .client-shell,
body[data-demo="true"]:not(.navigation-fullscreen-active) .client-shell {
  height: auto !important;
  min-height: 100vh !important;
  min-height: 100dvh !important;
}

body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback),
body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) {
  position: relative !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 12px !important;
  overflow: visible !important;
}

body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) #map,
body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) #map {
  width: 100% !important;
  height: clamp(360px, 58vh, 620px) !important;
  height: clamp(360px, 58dvh, 620px) !important;
  min-height: 0 !important;
  border-radius: 18px !important;
  box-shadow: 0 18px 44px rgba(12, 24, 38, .14) !important;
}

body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .navigator-header.map-status-overlay,
body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .navigator-header.map-status-overlay {
  top: 22px !important;
  left: 22px !important;
  right: 22px !important;
  width: auto !important;
  max-width: 520px !important;
}

body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-fine-overlay,
body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-fine-overlay {
  top: 22px !important;
  right: 22px !important;
}

body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-fullscreen-button,
body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-fullscreen-button {
  position: absolute !important;
  right: 22px !important;
  bottom: 22px !important;
  width: auto !important;
  min-width: 150px !important;
  min-height: 52px !important;
}

@media (max-width: 980px) {
  body[data-app-mode="client"]:not(.navigation-fullscreen-active) .client-shell,
  body[data-demo="true"]:not(.navigation-fullscreen-active) .client-shell {
    display: flex !important;
    flex-direction: column-reverse !important;
  }
  body[data-app-mode="client"]:not(.navigation-fullscreen-active) .client-shell .sidebar,
  body[data-demo="true"]:not(.navigation-fullscreen-active) .client-shell .sidebar {
    max-height: none !important;
    overflow: visible !important;
  }
}

@media (max-width: 760px) {
  body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback),
  body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) {
    padding: 10px !important;
  }
  body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) #map,
  body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) #map {
    height: clamp(330px, 54vh, 520px) !important;
    height: clamp(330px, 54dvh, 520px) !important;
    border-radius: 16px !important;
  }
  body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .navigator-header.map-status-overlay,
  body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .navigator-header.map-status-overlay {
    top: 18px !important;
    left: 18px !important;
    right: 18px !important;
    max-width: none !important;
    padding: 9px !important;
  }
  body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .navigator-status-grid,
  body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .navigator-status-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-fine-overlay,
  body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-fine-overlay {
    top: auto !important;
    right: 18px !important;
    bottom: 82px !important;
  }
  body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-fullscreen-button,
  body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-fullscreen-button {
    right: 18px !important;
    bottom: 18px !important;
    min-width: 148px !important;
    min-height: 50px !important;
  }
}

@media (max-width: 390px) {
  body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) #map,
  body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) #map {
    height: clamp(310px, 50vh, 480px) !important;
    height: clamp(310px, 50dvh, 480px) !important;
  }
}


/* v46: контрольный радиус вместе с катером + ниже окно штрафов + облегчение клиентской карты */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay,
body[data-demo="true"] .map-area.navigation-fullscreen-active .map-fine-overlay,
body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay,
body[data-demo="true"] .map-area:fullscreen .map-fine-overlay,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
  top: calc(142px + env(safe-area-inset-top)) !important;
  right: calc(14px + env(safe-area-inset-right)) !important;
  bottom: auto !important;
}

body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-fine-overlay,
body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-fine-overlay {
  top: 72px !important;
  right: 22px !important;
  bottom: auto !important;
}

body[data-app-mode="client"] #map,
body[data-demo="true"] #map {
  contain: layout paint size;
  touch-action: pan-x pan-y pinch-zoom;
}

body[data-app-mode="client"] .maplibregl-canvas,
body[data-demo="true"] .maplibregl-canvas {
  outline: none;
}

body[data-app-mode="client"] .maplibregl-ctrl-bottom-left,
body[data-app-mode="client"] .maplibregl-ctrl-bottom-right,
body[data-demo="true"] .maplibregl-ctrl-bottom-left,
body[data-demo="true"] .maplibregl-ctrl-bottom-right {
  max-width: min(68vw, 360px);
  font-size: 10px;
}

@media (max-width: 760px) {
  body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-fine-overlay,
  body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-fine-overlay {
    top: auto !important;
    bottom: 94px !important;
    right: 18px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay,
  body[data-demo="true"] .map-area.navigation-fullscreen-active .map-fine-overlay,
  body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay,
  body[data-demo="true"] .map-area:fullscreen .map-fine-overlay,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
    top: calc(150px + env(safe-area-inset-top)) !important;
    right: calc(10px + env(safe-area-inset-right)) !important;
  }
}


/* v46: нормализация карты контроля, чтобы карта не закрывала страницу вне fullscreen */
body[data-app-mode="monitor"]:not(.navigation-page-lock) {
  overflow: auto !important;
  height: auto !important;
  min-height: 100vh !important;
}

body[data-app-mode="monitor"] .monitor-shell {
  min-height: 100vh !important;
  height: auto !important;
  align-items: stretch;
}

body[data-app-mode="monitor"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) {
  position: sticky !important;
  top: 0 !important;
  align-self: start;
  height: 100vh !important;
  min-height: 640px !important;
  max-height: 100vh !important;
  padding: 20px !important;
  overflow: hidden !important;
}

body[data-app-mode="monitor"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) #map {
  height: calc(var(--app-vh, 100vh) - 40px) !important;
  min-height: 600px !important;
  max-height: calc(var(--app-vh, 100vh) - 40px) !important;
}

body[data-app-mode="monitor"] .map-fine-overlay:not(.visible) {
  opacity: 0 !important;
  pointer-events: none !important;
}

@media (max-width: 980px) {
  body[data-app-mode="monitor"] .monitor-shell {
    display: block !important;
    height: auto !important;
  }
  body[data-app-mode="monitor"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) {
    position: relative !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 12px !important;
    overflow: visible !important;
  }
  body[data-app-mode="monitor"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) #map {
    height: clamp(420px, 58vh, 680px) !important;
    min-height: 420px !important;
    max-height: 680px !important;
  }
}

/* v47/v48 dispatcher admin panel */
.admin-page {
  width: min(1480px, 100%);
  min-height: 100vh;
  margin: 0 auto;
  padding: max(18px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(28px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));
}

.admin-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 18px 42px rgba(12, 24, 38, 0.08);
}

.admin-hero h1 {
  margin: 0 0 8px;
  font-size: clamp(28px, 4vw, 48px);
  letter-spacing: -0.04em;
}

.admin-hero .subtle {
  max-width: 820px;
  margin: 0;
  line-height: 1.55;
}

.admin-hero-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
  min-width: min(380px, 100%);
}

.admin-hero-actions a,
.admin-hero-actions button,
.admin-session-actions a,
.admin-session-actions button {
  text-decoration: none;
  white-space: nowrap;
}

.admin-stats {
  display: grid;
  grid-template-columns: repeat(6, minmax(130px, 1fr));
  gap: 12px;
  margin: 16px 0;
}

.admin-stats article,
.admin-panel,
.admin-session-card,
.admin-table-row,
.admin-event-row {
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 14px 32px rgba(12, 24, 38, 0.06);
}

.admin-stats article {
  display: grid;
  gap: 6px;
  min-width: 0;
  padding: 16px;
  border-radius: 18px;
}

.admin-stats span,
.admin-table-row small,
.admin-session-metrics small,
.admin-session-extra,
.admin-event-row span {
  color: var(--muted);
}

.admin-stats strong {
  overflow: hidden;
  font-size: clamp(22px, 3vw, 34px);
  letter-spacing: -0.04em;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(320px, 0.7fr);
  gap: 16px;
}

.admin-panel {
  min-width: 0;
  padding: 18px;
  border-radius: 22px;
}

.admin-panel-wide {
  grid-column: span 2;
}

.admin-panel h2 {
  margin: 0 0 8px;
}

.admin-session-list {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.admin-session-card {
  display: grid;
  grid-template-columns: minmax(210px, 1fr) minmax(320px, 1.15fr) minmax(220px, 0.8fr);
  gap: 14px;
  align-items: center;
  padding: 14px;
  border-radius: 20px;
}

.admin-session-card.danger,
.admin-table-row.danger {
  border-color: rgba(201, 42, 42, 0.32);
  background: linear-gradient(0deg, rgba(201, 42, 42, 0.07), rgba(255, 255, 255, 0.94));
}

.admin-session-main h3 {
  margin: 8px 0 4px;
  font-size: 22px;
}

.admin-session-main p {
  margin: 0;
  color: var(--muted);
  overflow-wrap: anywhere;
}

.admin-session-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.admin-session-metrics span {
  display: grid;
  gap: 2px;
  min-width: 0;
  padding: 10px;
  border-radius: 14px;
  background: rgba(15, 118, 110, 0.08);
}

.admin-session-metrics b {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-session-extra {
  display: grid;
  gap: 6px;
  grid-column: 1 / -1;
  padding-top: 8px;
  border-top: 1px solid var(--line);
  font-size: 13px;
}

.admin-session-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.admin-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 26px;
  padding: 4px 10px;
  border-radius: 999px;
  color: #0f5132;
  background: rgba(47, 179, 68, 0.16);
  font-size: 12px;
  font-weight: 800;
  font-style: normal;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.admin-status-pill.busy,
.admin-status-pill.finishing {
  color: #7a4b00;
  background: rgba(240, 140, 0, 0.18);
}

.admin-status-pill.free {
  color: #0f5132;
  background: rgba(47, 179, 68, 0.14);
}

.admin-label {
  display: grid;
  gap: 8px;
  margin-top: 12px;
  color: var(--muted);
  font-weight: 700;
}

.admin-label select,
.admin-label textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px;
  font: inherit;
  color: var(--text);
  background: white;
}

.admin-label textarea {
  resize: vertical;
}

.admin-boat-table {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.admin-table-head,
.admin-table-row {
  display: grid;
  grid-template-columns: 1.05fr 0.7fr 1fr 1fr 0.72fr 1fr 0.8fr;
  gap: 10px;
  align-items: center;
}

.admin-table-head {
  padding: 0 12px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-table-row {
  min-width: 0;
  padding: 12px;
  border-radius: 16px;
}

.admin-table-row > span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.admin-table-row b,
.admin-table-row small {
  display: block;
}

.admin-table-row small {
  margin-top: 3px;
  font-size: 12px;
}

.admin-row-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.admin-row-actions a {
  color: #0f766e;
  font-weight: 800;
  text-decoration: none;
}

.admin-row-actions button {
  padding: 7px 10px;
  color: #c92a2a;
  background: rgba(201, 42, 42, 0.1);
}

.admin-event-list {
  display: grid;
  gap: 8px;
  max-height: 560px;
  overflow: auto;
  padding-right: 4px;
}

.admin-event-row {
  display: grid;
  grid-template-columns: 92px minmax(160px, 0.8fr) minmax(0, 1.5fr) auto;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 14px;
}

.admin-event-row.danger {
  border-color: rgba(201, 42, 42, 0.28);
  background: rgba(201, 42, 42, 0.06);
}

.admin-event-row.info {
  background: rgba(15, 118, 110, 0.05);
}

.admin-event-row time {
  color: var(--muted);
  font-size: 12px;
}

.admin-event-row em {
  color: #c92a2a;
  font-style: normal;
  font-weight: 800;
}

.danger-text {
  color: #c92a2a !important;
}

@media (max-width: 1180px) {
  .admin-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .admin-grid {
    grid-template-columns: 1fr;
  }
  .admin-panel-wide {
    grid-column: auto;
  }
  .admin-session-card {
    grid-template-columns: 1fr;
  }
  .admin-session-actions {
    justify-content: flex-start;
  }
  .admin-table-head {
    display: none;
  }
  .admin-table-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .admin-page {
    padding: 12px;
  }
  .admin-hero {
    display: grid;
    border-radius: 18px;
  }
  .admin-hero-actions {
    justify-content: stretch;
    min-width: 0;
  }
  .admin-hero-actions > * {
    flex: 1 1 100%;
  }
  .admin-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .admin-session-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .admin-table-row {
    grid-template-columns: 1fr;
  }
  .admin-event-row {
    grid-template-columns: 1fr;
  }
}

/* v48 trip history + GPS filter */
.admin-history-list {
  display: grid;
  gap: 8px;
  max-height: 560px;
  overflow: auto;
  padding-right: 4px;
}

.admin-history-row {
  display: grid;
  grid-template-columns: minmax(170px, 1.2fr) minmax(170px, 1.1fr) 0.7fr 0.7fr minmax(150px, 0.9fr) minmax(90px, 0.6fr);
  gap: 10px;
  align-items: center;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 12px 26px rgba(12, 24, 38, 0.05);
}

.admin-history-row.active {
  border-color: rgba(240, 140, 0, 0.32);
  background: linear-gradient(0deg, rgba(240, 140, 0, 0.07), rgba(255, 255, 255, 0.94));
}

.admin-history-row > div {
  min-width: 0;
  overflow-wrap: anywhere;
}

.admin-history-row strong,
.admin-history-row b,
.admin-history-row span,
.admin-history-row small {
  display: block;
}

.admin-history-row small,
.admin-history-row span {
  color: var(--muted);
  font-size: 12px;
}

@media (max-width: 1180px) {
  .admin-history-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .admin-history-row {
    grid-template-columns: 1fr;
  }
}

/* v51: честные штрафы, офлайн-режим и новый экран клиента */
.client-start-card-v51 {
  width: min(520px, 100%);
  gap: 13px;
}
.client-start-card-v51 h1 {
  font-size: clamp(24px, 5vw, 34px);
  line-height: 1.08;
}
.client-start-boat-summary,
.client-start-tariff,
.client-start-rules {
  border: 1px solid rgba(15, 118, 110, .14);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(240, 253, 250, .94), rgba(255,255,255,.96));
}
.client-start-boat-summary {
  display: grid;
  gap: 4px;
  padding: 14px;
}
.client-start-boat-summary span,
.client-start-boat-summary small {
  color: #64748b;
  font-weight: 700;
}
.client-start-boat-summary strong {
  color: #0f172a;
  font-size: 22px;
}
.client-start-tariff {
  padding: 12px 14px;
  color: #0f766e;
  font-weight: 850;
}
.client-start-rules {
  display: grid;
  gap: 8px;
  padding: 13px 14px;
  color: #334155;
  font-size: 13px;
  line-height: 1.32;
}
.client-start-rules strong {
  color: #0f172a;
  font-size: 14px;
}
.client-start-rules span {
  position: relative;
  padding-left: 20px;
}
.client-start-rules span::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: #0f766e;
  font-weight: 900;
}
.app-system-status.danger {
  background: rgba(255, 235, 238, .98);
}
body[data-app-mode="client"] .app-system-status.danger {
  top: calc(72px + env(safe-area-inset-top));
  width: min(560px, calc(100vw - 24px));
  border-radius: 18px;
}
.admin-session-card.offline,
.admin-table-row.offline {
  border-color: rgba(240, 140, 0, .45) !important;
  background: rgba(255, 249, 219, .72) !important;
}
.admin-session-card.offline .admin-status-pill,
.admin-table-row.offline .admin-status-pill {
  color: #7c2d12;
  background: rgba(251, 146, 60, .18);
}
@media (max-width: 560px) {
  .client-start-card-v51 {
    max-height: calc(var(--app-vh) - 28px - env(safe-area-inset-top) - env(safe-area-inset-bottom));
    overflow: auto;
    padding: 18px;
    border-radius: 22px;
  }
  .client-start-rules {
    font-size: 12px;
  }
}

/* v51 dispatcher / monitor / test improvements */
.dispatcher-notifications-panel { border: 1px solid rgba(15, 118, 110, 0.16); }
.dispatcher-notifications { display: grid; gap: 10px; }
.dispatcher-notification {
  width: 100%; text-align: left; border: 1px solid rgba(15, 23, 42, 0.08); border-radius: 16px;
  padding: 12px 14px; background: #f8fafc; color: #0f172a; box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
}
.dispatcher-notification strong { display: block; font-size: 14px; margin-bottom: 4px; }
.dispatcher-notification span { display: block; font-size: 12px; color: #475569; line-height: 1.35; }
.dispatcher-notification.danger { background: #fff1f2; border-color: rgba(225, 29, 72, 0.28); }
.dispatcher-notification.warn { background: #fffbeb; border-color: rgba(217, 119, 6, 0.30); }
.dispatcher-notification.offline { background: #f1f5f9; border-color: rgba(71, 85, 105, 0.25); }
.dispatcher-notification.info { background: #eef6ff; border-color: rgba(37, 99, 235, 0.22); }

.monitor-event-dock {
  position: absolute;
  left: calc(18px + env(safe-area-inset-left));
  bottom: calc(18px + env(safe-area-inset-bottom));
  z-index: 9;
  width: min(430px, calc(100% - 36px));
  display: grid;
  gap: 8px;
  pointer-events: none;
}
.monitor-event-chip {
  border-radius: 16px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.93);
  border: 1px solid rgba(15, 23, 42, 0.10);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.16);
  backdrop-filter: blur(12px);
}
.monitor-event-chip strong { display: block; font-size: 13px; color: #0f172a; }
.monitor-event-chip span { display: block; font-size: 12px; color: #475569; margin-top: 2px; }
.monitor-event-chip.error, .monitor-event-chip.danger { border-color: rgba(225, 29, 72, 0.30); background: rgba(255, 241, 242, 0.94); }
.monitor-event-chip.warn { border-color: rgba(217, 119, 6, 0.32); background: rgba(255, 251, 235, 0.94); }
.monitor-event-chip.offline { background: rgba(241, 245, 249, 0.94); }

.control-boat-card { border-left: 6px solid #22c55e; }
.control-boat-card.control-status-warn { border-left-color: #f59e0b; }
.control-boat-card.control-status-danger { border-left-color: #ef4444; }
.control-boat-card.control-status-offline { border-left-color: #64748b; opacity: 0.88; }
.control-boat-card-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.control-boat-card-head h3 { margin: 0; }
.control-status-dot {
  display: inline-flex; align-items: center; gap: 6px; border-radius: 999px; padding: 6px 9px;
  font-size: 11px; font-weight: 800; background: #dcfce7; color: #166534; white-space: nowrap;
}
.control-status-dot::before { content: ''; width: 8px; height: 8px; border-radius: 999px; background: currentColor; }
.control-status-dot.warn { background: #fef3c7; color: #92400e; }
.control-status-dot.danger { background: #fee2e2; color: #991b1b; }
.control-status-dot.offline { background: #e2e8f0; color: #334155; }
.native-boat-marker.marker-status-warn svg { filter: drop-shadow(0 4px 12px rgba(245, 158, 11, 0.60)); }
.native-boat-marker.marker-status-danger svg { filter: drop-shadow(0 4px 14px rgba(239, 68, 68, 0.70)); }
.native-boat-marker.marker-status-offline { opacity: 0.55; }
.native-boat-shape.status-warn .boat-hull { stroke: #f59e0b; stroke-width: 4.8px; }
.native-boat-shape.status-danger .boat-hull { stroke: #ef4444; stroke-width: 4.8px; }
.native-boat-shape.status-offline .boat-hull { stroke: #64748b; stroke-width: 4.8px; }

.test-page { min-height: 100vh; padding: max(22px, env(safe-area-inset-top)) max(18px, env(safe-area-inset-right)) max(28px, env(safe-area-inset-bottom)) max(18px, env(safe-area-inset-left)); background: #eef4f8; }
.test-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; max-width: 1100px; margin: 18px auto 0; }
.test-hero { max-width: 1100px; margin: 0 auto; }
.test-status { white-space: pre-wrap; max-height: 260px; overflow: auto; border-radius: 16px; padding: 14px; background: #0f172a; color: #e2e8f0; font-size: 12px; line-height: 1.45; }
@media (max-width: 760px) {
  .test-grid { grid-template-columns: 1fr; }
  .monitor-event-dock { display: none; }
}

/* v51: обязательный инструктаж клиента */
.client-briefing-card {
  width: min(560px, 100%);
  gap: 14px;
}
.client-briefing-card h1 {
  margin: 0;
  font-size: clamp(24px, 5vw, 34px);
  line-height: 1.08;
}
.client-briefing-list {
  display: grid;
  gap: 10px;
}
.client-briefing-list div {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 10px;
  align-items: start;
  padding: 12px;
  border: 1px solid rgba(15, 118, 110, .15);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(240, 253, 250, .96), rgba(255,255,255,.98));
  color: #334155;
  font-size: 14px;
  line-height: 1.34;
}
.client-briefing-list strong {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: #0f766e;
  color: #fff;
  font-size: 14px;
}
.client-briefing-check {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 10px;
  align-items: start;
  padding: 13px 14px;
  border-radius: 16px;
  background: rgba(15, 23, 42, .06);
  color: #0f172a !important;
  font-size: 14px !important;
  font-weight: 850 !important;
}
.client-briefing-check input {
  width: 20px !important;
  height: 20px;
  margin: 1px 0 0;
  accent-color: #0f766e;
}
@media (max-width: 560px) {
  .client-briefing-card {
    max-height: calc(var(--app-vh) - 28px - env(safe-area-inset-top) - env(safe-area-inset-bottom));
    overflow: auto;
    padding: 18px;
    border-radius: 22px;
  }
  .client-briefing-list div {
    grid-template-columns: 30px 1fr;
    padding: 10px;
    font-size: 13px;
  }
}

/* v53: отдельные клиентские карты iPhone / Android */
.client-router-page {
  min-height: 100vh;
  min-height: 100dvh;
  display: grid;
  place-items: center;
  padding: max(18px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) max(18px, env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left));
  background: radial-gradient(circle at top left, rgba(14,165,233,.18), transparent 34%), #f4f7fb;
}
.client-router-card {
  width: min(560px, 100%);
  padding: 26px;
  border: 1px solid rgba(15, 118, 110, .16);
  border-radius: 26px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 24px 70px rgba(12,24,38,.16);
}
.client-router-card h1 { margin: 0 0 10px; font-size: clamp(28px, 7vw, 44px); line-height: 1.04; }
.client-router-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 18px; }
.client-router-actions a { text-align: center; text-decoration: none; }
.client-platform-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin: 0 0 12px;
  padding: 8px 11px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.15;
}
.client-platform-badge.ios { color: #075985; background: rgba(14,165,233,.13); border: 1px solid rgba(14,165,233,.24); }
.client-platform-badge.android { color: #166534; background: rgba(34,197,94,.13); border: 1px solid rgba(34,197,94,.24); }

body[data-app-mode="client"][data-client-platform="ios"] {
  -webkit-text-size-adjust: 100%;
  overscroll-behavior: none;
}
body[data-app-mode="client"][data-client-platform="ios"] .client-start-gate {
  padding-top: max(18px, env(safe-area-inset-top));
  padding-bottom: max(18px, env(safe-area-inset-bottom));
}
body[data-app-mode="client"][data-client-platform="ios"] .client-start-card {
  border-radius: 28px;
  box-shadow: 0 22px 64px rgba(2, 132, 199, .16);
}
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-active,
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-fallback {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: var(--app-vh, 100dvh) !important;
  min-height: var(--app-vh, 100dvh) !important;
  padding: 0 !important;
  border-radius: 0 !important;
  overflow: hidden !important;
  background: #dfe8ef;
}
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-active #map,
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-fallback #map {
  height: var(--app-vh, 100dvh) !important;
  min-height: var(--app-vh, 100dvh) !important;
  border-radius: 0 !important;
}
body[data-app-mode="client"][data-client-platform="ios"] .navigator-header.map-status-overlay {
  border-color: rgba(14,165,233,.22);
  background: linear-gradient(135deg, rgba(240,249,255,.96), rgba(255,255,255,.88));
}
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
  top: calc(10px + env(safe-area-inset-top)) !important;
  left: calc(10px + env(safe-area-inset-left)) !important;
  right: calc(10px + env(safe-area-inset-right)) !important;
  width: auto !important;
  max-width: none !important;
}
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, .9fr) !important;
  grid-template-areas:
    "follow course stop"
    "gps gps spare" !important;
  left: calc(10px + env(safe-area-inset-left)) !important;
  right: calc(100px + env(safe-area-inset-right)) !important;
  bottom: calc(12px + env(safe-area-inset-bottom)) !important;
  gap: 7px !important;
  padding: 8px !important;
  background: rgba(255,255,255,.90) !important;
  -webkit-backdrop-filter: blur(20px) saturate(1.3) !important;
  backdrop-filter: blur(20px) saturate(1.3) !important;
}
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-active .map-toolbar button,
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-fallback .map-toolbar button {
  min-height: 44px !important;
  font-size: 11px !important;
  touch-action: manipulation;
}
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-active .map-fullscreen-button,
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  width: 84px !important;
  min-height: 62px !important;
  bottom: calc(12px + env(safe-area-inset-bottom)) !important;
}
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  bottom: calc(166px + env(safe-area-inset-bottom)) !important;
}
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  bottom: calc(238px + env(safe-area-inset-bottom)) !important;
}
body[data-app-mode="client"][data-client-platform="ios"] .maplibregl-ctrl-top-right { display: none !important; }

body[data-app-mode="client"][data-client-platform="android"] {
  overscroll-behavior: contain;
  touch-action: manipulation;
}
body[data-app-mode="client"][data-client-platform="android"] .client-start-card {
  border-radius: 22px;
  box-shadow: 0 22px 60px rgba(22, 163, 74, .14);
}
body[data-app-mode="client"][data-client-platform="android"] .navigator-header.map-status-overlay {
  border-color: rgba(22,163,74,.20);
  background: linear-gradient(135deg, rgba(240,253,244,.96), rgba(255,255,255,.88));
}
body[data-app-mode="client"][data-client-platform="android"] .toolbar-gps-button {
  border-color: #15803d !important;
  background: linear-gradient(135deg, #22c55e, #15803d) !important;
}
body[data-app-mode="client"][data-client-platform="android"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"][data-client-platform="android"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"][data-client-platform="android"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  grid-template-columns: minmax(78px, .9fr) minmax(76px, .9fr) minmax(96px, 1fr) !important;
  grid-template-areas:
    "follow course stop"
    "gps gps spare" !important;
  left: calc(12px + env(safe-area-inset-left)) !important;
  right: calc(104px + env(safe-area-inset-right)) !important;
  bottom: calc(14px + env(safe-area-inset-bottom)) !important;
  gap: 9px !important;
  padding: 9px !important;
  background: rgba(255,255,255,.92) !important;
}
body[data-app-mode="client"][data-client-platform="android"] .map-area.navigation-fullscreen-active .map-toolbar button,
body[data-app-mode="client"][data-client-platform="android"] .map-area:fullscreen .map-toolbar button,
body[data-app-mode="client"][data-client-platform="android"] .map-area.navigation-fullscreen-fallback .map-toolbar button {
  min-height: 48px !important;
  font-size: 12px !important;
  touch-action: manipulation;
}
body[data-app-mode="client"][data-client-platform="android"] .map-area.navigation-fullscreen-active .map-fullscreen-button,
body[data-app-mode="client"][data-client-platform="android"] .map-area:fullscreen .map-fullscreen-button,
body[data-app-mode="client"][data-client-platform="android"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  width: 88px !important;
  min-height: 66px !important;
  bottom: calc(14px + env(safe-area-inset-bottom)) !important;
}
body[data-app-mode="client"][data-client-platform="android"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"][data-client-platform="android"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"][data-client-platform="android"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  bottom: calc(172px + env(safe-area-inset-bottom)) !important;
}
body[data-app-mode="client"][data-client-platform="android"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"][data-client-platform="android"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"][data-client-platform="android"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  bottom: calc(244px + env(safe-area-inset-bottom)) !important;
}
body[data-app-mode="client"][data-client-platform="android"] #map {
  touch-action: none;
}

@media (max-width: 390px) {
  body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"][data-client-platform="ios"] .map-area.navigation-fullscreen-fallback .map-toolbar,
  body[data-app-mode="client"][data-client-platform="android"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"][data-client-platform="android"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"][data-client-platform="android"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    grid-template-areas:
      "follow stop"
      "course spare"
      "gps gps" !important;
    right: calc(96px + env(safe-area-inset-right)) !important;
  }
}

@media (max-width: 560px) {
  .client-router-actions { grid-template-columns: 1fr; }
}

/* v56: координаты в редакторе и клиенты без GPS на карте контроля */
.editor-coordinate-panel .tool-grid {
  margin-top: 10px;
}
.client-chip.pending-gps,
.client-chip:disabled {
  color: #8a5a00;
  background: rgba(250, 176, 5, 0.14);
  border-color: rgba(250, 176, 5, 0.35);
  cursor: default;
}


/* v57: protected sections */
.protected-logout{position:fixed;right:14px;bottom:14px;z-index:9999;display:flex;gap:8px;align-items:center}
.protected-logout a{display:inline-flex;align-items:center;justify-content:center;padding:9px 12px;border-radius:999px;background:rgba(15,23,42,.88);color:#fff;text-decoration:none;font-size:13px;font-weight:800;box-shadow:0 10px 28px rgba(15,23,42,.22);backdrop-filter:blur(10px)}
.protected-logout a:first-child{background:rgba(15,118,110,.9)}
@media (max-width:720px){.protected-logout{right:10px;bottom:10px}.protected-logout a{font-size:12px;padding:8px 10px}}

/* v60: PC-oriented control map + stable fullscreen control buttons + trip trajectory layer */
body[data-app-mode="monitor"] {
  overflow: hidden;
  background: #e6edf3;
}

body[data-app-mode="monitor"] .monitor-shell {
  display: grid;
  grid-template-columns: minmax(360px, 27vw) minmax(0, 1fr);
  height: 100vh;
  height: 100dvh;
  min-height: 720px;
  gap: 0;
}

body[data-app-mode="monitor"] .monitor-sidebar {
  height: 100vh;
  height: 100dvh;
  max-height: none;
  overflow: auto;
  padding: 18px 16px 26px;
  border-right: 1px solid rgba(15, 23, 42, .08);
  background: linear-gradient(180deg, rgba(248,250,252,.98), rgba(241,245,249,.98));
}

body[data-app-mode="monitor"] .monitor-sidebar .brand {
  margin-bottom: 14px;
}

body[data-app-mode="monitor"] .monitor-sidebar .brand h1 {
  font-size: 30px;
  letter-spacing: -.04em;
}

body[data-app-mode="monitor"] .monitor-sidebar .brand .subtle {
  font-size: 13px;
  line-height: 1.35;
}

body[data-app-mode="monitor"] .monitor-sidebar .panel {
  margin-bottom: 12px;
  padding: 14px;
  border-radius: 18px;
}

body[data-app-mode="monitor"] .monitor-stats {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 7px;
}

body[data-app-mode="monitor"] .monitor-stats span {
  min-height: 58px;
  align-content: center;
  border-radius: 14px;
}

body[data-app-mode="monitor"] .quick-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

body[data-app-mode="monitor"] .quick-actions > * {
  min-width: 0;
  justify-content: center;
  text-align: center;
}

body[data-app-mode="monitor"] .monitor-device-list {
  display: grid;
  gap: 10px;
}

body[data-app-mode="monitor"] .control-boat-card {
  border-radius: 18px;
}

body[data-app-mode="monitor"] .map-area {
  min-height: 100vh;
  min-height: 100dvh;
  height: 100vh;
  height: 100dvh;
  padding: 16px;
  background: #dbe8ef;
}

body[data-app-mode="monitor"] #map {
  height: calc(100vh - 32px);
  height: calc(100dvh - 32px);
  min-height: 680px;
  border-radius: 24px;
  box-shadow: 0 22px 70px rgba(15, 23, 42, .18);
}

body[data-app-mode="monitor"] .map-status-overlay {
  top: 32px;
  left: 32px;
  width: min(420px, calc(100% - 360px));
  border-radius: 20px;
}

body[data-app-mode="monitor"] .map-fullscreen-button {
  top: 32px;
  right: 32px;
  bottom: auto;
  min-width: 144px;
  border-radius: 16px;
}

body[data-app-mode="monitor"] .map-fine-overlay {
  top: 92px;
  right: 32px;
  min-width: 160px;
  border-radius: 18px;
}

body[data-app-mode="monitor"] .map-toolbar {
  left: auto;
  right: 32px;
  bottom: 32px;
  display: grid;
  grid-template-columns: repeat(2, minmax(112px, 1fr));
  gap: 8px;
  width: 260px;
  max-width: none;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.65);
  border-radius: 22px;
  background: rgba(255,255,255,.82);
  box-shadow: 0 18px 48px rgba(15,23,42,.22);
}

body[data-app-mode="monitor"] .map-toolbar button {
  position: static !important;
  inset: auto !important;
  min-width: 0 !important;
  min-height: 44px;
  padding: 10px 12px;
  border-radius: 14px;
  transform: none !important;
}

body[data-app-mode="monitor"] .map-toolbar #map-trip-stop-button {
  grid-column: span 2;
}

body[data-app-mode="monitor"] .control-track-legend {
  position: absolute;
  left: 32px;
  bottom: 32px;
  z-index: 720;
  display: grid;
  gap: 2px;
  max-width: min(360px, calc(100% - 340px));
  padding: 11px 14px;
  border: 1px solid rgba(29,78,216,.18);
  border-radius: 18px;
  color: #102033;
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 48px rgba(15,23,42,.16);
  backdrop-filter: blur(16px) saturate(1.18);
  -webkit-backdrop-filter: blur(16px) saturate(1.18);
  pointer-events: none;
}

body[data-app-mode="monitor"] .control-track-legend b {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .04em;
}

body[data-app-mode="monitor"] .control-track-legend span {
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
}

body[data-app-mode="monitor"] .map-area:fullscreen,
body[data-app-mode="monitor"] .map-area.navigation-fullscreen-fallback {
  padding: 0;
}

body[data-app-mode="monitor"] .map-area:fullscreen #map,
body[data-app-mode="monitor"] .map-area.navigation-fullscreen-fallback #map {
  height: 100vh;
  height: 100dvh;
  min-height: 100vh;
  min-height: 100dvh;
  border-radius: 0;
}

body[data-app-mode="monitor"] .map-area:fullscreen .map-status-overlay,
body[data-app-mode="monitor"] .map-area.navigation-fullscreen-fallback .map-status-overlay {
  top: 24px;
  left: 24px;
  width: min(430px, calc(100vw - 360px));
}

body[data-app-mode="monitor"] .map-area:fullscreen .map-fullscreen-button,
body[data-app-mode="monitor"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  position: absolute;
  top: 24px;
  right: 24px;
  bottom: auto;
}

body[data-app-mode="monitor"] .map-area:fullscreen .map-fine-overlay,
body[data-app-mode="monitor"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
  top: 84px;
  right: 24px;
}

body[data-app-mode="monitor"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="monitor"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  left: auto;
  right: 24px;
  bottom: 24px;
  width: 270px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body[data-app-mode="monitor"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="monitor"] .map-area.navigation-fullscreen-fallback #map-follow-button,
body[data-app-mode="monitor"] .map-area:fullscreen #map-course-button,
body[data-app-mode="monitor"] .map-area.navigation-fullscreen-fallback #map-course-button {
  position: static !important;
  right: auto !important;
  bottom: auto !important;
  z-index: auto;
  width: auto;
  min-width: 0 !important;
  min-height: 44px;
  color: inherit;
  box-shadow: 0 10px 24px rgba(12,24,38,.16);
}

body[data-app-mode="monitor"] .map-area:fullscreen #map-follow-button.active-toggle,
body[data-app-mode="monitor"] .map-area.navigation-fullscreen-fallback #map-follow-button.active-toggle,
body[data-app-mode="monitor"] .map-area:fullscreen #map-course-button.active-toggle,
body[data-app-mode="monitor"] .map-area.navigation-fullscreen-fallback #map-course-button.active-toggle {
  color: #fff;
  background: #0f766e;
}

body[data-app-mode="monitor"] .map-area:fullscreen .control-track-legend,
body[data-app-mode="monitor"] .map-area.navigation-fullscreen-fallback .control-track-legend {
  left: 24px;
  bottom: 24px;
}

@media (max-width: 1180px) {
  body[data-app-mode="monitor"] {
    overflow: auto;
  }
  body[data-app-mode="monitor"] .monitor-shell {
    grid-template-columns: 1fr;
    height: auto;
    min-height: 100vh;
  }
  body[data-app-mode="monitor"] .monitor-sidebar {
    height: auto;
    max-height: none;
    order: 2;
  }
  body[data-app-mode="monitor"] .map-area {
    order: 1;
    height: 68vh;
    min-height: 620px;
  }
  body[data-app-mode="monitor"] #map {
    height: calc(68vh - 32px);
    min-height: 588px;
  }
}

/* v61: PC Pro map editor */
body.editor-pro-body,
body:has(.editor-pro-shell) {
  overflow: hidden;
  background: #e8f0f7;
}
.editor-pro-shell {
  grid-template-columns: minmax(430px, 25vw) minmax(0, 1fr) !important;
  height: 100vh;
  height: 100dvh;
  min-height: 720px;
  background: #e8f0f7;
}
.editor-pro-shell .editor-sidebar {
  height: 100vh;
  height: 100dvh;
  overflow-y: auto;
  padding: 18px 16px 92px;
  border-right: 1px solid rgba(15, 23, 42, .12);
  background: linear-gradient(180deg, rgba(248, 250, 252, .98), rgba(236, 244, 252, .98));
}
.editor-pro-shell .brand,
.editor-pro-shell .panel {
  border: 1px solid rgba(15, 23, 42, .10);
  box-shadow: 0 10px 28px rgba(15, 23, 42, .08);
}
.editor-pro-shell .brand h1 {
  font-size: 28px;
  letter-spacing: -.04em;
}
.editor-pro-shell .editor-mode-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.editor-pro-shell .editor-mode-grid button,
.editor-pro-shell .tool-grid button,
.editor-pro-shell .editor-action-row button {
  min-height: 44px;
}
.editor-pro-shell .editor-pro-stage {
  height: 100vh;
  height: 100dvh;
  min-height: 720px;
}
.editor-pro-ribbon {
  position: absolute;
  z-index: 40;
  left: 18px;
  right: 18px;
  top: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 10px 12px 10px 14px;
  border: 1px solid rgba(15, 23, 42, .16);
  border-radius: 18px;
  background: rgba(255, 255, 255, .92);
  box-shadow: 0 18px 44px rgba(15, 23, 42, .16);
  backdrop-filter: blur(14px);
}
.editor-pro-ribbon strong {
  display: block;
  font-size: 15px;
  color: #0f172a;
}
.editor-pro-ribbon span {
  display: block;
  margin-top: 2px;
  font-size: 12px;
  font-weight: 800;
  color: #475569;
}
.editor-ribbon-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex: 0 0 auto;
}
.editor-ribbon-actions button {
  min-height: 36px;
  padding: 8px 12px;
}
.editor-stats-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 8px 0 12px;
}
.editor-stats-grid span {
  display: grid;
  gap: 1px;
  padding: 10px 11px;
  border: 1px solid rgba(15, 23, 42, .10);
  border-radius: 14px;
  background: rgba(255, 255, 255, .72);
}
.editor-stats-grid b {
  font-size: 20px;
  color: #0f766e;
  line-height: 1;
}
.editor-stats-grid small {
  color: #64748b;
  font-weight: 800;
  font-size: 11px;
}
.editor-layer-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 8px 0 12px;
}
.editor-layer-grid label {
  display: flex;
  align-items: center;
  gap: 7px;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid rgba(15, 23, 42, .10);
  border-radius: 12px;
  background: rgba(255, 255, 255, .72);
  font-size: 13px;
  font-weight: 900;
  color: #334155;
}
.editor-layer-grid input {
  width: 16px;
  height: 16px;
  accent-color: #0f766e;
}
.editor-bulk-panel textarea,
.editor-selection-panel input,
.editor-coordinate-panel input,
#guide-story {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}
.editor-bulk-panel textarea {
  min-height: 120px;
  resize: vertical;
}
.editor-pro-actions {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.editor-measure-panel #measure-toggle.active-tool,
.editor-pro-shell button.active-tool {
  color: #fff;
  border-color: #0f766e;
  background: #0f766e;
  box-shadow: 0 10px 28px rgba(15, 118, 110, .26);
}
.editor-pro-shell .simple-object-list {
  max-height: 280px;
}
.editor-pro-shell .object-row {
  border-radius: 13px;
}
.editor-pro-shell .editor-map-toolbar.simple-map-toolbar {
  top: 88px;
  left: 18px;
  right: auto;
  bottom: auto;
  max-width: min(680px, calc(100% - 36px));
  padding: 9px;
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 42, .16);
  background: rgba(255, 255, 255, .90);
  box-shadow: 0 16px 38px rgba(15, 23, 42, .14);
  backdrop-filter: blur(14px);
}
.editor-pro-shell .editor-toast {
  bottom: 24px;
}
.editor-pro-shell .maplibregl-ctrl-top-right {
  top: 92px;
}
.editor-pro-shell .protected-logout {
  left: 18px;
  right: auto;
  bottom: 18px;
}
@media (min-width: 1440px) {
  .editor-pro-shell {
    grid-template-columns: 500px minmax(0, 1fr) !important;
  }
  .editor-stats-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 980px) {
  body.editor-pro-body,
body:has(.editor-pro-shell) { overflow: auto; }
  .editor-pro-shell {
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(56vh, 1fr) auto;
    min-height: 100vh;
  }
  .editor-pro-shell .editor-sidebar {
    order: 2;
    height: auto;
    max-height: none;
    padding: 14px 12px 86px;
  }
  .editor-pro-shell .editor-pro-stage {
    order: 1;
    height: 56vh;
    min-height: 420px;
  }
  .editor-pro-ribbon {
    left: 10px;
    right: 10px;
    top: 10px;
    flex-direction: column;
    align-items: stretch;
  }
  .editor-ribbon-actions,
  .editor-pro-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .editor-pro-shell .editor-map-toolbar.simple-map-toolbar {
    top: 102px;
    left: 10px;
    right: 10px;
    max-width: none;
  }
}

/* v63: демо-карту оставляем без отдельной кнопки «Старт», чтобы не было пустой ячейки в панели */
body[data-demo="true"] .map-toolbar,
body[data-demo="true"] .map-area:fullscreen .map-toolbar,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  grid-template-areas:
    "follow course stop"
    "gps gps spare" !important;
}
@media (max-width: 390px) {
  body[data-demo="true"] .map-area:fullscreen .map-toolbar,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    grid-template-areas:
      "follow stop"
      "course spare"
      "gps gps" !important;
  }
}

/* v64: аккуратный fullscreen, кнопка Старт внутри панели + режим «Скрыть» */
.map-panel-hide-button,
.map-panel-show-button,
.map-speed-focus {
  box-sizing: border-box;
}

.map-panel-show-button,
.map-speed-focus {
  display: none;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay,
body[data-demo="true"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
body[data-demo="true"] .map-area:fullscreen .navigator-header.map-status-overlay,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
  top: calc(22px + env(safe-area-inset-top)) !important;
  left: calc(12px + env(safe-area-inset-left)) !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  width: auto !important;
  max-width: 560px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  display: grid !important;
  grid-template-columns: minmax(72px, 1fr) minmax(88px, 1.12fr) minmax(72px, 1fr) !important;
  grid-template-areas:
    "start gps stop"
    "follow course spare"
    "hide hide hide" !important;
  align-items: stretch !important;
  justify-items: stretch !important;
  gap: 7px !important;
  left: calc(8px + env(safe-area-inset-left)) !important;
  right: calc(96px + env(safe-area-inset-right)) !important;
  bottom: max(2px, env(safe-area-inset-bottom)) !important;
  max-width: none !important;
  width: auto !important;
  padding: 7px !important;
  border-radius: 18px 18px 14px 14px !important;
  background: rgba(255,255,255,.90) !important;
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 32px rgba(12,24,38,.18) !important;
}

body[data-demo="true"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-demo="true"] .map-area:fullscreen .map-toolbar,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  grid-template-areas:
    "follow course stop"
    "gps spare hide" !important;
  gap: 7px !important;
  left: calc(8px + env(safe-area-inset-left)) !important;
  right: calc(96px + env(safe-area-inset-right)) !important;
  bottom: max(2px, env(safe-area-inset-bottom)) !important;
  max-width: none !important;
  width: auto !important;
  padding: 7px !important;
  border-radius: 18px 18px 14px 14px !important;
  background: rgba(255,255,255,.90) !important;
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 32px rgba(12,24,38,.18) !important;
}

body[data-app-mode="client"] #map-route-start-button { grid-area: start !important; }
body[data-app-mode="client"] #map-gps-start-button,
body[data-demo="true"] #map-gps-start-button { grid-area: gps !important; grid-column: auto !important; }
body[data-app-mode="client"] #map-trip-stop-button,
body[data-demo="true"] #map-trip-stop-button { grid-area: stop !important; }
body[data-app-mode="client"] #map-follow-button,
body[data-demo="true"] #map-follow-button { grid-area: follow !important; }
body[data-app-mode="client"] #map-course-button,
body[data-demo="true"] #map-course-button { grid-area: course !important; }
body[data-app-mode="client"] #navigator-removed-button,
body[data-demo="true"] #navigator-removed-button { grid-area: spare !important; }
body[data-app-mode="client"] #map-panel-hide-button,
body[data-demo="true"] #map-panel-hide-button { grid-area: hide !important; }

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar button,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar button,
body[data-demo="true"] .map-area.navigation-fullscreen-active .map-toolbar button,
body[data-demo="true"] .map-area:fullscreen .map-toolbar button,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-toolbar button {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 42px !important;
  padding: 7px 5px !important;
  border-radius: 13px !important;
  font-size: 11.5px !important;
  line-height: 1.08 !important;
  white-space: normal !important;
  text-align: center !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  min-height: 46px !important;
  font-size: 13px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-panel-hide-button,
body[data-app-mode="client"] .map-area:fullscreen #map-panel-hide-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-panel-hide-button,
body[data-demo="true"] .map-area.navigation-fullscreen-active #map-panel-hide-button,
body[data-demo="true"] .map-area:fullscreen #map-panel-hide-button,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback #map-panel-hide-button {
  min-height: 38px !important;
  color: #334155 !important;
  background: rgba(241,245,249,.96) !important;
  border-color: rgba(100,116,139,.28) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fullscreen-button,
body[data-app-mode="client"] .map-area:fullscreen .map-fullscreen-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button,
body[data-demo="true"] .map-area.navigation-fullscreen-active .map-fullscreen-button,
body[data-demo="true"] .map-area:fullscreen .map-fullscreen-button,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  right: calc(8px + env(safe-area-inset-right)) !important;
  bottom: max(2px, env(safe-area-inset-bottom)) !important;
  width: 82px !important;
  min-height: 58px !important;
  padding: 7px !important;
  border-radius: 18px 18px 14px 14px !important;
  font-size: 10.5px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button,
body[data-demo="true"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-demo="true"] .map-area:fullscreen .map-sos-button,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  right: calc(13px + env(safe-area-inset-right)) !important;
  bottom: calc(196px + env(safe-area-inset-bottom)) !important;
  width: 60px !important;
  height: 60px !important;
  min-height: 60px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button,
body[data-demo="true"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-demo="true"] .map-area:fullscreen .map-locate-boat-button,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  right: calc(13px + env(safe-area-inset-right)) !important;
  bottom: calc(264px + env(safe-area-inset-bottom)) !important;
  width: 60px !important;
  height: 56px !important;
  min-width: 60px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .client-message-alert,
body[data-app-mode="client"] .map-area:fullscreen .client-message-alert,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .client-message-alert,
body[data-demo="true"] .map-area.navigation-fullscreen-active .client-message-alert,
body[data-demo="true"] .map-area:fullscreen .client-message-alert,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .client-message-alert {
  bottom: calc(176px + env(safe-area-inset-bottom)) !important;
  right: calc(92px + env(safe-area-inset-right)) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay,
body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay,
body[data-demo="true"] .map-area.navigation-fullscreen-active .map-fine-overlay,
body[data-demo="true"] .map-area:fullscreen .map-fine-overlay,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
  top: calc(156px + env(safe-area-inset-top)) !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-toolbar,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fullscreen-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-sos-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fine-overlay,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-danger-alert,
body[data-app-mode="client"] .map-area.client-panel-hidden .client-message-alert,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-sos-alert,
body[data-demo="true"] .map-area.client-panel-hidden .navigator-header.map-status-overlay,
body[data-demo="true"] .map-area.client-panel-hidden .map-toolbar,
body[data-demo="true"] .map-area.client-panel-hidden .map-fullscreen-button,
body[data-demo="true"] .map-area.client-panel-hidden .map-sos-button,
body[data-demo="true"] .map-area.client-panel-hidden .map-fine-overlay,
body[data-demo="true"] .map-area.client-panel-hidden .map-danger-alert,
body[data-demo="true"] .map-area.client-panel-hidden .client-message-alert,
body[data-demo="true"] .map-area.client-panel-hidden .map-sos-alert {
  display: none !important;
  pointer-events: none !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-locate-boat-button,
body[data-demo="true"] .map-area.client-panel-hidden .map-locate-boat-button {
  display: grid !important;
  pointer-events: auto !important;
  right: calc(14px + env(safe-area-inset-right)) !important;
  bottom: calc(88px + env(safe-area-inset-bottom)) !important;
  width: 64px !important;
  height: 58px !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.94) !important;
  box-shadow: 0 14px 34px rgba(12,24,38,.22) !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-panel-show-button,
body[data-demo="true"] .map-area.client-panel-hidden .map-panel-show-button {
  position: absolute !important;
  z-index: 760 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  right: calc(14px + env(safe-area-inset-right)) !important;
  bottom: calc(18px + env(safe-area-inset-bottom)) !important;
  width: 94px !important;
  min-height: 58px !important;
  padding: 8px 7px !important;
  border: 1px solid rgba(15,118,110,.25) !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.94) !important;
  color: #0f766e !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  line-height: 1.05 !important;
  text-align: center !important;
  box-shadow: 0 14px 34px rgba(12,24,38,.22) !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus,
body[data-demo="true"] .map-area.client-panel-hidden .map-speed-focus {
  --speed-progress: 0%;
  position: absolute !important;
  z-index: 758 !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  left: calc(14px + env(safe-area-inset-left)) !important;
  right: calc(122px + env(safe-area-inset-right)) !important;
  bottom: calc(18px + env(safe-area-inset-bottom)) !important;
  min-height: 76px !important;
  padding: 10px 12px !important;
  border: 1px solid rgba(15,118,110,.20) !important;
  border-radius: 24px !important;
  background: rgba(255,255,255,.94) !important;
  box-shadow: 0 16px 44px rgba(12,24,38,.22) !important;
  backdrop-filter: blur(10px);
}

.map-speed-focus-gauge {
  flex: 0 0 54px;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: conic-gradient(#0f766e var(--speed-progress), rgba(15,118,110,.12) 0);
  box-shadow: inset 0 0 0 1px rgba(15,118,110,.10);
}
.map-speed-focus.speed-warning .map-speed-focus-gauge { background: conic-gradient(#f59e0b var(--speed-progress), rgba(245,158,11,.16) 0); }
.map-speed-focus.speed-danger .map-speed-focus-gauge { background: conic-gradient(#dc2626 var(--speed-progress), rgba(220,38,38,.16) 0); }
.map-speed-focus-gauge span {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #fff;
  box-shadow: inset 0 1px 4px rgba(12,24,38,.10);
}
.map-speed-focus-text {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.map-speed-focus-text small {
  color: #64748b;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.map-speed-focus-text strong {
  color: #0f172a;
  font-size: clamp(26px, 8vw, 42px);
  line-height: .95;
  font-weight: 950;
}
.map-speed-focus-text em {
  color: #475569;
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
}
.map-speed-focus.speed-danger .map-speed-focus-text strong,
.map-speed-focus.speed-danger .map-speed-focus-text em { color: #b91c1c; }

@media (max-width: 390px) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-areas:
      "start gps"
      "follow course"
      "stop spare"
      "hide hide" !important;
    right: calc(90px + env(safe-area-inset-right)) !important;
    gap: 6px !important;
    padding: 6px !important;
  }
  body[data-demo="true"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-demo="true"] .map-area:fullscreen .map-toolbar,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-areas:
      "follow course"
      "gps spare"
      "stop hide" !important;
    right: calc(90px + env(safe-area-inset-right)) !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar button,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar button,
  body[data-demo="true"] .map-area.navigation-fullscreen-active .map-toolbar button,
  body[data-demo="true"] .map-area:fullscreen .map-toolbar button,
  body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-toolbar button {
    min-height: 38px !important;
    padding: 6px 4px !important;
    font-size: 10.5px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
    bottom: calc(232px + env(safe-area-inset-bottom)) !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
    bottom: calc(300px + env(safe-area-inset-bottom)) !important;
  }
  body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus,
  body[data-demo="true"] .map-area.client-panel-hidden .map-speed-focus {
    right: calc(112px + env(safe-area-inset-right)) !important;
    min-height: 66px !important;
    padding: 8px 9px !important;
  }
  .map-speed-focus-gauge {
    flex-basis: 46px;
    width: 46px;
    height: 46px;
  }
  .map-speed-focus-gauge span {
    width: 30px;
    height: 30px;
  }
}

/* v65: редактирование данных катеров на карте контроля */
.boat-profile-meta {
  margin: 6px 0 10px;
  color: #506172;
  font-size: 12px;
  line-height: 1.35;
}
.boat-edit-form {
  display: grid;
  gap: 8px;
  margin: 12px 0;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(15, 118, 110, 0.16);
  background: rgba(240, 253, 250, 0.92);
}
.boat-edit-form label {
  display: grid;
  gap: 5px;
  font-size: 12px;
  font-weight: 800;
  color: #0f3f3a;
}
.boat-edit-form input,
.boat-edit-form textarea {
  width: 100%;
  border: 1px solid rgba(15, 118, 110, 0.2);
  border-radius: 12px;
  padding: 9px 10px;
  font: inherit;
  background: #fff;
  color: #17212b;
  resize: vertical;
}
.boat-edit-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.boat-edit-actions button {
  min-height: 38px;
}

/* v66: стабильное размещение всех кнопок в fullscreen — компактная сетка, без ухода за нижнюю белую панель */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  position: absolute !important;
  z-index: 780 !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  grid-template-areas:
    "start gps stop hide"
    "follow course spare spare" !important;
  align-items: stretch !important;
  justify-items: stretch !important;
  gap: 6px !important;
  left: calc(8px + env(safe-area-inset-left)) !important;
  right: calc(8px + env(safe-area-inset-right)) !important;
  bottom: calc(22px + env(safe-area-inset-bottom)) !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  padding: 7px !important;
  border-radius: 18px !important;
  background: rgba(255, 255, 255, .92) !important;
  border: 1px solid rgba(15, 118, 110, .12) !important;
  box-shadow: 0 14px 34px rgba(12, 24, 38, .20) !important;
  backdrop-filter: blur(10px);
  box-sizing: border-box !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar button,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button {
  position: static !important;
  inset: auto !important;
  z-index: auto !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  height: 38px !important;
  min-height: 38px !important;
  max-height: 38px !important;
  padding: 5px 5px !important;
  border-radius: 12px !important;
  font-size: 10.8px !important;
  line-height: 1.05 !important;
  font-weight: 900 !important;
  white-space: normal !important;
  text-align: center !important;
  letter-spacing: -0.01em !important;
  box-shadow: 0 8px 18px rgba(12, 24, 38, .14) !important;
  box-sizing: border-box !important;
  transform: none !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  grid-area: start !important;
  height: 40px !important;
  min-height: 40px !important;
  max-height: 40px !important;
  font-size: 12px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button { grid-area: gps !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button { grid-area: stop !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-panel-hide-button,
body[data-app-mode="client"] .map-area:fullscreen #map-panel-hide-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-panel-hide-button { grid-area: hide !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button { grid-area: follow !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button { grid-area: course !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button { grid-area: spare !important; }

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fullscreen-button,
body[data-app-mode="client"] .map-area:fullscreen .map-fullscreen-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  position: absolute !important;
  z-index: 790 !important;
  top: calc(12px + env(safe-area-inset-top)) !important;
  right: calc(10px + env(safe-area-inset-right)) !important;
  bottom: auto !important;
  width: 72px !important;
  min-width: 72px !important;
  max-width: 72px !important;
  height: 42px !important;
  min-height: 42px !important;
  padding: 5px 6px !important;
  border-radius: 14px !important;
  font-size: 10px !important;
  line-height: 1.05 !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
  top: calc(12px + env(safe-area-inset-top)) !important;
  left: calc(8px + env(safe-area-inset-left)) !important;
  right: calc(90px + env(safe-area-inset-right)) !important;
  max-width: none !important;
  padding: 8px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  right: calc(10px + env(safe-area-inset-right)) !important;
  bottom: calc(134px + env(safe-area-inset-bottom)) !important;
  width: 56px !important;
  height: 56px !important;
  min-width: 56px !important;
  min-height: 56px !important;
  border-radius: 18px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  right: calc(10px + env(safe-area-inset-right)) !important;
  bottom: calc(198px + env(safe-area-inset-bottom)) !important;
  width: 56px !important;
  height: 52px !important;
  min-width: 56px !important;
  min-height: 52px !important;
  border-radius: 18px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button img,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button img,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button img {
  width: 28px !important;
  height: 28px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .client-message-alert,
body[data-app-mode="client"] .map-area:fullscreen .client-message-alert,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .client-message-alert {
  bottom: calc(124px + env(safe-area-inset-bottom)) !important;
  left: calc(8px + env(safe-area-inset-left)) !important;
  right: calc(74px + env(safe-area-inset-right)) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay,
body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
  top: calc(104px + env(safe-area-inset-top)) !important;
  right: calc(10px + env(safe-area-inset-right)) !important;
}

@media (max-width: 430px) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    grid-template-areas:
      "start gps stop hide"
      "follow course spare spare" !important;
    gap: 5px !important;
    left: calc(6px + env(safe-area-inset-left)) !important;
    right: calc(6px + env(safe-area-inset-right)) !important;
    bottom: calc(20px + env(safe-area-inset-bottom)) !important;
    padding: 6px !important;
    border-radius: 16px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar button,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button {
    height: 35px !important;
    min-height: 35px !important;
    max-height: 35px !important;
    padding: 4px 3px !important;
    border-radius: 11px !important;
    font-size: 9.8px !important;
    line-height: 1.02 !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
    height: 37px !important;
    min-height: 37px !important;
    max-height: 37px !important;
    font-size: 10.8px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
    bottom: calc(126px + env(safe-area-inset-bottom)) !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
    bottom: calc(188px + env(safe-area-inset-bottom)) !important;
  }
}

@media (max-width: 340px) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    grid-template-areas:
      "start gps stop"
      "follow course hide"
      "spare spare spare" !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
    bottom: calc(164px + env(safe-area-inset-bottom)) !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
    bottom: calc(226px + env(safe-area-inset-bottom)) !important;
  }
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-panel-show-button {
  bottom: calc(24px + env(safe-area-inset-bottom)) !important;
  width: 88px !important;
  min-height: 54px !important;
  font-size: 10.5px !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-locate-boat-button {
  bottom: calc(88px + env(safe-area-inset-bottom)) !important;
  width: 58px !important;
  height: 54px !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus {
  bottom: calc(24px + env(safe-area-inset-bottom)) !important;
  right: calc(110px + env(safe-area-inset-right)) !important;
}


/* v67: 9:16 portrait fullscreen rebuild — панель управления заново + чистый режим спидометра */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
body[data-app-mode="client"] .map-area:fullscreen,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
  --wg-safe-top: max(10px, env(safe-area-inset-top));
  --wg-safe-bottom: max(30px, calc(env(safe-area-inset-bottom) + 24px));
  --wg-panel-gap: clamp(6px, 1.6vw, 9px);
  --wg-panel-radius: clamp(18px, 5vw, 24px);
  overflow: hidden !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  position: absolute !important;
  z-index: 790 !important;
  display: grid !important;
  grid-template-columns: 1.12fr 1fr 1fr !important;
  grid-template-areas:
    "start start stop"
    "gps follow course"
    "spare hide hide" !important;
  gap: var(--wg-panel-gap) !important;
  left: calc(10px + env(safe-area-inset-left)) !important;
  right: calc(10px + env(safe-area-inset-right)) !important;
  bottom: var(--wg-safe-bottom) !important;
  width: auto !important;
  max-width: min(560px, calc(100vw - 20px - env(safe-area-inset-left) - env(safe-area-inset-right))) !important;
  min-width: 0 !important;
  margin: 0 auto !important;
  padding: clamp(7px, 2vw, 10px) !important;
  border-radius: var(--wg-panel-radius) !important;
  border: 1px solid rgba(15, 118, 110, .16) !important;
  background: rgba(255, 255, 255, .93) !important;
  box-shadow: 0 18px 46px rgba(15, 23, 42, .24) !important;
  backdrop-filter: blur(14px) saturate(1.12) !important;
  -webkit-backdrop-filter: blur(14px) saturate(1.12) !important;
  box-sizing: border-box !important;
  transform: translateZ(0) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar button,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button {
  position: static !important;
  inset: auto !important;
  z-index: auto !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  height: clamp(39px, 5.3vh, 48px) !important;
  min-height: 39px !important;
  max-height: 48px !important;
  padding: 6px 7px !important;
  border-radius: clamp(12px, 3.4vw, 16px) !important;
  font-size: clamp(10.5px, 3vw, 13px) !important;
  line-height: 1.05 !important;
  font-weight: 900 !important;
  letter-spacing: -0.015em !important;
  white-space: normal !important;
  text-align: center !important;
  box-shadow: 0 9px 18px rgba(15, 23, 42, .14) !important;
  transform: none !important;
  box-sizing: border-box !important;
  touch-action: manipulation !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  grid-area: start !important;
  min-height: 46px !important;
  height: clamp(46px, 6vh, 54px) !important;
  max-height: 54px !important;
  font-size: clamp(14px, 3.7vw, 16px) !important;
  border-radius: clamp(15px, 4vw, 19px) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button { grid-area: gps !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button { grid-area: stop !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button { grid-area: follow !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button { grid-area: course !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button { grid-area: spare !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-panel-hide-button,
body[data-app-mode="client"] .map-area:fullscreen #map-panel-hide-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-panel-hide-button {
  grid-area: hide !important;
  background: linear-gradient(180deg, rgba(248,250,252,.98), rgba(226,232,240,.96)) !important;
  color: #334155 !important;
  border-color: rgba(100,116,139,.22) !important;
}

body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) #map-panel-hide-button,
body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-panel-show-button,
body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(.navigation-fullscreen-fallback) .map-speed-focus {
  display: none !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
  top: calc(var(--wg-safe-top) + 2px) !important;
  left: calc(10px + env(safe-area-inset-left)) !important;
  right: calc(88px + env(safe-area-inset-right)) !important;
  width: auto !important;
  max-width: 540px !important;
  padding: 8px 9px !important;
  border-radius: 18px !important;
  box-shadow: 0 14px 34px rgba(15,23,42,.18) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header-title-row,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header-title-row,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header-title-row {
  gap: 6px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header-title-row strong,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header-title-row strong,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header-title-row strong {
  font-size: clamp(16px, 4.4vw, 22px) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-grid,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-grid,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 5px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip {
  padding: 5px 4px !important;
  border-radius: 12px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip small,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip small,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip small {
  font-size: 8.5px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip b,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip b,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip b {
  font-size: clamp(10.5px, 2.8vw, 12.5px) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-status-detail,
body[data-app-mode="client"] .map-area:fullscreen #map-status-detail,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-status-detail {
  display: none !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fullscreen-button,
body[data-app-mode="client"] .map-area:fullscreen .map-fullscreen-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  position: absolute !important;
  z-index: 800 !important;
  top: calc(var(--wg-safe-top) + 2px) !important;
  right: calc(10px + env(safe-area-inset-right)) !important;
  bottom: auto !important;
  width: 72px !important;
  min-width: 72px !important;
  height: 46px !important;
  min-height: 46px !important;
  padding: 6px !important;
  border-radius: 16px !important;
  font-size: 10px !important;
  line-height: 1.05 !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(var(--wg-safe-bottom) + 174px) !important;
  width: 58px !important;
  height: 58px !important;
  min-width: 58px !important;
  min-height: 58px !important;
  border-radius: 20px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(var(--wg-safe-bottom) + 240px) !important;
  width: 58px !important;
  height: 54px !important;
  min-width: 58px !important;
  min-height: 54px !important;
  border-radius: 20px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button img,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button img,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button img {
  width: 29px !important;
  height: 29px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .client-message-alert,
body[data-app-mode="client"] .map-area:fullscreen .client-message-alert,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .client-message-alert {
  left: calc(10px + env(safe-area-inset-left)) !important;
  right: calc(82px + env(safe-area-inset-right)) !important;
  bottom: calc(var(--wg-safe-bottom) + 166px) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay,
body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
  top: calc(var(--wg-safe-top) + 86px) !important;
  right: calc(10px + env(safe-area-inset-right)) !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-toolbar,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fullscreen-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-sos-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fine-overlay,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-danger-alert,
body[data-app-mode="client"] .map-area.client-panel-hidden .client-message-alert,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-sos-alert {
  display: none !important;
  pointer-events: none !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-panel-show-button {
  position: absolute !important;
  z-index: 812 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(max(30px, env(safe-area-inset-bottom)) + 18px) !important;
  width: 92px !important;
  min-width: 92px !important;
  min-height: 58px !important;
  padding: 8px 9px !important;
  border-radius: 21px !important;
  border: 1px solid rgba(15,118,110,.20) !important;
  background: rgba(255,255,255,.96) !important;
  color: #0f766e !important;
  font-size: 11px !important;
  font-weight: 950 !important;
  line-height: 1.05 !important;
  text-align: center !important;
  box-shadow: 0 16px 40px rgba(15,23,42,.24) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  pointer-events: auto !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-locate-boat-button {
  display: inline-flex !important;
  pointer-events: auto !important;
  z-index: 812 !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(max(30px, env(safe-area-inset-bottom)) + 88px) !important;
  width: 62px !important;
  height: 58px !important;
  min-width: 62px !important;
  min-height: 58px !important;
  border-radius: 22px !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus {
  --speed-progress: 0%;
  position: absolute !important;
  z-index: 811 !important;
  display: grid !important;
  grid-template-columns: 96px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 14px !important;
  left: calc(12px + env(safe-area-inset-left)) !important;
  right: calc(116px + env(safe-area-inset-right)) !important;
  bottom: calc(max(30px, env(safe-area-inset-bottom)) + 18px) !important;
  min-height: 132px !important;
  padding: 14px !important;
  border: 1px solid rgba(15,118,110,.20) !important;
  border-radius: 30px !important;
  background: linear-gradient(180deg, rgba(255,255,255,.97), rgba(240,253,250,.94)) !important;
  box-shadow: 0 18px 48px rgba(15,23,42,.26) !important;
  backdrop-filter: blur(14px) saturate(1.12) !important;
  -webkit-backdrop-filter: blur(14px) saturate(1.12) !important;
  pointer-events: none !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge {
  width: 96px !important;
  height: 96px !important;
  flex: none !important;
  border-radius: 50% !important;
  display: grid !important;
  place-items: center !important;
  background:
    radial-gradient(circle at center, rgba(255,255,255,.98) 0 47%, transparent 48%),
    conic-gradient(#0f766e var(--speed-progress), rgba(15,118,110,.13) 0) !important;
  box-shadow: inset 0 0 0 1px rgba(15,118,110,.10), 0 8px 20px rgba(15,23,42,.10) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-warning .map-speed-focus-gauge {
  background:
    radial-gradient(circle at center, rgba(255,255,255,.98) 0 47%, transparent 48%),
    conic-gradient(#f59e0b var(--speed-progress), rgba(245,158,11,.16) 0) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-danger .map-speed-focus-gauge {
  background:
    radial-gradient(circle at center, rgba(255,255,255,.98) 0 47%, transparent 48%),
    conic-gradient(#dc2626 var(--speed-progress), rgba(220,38,38,.16) 0) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge span {
  width: 18px !important;
  height: 18px !important;
  border-radius: 50% !important;
  background: #0f766e !important;
  box-shadow: 0 0 0 9px rgba(15,118,110,.10) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-warning .map-speed-focus-gauge span { background: #f59e0b !important; }
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-danger .map-speed-focus-gauge span { background: #dc2626 !important; }
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text {
  min-width: 0 !important;
  display: grid !important;
  gap: 5px !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text small {
  color: #64748b !important;
  font-size: 11px !important;
  font-weight: 950 !important;
  letter-spacing: .10em !important;
  text-transform: uppercase !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text strong {
  color: #0f172a !important;
  font-size: clamp(34px, 10vw, 56px) !important;
  line-height: .88 !important;
  font-weight: 950 !important;
  letter-spacing: -0.06em !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text em {
  color: #475569 !important;
  font-size: clamp(12px, 3.3vw, 15px) !important;
  font-style: normal !important;
  font-weight: 900 !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-danger .map-speed-focus-text strong,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-danger .map-speed-focus-text em { color: #b91c1c !important; }

@media (max-aspect-ratio: 10/17) and (orientation: portrait) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    bottom: calc(max(34px, env(safe-area-inset-bottom)) + 18px) !important;
  }
}

@media (max-width: 370px) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    grid-template-columns: 1fr 1fr 1fr !important;
    grid-template-areas:
      "start start stop"
      "gps follow course"
      "spare hide hide" !important;
    gap: 5px !important;
    left: calc(7px + env(safe-area-inset-left)) !important;
    right: calc(7px + env(safe-area-inset-right)) !important;
    padding: 6px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar button,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button {
    height: 38px !important;
    min-height: 38px !important;
    max-height: 42px !important;
    padding: 5px 4px !important;
    font-size: 10.2px !important;
  }
  body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus {
    grid-template-columns: 82px minmax(0, 1fr) !important;
    right: calc(106px + env(safe-area-inset-right)) !important;
    min-height: 118px !important;
    padding: 11px !important;
    border-radius: 26px !important;
  }
  body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge {
    width: 82px !important;
    height: 82px !important;
  }
  body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text strong {
    font-size: clamp(29px, 9vw, 42px) !important;
  }
}


/* v68: финальная переработка fullscreen-панели под 9:16. Этот блок должен быть последним и перекрывать старые правила. */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
body[data-app-mode="client"] .map-area:fullscreen,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
  --wg-client-top: max(10px, env(safe-area-inset-top));
  --wg-client-bottom: max(54px, calc(env(safe-area-inset-bottom) + 42px));
  --wg-client-side: clamp(8px, 2.7vw, 14px);
  overflow: hidden !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  position: absolute !important;
  z-index: 920 !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  grid-template-areas:
    "start start start"
    "gps stop spare"
    "follow course hide" !important;
  align-items: stretch !important;
  justify-items: stretch !important;
  gap: clamp(5px, 1.8vw, 8px) !important;
  left: calc(var(--wg-client-side) + env(safe-area-inset-left)) !important;
  right: calc(var(--wg-client-side) + env(safe-area-inset-right)) !important;
  bottom: var(--wg-client-bottom) !important;
  top: auto !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: min(560px, calc(100vw - 2 * var(--wg-client-side) - env(safe-area-inset-left) - env(safe-area-inset-right))) !important;
  height: auto !important;
  max-height: none !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: clamp(7px, 2vw, 10px) !important;
  border-radius: clamp(20px, 5vw, 26px) !important;
  border: 1px solid rgba(15, 118, 110, .16) !important;
  background: rgba(255, 255, 255, .96) !important;
  box-shadow: 0 18px 46px rgba(15, 23, 42, .26) !important;
  backdrop-filter: blur(16px) saturate(1.12) !important;
  -webkit-backdrop-filter: blur(16px) saturate(1.12) !important;
  transform: translateZ(0) !important;
  box-sizing: border-box !important;
  pointer-events: auto !important;
  visibility: visible !important;
  opacity: 1 !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button {
  position: static !important;
  inset: auto !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  height: clamp(38px, 5.3vh, 46px) !important;
  min-height: 38px !important;
  max-height: 46px !important;
  padding: 5px 6px !important;
  margin: 0 !important;
  border-radius: clamp(12px, 3.4vw, 16px) !important;
  font-size: clamp(10.5px, 2.9vw, 12.8px) !important;
  line-height: 1.02 !important;
  font-weight: 900 !important;
  letter-spacing: -.01em !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  text-align: center !important;
  visibility: visible !important;
  opacity: 1 !important;
  box-sizing: border-box !important;
  transform: none !important;
  touch-action: manipulation !important;
  pointer-events: auto !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  grid-area: start !important;
  display: inline-flex !important;
  height: clamp(50px, 6.6vh, 60px) !important;
  min-height: 50px !important;
  max-height: 60px !important;
  font-size: clamp(17px, 5vw, 22px) !important;
  font-weight: 950 !important;
  letter-spacing: .02em !important;
  border-radius: clamp(17px, 4.4vw, 22px) !important;
  border: 2px solid rgba(21, 128, 61, .34) !important;
  color: #064e3b !important;
  background: linear-gradient(180deg, #dcfce7, #86efac) !important;
  box-shadow: 0 13px 25px rgba(21, 128, 61, .24) !important;
  opacity: 1 !important;
  visibility: visible !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button:disabled,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button:disabled,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button:disabled {
  opacity: 1 !important;
  filter: saturate(.9) brightness(.98) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button { grid-area: gps !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button { grid-area: stop !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button { grid-area: spare !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button { grid-area: follow !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button { grid-area: course !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-panel-hide-button,
body[data-app-mode="client"] .map-area:fullscreen #map-panel-hide-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-panel-hide-button {
  grid-area: hide !important;
  color: #334155 !important;
  background: linear-gradient(180deg, rgba(248,250,252,.98), rgba(226,232,240,.98)) !important;
  border-color: rgba(100,116,139,.28) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fullscreen-button,
body[data-app-mode="client"] .map-area:fullscreen .map-fullscreen-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  position: absolute !important;
  z-index: 925 !important;
  top: calc(var(--wg-client-top) + 2px) !important;
  right: calc(10px + env(safe-area-inset-right)) !important;
  bottom: auto !important;
  left: auto !important;
  width: 72px !important;
  min-width: 72px !important;
  height: 44px !important;
  min-height: 44px !important;
  max-height: 44px !important;
  padding: 5px !important;
  border-radius: 16px !important;
  font-size: 10px !important;
  line-height: 1.05 !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
  top: calc(var(--wg-client-top) + 2px) !important;
  left: calc(10px + env(safe-area-inset-left)) !important;
  right: calc(90px + env(safe-area-inset-right)) !important;
  width: auto !important;
  max-width: 540px !important;
  padding: 8px !important;
  border-radius: 18px !important;
  box-sizing: border-box !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-status-detail,
body[data-app-mode="client"] .map-area:fullscreen #map-status-detail,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-status-detail { display: none !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-grid,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-grid,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 4px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip { padding: 4px 3px !important; border-radius: 11px !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip small,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip small,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip small { font-size: 8px !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip b,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip b,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip b { font-size: clamp(10px, 2.7vw, 12px) !important; }

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  position: absolute !important;
  z-index: 915 !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(var(--wg-client-bottom) + 178px) !important;
  width: 56px !important;
  min-width: 56px !important;
  height: 56px !important;
  min-height: 56px !important;
  border-radius: 19px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  position: absolute !important;
  z-index: 915 !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(var(--wg-client-bottom) + 244px) !important;
  width: 56px !important;
  min-width: 56px !important;
  height: 52px !important;
  min-height: 52px !important;
  border-radius: 19px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button img,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button img,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button img { width: 28px !important; height: 28px !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay,
body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
  top: calc(var(--wg-client-top) + 82px) !important;
  right: calc(10px + env(safe-area-inset-right)) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .client-message-alert,
body[data-app-mode="client"] .map-area:fullscreen .client-message-alert,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .client-message-alert {
  left: calc(10px + env(safe-area-inset-left)) !important;
  right: calc(82px + env(safe-area-inset-right)) !important;
  bottom: calc(var(--wg-client-bottom) + 170px) !important;
}

/* Скрытый режим: только интерактивный спидометр, возврат к катеру и кнопка возврата панели. */
body[data-app-mode="client"] .map-area.client-panel-hidden .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-toolbar,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fullscreen-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-sos-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fine-overlay,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-danger-alert,
body[data-app-mode="client"] .map-area.client-panel-hidden .client-message-alert,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-sos-alert {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus {
  --speed-progress: 0%;
  position: absolute !important;
  z-index: 930 !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  justify-items: center !important;
  align-items: center !important;
  gap: clamp(10px, 3vw, 15px) !important;
  left: 50% !important;
  right: auto !important;
  top: calc(var(--wg-client-top) + 74px) !important;
  bottom: auto !important;
  width: min(86vw, 360px) !important;
  min-height: 0 !important;
  padding: clamp(16px, 4.8vw, 24px) !important;
  border-radius: clamp(30px, 8vw, 40px) !important;
  border: 1px solid rgba(15,118,110,.20) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.97), rgba(240,253,250,.94)) !important;
  box-shadow: 0 22px 58px rgba(15,23,42,.28) !important;
  backdrop-filter: blur(16px) saturate(1.15) !important;
  -webkit-backdrop-filter: blur(16px) saturate(1.15) !important;
  transform: translateX(-50%) !important;
  pointer-events: none !important;
  visibility: visible !important;
  opacity: 1 !important;
  text-align: center !important;
  box-sizing: border-box !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge {
  width: min(46vw, 174px) !important;
  height: min(46vw, 174px) !important;
  min-width: 128px !important;
  min-height: 128px !important;
  border-radius: 50% !important;
  display: grid !important;
  place-items: center !important;
  background:
    radial-gradient(circle at center, rgba(255,255,255,.98) 0 48%, transparent 49%),
    conic-gradient(#0f766e var(--speed-progress), rgba(15,118,110,.13) 0) !important;
  box-shadow: inset 0 0 0 1px rgba(15,118,110,.10), 0 12px 28px rgba(15,23,42,.12) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-warning .map-speed-focus-gauge {
  background:
    radial-gradient(circle at center, rgba(255,255,255,.98) 0 48%, transparent 49%),
    conic-gradient(#f59e0b var(--speed-progress), rgba(245,158,11,.16) 0) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-danger .map-speed-focus-gauge {
  background:
    radial-gradient(circle at center, rgba(255,255,255,.98) 0 48%, transparent 49%),
    conic-gradient(#dc2626 var(--speed-progress), rgba(220,38,38,.16) 0) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge span {
  width: 22px !important;
  height: 22px !important;
  border-radius: 999px !important;
  background: #0f766e !important;
  box-shadow: 0 0 0 10px rgba(15,118,110,.10) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-warning .map-speed-focus-gauge span { background: #f59e0b !important; }
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-danger .map-speed-focus-gauge span { background: #dc2626 !important; }
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text {
  display: grid !important;
  justify-items: center !important;
  gap: 6px !important;
  min-width: 0 !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text small {
  color: #64748b !important;
  font-size: clamp(11px, 3vw, 13px) !important;
  font-weight: 950 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text strong {
  color: #0f172a !important;
  font-size: clamp(48px, 16vw, 74px) !important;
  line-height: .85 !important;
  font-weight: 950 !important;
  letter-spacing: -0.07em !important;
  white-space: nowrap !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text em {
  color: #475569 !important;
  font-size: clamp(13px, 3.6vw, 17px) !important;
  font-style: normal !important;
  font-weight: 900 !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-danger .map-speed-focus-text strong,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-danger .map-speed-focus-text em { color: #b91c1c !important; }
body[data-app-mode="client"] .map-area.client-panel-hidden .map-panel-show-button {
  position: absolute !important;
  z-index: 935 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(max(42px, env(safe-area-inset-bottom)) + 12px) !important;
  width: 116px !important;
  min-width: 116px !important;
  min-height: 58px !important;
  padding: 9px 10px !important;
  border-radius: 22px !important;
  border: 1px solid rgba(15,118,110,.22) !important;
  background: rgba(255,255,255,.97) !important;
  color: #0f766e !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  line-height: 1.05 !important;
  text-align: center !important;
  box-shadow: 0 16px 42px rgba(15,23,42,.25) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  pointer-events: auto !important;
  visibility: visible !important;
  opacity: 1 !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-locate-boat-button {
  position: absolute !important;
  z-index: 935 !important;
  display: inline-flex !important;
  pointer-events: auto !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(max(42px, env(safe-area-inset-bottom)) + 84px) !important;
  width: 64px !important;
  height: 60px !important;
  min-width: 64px !important;
  min-height: 60px !important;
  border-radius: 22px !important;
  visibility: visible !important;
  opacity: 1 !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-locate-boat-button img { width: 31px !important; height: 31px !important; }

@media (max-height: 690px) and (orientation: portrait) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    bottom: max(42px, calc(env(safe-area-inset-bottom) + 30px)) !important;
    gap: 5px !important;
    padding: 7px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button {
    height: 36px !important;
    min-height: 36px !important;
    max-height: 40px !important;
    font-size: 10.4px !important;
    padding: 4px 5px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
    height: 47px !important;
    min-height: 47px !important;
    max-height: 52px !important;
    font-size: 16px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button { bottom: 214px !important; }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button { bottom: 276px !important; }
  body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus {
    top: calc(var(--wg-client-top) + 56px) !important;
    width: min(84vw, 330px) !important;
    padding: 14px !important;
  }
  body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge {
    width: min(40vw, 145px) !important;
    height: min(40vw, 145px) !important;
    min-width: 116px !important;
    min-height: 116px !important;
  }
  body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text strong { font-size: clamp(40px, 13vw, 60px) !important; }
}


/* v69: автоматическое скрытие панели через 7 секунд, без кнопки «Скрыть». */
body[data-app-mode="client"] #map-panel-hide-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-panel-hide-button,
body[data-app-mode="client"] .map-area:fullscreen #map-panel-hide-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-panel-hide-button,
body[data-app-mode="client"] .map-area.client-panel-hidden #map-panel-hide-button {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  grid-area: auto !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  grid-template-areas:
    "start start"
    "gps spare"
    "follow course"
    "stop stop" !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  grid-auto-rows: minmax(38px, auto) !important;
  width: min(92vw, 360px) !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
  bottom: max(50px, calc(env(safe-area-inset-bottom) + 38px)) !important;
  padding: clamp(8px, 2.3vw, 11px) !important;
  gap: clamp(6px, 1.8vw, 8px) !important;
  box-sizing: border-box !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button {
  width: 100% !important;
  min-width: 0 !important;
  height: clamp(38px, 10.6vw, 44px) !important;
  min-height: clamp(38px, 10.6vw, 44px) !important;
  max-height: 48px !important;
  padding: 5px 7px !important;
  border-radius: 16px !important;
  font-size: clamp(11px, 3vw, 13px) !important;
  line-height: 1.05 !important;
  white-space: nowrap !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  grid-area: start !important;
  height: clamp(52px, 13.5vw, 60px) !important;
  min-height: clamp(52px, 13.5vw, 60px) !important;
  max-height: 66px !important;
  font-size: clamp(18px, 4.8vw, 23px) !important;
  border-radius: 22px !important;
  letter-spacing: .03em !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button { grid-area: stop !important; }

body[data-app-mode="client"] .map-area.client-panel-hidden {
  cursor: pointer;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-panel-show-button {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus {
  top: calc(var(--wg-client-top) + 70px) !important;
  pointer-events: none !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-locate-boat-button {
  bottom: calc(max(42px, env(safe-area-inset-bottom)) + 24px) !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden::after {
  content: "Коснитесь экрана — панель вернётся";
  position: absolute;
  z-index: 934;
  left: 50%;
  bottom: calc(max(42px, env(safe-area-inset-bottom)) + 22px);
  transform: translateX(-50%);
  max-width: min(78vw, 320px);
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(15, 23, 42, .72);
  color: #fff;
  font-size: 12px;
  font-weight: 850;
  line-height: 1.15;
  text-align: center;
  box-shadow: 0 12px 34px rgba(15,23,42,.22);
  pointer-events: none;
}

@media (max-height: 690px) and (orientation: portrait) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    bottom: max(46px, calc(env(safe-area-inset-bottom) + 34px)) !important;
    width: min(92vw, 342px) !important;
  }

  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
    height: 50px !important;
    min-height: 50px !important;
    font-size: 18px !important;
  }
}


/* v70: финальная широкая панель 9:16 — фиксируем сетку, стили кнопок и поднимаем SOS/катер. */
body[data-app-mode="client"] #map-panel-hide-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-panel-hide-button,
body[data-app-mode="client"] .map-area:fullscreen #map-panel-hide-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-panel-hide-button,
body[data-app-mode="client"] .map-area.client-panel-hidden #map-panel-hide-button {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  position: absolute !important;
  z-index: 930 !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  grid-template-areas:
    "start start gps gps"
    "follow course spare stop" !important;
  grid-auto-rows: auto !important;
  align-items: stretch !important;
  justify-items: stretch !important;
  gap: 7px !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
  bottom: max(26px, calc(env(safe-area-inset-bottom) + 18px)) !important;
  width: min(96vw, 430px) !important;
  max-width: calc(100vw - 12px - env(safe-area-inset-left) - env(safe-area-inset-right)) !important;
  min-width: 0 !important;
  padding: 9px !important;
  box-sizing: border-box !important;
  border-radius: 24px !important;
  border: 1px solid rgba(15, 23, 42, .10) !important;
  background: rgba(255, 255, 255, .94) !important;
  box-shadow: 0 18px 48px rgba(15, 23, 42, .22) !important;
  backdrop-filter: blur(16px) saturate(1.08) !important;
  -webkit-backdrop-filter: blur(16px) saturate(1.08) !important;
  overflow: visible !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button {
  position: static !important;
  transform: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-width: 0 !important;
  height: clamp(40px, 10.6vw, 46px) !important;
  min-height: clamp(40px, 10.6vw, 46px) !important;
  max-height: 48px !important;
  padding: 5px 5px !important;
  box-sizing: border-box !important;
  border-radius: 16px !important;
  border: 1px solid rgba(15, 23, 42, .12) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(241,245,249,.96)) !important;
  color: #0f172a !important;
  font-size: clamp(10px, 2.7vw, 12.5px) !important;
  line-height: 1.04 !important;
  font-weight: 900 !important;
  letter-spacing: -.01em !important;
  text-align: center !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  box-shadow: 0 8px 18px rgba(15, 23, 42, .10) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  grid-area: start !important;
  height: clamp(50px, 12.8vw, 58px) !important;
  min-height: clamp(50px, 12.8vw, 58px) !important;
  max-height: 62px !important;
  border-radius: 20px !important;
  border: 1px solid rgba(5, 150, 105, .36) !important;
  background: linear-gradient(135deg, #16a34a, #059669) !important;
  color: #fff !important;
  font-size: clamp(17px, 4.4vw, 21px) !important;
  font-weight: 1000 !important;
  letter-spacing: .035em !important;
  text-transform: uppercase !important;
  box-shadow: 0 12px 26px rgba(5, 150, 105, .26) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
  grid-area: gps !important;
  height: clamp(50px, 12.8vw, 58px) !important;
  min-height: clamp(50px, 12.8vw, 58px) !important;
  max-height: 62px !important;
  border-radius: 20px !important;
  border: 1px solid rgba(37, 99, 235, .34) !important;
  background: linear-gradient(135deg, #2563eb, #0ea5e9) !important;
  color: #fff !important;
  font-size: clamp(12px, 3.2vw, 15px) !important;
  font-weight: 1000 !important;
  letter-spacing: -.01em !important;
  box-shadow: 0 12px 26px rgba(37, 99, 235, .24) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button { grid-area: follow !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button { grid-area: course !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button { grid-area: spare !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button { grid-area: stop !important; }

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  position: absolute !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: max(178px, calc(env(safe-area-inset-bottom) + 166px)) !important;
  width: 58px !important;
  height: 58px !important;
  min-width: 58px !important;
  min-height: 58px !important;
  border-radius: 22px !important;
  font-size: 17px !important;
  z-index: 940 !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  position: absolute !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: max(246px, calc(env(safe-area-inset-bottom) + 234px)) !important;
  width: 58px !important;
  height: 58px !important;
  min-width: 58px !important;
  min-height: 58px !important;
  border-radius: 22px !important;
  z-index: 940 !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button img,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button img,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button img {
  width: 30px !important;
  height: 30px !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-toolbar,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-sos-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fine-overlay,
body[data-app-mode="client"] .map-area.client-panel-hidden .navigator-header.map-status-overlay {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-locate-boat-button {
  display: inline-flex !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(max(42px, env(safe-area-inset-bottom)) + 30px) !important;
  width: 62px !important;
  height: 62px !important;
  min-width: 62px !important;
  min-height: 62px !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

@media (max-width: 390px) and (orientation: portrait) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    width: min(97vw, 380px) !important;
    gap: 6px !important;
    padding: 8px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button {
    font-size: clamp(9.4px, 2.65vw, 11.5px) !important;
    padding-left: 4px !important;
    padding-right: 4px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
    font-size: clamp(11px, 3vw, 13.5px) !important;
  }
}

@media (max-height: 720px) and (orientation: portrait) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    bottom: max(22px, calc(env(safe-area-inset-bottom) + 14px)) !important;
    gap: 5px !important;
    padding: 7px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button {
    height: 38px !important;
    min-height: 38px !important;
    max-height: 42px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
    height: 48px !important;
    min-height: 48px !important;
    max-height: 52px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
    bottom: max(160px, calc(env(safe-area-inset-bottom) + 150px)) !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
    bottom: max(224px, calc(env(safe-area-inset-bottom) + 214px)) !important;
  }
}


/* v71: финальный Android fullscreen — один приоритетный слой поверх старых v64-v70. */
.locked-home {
  margin: 0;
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
  background: linear-gradient(135deg,#e8f7f3,#f6fbff);
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
body[data-app-mode="client"] .map-area:fullscreen,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
  --wg-v71-safe-top: max(10px, env(safe-area-inset-top));
  --wg-v71-safe-bottom: max(28px, calc(env(safe-area-inset-bottom) + 22px));
  --wg-v71-panel-height: 124px;
  --wg-v71-button: clamp(40px, 10.2vw, 46px);
  overflow: hidden !important;
  touch-action: pan-x pan-y !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map,
body[data-app-mode="client"] .map-area:fullscreen #map,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map {
  height: var(--app-vh, 100vh) !important;
  min-height: var(--app-vh, 100vh) !important;
  transform: translateZ(0);
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  position: absolute !important;
  z-index: 960 !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  grid-template-areas:
    "start start gps gps"
    "follow course spare stop" !important;
  gap: 7px !important;
  left: calc(6px + env(safe-area-inset-left)) !important;
  right: calc(6px + env(safe-area-inset-right)) !important;
  bottom: var(--wg-v71-safe-bottom) !important;
  width: auto !important;
  max-width: 520px !important;
  min-width: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 8px !important;
  box-sizing: border-box !important;
  border-radius: 22px !important;
  border: 1px solid rgba(15, 23, 42, .12) !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 10px 28px rgba(15,23,42,.16) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  contain: layout paint style;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button {
  position: static !important;
  inset: auto !important;
  z-index: auto !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-width: 0 !important;
  height: var(--wg-v71-button) !important;
  min-height: var(--wg-v71-button) !important;
  max-height: 48px !important;
  padding: 4px 5px !important;
  box-sizing: border-box !important;
  border-radius: 15px !important;
  border: 1px solid rgba(15,23,42,.12) !important;
  background: #f8fafc !important;
  color: #0f172a !important;
  font-size: clamp(10px, 2.62vw, 12px) !important;
  line-height: 1.02 !important;
  font-weight: 900 !important;
  letter-spacing: -0.02em !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  text-align: center !important;
  box-shadow: none !important;
  transform: none !important;
  touch-action: manipulation !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  grid-area: start !important;
  height: clamp(52px, 13.6vw, 60px) !important;
  min-height: clamp(52px, 13.6vw, 60px) !important;
  max-height: 62px !important;
  border-radius: 19px !important;
  border-color: rgba(5,150,105,.35) !important;
  background: linear-gradient(135deg,#16a34a,#059669) !important;
  color: #fff !important;
  font-size: clamp(18px, 4.8vw, 22px) !important;
  font-weight: 1000 !important;
  letter-spacing: .035em !important;
  text-transform: uppercase !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
  grid-area: gps !important;
  height: clamp(52px, 13.6vw, 60px) !important;
  min-height: clamp(52px, 13.6vw, 60px) !important;
  max-height: 62px !important;
  border-radius: 19px !important;
  border-color: rgba(37,99,235,.34) !important;
  background: linear-gradient(135deg,#2563eb,#0284c7) !important;
  color: #fff !important;
  font-size: clamp(12px, 3.2vw, 15px) !important;
  font-weight: 1000 !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button { grid-area: follow !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button { grid-area: course !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button { grid-area: spare !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button { grid-area: stop !important; }

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-panel-hide-button,
body[data-app-mode="client"] .map-area:fullscreen #map-panel-hide-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-panel-hide-button,
body[data-app-mode="client"] #map-panel-hide-button {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
  width: 0 !important;
  min-width: 0 !important;
  height: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fullscreen-button,
body[data-app-mode="client"] .map-area:fullscreen .map-fullscreen-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  position: absolute !important;
  z-index: 965 !important;
  top: var(--wg-v71-safe-top) !important;
  right: calc(8px + env(safe-area-inset-right)) !important;
  bottom: auto !important;
  width: 74px !important;
  min-width: 74px !important;
  height: 42px !important;
  min-height: 42px !important;
  padding: 4px 6px !important;
  border-radius: 15px !important;
  font-size: 10px !important;
  line-height: 1.05 !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
  position: absolute !important;
  z-index: 955 !important;
  top: var(--wg-v71-safe-top) !important;
  left: calc(8px + env(safe-area-inset-left)) !important;
  right: calc(90px + env(safe-area-inset-right)) !important;
  width: auto !important;
  max-width: none !important;
  padding: 7px !important;
  border-radius: 18px !important;
  box-shadow: 0 8px 22px rgba(15,23,42,.12) !important;
  background: rgba(255,255,255,.96) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-grid,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-grid,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-grid { gap: 4px !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip { padding: 5px 6px !important; border-radius: 12px !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip small,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip small,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip small { font-size: 9px !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip b,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip b,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip b { font-size: 11px !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header #map-status-detail,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header #map-status-detail,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header #map-status-detail { display: none !important; }

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  position: absolute !important;
  z-index: 970 !important;
  right: calc(10px + env(safe-area-inset-right)) !important;
  bottom: calc(var(--wg-v71-safe-bottom) + var(--wg-v71-panel-height) + 16px) !important;
  width: 56px !important;
  height: 56px !important;
  min-width: 56px !important;
  min-height: 56px !important;
  border-radius: 20px !important;
  font-size: 16px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  position: absolute !important;
  z-index: 970 !important;
  right: calc(10px + env(safe-area-inset-right)) !important;
  bottom: calc(var(--wg-v71-safe-bottom) + var(--wg-v71-panel-height) + 80px) !important;
  width: 56px !important;
  height: 56px !important;
  min-width: 56px !important;
  min-height: 56px !important;
  border-radius: 20px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button img,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button img,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button img {
  width: 30px !important;
  height: 30px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay,
body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
  z-index: 950 !important;
  top: calc(var(--wg-v71-safe-top) + 92px) !important;
  right: calc(8px + env(safe-area-inset-right)) !important;
  max-width: 120px !important;
  padding: 7px 8px !important;
  border-radius: 15px !important;
  box-shadow: 0 8px 22px rgba(15,23,42,.12) !important;
  background: rgba(255,255,255,.96) !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-toolbar,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fullscreen-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-sos-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fine-overlay,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-danger-alert,
body[data-app-mode="client"] .map-area.client-panel-hidden .client-message-alert,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-sos-alert,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-panel-show-button {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus {
  display: flex !important;
  visibility: visible !important;
  pointer-events: none !important;
  z-index: 980 !important;
  left: 50% !important;
  right: auto !important;
  top: auto !important;
  bottom: calc(26px + env(safe-area-inset-bottom)) !important;
  transform: translateX(-50%) translateZ(0) !important;
  width: min(86vw, 340px) !important;
  min-height: 132px !important;
  padding: 15px !important;
  border-radius: 30px !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 12px 36px rgba(15,23,42,.20) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-locate-boat-button {
  display: inline-flex !important;
  visibility: visible !important;
  pointer-events: auto !important;
  opacity: 1 !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(178px + env(safe-area-inset-bottom)) !important;
  width: 58px !important;
  height: 58px !important;
  min-width: 58px !important;
  min-height: 58px !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden::after {
  content: "Коснитесь карты — панель вернётся" !important;
  bottom: calc(178px + env(safe-area-inset-bottom)) !important;
  max-width: min(72vw, 300px) !important;
  background: rgba(15,23,42,.70) !important;
}

@media (max-width: 380px) and (orientation: portrait) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
  body[data-app-mode="client"] .map-area:fullscreen,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
    --wg-v71-panel-height: 118px;
    --wg-v71-button: 39px;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    gap: 5px !important;
    padding: 7px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
    height: 52px !important;
    min-height: 52px !important;
  }
}

@media (max-height: 690px) and (orientation: portrait) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
  body[data-app-mode="client"] .map-area:fullscreen,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
    --wg-v71-safe-bottom: max(22px, calc(env(safe-area-inset-bottom) + 16px));
    --wg-v71-panel-height: 112px;
    --wg-v71-button: 38px;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    gap: 5px !important;
    padding: 6px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button {
    font-size: 10px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
    height: 48px !important;
    min-height: 48px !important;
    font-size: 16px !important;
  }
}

/* v73: альтернативный клиентский fullscreen под Android — компактная панель и аккуратный speed-chip. */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
body[data-app-mode="client"] .map-area:fullscreen,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
  --wg-v73-safe-top: max(8px, env(safe-area-inset-top));
  --wg-v73-safe-bottom: max(18px, calc(env(safe-area-inset-bottom) + 14px));
  --wg-v73-toolbar-height: 132px;
  --wg-v73-btn-h: clamp(42px, 10.7vw, 48px);
  --wg-v73-main-btn-h: clamp(50px, 13.2vw, 58px);
  overflow: hidden !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  position: absolute !important;
  z-index: 2147483000 !important;
  left: 50% !important;
  right: auto !important;
  bottom: var(--wg-v73-safe-bottom) !important;
  width: min(calc(100vw - 16px), 540px) !important;
  min-width: 0 !important;
  max-width: none !important;
  margin: 0 !important;
  transform: translateX(-50%) translateZ(0) !important;
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  grid-template-areas:
    "start start gps gps"
    "follow course spare stop" !important;
  gap: 8px !important;
  padding: 10px !important;
  border-radius: 24px !important;
  border: 1px solid rgba(15, 23, 42, .14) !important;
  background: rgba(255, 255, 255, .98) !important;
  box-shadow: 0 12px 30px rgba(15, 23, 42, .18) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  contain: layout paint style !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
  position: static !important;
  inset: auto !important;
  z-index: auto !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-width: 0 !important;
  height: var(--wg-v73-btn-h) !important;
  min-height: var(--wg-v73-btn-h) !important;
  max-height: 50px !important;
  padding: 4px 6px !important;
  box-sizing: border-box !important;
  border-radius: 16px !important;
  border: 1px solid rgba(15, 23, 42, .13) !important;
  background: #f8fafc !important;
  color: #0f172a !important;
  box-shadow: none !important;
  transform: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  font-size: clamp(10.5px, 2.75vw, 12.5px) !important;
  line-height: 1.05 !important;
  font-weight: 900 !important;
  letter-spacing: -.015em !important;
  text-align: center !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  touch-action: manipulation !important;
  user-select: none !important;
  -webkit-tap-highlight-color: transparent !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  grid-area: start !important;
  height: var(--wg-v73-main-btn-h) !important;
  min-height: var(--wg-v73-main-btn-h) !important;
  max-height: 60px !important;
  border-radius: 20px !important;
  border-color: rgba(5, 150, 105, .38) !important;
  background: linear-gradient(135deg, #16a34a, #059669) !important;
  color: #fff !important;
  font-size: clamp(19px, 5vw, 23px) !important;
  font-weight: 1000 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
  grid-area: gps !important;
  height: var(--wg-v73-main-btn-h) !important;
  min-height: var(--wg-v73-main-btn-h) !important;
  max-height: 60px !important;
  border-radius: 20px !important;
  border-color: rgba(37, 99, 235, .36) !important;
  background: linear-gradient(135deg, #2563eb, #0284c7) !important;
  color: #fff !important;
  font-size: clamp(13px, 3.35vw, 15.5px) !important;
  font-weight: 1000 !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button { grid-area: follow !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button { grid-area: course !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button { grid-area: spare !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button { grid-area: stop !important; }

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fullscreen-button,
body[data-app-mode="client"] .map-area:fullscreen .map-fullscreen-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  position: absolute !important;
  z-index: 2147483050 !important;
  top: calc(var(--wg-v73-safe-top) + 2px) !important;
  right: calc(8px + env(safe-area-inset-right)) !important;
  bottom: auto !important;
  width: 74px !important;
  min-width: 74px !important;
  height: 42px !important;
  min-height: 42px !important;
  border-radius: 15px !important;
  padding: 4px 6px !important;
  font-size: 10px !important;
  line-height: 1.05 !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
  position: absolute !important;
  z-index: 2147481000 !important;
  top: calc(var(--wg-v73-safe-top) + 2px) !important;
  left: calc(8px + env(safe-area-inset-left)) !important;
  right: calc(88px + env(safe-area-inset-right)) !important;
  width: auto !important;
  max-width: none !important;
  padding: 7px !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 8px 22px rgba(15,23,42,.12) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-grid,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-grid,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-grid { gap: 4px !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip { padding: 5px 6px !important; border-radius: 12px !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip small,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip small,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip small { font-size: 9px !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip b,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip b,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip b { font-size: 11px !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-status-detail,
body[data-app-mode="client"] .map-area:fullscreen #map-status-detail,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-status-detail { display: none !important; }

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  position: absolute !important;
  z-index: 2147483060 !important;
  right: calc(10px + env(safe-area-inset-right)) !important;
  width: 54px !important;
  height: 54px !important;
  min-width: 54px !important;
  min-height: 54px !important;
  border-radius: 19px !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: none !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  bottom: calc(var(--wg-v73-safe-bottom) + var(--wg-v73-toolbar-height) + 14px) !important;
  font-size: 15px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  bottom: calc(var(--wg-v73-safe-bottom) + var(--wg-v73-toolbar-height) + 76px) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button img,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button img,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button img {
  width: 29px !important;
  height: 29px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay,
body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
  z-index: 2147481000 !important;
  top: calc(var(--wg-v73-safe-top) + 90px) !important;
  right: calc(8px + env(safe-area-inset-right)) !important;
  max-width: 116px !important;
  padding: 7px 8px !important;
  border-radius: 15px !important;
  background: rgba(255,255,255,.95) !important;
  box-shadow: 0 8px 22px rgba(15,23,42,.12) !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-toolbar,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fullscreen-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-sos-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fine-overlay,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-danger-alert,
body[data-app-mode="client"] .map-area.client-panel-hidden .client-message-alert,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-sos-alert {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus {
  position: absolute !important;
  z-index: 2147483030 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  left: calc(10px + env(safe-area-inset-left)) !important;
  right: auto !important;
  top: calc(var(--wg-v73-safe-top) + 8px) !important;
  bottom: auto !important;
  transform: translateZ(0) !important;
  width: auto !important;
  min-width: 142px !important;
  max-width: min(56vw, 230px) !important;
  height: 52px !important;
  min-height: 52px !important;
  padding: 7px 10px !important;
  box-sizing: border-box !important;
  border-radius: 18px !important;
  border: 1px solid rgba(15,23,42,.12) !important;
  background: rgba(255,255,255,.97) !important;
  box-shadow: 0 10px 26px rgba(15,23,42,.16) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: none !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge {
  flex: 0 0 36px !important;
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  border-radius: 50% !important;
  background: conic-gradient(#0f766e var(--speed-progress), rgba(15,118,110,.14) 0) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-warning .map-speed-focus-gauge { background: conic-gradient(#f59e0b var(--speed-progress), rgba(245,158,11,.16) 0) !important; }
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-danger .map-speed-focus-gauge { background: conic-gradient(#dc2626 var(--speed-progress), rgba(220,38,38,.16) 0) !important; }
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge span {
  width: 22px !important;
  height: 22px !important;
  border-radius: 50% !important;
  background: #fff !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text {
  min-width: 0 !important;
  display: grid !important;
  gap: 0 !important;
  text-align: left !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text small {
  font-size: 8px !important;
  line-height: 1 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  color: #64748b !important;
  font-weight: 900 !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text strong {
  display: block !important;
  font-size: clamp(20px, 5.6vw, 25px) !important;
  line-height: .95 !important;
  color: #0f172a !important;
  font-weight: 1000 !important;
  letter-spacing: -.055em !important;
  white-space: nowrap !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text em {
  display: block !important;
  max-width: 130px !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-size: 9px !important;
  line-height: 1.05 !important;
  font-style: normal !important;
  font-weight: 800 !important;
  color: #475569 !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-danger .map-speed-focus-text strong,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-danger .map-speed-focus-text em { color: #b91c1c !important; }

body[data-app-mode="client"] .map-area.client-panel-hidden .map-panel-show-button {
  position: absolute !important;
  z-index: 2147483065 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  left: 50% !important;
  right: auto !important;
  bottom: var(--wg-v73-safe-bottom) !important;
  transform: translateX(-50%) translateZ(0) !important;
  width: 132px !important;
  min-width: 132px !important;
  height: 48px !important;
  min-height: 48px !important;
  padding: 0 14px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(15,118,110,.24) !important;
  background: rgba(255,255,255,.98) !important;
  color: #0f766e !important;
  box-shadow: 0 12px 28px rgba(15,23,42,.18) !important;
  font-size: 15px !important;
  line-height: 1 !important;
  font-weight: 1000 !important;
  text-align: center !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  touch-action: manipulation !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-locate-boat-button {
  position: absolute !important;
  z-index: 2147483060 !important;
  display: inline-flex !important;
  right: calc(10px + env(safe-area-inset-right)) !important;
  bottom: calc(var(--wg-v73-safe-bottom) + 58px) !important;
  width: 54px !important;
  height: 54px !important;
  min-width: 54px !important;
  min-height: 54px !important;
  border-radius: 19px !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-locate-boat-button img { width: 29px !important; height: 29px !important; }
body[data-app-mode="client"] .map-area.client-panel-hidden::after { display: none !important; content: none !important; }

@media (max-width: 374px) and (orientation: portrait) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
  body[data-app-mode="client"] .map-area:fullscreen,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
    --wg-v73-toolbar-height: 122px;
    --wg-v73-btn-h: 39px;
    --wg-v73-main-btn-h: 49px;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    width: min(calc(100vw - 12px), 540px) !important;
    gap: 6px !important;
    padding: 8px !important;
    border-radius: 21px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button {
    font-size: 10px !important;
    padding-left: 4px !important;
    padding-right: 4px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button { font-size: 18px !important; }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button { font-size: 12px !important; }
}

@media (max-height: 690px) and (orientation: portrait) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
  body[data-app-mode="client"] .map-area:fullscreen,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
    --wg-v73-safe-bottom: max(14px, calc(env(safe-area-inset-bottom) + 10px));
    --wg-v73-toolbar-height: 118px;
    --wg-v73-btn-h: 38px;
    --wg-v73-main-btn-h: 48px;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
  body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
    padding: 6px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    gap: 6px !important;
    padding: 8px !important;
  }
}


/* v74: финальная панель fullscreen 9:16 для Android — новые удобные кнопки */
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  position: fixed !important;
  left: max(10px, calc(env(safe-area-inset-left) + 10px)) !important;
  right: max(10px, calc(env(safe-area-inset-right) + 10px)) !important;
  bottom: max(12px, calc(env(safe-area-inset-bottom) + 12px)) !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  grid-template-areas:
    "start gps stop"
    "follow course spare" !important;
  gap: 8px !important;
  align-items: stretch !important;
  padding: 10px !important;
  border-radius: 22px !important;
  background: rgba(255,255,255,0.96) !important;
  border: 1px solid rgba(148,163,184,0.32) !important;
  box-shadow: 0 12px 30px rgba(15,23,42,0.16) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  z-index: 1300 !important;
}

body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button {
  position: static !important;
  width: 100% !important;
  min-width: 0 !important;
  min-height: 54px !important;
  height: 54px !important;
  margin: 0 !important;
  padding: 0 8px !important;
  border-radius: 16px !important;
  font-size: 14px !important;
  line-height: 1.15 !important;
  font-weight: 800 !important;
  letter-spacing: -0.01em !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  box-shadow: none !important;
  transform: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  grid-area: start !important;
  background: linear-gradient(180deg, #10b981 0%, #059669 100%) !important;
  border: 1px solid #047857 !important;
  color: #ffffff !important;
  min-height: 58px !important;
  height: 58px !important;
  box-shadow: 0 10px 24px rgba(5,150,105,0.28) !important;
}

body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
  grid-area: gps !important;
  background: linear-gradient(180deg, #3b82f6 0%, #2563eb 100%) !important;
  border: 1px solid #1d4ed8 !important;
  color: #ffffff !important;
  min-height: 58px !important;
  height: 58px !important;
  box-shadow: 0 10px 24px rgba(37,99,235,0.25) !important;
}

body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button {
  grid-area: stop !important;
}

body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button { grid-area: follow !important; }

body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button { grid-area: course !important; }

body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button { grid-area: spare !important; }

body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button {
  background: #f8fafc !important;
  border: 1px solid rgba(148,163,184,0.5) !important;
  color: #0f172a !important;
}

body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button.active-toggle,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button.active-toggle,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button.active-toggle {
  background: #0f172a !important;
  color: #ffffff !important;
  border-color: #0f172a !important;
}

body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  position: fixed !important;
  right: max(12px, calc(env(safe-area-inset-right) + 12px)) !important;
  bottom: max(154px, calc(env(safe-area-inset-bottom) + 154px)) !important;
  width: 64px !important;
  height: 64px !important;
  min-width: 64px !important;
  min-height: 64px !important;
  border-radius: 999px !important;
  z-index: 1310 !important;
  box-shadow: 0 12px 28px rgba(220,38,38,0.28) !important;
}

body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  position: fixed !important;
  right: max(12px, calc(env(safe-area-inset-right) + 12px)) !important;
  bottom: max(228px, calc(env(safe-area-inset-bottom) + 228px)) !important;
  width: 64px !important;
  height: 64px !important;
  min-width: 64px !important;
  min-height: 64px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,0.96) !important;
  border: 1px solid rgba(148,163,184,0.42) !important;
  box-shadow: 0 12px 28px rgba(15,23,42,0.15) !important;
  z-index: 1310 !important;
}

body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button img,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button img,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button img {
  width: 30px !important;
  height: 30px !important;
}

body[data-app-mode="client"] .map-area:fullscreen .map-fullscreen-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fullscreen-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  position: fixed !important;
  top: max(12px, calc(env(safe-area-inset-top) + 12px)) !important;
  right: max(12px, calc(env(safe-area-inset-right) + 12px)) !important;
  width: auto !important;
  min-width: 96px !important;
  height: 42px !important;
  min-height: 42px !important;
  padding: 0 14px !important;
  border-radius: 14px !important;
  background: rgba(255,255,255,0.95) !important;
  color: #0f172a !important;
  border: 1px solid rgba(148,163,184,0.4) !important;
  box-shadow: 0 10px 24px rgba(15,23,42,0.14) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  z-index: 1310 !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-panel-show-button {
  position: fixed !important;
  right: max(12px, calc(env(safe-area-inset-right) + 12px)) !important;
  bottom: max(18px, calc(env(safe-area-inset-bottom) + 18px)) !important;
  width: 96px !important;
  height: 46px !important;
  min-height: 46px !important;
  border-radius: 15px !important;
  background: rgba(255,255,255,0.96) !important;
  color: #0f172a !important;
  border: 1px solid rgba(148,163,184,0.42) !important;
  box-shadow: 0 12px 28px rgba(15,23,42,0.16) !important;
  z-index: 1310 !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus {
  display: grid !important;
  place-items: center !important;
  position: fixed !important;
  inset: auto 16px 16px 16px !important;
  bottom: max(18px, calc(env(safe-area-inset-bottom) + 18px)) !important;
  left: 16px !important;
  right: 124px !important;
  min-height: 92px !important;
  border-radius: 22px !important;
  background: rgba(255,255,255,0.94) !important;
  border: 1px solid rgba(148,163,184,0.32) !important;
  box-shadow: 0 14px 32px rgba(15,23,42,0.16) !important;
  z-index: 1305 !important;
}

@media (max-width: 430px) {
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    left: 8px !important;
    right: 8px !important;
    bottom: max(8px, calc(env(safe-area-inset-bottom) + 8px)) !important;
    gap: 7px !important;
    padding: 8px !important;
  }
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button {
    min-height: 50px !important;
    height: 50px !important;
    font-size: 13px !important;
    border-radius: 15px !important;
  }
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
    min-height: 54px !important;
    height: 54px !important;
  }
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
    width: 58px !important; height: 58px !important; min-width: 58px !important; min-height: 58px !important;
    bottom: max(146px, calc(env(safe-area-inset-bottom) + 146px)) !important;
  }
  body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
    width: 58px !important; height: 58px !important; min-width: 58px !important; min-height: 58px !important;
    bottom: max(214px, calc(env(safe-area-inset-bottom) + 214px)) !important;
  }
  body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus {
    right: 116px !important;
    min-height: 86px !important;
  }
}


/* v74: 9:16 fullscreen controls redesign — large, stable, readable buttons for client map */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
body[data-app-mode="client"] .map-area:fullscreen,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
  --wg-v74-side-gap: max(12px, calc(env(safe-area-inset-left) + 10px));
  --wg-v74-right-gap: max(12px, calc(env(safe-area-inset-right) + 10px));
  --wg-v74-bottom-gap: max(14px, calc(env(safe-area-inset-bottom) + 12px));
  --wg-v74-panel-h: 182px;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-panel-hide-button,
body[data-app-mode="client"] .map-area:fullscreen #map-panel-hide-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-panel-hide-button {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  position: absolute !important;
  z-index: 2147483050 !important;
  left: 50% !important;
  right: auto !important;
  bottom: var(--wg-v74-bottom-gap) !important;
  transform: translateX(-50%) translateZ(0) !important;
  width: min(calc(100vw - 24px - env(safe-area-inset-left) - env(safe-area-inset-right)), 430px) !important;
  max-width: calc(100vw - 24px - env(safe-area-inset-left) - env(safe-area-inset-right)) !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  grid-template-areas:
    "start start gps gps"
    "follow follow course course"
    "spare spare stop stop" !important;
  gap: 8px !important;
  padding: 10px !important;
  border-radius: 24px !important;
  border: 1px solid rgba(148, 163, 184, .28) !important;
  background: rgba(255,255,255,.97) !important;
  box-shadow: 0 18px 44px rgba(15, 23, 42, .22) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  overflow: visible !important;
  pointer-events: auto !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button { grid-area: start !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button { grid-area: gps !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button { grid-area: follow !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button { grid-area: course !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button { grid-area: spare !important; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button { grid-area: stop !important; }

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-width: 0 !important;
  min-height: 46px !important;
  height: 46px !important;
  margin: 0 !important;
  padding: 0 10px !important;
  border-radius: 16px !important;
  border: 1px solid rgba(203,213,225,.95) !important;
  background: #ffffff !important;
  color: #0f172a !important;
  box-shadow: none !important;
  font-size: 13px !important;
  line-height: 1.05 !important;
  font-weight: 900 !important;
  letter-spacing: -.01em !important;
  text-align: center !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  touch-action: manipulation !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  min-height: 54px !important;
  height: 54px !important;
  font-size: 18px !important;
  border: none !important;
  background: linear-gradient(180deg, #16a34a 0%, #15803d 100%) !important;
  color: #ffffff !important;
  box-shadow: 0 10px 24px rgba(22,163,74,.28) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
  min-height: 54px !important;
  height: 54px !important;
  font-size: 15px !important;
  border: none !important;
  background: linear-gradient(180deg, #2563eb 0%, #1d4ed8 100%) !important;
  color: #ffffff !important;
  box-shadow: 0 10px 24px rgba(37,99,235,.26) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button.gps-running,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button.gps-running,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button.gps-running {
  background: linear-gradient(180deg, #0f766e 0%, #0d9488 100%) !important;
  box-shadow: 0 10px 24px rgba(13,148,136,.24) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button.gps-needs-help,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button.gps-needs-help,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button.gps-needs-help {
  background: linear-gradient(180deg, #f59e0b 0%, #d97706 100%) !important;
  color: #fff !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button.active-toggle,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button.active-toggle,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button.active-toggle,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button.active-toggle,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button.active-toggle,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button.active-toggle,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button.active-toggle,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button.active-toggle,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button.active-toggle {
  background: #0f766e !important;
  border-color: #0f766e !important;
  color: #fff !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button {
  background: #fff7ed !important;
  border-color: rgba(251,146,60,.45) !important;
  color: #c2410c !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  position: absolute !important;
  z-index: 2147483060 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  right: var(--wg-v74-right-gap) !important;
  left: auto !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  touch-action: manipulation !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  bottom: calc(var(--wg-v74-bottom-gap) + var(--wg-v74-panel-h) + 10px) !important;
  width: 58px !important;
  min-width: 58px !important;
  height: 58px !important;
  min-height: 58px !important;
  border-radius: 20px !important;
  font-size: 18px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  bottom: calc(var(--wg-v74-bottom-gap) + var(--wg-v74-panel-h) + 78px) !important;
  width: 58px !important;
  min-width: 58px !important;
  height: 58px !important;
  min-height: 58px !important;
  border-radius: 20px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button img,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button img,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button img {
  width: 30px !important;
  height: 30px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active.client-panel-hidden .map-panel-show-button,
body[data-app-mode="client"] .map-area:fullscreen.client-panel-hidden .map-panel-show-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback.client-panel-hidden .map-panel-show-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-panel-show-button {
  position: absolute !important;
  z-index: 2147483065 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  left: 50% !important;
  right: auto !important;
  bottom: var(--wg-v74-bottom-gap) !important;
  transform: translateX(-50%) !important;
  width: 128px !important;
  min-width: 128px !important;
  height: 46px !important;
  min-height: 46px !important;
  border-radius: 17px !important;
  border: 1px solid rgba(15,118,110,.22) !important;
  background: rgba(255,255,255,.98) !important;
  color: #0f766e !important;
  box-shadow: 0 12px 28px rgba(15,23,42,.16) !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-locate-boat-button {
  right: var(--wg-v74-right-gap) !important;
  bottom: calc(var(--wg-v74-bottom-gap) + 54px) !important;
}

@media (max-width: 390px), (max-height: 740px) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
  body[data-app-mode="client"] .map-area:fullscreen,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
    --wg-v74-panel-h: 170px;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
    width: min(calc(100vw - 18px - env(safe-area-inset-left) - env(safe-area-inset-right)), 410px) !important;
    gap: 6px !important;
    padding: 8px !important;
    border-radius: 22px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button {
    min-height: 42px !important;
    height: 42px !important;
    font-size: 12px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
    min-height: 50px !important;
    height: 50px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button { font-size: 16px !important; }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button { font-size: 14px !important; }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
    width: 54px !important;
    min-width: 54px !important;
    height: 54px !important;
    min-height: 54px !important;
    border-radius: 18px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
    bottom: calc(var(--wg-v74-bottom-gap) + var(--wg-v74-panel-h) + 8px) !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
    bottom: calc(var(--wg-v74-bottom-gap) + var(--wg-v74-panel-h) + 70px) !important;
  }
}


/* v75: replace fullscreen toolbar with independent floating buttons for 9:16 Android */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
body[data-app-mode="client"] .map-area:fullscreen,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
  --wg-v75-side-gap: max(12px, calc(env(safe-area-inset-left) + 10px));
  --wg-v75-right-gap: max(12px, calc(env(safe-area-inset-right) + 10px));
  --wg-v75-bottom-gap: max(14px, calc(env(safe-area-inset-bottom) + 12px));
  --wg-v75-small-row-y: calc(var(--wg-v75-bottom-gap) + 62px);
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-panel-show-button,
body[data-app-mode="client"] .map-area:fullscreen .map-panel-show-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-panel-show-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-panel-hide-button,
body[data-app-mode="client"] .map-area:fullscreen #map-panel-hide-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-panel-hide-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-speed-focus,
body[data-app-mode="client"] .map-area:fullscreen .map-speed-focus,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-speed-focus {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar {
  position: absolute !important;
  inset: 0 !important;
  left: 0 !important;
  right: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  z-index: 2147483050 !important;
  width: auto !important;
  height: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  display: block !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  transform: none !important;
  overflow: visible !important;
  pointer-events: none !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button {
  position: absolute !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
  min-width: 0 !important;
  height: 44px !important;
  min-height: 44px !important;
  padding: 0 12px !important;
  border-radius: 16px !important;
  border: 1px solid rgba(203,213,225,.98) !important;
  background: rgba(255,255,255,.98) !important;
  color: #0f172a !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: -.01em !important;
  text-align: center !important;
  white-space: nowrap !important;
  box-shadow: 0 10px 24px rgba(15,23,42,.14) !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  touch-action: manipulation !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  left: var(--wg-v75-side-gap) !important;
  bottom: var(--wg-v75-bottom-gap) !important;
  width: calc(50% - 18px - env(safe-area-inset-left)) !important;
  max-width: 220px !important;
  height: 52px !important;
  min-height: 52px !important;
  border: none !important;
  border-radius: 18px !important;
  background: linear-gradient(180deg, #16a34a 0%, #15803d 100%) !important;
  color: #fff !important;
  font-size: 18px !important;
  box-shadow: 0 12px 28px rgba(22,163,74,.28) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
  right: var(--wg-v75-right-gap) !important;
  bottom: var(--wg-v75-bottom-gap) !important;
  width: calc(50% - 18px - env(safe-area-inset-right)) !important;
  max-width: 220px !important;
  height: 52px !important;
  min-height: 52px !important;
  border: none !important;
  border-radius: 18px !important;
  background: linear-gradient(180deg, #2563eb 0%, #1d4ed8 100%) !important;
  color: #fff !important;
  font-size: 15px !important;
  box-shadow: 0 12px 28px rgba(37,99,235,.26) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button.gps-running,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button.gps-running,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button.gps-running {
  background: linear-gradient(180deg, #0f766e 0%, #0d9488 100%) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button.gps-needs-help,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button.gps-needs-help,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button.gps-needs-help {
  background: linear-gradient(180deg, #f59e0b 0%, #d97706 100%) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button {
  left: var(--wg-v75-side-gap) !important;
  bottom: var(--wg-v75-small-row-y) !important;
  width: calc(25% - 12px) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button {
  left: calc(25% + 2px) !important;
  bottom: var(--wg-v75-small-row-y) !important;
  width: calc(25% - 12px) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button {
  right: calc(25% + 2px) !important;
  bottom: var(--wg-v75-small-row-y) !important;
  width: calc(25% - 12px) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button {
  right: var(--wg-v75-right-gap) !important;
  bottom: var(--wg-v75-small-row-y) !important;
  width: calc(25% - 12px) !important;
  background: #fff7ed !important;
  border-color: rgba(251,146,60,.5) !important;
  color: #c2410c !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button.active-toggle,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button.active-toggle,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button.active-toggle,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button.active-toggle,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button.active-toggle,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button.active-toggle,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button.active-toggle,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button.active-toggle,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button.active-toggle {
  background: #0f766e !important;
  border-color: #0f766e !important;
  color: #fff !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button.control-removed,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button.control-removed,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button.control-removed {
  background: #f8fafc !important;
  color: #94a3b8 !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  position: absolute !important;
  z-index: 2147483060 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  right: var(--wg-v75-right-gap) !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  touch-action: manipulation !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  bottom: calc(var(--wg-v75-small-row-y) + 54px) !important;
  width: 58px !important;
  min-width: 58px !important;
  height: 58px !important;
  min-height: 58px !important;
  border-radius: 20px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  bottom: calc(var(--wg-v75-small-row-y) + 126px) !important;
  width: 58px !important;
  min-width: 58px !important;
  height: 58px !important;
  min-height: 58px !important;
  border-radius: 20px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button img,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button img,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button img {
  width: 30px !important;
  height: 30px !important;
}

@media (max-width: 420px) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
  body[data-app-mode="client"] .map-area:fullscreen,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
    --wg-v75-small-row-y: calc(var(--wg-v75-bottom-gap) + 58px);
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button {
    font-size: 12px !important;
    height: 42px !important;
    min-height: 42px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
    height: 50px !important;
    min-height: 50px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button { font-size: 17px !important; }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button { font-size: 14px !important; }
}

@media (max-width: 360px) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
  body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button {
    font-size: 11px !important;
  }
}


/* v75: rebuilt fullscreen controls from scratch — hide old panel, use new floating controls */
.map-fs-controls,
.map-fs-exit-button { display: none; }

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-panel-show-button,
body[data-app-mode="client"] .map-area:fullscreen .map-panel-show-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-panel-show-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-speed-focus,
body[data-app-mode="client"] .map-area:fullscreen .map-speed-focus,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-speed-focus {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-controls,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-controls,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-controls {
  position: absolute !important;
  z-index: 2147483070 !important;
  display: block !important;
  left: 50% !important;
  bottom: max(14px, calc(env(safe-area-inset-bottom) + 12px)) !important;
  transform: translateX(-50%) !important;
  width: min(calc(100vw - 24px - env(safe-area-inset-left) - env(safe-area-inset-right)), 432px) !important;
  max-width: calc(100vw - 24px - env(safe-area-inset-left) - env(safe-area-inset-right)) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-controls-grid,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-controls-grid,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-controls-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 9px !important;
  padding: 10px !important;
  border-radius: 24px !important;
  border: 1px solid rgba(203,213,225,.9) !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 18px 46px rgba(15,23,42,.22) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-width: 0 !important;
  min-height: 50px !important;
  height: 50px !important;
  padding: 0 12px !important;
  border-radius: 17px !important;
  border: 1px solid rgba(203,213,225,.95) !important;
  background: #ffffff !important;
  color: #0f172a !important;
  font-size: 15px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  letter-spacing: -.015em !important;
  white-space: nowrap !important;
  text-align: center !important;
  box-shadow: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  touch-action: manipulation !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button-primary,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button-primary,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button-primary {
  min-height: 56px !important;
  height: 56px !important;
  background: linear-gradient(180deg, #16a34a 0%, #15803d 100%) !important;
  color: #ffffff !important;
  border: none !important;
  box-shadow: 0 10px 26px rgba(22,163,74,.28) !important;
  font-size: 19px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button-primary.route-running,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button-primary.route-running,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button-primary.route-running {
  background: linear-gradient(180deg, #0f766e 0%, #0d9488 100%) !important;
  box-shadow: 0 10px 26px rgba(13,148,136,.24) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button-gps,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button-gps,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button-gps {
  min-height: 56px !important;
  height: 56px !important;
  background: linear-gradient(180deg, #2563eb 0%, #1d4ed8 100%) !important;
  color: #ffffff !important;
  border: none !important;
  box-shadow: 0 10px 26px rgba(37,99,235,.28) !important;
  font-size: 16px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button-gps.gps-running,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button-gps.gps-running,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button-gps.gps-running {
  background: linear-gradient(180deg, #0f766e 0%, #0d9488 100%) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button-gps.gps-needs-help,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button-gps.gps-needs-help,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button-gps.gps-needs-help {
  background: linear-gradient(180deg, #f59e0b 0%, #d97706 100%) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button-stop,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button-stop,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button-stop {
  background: #fff7ed !important;
  color: #c2410c !important;
  border-color: rgba(251,146,60,.48) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button.active-toggle,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button.active-toggle,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button.active-toggle {
  background: #0f766e !important;
  color: #ffffff !important;
  border-color: #0f766e !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button.control-removed,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button.control-removed,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button.control-removed {
  opacity: .78 !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button:disabled,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button:disabled,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button:disabled {
  opacity: .58 !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-exit-button,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-exit-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-exit-button {
  position: absolute !important;
  z-index: 2147483072 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  top: max(12px, calc(env(safe-area-inset-top) + 8px)) !important;
  right: max(12px, calc(env(safe-area-inset-right) + 10px)) !important;
  min-width: 92px !important;
  height: 42px !important;
  padding: 0 14px !important;
  border-radius: 15px !important;
  border: 1px solid rgba(203,213,225,.92) !important;
  background: rgba(255,255,255,.96) !important;
  color: #0f172a !important;
  box-shadow: 0 10px 24px rgba(15,23,42,.14) !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  pointer-events: auto !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  position: absolute !important;
  z-index: 2147483071 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  right: max(12px, calc(env(safe-area-inset-right) + 10px)) !important;
  left: auto !important;
  pointer-events: auto !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  bottom: calc(max(14px, env(safe-area-inset-bottom) + 12px) + 146px) !important;
  width: 58px !important;
  height: 58px !important;
  min-width: 58px !important;
  min-height: 58px !important;
  border-radius: 20px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  bottom: calc(max(14px, env(safe-area-inset-bottom) + 12px) + 214px) !important;
  width: 58px !important;
  height: 58px !important;
  min-width: 58px !important;
  min-height: 58px !important;
  border-radius: 20px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button img,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button img,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button img {
  width: 30px !important;
  height: 30px !important;
}

@media (max-width: 390px), (max-height: 740px) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-controls,
  body[data-app-mode="client"] .map-area:fullscreen .map-fs-controls,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-controls {
    width: min(calc(100vw - 18px - env(safe-area-inset-left) - env(safe-area-inset-right)), 410px) !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-controls-grid,
  body[data-app-mode="client"] .map-area:fullscreen .map-fs-controls-grid,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-controls-grid {
    gap: 7px !important;
    padding: 8px !important;
    border-radius: 21px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-fs-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button {
    min-height: 46px !important;
    height: 46px !important;
    font-size: 13px !important;
    padding: 0 10px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button-primary,
  body[data-app-mode="client"] .map-area:fullscreen .map-fs-button-primary,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button-primary,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button-gps,
  body[data-app-mode="client"] .map-area:fullscreen .map-fs-button-gps,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button-gps {
    min-height: 52px !important;
    height: 52px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button-primary,
  body[data-app-mode="client"] .map-area:fullscreen .map-fs-button-primary,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button-primary { font-size: 17px !important; }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button-gps,
  body[data-app-mode="client"] .map-area:fullscreen .map-fs-button-gps,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button-gps { font-size: 15px !important; }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
    width: 54px !important;
    height: 54px !important;
    min-width: 54px !important;
    min-height: 54px !important;
    border-radius: 18px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
    bottom: calc(max(14px, env(safe-area-inset-bottom) + 12px) + 138px) !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
    bottom: calc(max(14px, env(safe-area-inset-bottom) + 12px) + 202px) !important;
  }
}


/* v76: fullscreen controls layout — 2 big + 4 small */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
body[data-app-mode="client"] .map-area:fullscreen,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
  --wg-v76-side-gap: max(12px, calc(env(safe-area-inset-left) + 10px));
  --wg-v76-right-gap: max(12px, calc(env(safe-area-inset-right) + 10px));
  --wg-v76-bottom-gap: max(14px, calc(env(safe-area-inset-bottom) + 12px));
  --wg-v76-small-h: 42px;
  --wg-v76-big-h: 52px;
  --wg-v76-gap: 8px;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  left: var(--wg-v76-side-gap) !important;
  bottom: var(--wg-v76-bottom-gap) !important;
  width: calc(50% - 18px - env(safe-area-inset-left)) !important;
  max-width: 220px !important;
  height: var(--wg-v76-big-h) !important;
  min-height: var(--wg-v76-big-h) !important;
  border-radius: 18px !important;
  font-size: 18px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
  right: var(--wg-v76-right-gap) !important;
  bottom: var(--wg-v76-bottom-gap) !important;
  width: calc(50% - 18px - env(safe-area-inset-right)) !important;
  max-width: 220px !important;
  height: var(--wg-v76-big-h) !important;
  min-height: var(--wg-v76-big-h) !important;
  border-radius: 18px !important;
  font-size: 15px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button {
  left: var(--wg-v76-side-gap) !important;
  bottom: calc(var(--wg-v76-bottom-gap) + var(--wg-v76-big-h) + var(--wg-v76-gap)) !important;
  width: calc(50% - 18px - env(safe-area-inset-left)) !important;
  max-width: 220px !important;
  height: var(--wg-v76-small-h) !important;
  min-height: var(--wg-v76-small-h) !important;
  border-radius: 15px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button {
  right: var(--wg-v76-right-gap) !important;
  bottom: calc(var(--wg-v76-bottom-gap) + var(--wg-v76-big-h) + var(--wg-v76-gap)) !important;
  width: calc(50% - 18px - env(safe-area-inset-right)) !important;
  max-width: 220px !important;
  height: var(--wg-v76-small-h) !important;
  min-height: var(--wg-v76-small-h) !important;
  border-radius: 15px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button {
  left: var(--wg-v76-side-gap) !important;
  bottom: calc(var(--wg-v76-bottom-gap) + var(--wg-v76-big-h) + var(--wg-v76-small-h) + (var(--wg-v76-gap) * 2)) !important;
  width: calc(50% - 18px - env(safe-area-inset-left)) !important;
  max-width: 220px !important;
  height: var(--wg-v76-small-h) !important;
  min-height: var(--wg-v76-small-h) !important;
  border-radius: 15px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button {
  right: var(--wg-v76-right-gap) !important;
  bottom: calc(var(--wg-v76-bottom-gap) + var(--wg-v76-big-h) + var(--wg-v76-small-h) + (var(--wg-v76-gap) * 2)) !important;
  width: calc(50% - 18px - env(safe-area-inset-right)) !important;
  max-width: 220px !important;
  height: var(--wg-v76-small-h) !important;
  min-height: var(--wg-v76-small-h) !important;
  border-radius: 15px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  bottom: calc(var(--wg-v76-bottom-gap) + var(--wg-v76-big-h) + (var(--wg-v76-small-h) * 2) + (var(--wg-v76-gap) * 3) + 10px) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  bottom: calc(var(--wg-v76-bottom-gap) + var(--wg-v76-big-h) + (var(--wg-v76-small-h) * 2) + (var(--wg-v76-gap) * 3) + 82px) !important;
}

@media (max-width: 390px) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
  body[data-app-mode="client"] .map-area:fullscreen,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
    --wg-v76-small-h: 40px;
    --wg-v76-big-h: 50px;
    --wg-v76-gap: 6px;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button {
    font-size: 12px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
    font-size: 17px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
    font-size: 14px !important;
  }
}


/* v77: fullscreen controls layout — 2 big bottom, 4 small on sides */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
body[data-app-mode="client"] .map-area:fullscreen,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
  --wg-v77-side-gap: max(12px, calc(env(safe-area-inset-left) + 10px));
  --wg-v77-right-gap: max(12px, calc(env(safe-area-inset-right) + 10px));
  --wg-v77-bottom-gap: max(14px, calc(env(safe-area-inset-bottom) + 12px));
  --wg-v77-small-h: 42px;
  --wg-v77-big-h: 52px;
  --wg-v77-small-w: min(108px, calc(32vw - 4px));
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  left: var(--wg-v77-side-gap) !important;
  bottom: var(--wg-v77-bottom-gap) !important;
  width: calc(50% - 18px - env(safe-area-inset-left)) !important;
  max-width: 220px !important;
  height: var(--wg-v77-big-h) !important;
  min-height: var(--wg-v77-big-h) !important;
  border-radius: 18px !important;
  font-size: 18px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
  right: var(--wg-v77-right-gap) !important;
  bottom: var(--wg-v77-bottom-gap) !important;
  width: calc(50% - 18px - env(safe-area-inset-right)) !important;
  max-width: 220px !important;
  height: var(--wg-v77-big-h) !important;
  min-height: var(--wg-v77-big-h) !important;
  border-radius: 18px !important;
  font-size: 15px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button {
  left: var(--wg-v77-side-gap) !important;
  bottom: calc(var(--wg-v77-bottom-gap) + var(--wg-v77-big-h) + 58px) !important;
  width: var(--wg-v77-small-w) !important;
  max-width: 114px !important;
  height: var(--wg-v77-small-h) !important;
  min-height: var(--wg-v77-small-h) !important;
  border-radius: 15px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button {
  left: var(--wg-v77-side-gap) !important;
  bottom: calc(var(--wg-v77-bottom-gap) + var(--wg-v77-big-h) + 8px) !important;
  width: var(--wg-v77-small-w) !important;
  max-width: 114px !important;
  height: var(--wg-v77-small-h) !important;
  min-height: var(--wg-v77-small-h) !important;
  border-radius: 15px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button {
  right: var(--wg-v77-right-gap) !important;
  bottom: calc(var(--wg-v77-bottom-gap) + var(--wg-v77-big-h) + 58px) !important;
  width: var(--wg-v77-small-w) !important;
  max-width: 114px !important;
  height: var(--wg-v77-small-h) !important;
  min-height: var(--wg-v77-small-h) !important;
  border-radius: 15px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button {
  right: var(--wg-v77-right-gap) !important;
  bottom: calc(var(--wg-v77-bottom-gap) + var(--wg-v77-big-h) + 8px) !important;
  width: var(--wg-v77-small-w) !important;
  max-width: 114px !important;
  height: var(--wg-v77-small-h) !important;
  min-height: var(--wg-v77-small-h) !important;
  border-radius: 15px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  bottom: calc(var(--wg-v77-bottom-gap) + var(--wg-v77-big-h) + (var(--wg-v77-small-h) * 2) + 92px) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  bottom: calc(var(--wg-v77-bottom-gap) + var(--wg-v77-big-h) + (var(--wg-v77-small-h) * 2) + 164px) !important;
}

@media (max-width: 390px) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
  body[data-app-mode="client"] .map-area:fullscreen,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
    --wg-v77-small-h: 40px;
    --wg-v77-big-h: 50px;
    --wg-v77-small-w: min(96px, calc(30vw - 4px));
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-toolbar > button,
  body[data-app-mode="client"] .map-area:fullscreen .map-toolbar > button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-toolbar > button {
    font-size: 11.5px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button { font-size: 17px !important; }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button { font-size: 14px !important; }
}


/* v78: final client fullscreen — minimal controls only */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
body[data-app-mode="client"] .map-area:fullscreen,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
  --wg-v78-side-gap: max(12px, calc(env(safe-area-inset-left) + 10px));
  --wg-v78-right-gap: max(12px, calc(env(safe-area-inset-right) + 10px));
  --wg-v78-bottom-gap: max(14px, calc(env(safe-area-inset-bottom) + 12px));
  --wg-v78-big-h: 54px;
  --wg-v78-small-h: 44px;
}

/* hide non-essential buttons in fullscreen */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #navigator-removed-button,
body[data-app-mode="client"] .map-area:fullscreen #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #navigator-removed-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-follow-button,
body[data-app-mode="client"] .map-area:fullscreen #map-follow-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-follow-button {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* keep only Start + GPS bottom */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button {
  left: var(--wg-v78-side-gap) !important;
  right: auto !important;
  bottom: var(--wg-v78-bottom-gap) !important;
  width: calc(50% - 18px - env(safe-area-inset-left)) !important;
  max-width: 220px !important;
  height: var(--wg-v78-big-h) !important;
  min-height: var(--wg-v78-big-h) !important;
  border-radius: 18px !important;
  font-size: 18px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button {
  right: var(--wg-v78-right-gap) !important;
  left: auto !important;
  bottom: var(--wg-v78-bottom-gap) !important;
  width: calc(50% - 18px - env(safe-area-inset-right)) !important;
  max-width: 220px !important;
  height: var(--wg-v78-big-h) !important;
  min-height: var(--wg-v78-big-h) !important;
  border-radius: 18px !important;
  font-size: 15px !important;
}

/* one small action button per side above the main row */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-course-button,
body[data-app-mode="client"] .map-area:fullscreen #map-course-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-course-button {
  left: var(--wg-v78-side-gap) !important;
  right: auto !important;
  bottom: calc(var(--wg-v78-bottom-gap) + var(--wg-v78-big-h) + 10px) !important;
  width: min(132px, calc(34vw + 6px)) !important;
  max-width: 132px !important;
  height: var(--wg-v78-small-h) !important;
  min-height: var(--wg-v78-small-h) !important;
  border-radius: 16px !important;
  font-size: 13px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-trip-stop-button,
body[data-app-mode="client"] .map-area:fullscreen #map-trip-stop-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-trip-stop-button {
  right: var(--wg-v78-right-gap) !important;
  left: auto !important;
  bottom: calc(var(--wg-v78-bottom-gap) + var(--wg-v78-big-h) + 10px) !important;
  width: min(132px, calc(34vw + 6px)) !important;
  max-width: 132px !important;
  height: var(--wg-v78-small-h) !important;
  min-height: var(--wg-v78-small-h) !important;
  border-radius: 16px !important;
  font-size: 13px !important;
}

/* place SOS and boat return higher and separated */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  right: var(--wg-v78-right-gap) !important;
  bottom: calc(var(--wg-v78-bottom-gap) + var(--wg-v78-big-h) + var(--wg-v78-small-h) + 88px) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  right: var(--wg-v78-right-gap) !important;
  bottom: calc(var(--wg-v78-bottom-gap) + var(--wg-v78-big-h) + var(--wg-v78-small-h) + 160px) !important;
}

@media (max-width: 390px) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active,
  body[data-app-mode="client"] .map-area:fullscreen,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback {
    --wg-v78-big-h: 50px;
    --wg-v78-small-h: 42px;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-route-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-route-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-route-start-button { font-size: 17px !important; }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-start-button,
  body[data-app-mode="client"] .map-area:fullscreen #map-gps-start-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-start-button { font-size: 14px !important; }
}


/* v79: final fullscreen polish — one exit button, decorative status, auto-hide controls + compact speedometer */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fullscreen-button,
body[data-app-mode="client"] .map-area:fullscreen .map-fullscreen-button {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}
/* keep exit only for fallback mode */
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fullscreen-button {
  position: absolute !important;
  top: max(10px, calc(env(safe-area-inset-top) + 8px)) !important;
  right: max(10px, calc(env(safe-area-inset-right) + 8px)) !important;
  left: auto !important;
  bottom: auto !important;
  width: auto !important;
  min-width: 84px !important;
  height: 38px !important;
  min-height: 38px !important;
  border-radius: 14px !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
  top: max(10px, calc(env(safe-area-inset-top) + 8px)) !important;
  left: max(10px, calc(env(safe-area-inset-left) + 8px)) !important;
  right: max(10px, calc(env(safe-area-inset-right) + 8px)) !important;
  width: auto !important;
  max-width: none !important;
  padding: 10px 12px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(255,255,255,.26) !important;
  background: linear-gradient(135deg, rgba(15,23,42,.78), rgba(30,41,59,.62)) !important;
  box-shadow: 0 14px 36px rgba(15,23,42,.24) !important;
  backdrop-filter: blur(10px) saturate(120%) !important;
  -webkit-backdrop-filter: blur(10px) saturate(120%) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header-title-row,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header-title-row,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header-title-row {
  display: flex !important;
  align-items: baseline !important;
  justify-content: space-between !important;
  gap: 10px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay #map-status-title,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay #map-status-title,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay #map-status-title {
  color: rgba(255,255,255,.72) !important;
  font-size: 11px !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  font-weight: 800 !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay #map-status-main,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay #map-status-main,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay #map-status-main {
  color: #fff !important;
  font-size: 16px !important;
  line-height: 1.1 !important;
  font-weight: 1000 !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-grid,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-grid,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0,1fr)) !important;
  gap: 8px !important;
  margin-top: 10px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip {
  padding: 8px 8px 7px !important;
  border-radius: 14px !important;
  background: rgba(255,255,255,.12) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip small,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip small,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip small {
  color: rgba(255,255,255,.72) !important;
  font-size: 10px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-chip b,
body[data-app-mode="client"] .map-area:fullscreen .navigator-status-chip b,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-chip b {
  color: #fff !important;
  font-size: 12px !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-status-detail,
body[data-app-mode="client"] .map-area:fullscreen #map-status-detail,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-status-detail {
  display: block !important;
  margin-top: 8px !important;
  color: rgba(255,255,255,.72) !important;
  font-size: 11px !important;
}

/* hidden controls mode after 7s */
body[data-app-mode="client"] .map-area.client-panel-hidden .map-toolbar > button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-sos-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-locate-boat-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fullscreen-button {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus {
  position: absolute !important;
  z-index: 2147483065 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  right: max(12px, calc(env(safe-area-inset-right) + 10px)) !important;
  bottom: max(14px, calc(env(safe-area-inset-bottom) + 12px)) !important;
  width: auto !important;
  max-width: 172px !important;
  min-width: 120px !important;
  padding: 8px 10px !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.96) !important;
  border: 1px solid rgba(148,163,184,.24) !important;
  box-shadow: 0 14px 34px rgba(15,23,42,.18) !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: none !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge {
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
  min-height: 42px !important;
  border-width: 4px !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge span {
  width: 24px !important; height: 24px !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text {
  min-width: 0 !important; display: grid !important; gap: 1px !important; text-align: left !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text small {
  font-size: 9px !important; color: #64748b !important; font-weight: 900 !important; text-transform: uppercase !important; letter-spacing: .08em !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text strong {
  font-size: 20px !important; line-height: 1 !important; color: #0f172a !important; font-weight: 1000 !important; white-space: nowrap !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text em {
  font-size: 10px !important; line-height: 1.1 !important; color: #475569 !important; font-style: normal !important; font-weight: 700 !important; white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .navigator-header.map-status-overlay {
  opacity: .92 !important;
}
@media (max-width: 390px) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-status-grid,
  body[data-app-mode="client"] .map-area:fullscreen .navigator-status-grid,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-status-grid {
    grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  }
}


/* v80 fix: when panel auto-hides, hide the white toolbar container itself */
body[data-app-mode="client"] .map-area.client-panel-hidden .map-toolbar {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-toolbar::before,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-toolbar::after {
  opacity: 0 !important;
  visibility: hidden !important;
  display: none !important;
  content: none !important;
}
/* also hide white panel remnants in all fullscreen variants */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active.client-panel-hidden .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen.client-panel-hidden .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback.client-panel-hidden .map-toolbar {
  transform: translateY(16px) !important;
}
/* creative compact speedometer */
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus {
  position: absolute !important;
  z-index: 2147483065 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  right: max(12px, calc(env(safe-area-inset-right) + 10px)) !important;
  bottom: max(14px, calc(env(safe-area-inset-bottom) + 12px)) !important;
  min-width: 134px !important;
  max-width: 182px !important;
  padding: 10px 12px !important;
  border-radius: 20px !important;
  background: linear-gradient(145deg, rgba(15,23,42,.92), rgba(30,41,59,.86)) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  box-shadow: 0 14px 34px rgba(15,23,42,.28), inset 0 1px 0 rgba(255,255,255,.08) !important;
  backdrop-filter: blur(10px) saturate(120%) !important;
  -webkit-backdrop-filter: blur(10px) saturate(120%) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus::after {
  content: "" !important;
  position: absolute !important;
  inset: auto 12px 8px 12px !important;
  height: 3px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, rgba(34,197,94,.18), rgba(59,130,246,.45), rgba(99,102,241,.18)) !important;
  opacity: .95 !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge {
  width: 46px !important;
  height: 46px !important;
  min-width: 46px !important;
  min-height: 46px !important;
  border: none !important;
  background: conic-gradient(#38bdf8 var(--speed-progress), rgba(56,189,248,.14) 0) !important;
  box-shadow: inset 0 0 0 4px rgba(255,255,255,.06), 0 0 0 1px rgba(255,255,255,.08) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-warning .map-speed-focus-gauge {
  background: conic-gradient(#f59e0b var(--speed-progress), rgba(245,158,11,.15) 0) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-danger .map-speed-focus-gauge {
  background: conic-gradient(#ef4444 var(--speed-progress), rgba(239,68,68,.16) 0) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge span {
  width: 26px !important;
  height: 26px !important;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.16), rgba(15,23,42,.98)) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text small {
  color: rgba(255,255,255,.64) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text strong {
  color: #ffffff !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text em {
  color: rgba(255,255,255,.72) !important;
}


/* v82: control map uses client connection links instead of QR assignment */
.boat-edit-form input[data-boat-edit-field="connect_url"] {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 12px;
}
.boat-profile-meta {
  word-break: break-word;
}


/* v83: hard hide every fullscreen controls container on idle, leave only yacht speedometer */
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fs-controls,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fs-controls-grid,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active.client-panel-hidden .map-fs-controls,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active.client-panel-hidden .map-fs-controls-grid,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active.client-panel-hidden .map-toolbar,
body[data-app-mode="client"] .map-area:fullscreen.client-panel-hidden .map-fs-controls,
body[data-app-mode="client"] .map-area:fullscreen.client-panel-hidden .map-fs-controls-grid,
body[data-app-mode="client"] .map-area:fullscreen.client-panel-hidden .map-toolbar,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback.client-panel-hidden .map-fs-controls,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback.client-panel-hidden .map-fs-controls-grid,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback.client-panel-hidden .map-toolbar {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  transform: translate3d(-9999px, 9999px, 0) !important;
  width: 0 !important;
  height: 0 !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-fs-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fullscreen-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fs-exit-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-sos-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-locate-boat-button,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-panel-show-button,
body[data-app-mode="client"] .map-area.client-panel-hidden #map-panel-hide-button {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-fs-controls::before,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fs-controls::after,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fs-controls-grid::before,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fs-controls-grid::after,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-toolbar::before,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-toolbar::after {
  display: none !important;
  content: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
}

/* Force the idle speedometer above all controls and make it visible after later fullscreen rules. */
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active.client-panel-hidden .map-speed-focus,
body[data-app-mode="client"] .map-area:fullscreen.client-panel-hidden .map-speed-focus,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback.client-panel-hidden .map-speed-focus {
  position: absolute !important;
  z-index: 2147483640 !important;
  display: grid !important;
  place-items: center !important;
  right: max(12px, calc(env(safe-area-inset-right) + 10px)) !important;
  bottom: max(16px, calc(env(safe-area-inset-bottom) + 14px)) !important;
  left: auto !important;
  top: auto !important;
  width: 124px !important;
  min-width: 124px !important;
  max-width: 124px !important;
  height: 124px !important;
  min-height: 124px !important;
  max-height: 124px !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 999px !important;
  background: radial-gradient(circle at 30% 26%, rgba(255,255,255,.16), rgba(255,255,255,.04) 26%, rgba(15,23,42,.98) 72%) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  box-shadow: 0 20px 44px rgba(15,23,42,.36), inset 0 1px 0 rgba(255,255,255,.12), inset 0 -10px 22px rgba(0,0,0,.38) !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: none !important;
  transform: none !important;
  overflow: hidden !important;
  backdrop-filter: blur(10px) saturate(120%) !important;
  -webkit-backdrop-filter: blur(10px) saturate(120%) !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus::before,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active.client-panel-hidden .map-speed-focus::before,
body[data-app-mode="client"] .map-area:fullscreen.client-panel-hidden .map-speed-focus::before,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback.client-panel-hidden .map-speed-focus::before {
  content: "SPEED" !important;
  position: absolute !important;
  top: 12px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  color: rgba(255,255,255,.62) !important;
  font-size: 9px !important;
  font-weight: 900 !important;
  letter-spacing: .22em !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus::after,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active.client-panel-hidden .map-speed-focus::after,
body[data-app-mode="client"] .map-area:fullscreen.client-panel-hidden .map-speed-focus::after,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback.client-panel-hidden .map-speed-focus::after {
  content: "km/h" !important;
  position: absolute !important;
  bottom: 16px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  height: auto !important;
  inset: auto auto 16px 50% !important;
  background: transparent !important;
  color: rgba(255,255,255,.72) !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: .08em !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active.client-panel-hidden .map-speed-focus-gauge,
body[data-app-mode="client"] .map-area:fullscreen.client-panel-hidden .map-speed-focus-gauge,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback.client-panel-hidden .map-speed-focus-gauge {
  position: absolute !important;
  width: 96px !important;
  height: 96px !important;
  min-width: 96px !important;
  min-height: 96px !important;
  border: none !important;
  border-radius: 999px !important;
  background: conic-gradient(from 220deg, rgba(16,185,129,.18), #22c55e calc(var(--speed-progress) * .45), #38bdf8 calc(var(--speed-progress) * .82), rgba(56,189,248,.12) 0) !important;
  box-shadow: inset 0 0 0 9px rgba(9,14,25,.88), inset 0 0 0 10px rgba(255,255,255,.04) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-warning .map-speed-focus-gauge {
  background: conic-gradient(from 220deg, rgba(245,158,11,.16), #f59e0b calc(var(--speed-progress) * .86), rgba(245,158,11,.10) 0) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus.speed-danger .map-speed-focus-gauge {
  background: conic-gradient(from 220deg, rgba(239,68,68,.16), #ef4444 calc(var(--speed-progress) * .90), rgba(239,68,68,.10) 0) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-gauge span,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active.client-panel-hidden .map-speed-focus-gauge span,
body[data-app-mode="client"] .map-area:fullscreen.client-panel-hidden .map-speed-focus-gauge span,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback.client-panel-hidden .map-speed-focus-gauge span {
  width: 62px !important;
  height: 62px !important;
  border-radius: 999px !important;
  background: radial-gradient(circle at 35% 32%, rgba(255,255,255,.12), rgba(15,23,42,.98) 66%) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08) !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active.client-panel-hidden .map-speed-focus-text,
body[data-app-mode="client"] .map-area:fullscreen.client-panel-hidden .map-speed-focus-text,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback.client-panel-hidden .map-speed-focus-text {
  position: absolute !important;
  inset: 0 !important;
  display: grid !important;
  place-items: center !important;
  gap: 0 !important;
  text-align: center !important;
  padding-top: 10px !important;
}
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text small,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text em { display: none !important; }
body[data-app-mode="client"] .map-area.client-panel-hidden .map-speed-focus-text strong,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active.client-panel-hidden .map-speed-focus-text strong,
body[data-app-mode="client"] .map-area:fullscreen.client-panel-hidden .map-speed-focus-text strong,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback.client-panel-hidden .map-speed-focus-text strong {
  color: #fff !important;
  font-size: 27px !important;
  line-height: 1 !important;
  font-weight: 1000 !important;
  text-shadow: 0 2px 10px rgba(0,0,0,.35) !important;
  letter-spacing: -.05em !important;
  margin-top: 4px !important;
}

/* v85: clean control desk — old monitor map UI removed */
body[data-app-mode="control-desk"] {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at 12% 0%, rgba(14,165,233,.16), transparent 28%),
    radial-gradient(circle at 88% 10%, rgba(20,184,166,.16), transparent 30%),
    #eef4f8;
  color: #0f172a;
}
.control-desk-shell {
  width: min(1480px, calc(100% - 28px));
  margin: 0 auto;
  padding: 18px 0 28px;
}
.control-desk-hero {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  padding: 22px;
  border-radius: 28px;
  background: linear-gradient(135deg, rgba(15,23,42,.96), rgba(15,118,110,.82));
  color: #fff;
  box-shadow: 0 24px 60px rgba(15,23,42,.18);
}
.control-desk-hero h1 { margin: 0; font-size: clamp(30px, 4vw, 54px); letter-spacing: -.06em; }
.control-desk-hero .subtle { max-width: 760px; color: rgba(255,255,255,.76); }
.control-desk-hero .eyebrow { color: rgba(125,211,252,.9); }
.control-desk-actions { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 10px; min-width: 290px; }
.control-desk-actions .secondary-button { color: #0f172a; background: rgba(255,255,255,.92); border-color: rgba(255,255,255,.34); }
.control-desk-topline {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
  margin: 14px 0;
}
.control-desk-topline article {
  padding: 14px 16px;
  border-radius: 20px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 12px 30px rgba(15,23,42,.08);
  border: 1px solid rgba(148,163,184,.22);
}
.control-desk-topline small { display: block; color: #64748b; font-weight: 800; font-size: 11px; text-transform: uppercase; letter-spacing: .08em; }
.control-desk-topline b { display: block; margin-top: 5px; font-size: clamp(19px, 2.2vw, 30px); letter-spacing: -.04em; }
.control-desk-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.control-desk-card {
  min-height: 190px;
  padding: 18px;
  border-radius: 24px;
  background: rgba(255,255,255,.95);
  border: 1px solid rgba(148,163,184,.2);
  box-shadow: 0 16px 38px rgba(15,23,42,.09);
}
.control-desk-card-wide { grid-column: span 2; }
.desk-card-head { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.desk-card-head span {
  display: inline-grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 14px;
  color: #0f766e;
  background: #ccfbf1;
  font-weight: 1000;
}
.desk-card-head h2 { margin: 0; font-size: 18px; letter-spacing: -.03em; }
.desk-big-status { margin: 0 0 8px; font-size: 20px; font-weight: 900; letter-spacing: -.03em; }
.desk-boat-list, .desk-link-list, .desk-list, .desk-log { display: grid; gap: 9px; }
.desk-boat-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
  padding: 12px;
  border-radius: 18px;
  background: #f8fafc;
  border: 1px solid rgba(148,163,184,.22);
}
.desk-boat-card h3 { margin: 0; font-size: 17px; }
.desk-boat-card p { margin: 3px 0 0; color: #64748b; font-size: 12px; }
.desk-boat-metrics { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.desk-boat-metrics span { padding: 9px; border-radius: 14px; background: #fff; }
.desk-boat-metrics b { display: block; font-size: 17px; }
.desk-boat-metrics small { color: #64748b; font-weight: 800; }
.desk-pill { padding: 7px 10px; border-radius: 999px; font-size: 12px; font-weight: 900; white-space: nowrap; }
.desk-pill.free { background: #dcfce7; color: #166534; }
.desk-pill.busy { background: #dbeafe; color: #1d4ed8; }
.desk-pill.danger { background: #fee2e2; color: #b91c1c; }
.desk-pill.offline { background: #f1f5f9; color: #475569; }
.desk-button-row { display: flex; flex-wrap: wrap; gap: 8px; grid-column: 1 / -1; }
.desk-list-row, .desk-alert, .desk-log-row {
  padding: 11px 12px;
  border-radius: 16px;
  background: #f8fafc;
  border: 1px solid rgba(148,163,184,.18);
}
.desk-list-row b, .desk-alert b { display: block; }
.desk-list-row span, .desk-alert small, .desk-list-row small { display: block; margin-top: 3px; color: #64748b; }
.desk-alert.danger { background: #fef2f2; border-color: rgba(248,113,113,.35); }
.desk-alert.warn { background: #fffbeb; border-color: rgba(251,191,36,.35); }
.desk-alert.offline { background: #f1f5f9; }
.desk-field { display: grid; gap: 6px; margin-bottom: 10px; font-weight: 800; color: #334155; }
.desk-field select, .desk-field textarea, .desk-link-row input {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #cbd5e1;
  border-radius: 14px;
  padding: 11px 12px;
  font: inherit;
  background: #fff;
}
.desk-link-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 8px;
  align-items: end;
  padding: 12px;
  border-radius: 18px;
  background: #f8fafc;
  border: 1px solid rgba(148,163,184,.2);
}
.desk-link-row label { display: grid; gap: 6px; min-width: 0; font-weight: 900; }
.desk-wide-link { display: inline-flex; justify-content: center; width: 100%; margin-top: 10px; text-decoration: none; }
.desk-log { max-height: 260px; overflow: auto; }
.desk-log-row { margin: 0; font-size: 13px; }
.desk-log-row.error { background: #fef2f2; color: #991b1b; }
.desk-log-row.warn { background: #fffbeb; color: #92400e; }
@media (max-width: 1180px) {
  .control-desk-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .control-desk-topline { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .control-desk-shell { width: min(100% - 18px, 560px); padding-top: 10px; }
  .control-desk-hero { display: grid; padding: 18px; }
  .control-desk-actions { min-width: 0; justify-content: stretch; }
  .control-desk-actions > * { flex: 1 1 130px; }
  .control-desk-grid, .control-desk-topline { grid-template-columns: 1fr; }
  .control-desk-card-wide { grid-column: auto; }
  .desk-link-row { grid-template-columns: 1fr; }
}


/* v86: control desk live map + trip route viewer */
.control-desk-map-card { grid-column: span 2; }
.desk-map-wrap {
  position: relative;
  min-height: 360px;
  border-radius: 24px;
  overflow: hidden;
  background: #0f172a;
  border: 1px solid rgba(148,163,184,.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.desk-control-map { position: absolute; inset: 0; width: 100%; height: 100%; }
.desk-map-empty {
  position: absolute;
  inset: 18px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 16px;
  border-radius: 20px;
  background: rgba(15,23,42,.72);
  color: rgba(255,255,255,.82);
  font-weight: 900;
  pointer-events: none;
  z-index: 5;
}
.desk-map-empty.hidden { display: none; }
.desk-map-connected {
  position: absolute;
  left: 12px;
  bottom: 12px;
  z-index: 6;
  display: grid;
  gap: 6px;
  max-width: min(440px, calc(100% - 24px));
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(15,23,42,.82);
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  box-shadow: 0 12px 28px rgba(15,23,42,.24);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.desk-map-connected span { display: block; }
.desk-map-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.desk-subtitle { margin: 16px 0 10px; font-size: 15px; letter-spacing: -.02em; color: #334155; }
.desk-boat-card.connected {
  border-color: rgba(34,197,94,.45);
  background: linear-gradient(135deg, #f0fdf4, #ffffff 72%);
  box-shadow: 0 12px 28px rgba(22,163,74,.08);
}
.desk-connected-line {
  margin-top: 6px !important;
  color: #15803d !important;
  font-weight: 900;
}
.active-session-row .mini-button,
.history-trip-row .mini-button { margin-top: 8px; width: fit-content; }
.history-trip-row button:disabled { opacity: .45; cursor: not-allowed; }
body[data-app-mode="control-desk"] .maplibregl-ctrl-bottom-left,
body[data-app-mode="control-desk"] .maplibregl-ctrl-bottom-right { display: none; }
@media (max-width: 900px) {
  .control-desk-map-card { grid-column: auto; }
  .desk-map-wrap { min-height: 310px; }
}


/* v87: control map fullscreen + left tools + consent-based media/video help */
.desk-map-actions .mini-button[disabled],
.desk-button-row .mini-button[disabled] { opacity: .45; cursor: not-allowed; }
body.desk-map-fullscreen-lock { overflow: hidden !important; }
.control-desk-map-card.desk-map-fullscreen-active {
  position: fixed !important;
  inset: 0 !important;
  z-index: 2147482500 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  grid-template-rows: auto minmax(0, 1fr) auto !important;
  width: 100vw !important;
  height: 100vh !important;
  height: 100dvh !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  border: none !important;
  background: #0f172a !important;
  box-shadow: none !important;
}
.control-desk-map-card.desk-map-fullscreen-active .desk-card-head {
  position: absolute !important;
  left: 12px !important;
  top: 12px !important;
  z-index: 12 !important;
  margin: 0 !important;
  padding: 10px 12px !important;
  border-radius: 18px !important;
  background: rgba(15,23,42,.82) !important;
  color: #fff !important;
  box-shadow: 0 12px 32px rgba(15,23,42,.32) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}
.control-desk-map-card.desk-map-fullscreen-active .desk-card-head span { background: rgba(45,212,191,.18); color: #99f6e4; }
.control-desk-map-card.desk-map-fullscreen-active .desk-card-head h2 { color: #fff; }
.control-desk-map-card.desk-map-fullscreen-active .desk-map-wrap {
  position: absolute !important;
  inset: 0 !important;
  min-height: 100vh !important;
  min-height: 100dvh !important;
  width: 100vw !important;
  height: 100vh !important;
  height: 100dvh !important;
  border-radius: 0 !important;
  border: none !important;
}
.control-desk-map-card.desk-map-fullscreen-active .desk-map-actions {
  position: absolute !important;
  left: 12px !important;
  top: 84px !important;
  z-index: 12 !important;
  display: grid !important;
  gap: 8px !important;
  width: 148px !important;
  margin: 0 !important;
  padding: 10px !important;
  border-radius: 20px !important;
  background: rgba(15,23,42,.82) !important;
  box-shadow: 0 12px 32px rgba(15,23,42,.32) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}
.control-desk-map-card.desk-map-fullscreen-active .desk-map-actions .mini-button {
  width: 100% !important;
  min-height: 38px !important;
  justify-content: center !important;
  color: #0f172a !important;
  background: #fff !important;
}
.control-desk-map-card.desk-map-fullscreen-active .desk-subtitle,
.control-desk-map-card.desk-map-fullscreen-active .desk-boat-list {
  position: absolute !important;
  left: 12px !important;
  z-index: 12 !important;
  width: min(310px, calc(100vw - 24px)) !important;
}
.control-desk-map-card.desk-map-fullscreen-active .desk-subtitle {
  top: 286px !important;
  margin: 0 !important;
  color: rgba(255,255,255,.86) !important;
  text-shadow: 0 1px 8px rgba(0,0,0,.35) !important;
}
.control-desk-map-card.desk-map-fullscreen-active .desk-boat-list {
  top: 314px !important;
  bottom: 14px !important;
  overflow: auto !important;
  padding-right: 4px !important;
}
.control-desk-map-card.desk-map-fullscreen-active .desk-boat-card {
  grid-template-columns: minmax(0, 1fr) auto !important;
  background: rgba(255,255,255,.92) !important;
  box-shadow: 0 12px 26px rgba(15,23,42,.18) !important;
}
.control-desk-map-card.desk-map-fullscreen-active .desk-boat-metrics { display: none !important; }
.control-desk-map-card.desk-map-fullscreen-active .desk-map-connected {
  right: 12px !important;
  left: auto !important;
  bottom: 12px !important;
  max-width: min(420px, calc(100vw - 340px)) !important;
}
body[data-app-mode="assist-call"] {
  margin: 0;
  min-height: 100vh;
  background: radial-gradient(circle at 20% 0%, rgba(56,189,248,.18), transparent 30%), #0f172a;
  color: #0f172a;
}
.assist-shell { min-height: 100vh; display: grid; place-items: center; padding: 18px; box-sizing: border-box; }
.assist-card { width: min(560px, 100%); padding: 22px; border-radius: 28px; background: rgba(255,255,255,.96); box-shadow: 0 24px 70px rgba(0,0,0,.25); }
.assist-card h1 { margin: 0 0 8px; font-size: clamp(28px, 5vw, 44px); letter-spacing: -.06em; }
.assist-stage { position: relative; display: grid; place-items: center; min-height: 320px; border-radius: 24px; background: #0f172a; overflow: hidden; margin: 16px 0; }
.assist-stage video { width: 100%; height: 100%; min-height: 320px; object-fit: cover; background: #0f172a; }
.assist-stage media { width: min(420px, calc(100% - 24px)); }
.assist-placeholder { position: absolute; inset: 16px; display: grid; place-items: center; border: 1px dashed rgba(255,255,255,.22); border-radius: 20px; color: rgba(255,255,255,.82); font-weight: 900; text-align: center; padding: 18px; }
.assist-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.client-message-alert .client-assist-open {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 10px;
  padding: 10px 14px;
  border-radius: 14px;
  background: #0f766e;
  color: #fff;
  font-weight: 900;
  text-decoration: none;
}
@media (max-width: 760px) {
  .control-desk-map-card.desk-map-fullscreen-active .desk-map-actions { top: 74px; width: 132px; }
  .control-desk-map-card.desk-map-fullscreen-active .desk-subtitle { top: 270px; }
  .control-desk-map-card.desk-map-fullscreen-active .desk-boat-list { top: 298px; width: min(270px, calc(100vw - 24px)); }
  .control-desk-map-card.desk-map-fullscreen-active .desk-map-connected { max-width: min(300px, calc(100vw - 24px)); }
}


/* v96 clean interface */
#navigator-removed-button, #fs-removed-button, .removed-toggle-button { display: none !important; visibility: hidden !important; pointer-events: none !important; }

/* v97 demo boat and fairway indicators */
.demo-boat-card { border: 1px solid rgba(14,116,144,.22); }
.demo-boat-layout { display:grid; grid-template-columns:minmax(260px, 360px) 1fr; gap:16px; align-items:stretch; }
.demo-boat-controls { display:grid; gap:10px; align-content:start; }
.demo-check { display:flex; gap:8px; align-items:center; font-weight:800; color:#334155; }
.demo-status { border-radius:16px; padding:12px; background:#f0fdfa; color:#0f3f3a; border:1px solid #cdeee8; line-height:1.45; font-size:13px; }
.demo-map-wrap { min-height:250px; border-radius:22px; overflow:hidden; border:1px solid #d6e5ee; background:linear-gradient(180deg,#e6f7fb,#f8fcff); }
.demo-water { fill:#e6f7fb; }
.demo-route-path { fill:none; stroke:#0f766e; stroke-width:5; stroke-linecap:round; stroke-linejoin:round; stroke-dasharray:1 0; }
.demo-checkpoint { fill:#ffffff; stroke:#0f766e; stroke-width:3; }
.demo-checkpoint.done { fill:#0f766e; }
.demo-boat-dot { fill:#2563eb; stroke:#ffffff; stroke-width:4; filter:drop-shadow(0 4px 8px rgba(15,23,42,.28)); }
.demo-boat-dot.violating { fill:#ef4444; }
.demo-boat-label, .demo-violation-label { fill:#0f172a; font-size:13px; font-weight:900; paint-order:stroke; stroke:#ffffff; stroke-width:4px; stroke-linejoin:round; }
.demo-violation-label { fill:#b42318; }
@media (max-width: 900px) { .demo-boat-layout { grid-template-columns:1fr; } }

/* v101: запрос «Слышать/Видеть» всегда поверх скрытых панелей */
body[data-app-mode="client"] .client-message-alert.assist-request-alert,
body[data-demo="true"] .client-message-alert.assist-request-alert,
body[data-app-mode="client"] .map-area.client-panel-hidden .client-message-alert.assist-request-alert,
body[data-demo="true"] .map-area.client-panel-hidden .client-message-alert.assist-request-alert,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .client-message-alert.assist-request-alert,
body[data-app-mode="client"] .map-area:fullscreen .client-message-alert.assist-request-alert,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .client-message-alert.assist-request-alert {
  display: grid !important;
  position: fixed !important;
  z-index: 2147483000 !important;
  left: calc(12px + env(safe-area-inset-left)) !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  top: calc(12px + env(safe-area-inset-top)) !important;
  bottom: auto !important;
  max-width: none !important;
  pointer-events: auto !important;
  border: 2px solid rgba(45,212,191,.78) !important;
  background: rgba(7,29,47,.96) !important;
  box-shadow: 0 18px 60px rgba(0,0,0,.42) !important;
}
body[data-app-mode="client"] .client-message-alert.assist-request-alert .client-assist-open,
body[data-demo="true"] .client-message-alert.assist-request-alert .client-assist-open {
  min-height: 48px !important;
  width: 100% !important;
  margin-top: 10px !important;
  font-size: 16px !important;
  border-radius: 16px !important;
}

/* V105: critical violation notices must stay visible above hidden client panels */
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fine-overlay.visible,
body[data-demo="true"] .map-area.client-panel-hidden .map-fine-overlay.visible {
  display: grid !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  position: fixed !important;
  z-index: 12050 !important;
  top: calc(12px + env(safe-area-inset-top)) !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  transform: none !important;
  min-width: 150px !important;
  max-width: min(46vw, 210px) !important;
  border-radius: 18px !important;
  padding: 10px 12px !important;
  background: rgba(255, 255, 255, .98) !important;
  box-shadow: 0 18px 44px rgba(15, 23, 42, .26) !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-fine-overlay.visible.danger,
body[data-demo="true"] .map-area.client-panel-hidden .map-fine-overlay.visible.danger {
  border-color: rgba(201, 42, 42, .35) !important;
  box-shadow: 0 20px 52px rgba(201, 42, 42, .24) !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-danger-alert.visible,
body[data-demo="true"] .map-area.client-panel-hidden .map-danger-alert.visible {
  display: flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  position: fixed !important;
  z-index: 12060 !important;
  left: 50% !important;
  top: calc(82px + env(safe-area-inset-top)) !important;
  bottom: auto !important;
  transform: translateX(-50%) scale(1) !important;
  width: min(620px, calc(100vw - 24px)) !important;
  max-width: calc(100vw - 24px) !important;
  min-width: 0 !important;
  min-height: 58px !important;
  padding: 12px 16px !important;
  border-radius: 20px !important;
  background: rgba(201, 42, 42, .98) !important;
  box-shadow: 0 22px 58px rgba(92, 0, 0, .38) !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-danger-alert.visible strong,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-danger-alert.visible span,
body[data-demo="true"] .map-area.client-panel-hidden .map-danger-alert.visible strong,
body[data-demo="true"] .map-area.client-panel-hidden .map-danger-alert.visible span {
  display: block !important;
  color: #fff !important;
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: normal !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-danger-alert.visible strong,
body[data-demo="true"] .map-area.client-panel-hidden .map-danger-alert.visible strong {
  font-size: 14px !important;
  line-height: 1.15 !important;
}

body[data-app-mode="client"] .map-area.client-panel-hidden .map-danger-alert.visible span,
body[data-demo="true"] .map-area.client-panel-hidden .map-danger-alert.visible span {
  font-size: 13px !important;
  line-height: 1.25 !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-danger-alert.visible,
body[data-app-mode="client"] .map-area:fullscreen .map-danger-alert.visible,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-danger-alert.visible,
body[data-demo="true"] .map-area.navigation-fullscreen-active .map-danger-alert.visible,
body[data-demo="true"] .map-area:fullscreen .map-danger-alert.visible,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-danger-alert.visible {
  position: fixed !important;
  z-index: 12060 !important;
  left: 50% !important;
  top: calc(82px + env(safe-area-inset-top)) !important;
  bottom: auto !important;
  transform: translateX(-50%) scale(1) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay.visible,
body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay.visible,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay.visible,
body[data-demo="true"] .map-area.navigation-fullscreen-active .map-fine-overlay.visible,
body[data-demo="true"] .map-area:fullscreen .map-fine-overlay.visible,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback .map-fine-overlay.visible {
  position: fixed !important;
  z-index: 12050 !important;
  top: calc(12px + env(safe-area-inset-top)) !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
}

@media (max-width: 520px) {
  body[data-app-mode="client"] .map-area.client-panel-hidden .map-fine-overlay.visible,
  body[data-demo="true"] .map-area.client-panel-hidden .map-fine-overlay.visible {
    max-width: calc(100vw - 24px) !important;
    left: calc(12px + env(safe-area-inset-left)) !important;
    right: calc(12px + env(safe-area-inset-right)) !important;
    width: auto !important;
  }
  body[data-app-mode="client"] .map-area.client-panel-hidden .map-danger-alert.visible,
  body[data-demo="true"] .map-area.client-panel-hidden .map-danger-alert.visible {
    top: calc(92px + env(safe-area-inset-top)) !important;
    width: calc(100vw - 24px) !important;
  }
}


/* v108: voice recording button restored for client fullscreen */
.map-toolbar .map-voice-button {
  background: #eef2ff;
  color: #3730a3;
  border-color: rgba(99,102,241,.35);
}
.map-toolbar .map-voice-button.voice-off,
.map-fs-button-voice.voice-off {
  background: #f8fafc !important;
  color: #64748b !important;
  border-color: rgba(148,163,184,.55) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button-voice,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button-voice,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button-voice {
  background: #eef2ff !important;
  color: #3730a3 !important;
  border-color: rgba(99,102,241,.45) !important;
}

/* v109: админ-функции перенесены в карту контроля, клиентское превью карты очищено */
body[data-app-mode="client"] .client-map-preview-hidden.map-status-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .client-map-preview-hidden.map-status-overlay,
body[data-app-mode="client"] .map-area:fullscreen .client-map-preview-hidden.map-status-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .client-map-preview-hidden.map-status-overlay {
  display: none !important;
}

.desk-event-list {
  display: grid;
  gap: 9px;
  max-height: 360px;
  overflow: auto;
}
.desk-event-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 6px 10px;
  align-items: start;
  padding: 11px 12px;
  border-radius: 16px;
  background: #f8fafc;
  border: 1px solid rgba(148,163,184,.2);
  font-size: 13px;
}
.desk-event-row time {
  color: #64748b;
  font-weight: 900;
  white-space: nowrap;
}
.desk-event-row strong { min-width: 0; }
.desk-event-row span {
  grid-column: 2 / -1;
  color: #64748b;
}
.desk-event-row em {
  color: #b45309;
  font-style: normal;
  font-weight: 1000;
}
.desk-event-row.danger,
.desk-event-row.error { background: #fef2f2; border-color: rgba(248,113,113,.38); }
.desk-event-row.warn,
.desk-event-row.warning { background: #fffbeb; border-color: rgba(251,191,36,.38); }
.desk-event-row.ok,
.desk-event-row.success { background: #f0fdf4; border-color: rgba(34,197,94,.32); }
.desk-log-actions { margin-bottom: 10px; }

body[data-app-mode="home"] .home-grid {
  align-items: stretch;
}


.simple-map-shape-marker {
  width: 46px;
  height: 46px;
  display: block;
  border: 0;
  background-color: transparent;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  color: transparent;
  font-size: 0;
  line-height: 0;
  cursor: grab;
  filter: drop-shadow(0 0 2px rgba(255,255,255,.95)) drop-shadow(0 2px 6px rgba(15,23,42,.25));
}
.simple-map-shape-marker.circle { background-image: url('./assets/map-shapes/circle.png'); }
.simple-map-shape-marker.triangle { background-image: url('./assets/map-shapes/triangle.png'); }
.simple-map-shape-marker.square { background-image: url('./assets/map-shapes/square.png'); }
.simple-map-shape-marker.selected {
  width: 54px;
  height: 54px;
  filter: drop-shadow(0 0 7px rgba(15,118,110,.7)) drop-shadow(0 2px 8px rgba(15,23,42,.35));
}
.editor-profile-panel select.field-control,
.editor-profile-panel input.field-control { margin-bottom: 8px; }

.editor-route-tabs {
  display: flex;
  gap: 7px;
  margin: 8px 0 10px;
  padding-bottom: 4px;
  overflow-x: auto;
}
.editor-route-tabs button {
  display: grid;
  flex: 0 0 auto;
  gap: 2px;
  min-height: 42px;
  max-width: 190px;
  padding: 7px 10px;
  border: 1px solid rgba(148,163,184,.42);
  border-radius: 8px;
  color: #334155;
  background: #f8fafc;
  text-align: left;
}
.editor-route-tabs button.selected {
  border-color: rgba(15,118,110,.62);
  color: #0f3f3a;
  background: #ecfdf5;
  box-shadow: inset 0 0 0 1px rgba(15,118,110,.12);
}
.editor-route-tabs button.active-route {
  border-bottom: 3px solid #2563eb;
}
.editor-route-tabs span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 900;
}
.editor-route-tabs small {
  color: #2563eb;
  font-size: 10px;
  font-weight: 900;
}

body[data-app-mode="client"] .map-danger-alert.caution {
  border-color: rgba(245,158,11,.72);
  background: rgba(180,83,9,.96);
  box-shadow: 0 18px 44px rgba(120,53,15,.30);
}
body[data-app-mode="client"] .map-area .map-danger-alert.caution.visible {
  border-color: rgba(245,158,11,.72) !important;
  background: rgba(180,83,9,.98) !important;
  box-shadow: 0 18px 44px rgba(120,53,15,.32) !important;
}


/* v112: карта контроля — иконки катеров и свернутые уведомления прямо на карте */
.desk-live-boat-marker {
  position: relative;
  width: 44px;
  height: 58px;
  cursor: pointer;
  z-index: 20;
}
.desk-live-boat-marker .boat-marker-svg {
  display: block;
  width: 44px;
  height: 58px;
  overflow: visible;
  filter: drop-shadow(0 4px 10px rgba(15, 23, 42, .35));
}
.desk-live-boat-marker .boat-alert-ring { display: none; }
.desk-live-boat-shape {
  transform-origin: 50% 50%;
  transition: transform .18s ease, filter .18s ease;
}
.desk-live-boat-shape.alert .boat-alert-ring { display: block; }
.desk-live-boat-shape.alert .boat-hull {
  stroke: #dc2626;
  stroke-width: 4.8px;
}
.desk-live-boat-label {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 5px);
  transform: translateX(-50%);
  max-width: 170px;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, .12);
  color: #0f172a;
  background: rgba(255, 255, 255, .94);
  box-shadow: 0 8px 18px rgba(15, 23, 42, .16);
  font-size: 11px;
  font-weight: 900;
  line-height: 1.15;
  white-space: nowrap;
  pointer-events: none;
}
.desk-live-boat-marker.marker-status-danger .desk-live-boat-label {
  border-color: rgba(220, 38, 38, .28);
  color: #b91c1c;
}
.desk-live-boat-marker.marker-status-offline {
  opacity: .64;
}
.desk-map-notification-dock {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 14;
  width: min(360px, calc(100% - 24px));
  color: #fff;
  pointer-events: auto;
}
.desk-map-notification-toggle {
  width: 100%;
  min-height: 38px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 16px;
  color: #fff;
  background: rgba(15,23,42,.86);
  box-shadow: 0 14px 34px rgba(15,23,42,.24);
  font-size: 12px;
  font-weight: 950;
  text-align: left;
  padding: 9px 12px;
  cursor: pointer;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.desk-map-notification-dock.has-items .desk-map-notification-toggle {
  background: rgba(127, 29, 29, .88);
}
.desk-map-notification-list {
  display: grid;
  gap: 7px;
  margin-top: 7px;
}
.desk-map-notification-dock.collapsed .desk-map-notification-list {
  display: none;
}
.desk-map-notification-item {
  display: grid;
  gap: 2px;
  width: 100%;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 14px;
  color: #fff;
  background: rgba(15,23,42,.82);
  box-shadow: 0 12px 28px rgba(15,23,42,.2);
  padding: 9px 10px;
  text-align: left;
  cursor: pointer;
}
.desk-map-notification-item.danger { background: rgba(185, 28, 28, .88); }
.desk-map-notification-item.warn { background: rgba(180, 83, 9, .88); }
.desk-map-notification-item.offline { background: rgba(51, 65, 85, .88); }
.desk-map-notification-item b {
  font-size: 12px;
  line-height: 1.2;
}
.desk-map-notification-item span,
.desk-map-notification-list p {
  margin: 0;
  color: rgba(255,255,255,.78);
  font-size: 11px;
  font-weight: 800;
}
body[data-app-mode="client"] .map-danger-alert strong {
  font-size: 14px;
}
body[data-app-mode="client"] .map-danger-alert span {
  font-size: 12px;
  white-space: normal;
}

/* v113: карта контроля показывает только актуальные подключения; фигуры карты залиты белым. */


.simple-arrow-start-marker {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: #ffffff;
  border: 3px solid #0b7285;
  box-shadow: 0 3px 10px rgba(15,23,42,.28);
}
.simple-arrow-start-marker::after {
  content: '1';
  position: absolute;
  inset: -1px 0 0 0;
  display: grid;
  place-items: center;
  font-size: 10px;
  font-weight: 900;
  color: #0b7285;
}
.demo-map-hint { margin-top: 4px; color: #0f766e; font-weight: 800; }

/* V118: стабильное отображение клиентских фигур и наконечников стрелок */
.client-map-shape {
  width: 48px;
  height: 48px;
  cursor: pointer;
  pointer-events: auto;
  filter: drop-shadow(0 0 3px rgba(255,255,255,.95)) drop-shadow(0 3px 7px rgba(15,23,42,.35));
}
.client-map-shape span { display: none; }
.client-direction-arrow-head {
  width: 46px;
  height: 46px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 2px 8px rgba(15,23,42,.28), 0 0 0 2px rgba(11,114,133,.28);
  color: #075985;
  display: grid;
  place-items: center;
  cursor: pointer;
  pointer-events: auto;
}
.client-direction-arrow-head span {
  display: block;
  font-size: 31px;
  line-height: 1;
  font-weight: 1000;
  transform-origin: center;
  text-shadow: 0 1px 0 #fff;
}


/* V119 client demo launch */
.client-demo-mode .client-start-card-v51 { border-color: rgba(14, 116, 144, .28); box-shadow: 0 22px 60px rgba(14, 116, 144, .18); }
.client-demo-mode .client-start-boat-summary { background: linear-gradient(135deg, rgba(236, 254, 255, .96), rgba(240, 253, 250, .96)); }
.client-demo-speed-field input { font-size: 18px; font-weight: 800; }
.navigator-launch-choice { display: inline-flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-top: 8px; padding: 6px; border-radius: 14px; background: rgba(15, 118, 110, .07); }
.navigator-launch-choice > span { font-weight: 900; color: #0f3f3b; padding: 0 4px; }
.navigator-launch-choice .demo-link { background: #ecfeff; border-color: rgba(8, 145, 178, .25); color: #075985; }
.client-demo-mode .gps-pill::after { content: ' · демо'; }

/* V120 demo navigator controls */
.navigator-demo-speed { display:inline-flex; align-items:center; gap:6px; font-weight:800; color:#0f172a; background:#eef7f6; border:1px solid rgba(15,118,110,.18); border-radius:12px; padding:6px 8px; }
.navigator-demo-speed input { width:58px; min-height:30px; border:1px solid rgba(15,23,42,.16); border-radius:9px; padding:4px 6px; font:inherit; font-weight:900; text-align:center; }
body.client-demo-running #client-start-gate { display:none !important; }
body.client-demo-mode #boat-session-status strong::after { content:""; }

/* V130: нормализация клиентского раздела и кнопка на случай пропажи GPS */
body[data-app-mode="client"] .client-gps-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
  align-items: stretch;
}
body[data-app-mode="client"] .gps-lost-button,
body[data-app-mode="client"] .toolbar-gps-lost-button,
body[data-app-mode="client"] .map-fs-button-warn {
  border: 1px solid rgba(245, 158, 11, .45) !important;
  background: linear-gradient(135deg, #fff7ed, #fffbeb) !important;
  color: #92400e !important;
  font-weight: 800 !important;
}
body[data-app-mode="client"] .gps-lost-button:disabled,
body[data-app-mode="client"] .toolbar-gps-lost-button:disabled,
body[data-app-mode="client"] .map-fs-button-warn:disabled {
  opacity: .58;
}
body[data-app-mode="client"] .client-gps-panel .client-hint {
  font-size: 12px;
  line-height: 1.35;
}
body[data-app-mode="client"] .client-start-boat-summary small {
  line-height: 1.35;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #map-gps-lost-button,
body[data-app-mode="client"] .map-area:fullscreen #map-gps-lost-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #map-gps-lost-button {
  display: inline-flex !important;
  grid-area: gpslost !important;
}
@media (max-width: 760px) {
  body[data-app-mode="client"] .client-gps-actions { grid-template-columns: 1fr; }
}


/* V133: Port PiterLand, client video button, contact choice, clear route layers */
.toolbar-video-call-button, .map-fs-button-camera {
  background: linear-gradient(135deg,#0b2f4d,#0f766e) !important;
  color: #fff !important;
  font-size: 18px !important;
}
body[data-app-mode="client"] .navigation-fullscreen-active .toolbar-video-call-button,
body[data-app-mode="client"] .map-area:fullscreen .toolbar-video-call-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .toolbar-video-call-button {
  display: inline-flex !important;
}
.map-fs-button-camera { border: 1px solid rgba(255,255,255,.28) !important; }
.desk-contact-modal { position:fixed; inset:0; z-index:9999; display:grid; place-items:center; padding:16px; background:rgba(6,24,38,.55); backdrop-filter:blur(8px); }
.desk-contact-modal.hidden { display:none; }
.desk-contact-card { width:min(440px,100%); border-radius:28px; background:#fff; box-shadow:0 28px 90px rgba(0,0,0,.3); padding:20px; border:1px solid rgba(215,180,106,.55); }
.desk-contact-card h3 { margin:0 0 4px; font-size:26px; letter-spacing:-.04em; color:#062239; }
.desk-contact-actions { display:grid; gap:10px; margin:14px 0; }
.desk-contact-actions button { border:1px solid #d7e2ec; background:linear-gradient(180deg,#fff,#f8fafc); border-radius:18px; min-height:64px; padding:12px; display:grid; gap:3px; text-align:left; cursor:pointer; }
.desk-contact-actions button:not(:disabled):hover { border-color:#d7b46a; box-shadow:0 12px 30px rgba(6,34,57,.12); }
.desk-contact-actions button:disabled { opacity:.45; cursor:not-allowed; }
.desk-contact-actions b { color:#062239; font-size:15px; }
.desk-contact-actions span { color:#64748b; font-size:13px; }
.desk-alert.video, .desk-map-notification-item.video { border-color:#d7b46a !important; background:#fff9e6 !important; }
.desk-live-boat-shape { transform-origin:50% 50%; transition: transform .28s linear; }
.client-map-shape, .simple-map-shape-marker { filter: drop-shadow(0 4px 8px rgba(0,0,0,.28)); }
.client-direction-arrow-head { filter: drop-shadow(0 3px 8px rgba(0,0,0,.3)); }


/* V136: клиентская карта — слои как на карте контроля и постоянная камера в fullscreen */
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #fs-camera-button,
body[data-app-mode="client"] .map-area:fullscreen #fs-camera-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #fs-camera-button,
body[data-app-mode="client"] .map-area.client-panel-hidden #fs-camera-button,
body[data-demo="true"] .map-area.navigation-fullscreen-active #fs-camera-button,
body[data-demo="true"] .map-area:fullscreen #fs-camera-button,
body[data-demo="true"] .map-area.navigation-fullscreen-fallback #fs-camera-button,
body[data-demo="true"] .map-area.client-panel-hidden #fs-camera-button {
  position: absolute !important;
  z-index: 2147483078 !important;
  right: max(12px, calc(env(safe-area-inset-right) + 12px)) !important;
  bottom: max(158px, calc(env(safe-area-inset-bottom) + 158px)) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 56px !important;
  height: 56px !important;
  min-width: 56px !important;
  min-height: 56px !important;
  border-radius: 999px !important;
  padding: 0 !important;
  border: 1px solid rgba(255,255,255,.72) !important;
  background: linear-gradient(135deg, rgba(6,35,57,.98), rgba(15,118,110,.98)) !important;
  color: #ffffff !important;
  font-size: 25px !important;
  line-height: 1 !important;
  box-shadow: 0 16px 40px rgba(6,35,57,.34), 0 0 0 4px rgba(255,255,255,.22) !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: none !important;
  touch-action: manipulation !important;
}
body[data-app-mode="client"] .map-area:not(.navigation-fullscreen-active):not(:fullscreen):not(.navigation-fullscreen-fallback) #fs-camera-button,
body[data-demo="true"] .map-area:not(.navigation-fullscreen-active):not(:fullscreen):not(.navigation-fullscreen-fallback) #fs-camera-button {
  display: none !important;
}
body[data-app-mode="client"] .toolbar-video-call-button {
  border-color: rgba(15,118,110,.34) !important;
  background: linear-gradient(135deg,#0b2f4d,#0f766e) !important;
  color:#fff !important;
  font-weight: 900 !important;
}
body[data-app-mode="client"] .client-map-shape,
body[data-app-mode="client"] .simple-map-shape-marker {
  width: 44px !important;
  height: 44px !important;
  filter: drop-shadow(0 0 3px rgba(255,255,255,.95)) drop-shadow(0 5px 10px rgba(6,35,57,.32)) !important;
}
body[data-app-mode="client"] .client-direction-arrow-head {
  background: rgba(255,255,255,.96) !important;
  color: #0b7285 !important;
  box-shadow: 0 5px 14px rgba(6,35,57,.28), 0 0 0 2px rgba(255,255,255,.95), 0 0 0 4px rgba(11,114,133,.22) !important;
}

/* V139: связь в fullscreen над кнопкой возврата к катеру + исправление видимости */
body[data-app-mode="client"] .map-fs-floating-camera {
  display: none !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-floating-camera,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-floating-camera,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-floating-camera {
  position: absolute !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: max(314px, calc(env(safe-area-inset-bottom) + 302px)) !important;
  width: 58px !important;
  height: 58px !important;
  min-width: 58px !important;
  min-height: 58px !important;
  border-radius: 22px !important;
  border: 1px solid rgba(255,255,255,.34) !important;
  background: linear-gradient(135deg,#0b2f4d,#0f766e) !important;
  color: #fff !important;
  font-size: 23px !important;
  box-shadow: 0 14px 34px rgba(7,31,49,.28) !important;
  z-index: 2147483074 !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: translateZ(0) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active.client-panel-hidden .map-fs-floating-camera,
body[data-app-mode="client"] .map-area:fullscreen.client-panel-hidden .map-fs-floating-camera,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback.client-panel-hidden .map-fs-floating-camera,
body[data-app-mode="client"] .map-area.client-panel-hidden .map-fs-floating-camera {
  position: absolute !important;
  display: inline-flex !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(max(42px, env(safe-area-inset-bottom)) + 104px) !important;
  width: 62px !important;
  height: 62px !important;
  min-width: 62px !important;
  min-height: 62px !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  z-index: 2147483074 !important;
}

/* V140: fullscreen client contact button above boat button + contact choice modal */
body[data-app-mode="client"] .toolbar-video-call-button {
  min-width: 72px !important;
  border-color: rgba(15,118,110,.34) !important;
  background: linear-gradient(135deg,#0b2f4d,#0f766e) !important;
  color:#fff !important;
  font-weight: 950 !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(max(42px, env(safe-area-inset-bottom)) + 84px) !important;
  width: 64px !important;
  height: 60px !important;
  min-width: 64px !important;
  min-height: 60px !important;
  border-radius: 22px !important;
  z-index: 2147483068 !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active #fs-camera-button,
body[data-app-mode="client"] .map-area:fullscreen #fs-camera-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #fs-camera-button,
body[data-app-mode="client"] .map-area.client-panel-hidden #fs-camera-button {
  position: absolute !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  right: calc(12px + env(safe-area-inset-right)) !important;
  bottom: calc(max(42px, env(safe-area-inset-bottom)) + 152px) !important;
  width: 64px !important;
  height: 60px !important;
  min-width: 64px !important;
  min-height: 60px !important;
  padding: 0 !important;
  border-radius: 22px !important;
  border: 1px solid rgba(255,255,255,.44) !important;
  background: linear-gradient(135deg,#0b2f4d,#0f766e) !important;
  color:#fff !important;
  font-size: 23px !important;
  font-weight: 950 !important;
  box-shadow: 0 14px 34px rgba(7,31,49,.28), 0 0 0 3px rgba(255,255,255,.18) !important;
  z-index: 2147483076 !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  touch-action: manipulation !important;
}
body[data-app-mode="client"] .client-contact-sheet.hidden { display: none !important; }
body[data-app-mode="client"] .client-contact-sheet {
  position: absolute;
  inset: 0;
  z-index: 2147483080;
  display: grid;
  place-items: end center;
  padding: 16px;
  pointer-events: auto;
}
body[data-app-mode="client"] .client-contact-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(6,24,38,.42);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}
body[data-app-mode="client"] .client-contact-card {
  position: relative;
  z-index: 1;
  width: min(440px, 100%);
  border-radius: 28px;
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(215,180,106,.55);
  box-shadow: 0 28px 90px rgba(0,0,0,.32);
  padding: 18px;
  color: #062239;
}
body[data-app-mode="client"] .client-contact-kicker {
  display:inline-flex;
  border-radius:999px;
  padding:5px 9px;
  background:#fff7e6;
  color:#7c5c1f;
  font-size:11px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.08em;
}
body[data-app-mode="client"] .client-contact-card h3 { margin: 10px 0 4px; font-size: 24px; line-height: 1.05; }
body[data-app-mode="client"] .client-contact-card p { margin: 0; color:#64748b; font-size:14px; line-height:1.35; }
body[data-app-mode="client"] .client-contact-actions { display:grid; gap:10px; margin:14px 0; }
body[data-app-mode="client"] .client-contact-actions button,
body[data-app-mode="client"] .client-contact-close {
  width:100%;
  border-radius:18px;
  min-height:58px;
  padding:12px;
  border:1px solid #d7e2ec;
  background:linear-gradient(180deg,#fff,#f8fafc);
  color:#062239;
  text-align:left;
  font-weight:900;
  cursor:pointer;
}
body[data-app-mode="client"] .client-contact-actions button b { display:block; font-size:15px; }
body[data-app-mode="client"] .client-contact-actions button span { display:block; margin-top:3px; color:#64748b; font-size:13px; font-weight:700; }
body[data-app-mode="client"] .client-contact-actions button:first-child { border-color:rgba(15,118,110,.35); background:linear-gradient(135deg,#0b2f4d,#0f766e); color:#fff; }
body[data-app-mode="client"] .client-contact-actions button:first-child span { color:rgba(255,255,255,.78); }
body[data-app-mode="client"] .client-contact-close { min-height:44px; text-align:center; background:#f1f5f9; color:#334155; }
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .maplibregl-canvas,
body[data-app-mode="client"] .map-area:fullscreen .maplibregl-canvas,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .maplibregl-canvas {
  filter: saturate(1.03) contrast(1.01) !important;
}


/* V142: буи контуром, видимые фигуры/стрелки и кнопка "Связь" внутри fullscreen-панели */
body[data-app-mode="client"] .map-fs-floating-camera,
body[data-app-mode="client"] #fs-camera-button.map-fs-floating-camera {
  display: none !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-controls-grid,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-controls-grid,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-controls-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active #fs-camera-button,
body[data-app-mode="client"] .map-area:fullscreen #fs-camera-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback #fs-camera-button,
body[data-app-mode="client"] .map-area.client-panel-hidden #fs-camera-button {
  position: static !important;
  right: auto !important;
  bottom: auto !important;
  width: 100% !important;
  height: 50px !important;
  min-width: 0 !important;
  min-height: 50px !important;
  padding: 0 12px !important;
  border-radius: 17px !important;
  border: 1px solid rgba(203,213,225,.95) !important;
  background: linear-gradient(135deg,#0b2f4d,#0f766e) !important;
  color: #fff !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  box-shadow: none !important;
  z-index: auto !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: none !important;
}

body[data-app-mode="client"] .toolbar-video-call-button,
body[data-app-mode="client"] .map-fs-button-camera {
  min-width: 84px !important;
  background: linear-gradient(135deg,#0b2f4d,#0f766e) !important;
  color: #fff !important;
  font-weight: 950 !important;
}


/* V143: серьёзный визуальный редизайн клиентской карты */
body[data-app-mode="client"] {
  --wg-glass-bg: linear-gradient(180deg, rgba(255,255,255,.95), rgba(248,250,252,.92));
  --wg-glass-border: rgba(255,255,255,.72);
  --wg-shadow-xl: 0 18px 44px rgba(2, 6, 23, .20);
  --wg-shadow-lg: 0 14px 34px rgba(2, 6, 23, .18);
}

body[data-app-mode="client"] .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
  top: calc(env(safe-area-inset-top) + 12px) !important;
  left: calc(env(safe-area-inset-left) + 12px) !important;
  right: calc(env(safe-area-inset-right) + 12px) !important;
  width: auto !important;
  max-width: none !important;
  padding: 14px 14px 12px !important;
  border-radius: 24px !important;
  border: 1px solid var(--wg-glass-border) !important;
  background: var(--wg-glass-bg) !important;
  box-shadow: var(--wg-shadow-xl) !important;
  backdrop-filter: blur(18px) saturate(1.18) !important;
  -webkit-backdrop-filter: blur(18px) saturate(1.18) !important;
}

body[data-app-mode="client"] .navigator-header-title-row {
  align-items: baseline !important;
  gap: 8px !important;
}
body[data-app-mode="client"] .navigator-header-title-row span,
body[data-app-mode="client"] .navigator-header #map-status-title {
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  color: #0f766e !important;
}
body[data-app-mode="client"] .navigator-header-title-row strong,
body[data-app-mode="client"] .navigator-header #map-status-main {
  font-size: 20px !important;
  line-height: 1.05 !important;
  letter-spacing: -.03em !important;
  color: #062239 !important;
}
body[data-app-mode="client"] .navigator-status-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
  margin-top: 10px !important;
}
body[data-app-mode="client"] .navigator-status-chip {
  min-width: 0 !important;
  padding: 10px 10px 9px !important;
  border-radius: 16px !important;
  border: 1px solid rgba(226,232,240,.95) !important;
  background: rgba(255,255,255,.80) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.72) !important;
}
body[data-app-mode="client"] .navigator-status-chip small {
  font-size: 10px !important;
  font-weight: 800 !important;
  color: #64748b !important;
  text-transform: uppercase !important;
}
body[data-app-mode="client"] .navigator-status-chip b {
  margin-top: 3px !important;
  font-size: 15px !important;
  color: #0f172a !important;
}
body[data-app-mode="client"] .navigator-header #map-status-detail {
  display: block !important;
  margin-top: 9px !important;
  color: #475569 !important;
  font-size: 12px !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-controls,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-controls,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-controls {
  width: min(calc(100vw - 20px - env(safe-area-inset-left) - env(safe-area-inset-right)), 470px) !important;
  bottom: max(12px, calc(env(safe-area-inset-bottom) + 10px)) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-controls-grid,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-controls-grid,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-controls-grid {
  gap: 10px !important;
  padding: 12px !important;
  border-radius: 28px !important;
  border: 1px solid rgba(255,255,255,.82) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(241,245,249,.97)) !important;
  box-shadow: 0 22px 60px rgba(15,23,42,.24) !important;
  backdrop-filter: blur(18px) saturate(1.15) !important;
  -webkit-backdrop-filter: blur(18px) saturate(1.15) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button {
  min-height: 54px !important;
  height: 54px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(203,213,225,.88) !important;
  background: linear-gradient(180deg,#ffffff,#f8fafc) !important;
  color: #0f172a !important;
  font-size: 15px !important;
  font-weight: 950 !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.78) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button.map-fs-button-primary,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button.map-fs-button-primary,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button.map-fs-button-primary {
  background: linear-gradient(135deg,#0f766e,#14b8a6) !important;
  color: #fff !important;
  border-color: rgba(15,118,110,.35) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button.map-fs-button-stop,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button.map-fs-button-stop,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button.map-fs-button-stop {
  background: linear-gradient(135deg,#991b1b,#ef4444) !important;
  color: #fff !important;
  border-color: rgba(220,38,38,.3) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button.map-fs-button-gps,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button.map-fs-button-gps,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button.map-fs-button-gps {
  background: linear-gradient(135deg,#0b5ed7,#38bdf8) !important;
  color: #fff !important;
  border-color: rgba(59,130,246,.28) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button.map-fs-button-warn,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button.map-fs-button-warn,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button.map-fs-button-warn {
  background: linear-gradient(135deg,#b45309,#f59e0b) !important;
  color: #fff !important;
  border-color: rgba(245,158,11,.35) !important;
}
body[data-app-mode="client"] .map-fs-button-camera,
body[data-app-mode="client"] .toolbar-video-call-button {
  background: linear-gradient(135deg,#0b2f4d,#0f766e) !important;
  color: #fff !important;
  border-color: rgba(15,118,110,.28) !important;
}

body[data-app-mode="client"] .map-fine-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay,
body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
  right: calc(env(safe-area-inset-right) + 12px) !important;
  left: auto !important;
  bottom: calc(max(42px, env(safe-area-inset-bottom)) + 224px) !important;
  min-width: 150px !important;
  padding: 12px 14px !important;
  border-radius: 20px !important;
  border: 1px solid rgba(255,255,255,.70) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(248,250,252,.92)) !important;
  box-shadow: var(--wg-shadow-lg) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}
body[data-app-mode="client"] .map-fine-overlay strong { font-size: 24px !important; }
body[data-app-mode="client"] .map-fine-overlay span { font-size: 11px !important; letter-spacing: .08em !important; text-transform: uppercase !important; }
body[data-app-mode="client"] .map-fine-overlay small { font-size: 12px !important; }

body[data-app-mode="client"] .map-danger-alert,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-danger-alert,
body[data-app-mode="client"] .map-area:fullscreen .map-danger-alert,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-danger-alert {
  top: calc(env(safe-area-inset-top) + 158px) !important;
  left: calc(env(safe-area-inset-left) + 12px) !important;
  right: calc(env(safe-area-inset-right) + 12px) !important;
  border-radius: 18px !important;
  border: 1px solid rgba(254,202,202,.92) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.97), rgba(254,242,242,.95)) !important;
  box-shadow: 0 16px 38px rgba(127,29,29,.16) !important;
}

body[data-app-mode="client"] .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  right: calc(env(safe-area-inset-right) + 12px) !important;
  bottom: calc(max(42px, env(safe-area-inset-bottom)) + 150px) !important;
  width: 68px !important;
  height: 68px !important;
  min-width: 68px !important;
  min-height: 68px !important;
  border-radius: 24px !important;
  border: 1px solid rgba(255,255,255,.5) !important;
  background: linear-gradient(135deg,#b91c1c,#ef4444) !important;
  box-shadow: 0 18px 36px rgba(127,29,29,.26), 0 0 0 4px rgba(255,255,255,.18) !important;
  font-size: 21px !important;
  font-weight: 950 !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  right: calc(env(safe-area-inset-right) + 12px) !important;
  bottom: calc(max(42px, env(safe-area-inset-bottom)) + 74px) !important;
  width: 68px !important;
  height: 64px !important;
  min-width: 68px !important;
  min-height: 64px !important;
  border-radius: 24px !important;
  border: 1px solid rgba(255,255,255,.55) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(241,245,249,.96)) !important;
  box-shadow: var(--wg-shadow-lg), 0 0 0 4px rgba(255,255,255,.16) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button img,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button img,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button img {
  width: 34px !important;
  height: 34px !important;
  filter: drop-shadow(0 2px 5px rgba(15,23,42,.18));
}

body[data-app-mode="client"] #map,
body[data-app-mode="client"] #simple-map {
  filter: saturate(1.06) contrast(1.02) !important;
}

@media (max-width: 640px) {
  body[data-app-mode="client"] .navigator-status-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  body[data-app-mode="client"] .navigator-header.map-status-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
  body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
    padding: 12px 12px 11px !important;
  }
  body[data-app-mode="client"] .navigator-header-title-row strong,
  body[data-app-mode="client"] .navigator-header #map-status-main {
    font-size: 18px !important;
  }
  body[data-app-mode="client"] .map-fine-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay,
  body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
    bottom: calc(max(42px, env(safe-area-inset-bottom)) + 236px) !important;
  }
}


/* V144: premium marine navigator UI */
body[data-app-mode="client"] {
  --wg-premium-navy: #062239;
  --wg-premium-navy-2: #0b2f4d;
  --wg-premium-teal: #0f766e;
  --wg-premium-gold: #d7b46a;
  --wg-premium-gold-soft: #f2deb1;
  --wg-premium-ice: #ecf5fb;
  --wg-premium-glass: linear-gradient(180deg, rgba(8,34,57,.88), rgba(11,47,77,.84));
  --wg-premium-glass-light: linear-gradient(180deg, rgba(255,255,255,.98), rgba(244,248,251,.96));
  --wg-premium-shadow: 0 20px 48px rgba(2, 12, 24, .34);
}

body[data-app-mode="client"] .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
  background: var(--wg-premium-glass) !important;
  border: 1px solid rgba(215,180,106,.38) !important;
  box-shadow: var(--wg-premium-shadow), inset 0 1px 0 rgba(255,255,255,.08) !important;
}
body[data-app-mode="client"] .navigator-header-title-row span,
body[data-app-mode="client"] .navigator-header #map-status-title {
  color: var(--wg-premium-gold-soft) !important;
}
body[data-app-mode="client"] .navigator-header-title-row strong,
body[data-app-mode="client"] .navigator-header #map-status-main,
body[data-app-mode="client"] .navigator-header #map-status-detail {
  color: #f8fbff !important;
}
body[data-app-mode="client"] .navigator-status-chip {
  border: 1px solid rgba(215,180,106,.18) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.06)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08) !important;
}
body[data-app-mode="client"] .navigator-status-chip small {
  color: rgba(215,180,106,.86) !important;
}
body[data-app-mode="client"] .navigator-status-chip b {
  color: #ffffff !important;
}

body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-controls-grid,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-controls-grid,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-controls-grid {
  background: linear-gradient(180deg, rgba(250,252,254,.97), rgba(237,244,248,.96)) !important;
  border: 1px solid rgba(215,180,106,.42) !important;
  box-shadow: 0 24px 62px rgba(2, 12, 24, .28), inset 0 1px 0 rgba(255,255,255,.82) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button {
  border: 1px solid rgba(201,213,224,.9) !important;
  background: linear-gradient(180deg,#ffffff,#eef4f8) !important;
  color: #08233a !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.9), 0 1px 0 rgba(255,255,255,.5) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button.map-fs-button-primary,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button.map-fs-button-primary,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button.map-fs-button-primary {
  background: linear-gradient(135deg, #0f766e, #14b8a6) !important;
  color: white !important;
  border-color: rgba(15,118,110,.45) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button.map-fs-button-gps,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button.map-fs-button-gps,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button.map-fs-button-gps {
  background: linear-gradient(135deg, #0b5ed7, #38bdf8) !important;
  color: white !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button.map-fs-button-warn,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button.map-fs-button-warn,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button.map-fs-button-warn {
  background: linear-gradient(135deg, #b7791f, #f59e0b) !important;
  color: white !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button.map-fs-button-stop,
body[data-app-mode="client"] .map-area:fullscreen .map-fs-button.map-fs-button-stop,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button.map-fs-button-stop {
  background: linear-gradient(135deg, #991b1b, #ef4444) !important;
  color: white !important;
}
body[data-app-mode="client"] .map-fs-button-camera,
body[data-app-mode="client"] .toolbar-video-call-button {
  background: linear-gradient(135deg, #062239, #0f766e) !important;
  border-color: rgba(215,180,106,.42) !important;
  color: #fff !important;
}

body[data-app-mode="client"] .map-fine-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay,
body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(245,248,251,.94)) !important;
  border: 1px solid rgba(215,180,106,.34) !important;
  box-shadow: 0 18px 42px rgba(2,12,24,.20) !important;
}
body[data-app-mode="client"] .map-fine-overlay strong {
  color: #062239 !important;
}
body[data-app-mode="client"] .map-fine-overlay span {
  color: #0f766e !important;
}

body[data-app-mode="client"] .map-danger-alert,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-danger-alert,
body[data-app-mode="client"] .map-area:fullscreen .map-danger-alert,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-danger-alert {
  border: 1px solid rgba(248,113,113,.30) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(254,242,242,.96)) !important;
  box-shadow: 0 18px 42px rgba(127,29,29,.15) !important;
}

body[data-app-mode="client"] .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
  background: linear-gradient(135deg, #991b1b, #ef4444) !important;
  border: 1px solid rgba(255,255,255,.42) !important;
  box-shadow: 0 20px 40px rgba(127,29,29,.28), 0 0 0 4px rgba(255,255,255,.14) !important;
}
body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(236,245,251,.96)) !important;
  border: 1px solid rgba(215,180,106,.34) !important;
  box-shadow: 0 18px 42px rgba(2,12,24,.20), 0 0 0 4px rgba(255,255,255,.14) !important;
}

body[data-app-mode="client"] #map,
body[data-app-mode="client"] #simple-map {
  filter: saturate(1.08) contrast(1.04) brightness(1.01) !important;
}


/* V145: mobile fullscreen focus, visible markers/arrows, top-down course */
body[data-app-mode="client"] .client-contour-buoy-marker {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 4px solid currentColor;
  background: rgba(255,255,255,.92);
  color: #16a34a;
  display: grid;
  place-items: center;
  box-shadow: 0 10px 20px rgba(2,12,24,.24), 0 0 0 2px rgba(255,255,255,.72);
  padding: 0;
}
body[data-app-mode="client"] .client-contour-buoy-marker.red { color: #dc2626; }
body[data-app-mode="client"] .client-contour-buoy-marker.green { color: #16a34a; }
body[data-app-mode="client"] .client-contour-buoy-marker span {
  font-size: 12px;
  font-weight: 950;
  line-height: 1;
}
body[data-app-mode="client"] .client-route-point-marker span {
  width: 28px !important;
  height: 28px !important;
  font-size: 11px !important;
}
body[data-app-mode="client"] .client-direction-arrow-head {
  width: 34px !important;
  height: 34px !important;
  border-radius: 999px !important;
  border: 2px solid rgba(255,255,255,.95) !important;
  background: linear-gradient(135deg,#0b7285,#38bdf8) !important;
  box-shadow: 0 10px 22px rgba(2,12,24,.24), 0 0 0 2px rgba(255,255,255,.72) !important;
}
body[data-app-mode="client"] .client-direction-arrow-head span {
  color: #ffffff !important;
  font-size: 18px !important;
  font-weight: 900 !important;
}
body[data-app-mode="client"] .client-map-shape,
body[data-app-mode="client"] .simple-map-shape-marker {
  width: 40px !important;
  height: 40px !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, rgba(6,34,57,.96), rgba(15,118,110,.94)) !important;
  border: 2px solid rgba(255,255,255,.92) !important;
  box-shadow: 0 10px 22px rgba(2,12,24,.24), 0 0 0 2px rgba(255,255,255,.72) !important;
}
body[data-app-mode="client"] .client-map-shape span,
body[data-app-mode="client"] .simple-map-shape-marker span {
  color: #ffffff !important;
  font-size: 20px !important;
}

/* mobile fullscreen arrangement */
@media (max-width: 820px) {
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-controls,
  body[data-app-mode="client"] .map-area:fullscreen .map-fs-controls,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-controls {
    width: min(calc(100vw - 16px - env(safe-area-inset-left) - env(safe-area-inset-right)), 100%) !important;
    bottom: max(8px, calc(env(safe-area-inset-bottom) + 8px)) !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-controls-grid,
  body[data-app-mode="client"] .map-area:fullscreen .map-fs-controls-grid,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-controls-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    padding: 10px !important;
    border-radius: 24px !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fs-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-fs-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fs-button {
    min-height: 52px !important;
    height: 52px !important;
    font-size: 14px !important;
  }
  body[data-app-mode="client"] .navigator-header.map-status-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .navigator-header.map-status-overlay,
  body[data-app-mode="client"] .map-area:fullscreen .navigator-header.map-status-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .navigator-header.map-status-overlay {
    top: calc(env(safe-area-inset-top) + 8px) !important;
    left: calc(env(safe-area-inset-left) + 8px) !important;
    right: calc(env(safe-area-inset-right) + 8px) !important;
    padding: 10px 10px 9px !important;
    border-radius: 18px !important;
  }
  body[data-app-mode="client"] .navigator-status-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }
  body[data-app-mode="client"] .navigator-status-chip {
    padding: 8px 8px 7px !important;
    border-radius: 14px !important;
  }
  body[data-app-mode="client"] .navigator-status-chip b {
    font-size: 14px !important;
  }
  /* push boat and SOS above fullscreen panel */
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
    bottom: calc(max(42px, env(safe-area-inset-bottom)) + 304px) !important;
    right: calc(env(safe-area-inset-right) + 10px) !important;
    width: 62px !important;
    height: 58px !important;
    min-width: 62px !important;
    min-height: 58px !important;
    z-index: 2147483072 !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
    bottom: calc(max(42px, env(safe-area-inset-bottom)) + 376px) !important;
    right: calc(env(safe-area-inset-right) + 10px) !important;
    width: 62px !important;
    height: 62px !important;
    min-width: 62px !important;
    min-height: 62px !important;
    z-index: 2147483073 !important;
  }
  body[data-app-mode="client"] .map-fine-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay,
  body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
    bottom: calc(max(42px, env(safe-area-inset-bottom)) + 446px) !important;
    right: calc(env(safe-area-inset-right) + 8px) !important;
    min-width: 132px !important;
    padding: 10px 12px !important;
  }
  body[data-app-mode="client"] .map-fine-overlay strong { font-size: 20px !important; }
}


/* V146: rotate map, compact fine panel, visible safe corridor, figures and contour buoys */
body[data-app-mode="client"] .client-contour-buoy-marker {
  width: 38px !important;
  height: 38px !important;
  border-width: 5px !important;
  background: rgba(255,255,255,.98) !important;
  box-shadow: 0 10px 24px rgba(2,12,24,.28), 0 0 0 3px rgba(255,255,255,.72) !important;
}
body[data-app-mode="client"] .client-contour-buoy-marker.red { color: #dc2626 !important; }
body[data-app-mode="client"] .client-contour-buoy-marker.green { color: #16a34a !important; }
body[data-app-mode="client"] .client-contour-buoy-marker span { font-size: 13px !important; font-weight: 950 !important; }

body[data-app-mode="client"] .client-map-shape,
body[data-app-mode="client"] .simple-map-shape-marker {
  width: 42px !important;
  height: 42px !important;
  border-radius: 999px !important;
  border: 2px solid rgba(255,255,255,.96) !important;
  box-shadow: 0 10px 24px rgba(2,12,24,.28), 0 0 0 2px rgba(255,255,255,.76) !important;
}
body[data-app-mode="client"] .client-map-shape span,
body[data-app-mode="client"] .simple-map-shape-marker span {
  color: #ffffff !important;
  font-size: 22px !important;
  font-weight: 900 !important;
}

body[data-app-mode="client"] .client-direction-arrow-head {
  width: 36px !important;
  height: 36px !important;
  background: linear-gradient(135deg,#0b7285,#38bdf8) !important;
  border: 2px solid rgba(255,255,255,.96) !important;
  box-shadow: 0 10px 22px rgba(2,12,24,.25), 0 0 0 2px rgba(255,255,255,.72) !important;
}
body[data-app-mode="client"] .client-direction-arrow-head span {
  font-size: 18px !important;
  color: #ffffff !important;
}

@media (max-width: 820px) {
  body[data-app-mode="client"] .map-fine-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-fine-overlay,
  body[data-app-mode="client"] .map-area:fullscreen .map-fine-overlay,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-fine-overlay {
    right: calc(env(safe-area-inset-right) + 8px) !important;
    bottom: calc(max(42px, env(safe-area-inset-bottom)) + 454px) !important;
    left: auto !important;
    width: 134px !important;
    min-width: 134px !important;
    max-width: 134px !important;
    padding: 8px 10px !important;
    border-radius: 16px !important;
    box-shadow: 0 12px 28px rgba(2,12,24,.18) !important;
  }
  body[data-app-mode="client"] .map-fine-overlay span { font-size: 10px !important; }
  body[data-app-mode="client"] .map-fine-overlay strong { font-size: 18px !important; line-height: 1 !important; }
  body[data-app-mode="client"] .map-fine-overlay small { font-size: 11px !important; }

  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-locate-boat-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-locate-boat-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-locate-boat-button {
    bottom: calc(max(42px, env(safe-area-inset-bottom)) + 292px) !important;
  }
  body[data-app-mode="client"] .map-area.navigation-fullscreen-active .map-sos-button,
  body[data-app-mode="client"] .map-area:fullscreen .map-sos-button,
  body[data-app-mode="client"] .map-area.navigation-fullscreen-fallback .map-sos-button {
    bottom: calc(max(42px, env(safe-area-inset-bottom)) + 364px) !important;
  }
}


/* V147: client layers like route-map, contour buoys, clearer direction arrows */
body[data-app-mode="client"] .client-contour-buoy-marker {
  width: 40px !important;
  height: 40px !important;
  border-width: 5px !important;
  background: rgba(255,255,255,.99) !important;
  box-shadow: 0 10px 22px rgba(2,12,24,.26), 0 0 0 3px rgba(255,255,255,.74) !important;
}
body[data-app-mode="client"] .client-direction-arrow-head {
  width: 38px !important;
  height: 38px !important;
  background: linear-gradient(135deg,#0ea5e9,#38bdf8) !important;
  border: 2px solid rgba(255,255,255,.98) !important;
  box-shadow: 0 10px 22px rgba(2,12,24,.22), 0 0 0 2px rgba(255,255,255,.74) !important;
}
body[data-app-mode="client"] .client-direction-arrow-head span {
  font-size: 19px !important;
  font-weight: 950 !important;
}
body[data-app-mode="client"] .client-map-shape,
body[data-app-mode="client"] .simple-map-shape-marker {
  background: linear-gradient(135deg,#0f172a,#0f766e) !important;
}


/* V148: persistent corridor area, green figure dots, no buoy labels */
body[data-app-mode="client"] .client-figure-dot-marker {
  width: 24px !important;
  height: 24px !important;
  border-radius: 999px !important;
  border: 3px solid rgba(255,255,255,.96) !important;
  background: #22c55e !important;
  box-shadow: 0 8px 18px rgba(2,12,24,.22), 0 0 0 2px rgba(255,255,255,.72) !important;
  padding: 0 !important;
}
body[data-app-mode="client"] .client-figure-dot-marker span {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  border-radius: 999px !important;
}
body[data-app-mode="client"] .client-contour-buoy-marker span {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  border-radius: 999px !important;
  font-size: 0 !important;
  line-height: 0 !important;
}


/* V149: вернуть настоящие фигуры + fullscreen radio controls */
body[data-app-mode="client"] .client-map-shape,
body[data-app-mode="client"] .simple-map-shape-marker.client-map-shape {
  width: 44px !important;
  height: 44px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 18px !important;
  border: 2px solid rgba(255,255,255,.96) !important;
  background: linear-gradient(135deg,#062239,#0f766e) !important;
  box-shadow: 0 10px 24px rgba(2,12,24,.28), 0 0 0 2px rgba(255,255,255,.76) !important;
  padding: 0 !important;
}
body[data-app-mode="client"] .client-map-shape.circle { border-radius: 999px !important; }
body[data-app-mode="client"] .client-map-shape.triangle { border-radius: 16px !important; }
body[data-app-mode="client"] .client-map-shape.square { border-radius: 12px !important; }
body[data-app-mode="client"] .client-map-shape span {
  color: #ffffff !important;
  font-size: 24px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
  text-shadow: 0 2px 5px rgba(0,0,0,.28) !important;
}
body[data-app-mode="client"] .client-figure-dot-marker { display: none !important; }

body[data-app-mode="client"] .map-fs-button-radio {
  background: linear-gradient(135deg,#1f2937,#0f766e) !important;
  color: #fff !important;
  border-color: rgba(215,180,106,.35) !important;
}
body[data-app-mode="client"] .client-radio-sheet.hidden { display: none !important; }
body[data-app-mode="client"] .client-radio-sheet {
  position: absolute;
  inset: 0;
  z-index: 2147483081;
  display: grid;
  place-items: end center;
  padding: 16px;
  pointer-events: auto;
}
body[data-app-mode="client"] .client-radio-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(6,24,38,.42);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}
body[data-app-mode="client"] .client-radio-card {
  position: relative;
  z-index: 1;
  width: min(440px, 100%);
  border-radius: 28px;
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(215,180,106,.55);
  box-shadow: 0 28px 90px rgba(0,0,0,.32);
  padding: 18px;
  color: #062239;
}
body[data-app-mode="client"] .client-radio-card h3 { margin: 0 0 6px; font-size: 26px; letter-spacing: -.04em; }
body[data-app-mode="client"] .client-radio-card p { margin: 0 0 12px; color: #64748b; font-size: 14px; line-height: 1.35; }
body[data-app-mode="client"] .client-radio-card strong { display: block; margin: 10px 0 14px; font-size: 18px; color: #062239; }
body[data-app-mode="client"] .client-radio-actions { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 12px; }
body[data-app-mode="client"] .client-radio-actions button {
  min-height: 48px;
  border-radius: 16px;
  border: 1px solid #d7e2ec;
  background: linear-gradient(180deg,#fff,#f8fafc);
  font-weight: 900;
  color: #062239;
}


/* V150: radio disabled, verify figures/arrows/layers on client map */
body[data-app-mode="client"] #fs-radio-button,
body[data-app-mode="client"] .map-fs-button-radio,
body[data-app-mode="client"] .client-radio-sheet,
body[data-app-mode="client"] #client-radio-audio {
  display: none !important;
}

body[data-app-mode="client"] .client-map-shape,
body[data-app-mode="client"] .simple-map-shape-marker.client-map-shape {
  background-image: none !important;
  width: 46px !important;
  height: 46px !important;
  z-index: 30 !important;
}
body[data-app-mode="client"] .client-map-shape.circle { border-radius: 999px !important; }
body[data-app-mode="client"] .client-map-shape.triangle { border-radius: 14px !important; }
body[data-app-mode="client"] .client-map-shape.square { border-radius: 12px !important; }
body[data-app-mode="client"] .client-map-shape span {
  display: block !important;
  color: #ffffff !important;
  font-size: 25px !important;
  line-height: 1 !important;
}
body[data-app-mode="client"] .client-direction-arrow-head {
  z-index: 29 !important;
}
body[data-app-mode="client"] .client-contour-buoy-marker {
  z-index: 28 !important;
}


/* V151: route-map arrow parity on client map */
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker {
  width: 32px !important;
  height: 32px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  pointer-events: none !important;
  z-index: 31 !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner {
  width: 0 !important;
  height: 0 !important;
  border-top: 10px solid transparent !important;
  border-bottom: 10px solid transparent !important;
  border-left: 22px solid #0ea5e9 !important;
  filter: drop-shadow(0 0 2px #fff) drop-shadow(0 4px 8px rgba(15,23,42,.35)) !important;
  transform-origin: center center !important;
}


/* V152: full client layer parity with navigator-route-map */
body[data-app-mode="client"] .navigator-shape-marker.client-route-shape-marker {
  width: 30px !important;
  height: 30px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  pointer-events: auto !important;
  z-index: 32 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  filter: none !important;
}
body[data-app-mode="client"] .navigator-shape-marker.client-route-shape-marker .shape-inner {
  width: 24px !important;
  height: 24px !important;
  box-sizing: border-box !important;
  background: #fff !important;
  border: 3px solid #111827 !important;
  filter: drop-shadow(0 4px 8px rgba(15,23,42,.25)) !important;
}
body[data-app-mode="client"] .navigator-shape-marker.client-route-shape-marker.circle .shape-inner { border-radius: 999px !important; }
body[data-app-mode="client"] .navigator-shape-marker.client-route-shape-marker.square .shape-inner { border-radius: 3px !important; }
body[data-app-mode="client"] .navigator-shape-marker.client-route-shape-marker.triangle .shape-inner {
  width: 0 !important;
  height: 0 !important;
  background: transparent !important;
  border-left: 14px solid transparent !important;
  border-right: 14px solid transparent !important;
  border-top: 25px solid #111827 !important;
  border-bottom: 0 !important;
  position: relative !important;
}
body[data-app-mode="client"] .navigator-shape-marker.client-route-shape-marker.triangle .shape-inner::after {
  content: "" !important;
  position: absolute !important;
  left: -9px !important;
  top: -22px !important;
  width: 0 !important;
  height: 0 !important;
  border-left: 9px solid transparent !important;
  border-right: 9px solid transparent !important;
  border-top: 16px solid #fff !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker {
  width: 32px !important;
  height: 32px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  pointer-events: none !important;
  z-index: 31 !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner {
  width: 0 !important;
  height: 0 !important;
  border-top: 10px solid transparent !important;
  border-bottom: 10px solid transparent !important;
  border-left: 22px solid #0ea5e9 !important;
  filter: drop-shadow(0 0 2px #fff) drop-shadow(0 4px 8px rgba(15,23,42,.35)) !important;
  transform-origin: center center !important;
}


/* V153: buoys like control map, clearer arrows */
body[data-app-mode="client"] .client-contour-buoy-marker {
  display: none !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker {
  width: 44px !important;
  height: 44px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  pointer-events: none !important;
  z-index: 31 !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner {
  width: 44px !important;
  height: 44px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transform-origin: center center !important;
  filter: drop-shadow(0 0 3px rgba(255,255,255,.98)) drop-shadow(0 5px 10px rgba(15,23,42,.32)) !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg {
  width: 38px !important;
  height: 38px !important;
  overflow: visible !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg path {
  fill: none;
  stroke: #0ea5e9;
  stroke-width: 7;
  stroke-linecap: round;
  stroke-linejoin: round;
}


/* V161: stable mobile client layers restore */
body[data-app-mode="client"] .simple-buoy-marker.client-control-buoy-marker { display: none !important; }
body[data-app-mode="client"] .client-contour-buoy-marker { display: none !important; }
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker {
  width: 28px !important;
  height: 28px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  pointer-events: none !important;
  z-index: 35 !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner,
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg {
  width: 26px !important;
  height: 26px !important;
  overflow: visible !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg path {
  fill: none !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg .arrow-halo {
  stroke: rgba(255,255,255,.98) !important;
  stroke-width: 9 !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg .arrow-core {
  stroke: #0ea5e9 !important;
  stroke-width: 5 !important;
}
@media (max-width: 820px) {
  body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker {
    width: 26px !important;
    height: 26px !important;
  }
  body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner,
  body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg {
    width: 24px !important;
    height: 24px !important;
  }
  body[data-app-mode="client"] .client-route-shape-marker {
    width: 32px !important;
    height: 32px !important;
    z-index: 34 !important;
  }
}


/* V162: arrowheads only, no green-red buoy crosslinks */
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker {
  width: 24px !important;
  height: 24px !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner {
  width: 24px !important;
  height: 24px !important;
  filter: drop-shadow(0 0 2px rgba(255,255,255,.98)) drop-shadow(0 2px 6px rgba(15,23,42,.24)) !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg {
  width: 20px !important;
  height: 20px !important;
  overflow: visible !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg .arrow-halo {
  stroke: rgba(255,255,255,.98) !important;
  stroke-width: 8 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
  fill: none !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg .arrow-core {
  stroke: #0ea5e9 !important;
  stroke-width: 4.5 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
  fill: none !important;
}


/* V163: hard cache refresh + block-arrow markers */
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker {
  width: 34px !important;
  height: 20px !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner {
  width: 34px !important;
  height: 20px !important;
  filter: drop-shadow(0 0 2px rgba(255,255,255,.98)) drop-shadow(0 2px 6px rgba(15,23,42,.24)) !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg {
  width: 34px !important;
  height: 20px !important;
  overflow: visible !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg .arrow-halo {
  fill: rgba(255,255,255,.98) !important;
  stroke: none !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg .arrow-core {
  fill: #111111 !important;
  stroke: none !important;
}
@media (max-width: 820px) {
  body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker {
    width: 30px !important;
    height: 18px !important;
  }
  body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner,
  body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg {
    width: 30px !important;
    height: 18px !important;
  }
}


/* V164: remove all old arrows, add black block arrows only */
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker {
  width: 28px !important;
  height: 14px !important;
  z-index: 35 !important;
  pointer-events: none !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner {
  width: 28px !important;
  height: 14px !important;
  transform-origin: center center !important;
  filter: drop-shadow(0 1px 3px rgba(255,255,255,.35)) drop-shadow(0 2px 4px rgba(0,0,0,.25)) !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg {
  width: 28px !important;
  height: 14px !important;
  overflow: visible !important;
}
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg .arrow-core {
  fill: #000000 !important;
  stroke: none !important;
}
@media (max-width: 820px) {
  body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker,
  body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner,
  body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker .arrow-inner svg {
    width: 24px !important;
    height: 12px !important;
  }
}


/* V165: fix invalid filter and prevent old/new arrow overlap */
body[data-app-mode="client"] .navigator-arrow-marker.client-route-arrow-marker {
  display: none !important;
}
body[data-app-mode="client"] .client-black-arrow-v165 {
  width: 30px !important;
  height: 15px !important;
  z-index: 50 !important;
  pointer-events: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
body[data-app-mode="client"] .client-black-arrow-v165 .arrow-inner {
  width: 30px !important;
  height: 15px !important;
  transform-origin: center center !important;
  filter: drop-shadow(0 1px 3px rgba(255,255,255,.35)) drop-shadow(0 2px 4px rgba(0,0,0,.25)) !important;
}
body[data-app-mode="client"] .client-black-arrow-v165 svg {
  width: 30px !important;
  height: 15px !important;
  overflow: visible !important;
}
body[data-app-mode="client"] .client-black-arrow-v165 svg path {
  fill: #000000 !important;
  stroke: none !important;
}
@media (max-width: 820px) {
  body[data-app-mode="client"] .client-black-arrow-v165,
  body[data-app-mode="client"] .client-black-arrow-v165 .arrow-inner,
  body[data-app-mode="client"] .client-black-arrow-v165 svg {
    width: 26px !important;
    height: 13px !important;
  }
}


/* V167: offline area export module */
body[data-app-mode="offline-area-export"] { margin: 0; min-height: 100vh; background: #e2e8f0; color: #0f172a; }
.offline-area-shell { min-height: 100vh; display: grid; grid-template-columns: minmax(310px, 380px) 1fr; }
.offline-area-panel { background: rgba(255,255,255,.96); border-right: 1px solid rgba(15,23,42,.12); padding: 18px; overflow: auto; box-shadow: 10px 0 34px rgba(15,23,42,.08); z-index: 2; }
.offline-area-panel h1 { margin: 0 0 8px; font-size: 28px; line-height: 1.05; }
.offline-area-card { margin-top: 14px; padding: 14px; border: 1px solid rgba(15,23,42,.10); border-radius: 18px; background: #fff; display: grid; gap: 10px; }
.offline-area-card h2 { margin: 0; font-size: 16px; }
.offline-area-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.offline-area-fields label { font-size: 12px; color: #475569; font-weight: 800; }
.offline-area-fields input { width: 100%; box-sizing: border-box; margin-top: 5px; border: 1px solid #cbd5e1; border-radius: 12px; padding: 10px; font: inherit; }
.offline-area-card progress { width: 100%; height: 12px; accent-color: #0f766e; }
.offline-area-open-client { text-align: center; text-decoration: none; }
.warning-card { background: #f8fafc; }
.offline-area-map-wrap { position: relative; min-height: 100vh; }
#offline-area-map { position: absolute; inset: 0; background: #b9d8f3; }
.offline-area-map-badge { position: absolute; left: 16px; top: 16px; z-index: 3; padding: 10px 12px; border-radius: 14px; background: rgba(15,23,42,.82); color: #fff; font-weight: 800; box-shadow: 0 10px 30px rgba(15,23,42,.22); }
@media (max-width: 840px) { .offline-area-shell { grid-template-columns: 1fr; grid-template-rows: auto 62vh; } .offline-area-panel { max-height: 44vh; border-right: 0; border-bottom: 1px solid rgba(15,23,42,.12); } .offline-area-map-wrap { min-height: 62vh; } }
