:root {
  color-scheme: light;
  font-family: "Segoe UI", Arial, sans-serif;
  background: #eef2f6;
  color: #17202a;
  --cama-sidebar-width: 218px;
  --cama-sidebar-collapsed-width: 70px;
}

/* YMIC professional information-center redesign */
:root {
  --ymic-navy: #0b1f33;
  --ymic-blue: #123a5a;
  --ymic-sky: #2b7da8;
  --ymic-bg: #eef3f7;
  --ymic-panel: #ffffff;
  --ymic-line: #d6e0e8;
  --ymic-muted: #607184;
  --ymic-good: #1f8a5b;
  --ymic-warn: #c89122;
  --ymic-bad: #c24135;
  --ymic-none: #81909f;
  --ymic-header-height: 118px;
  --cama-sidebar-width: 260px;
  --cama-sidebar-collapsed-width: 72px;
}

body {
  background: var(--ymic-bg);
  color: #17202a;
  padding-top: var(--ymic-header-height);
}

.ymic-top-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 45;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  height: var(--ymic-header-height);
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
  background:
    radial-gradient(circle at 12% 12%, rgba(142, 221, 235, 0.24), transparent 32%),
    linear-gradient(180deg, #f7fdff 0%, #eaf8fb 100%);
  color: #0b2740;
  padding: 12px 24px;
  box-shadow: 0 8px 22px rgba(20, 123, 154, 0.12);
}

.ymic-header-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  min-width: 0;
  width: 100%;
}

.ymic-header-logo-slot {
  position: absolute;
  left: 24px;
}

.ymic-header-station-slot {
  position: absolute;
  left: 18px;
  bottom: 0;
  display: block;
  width: 190px;
  height: 112px;
  overflow: hidden;
  pointer-events: none;
  filter: drop-shadow(0 8px 16px rgba(22, 75, 94, 0.16));
}

.ymic-header-station-slot img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 38% 56%;
  mix-blend-mode: normal;
  opacity: 1;
}

.ymic-header-logo-slot .cama-logo-wrap {
  width: 82px;
  height: 76px;
}

.ymic-header-logo-slot img {
  max-width: 82px;
  max-height: 76px;
  object-fit: contain;
}

.ymic-header-text {
  display: grid;
  gap: 4px;
  line-height: 1.18;
  min-width: 0;
  text-align: center;
}

.ymic-header-text strong {
  color: #082844;
  font-size: 34px;
  font-weight: 950;
}

.ymic-header-text span,
.ymic-header-text em {
  color: #163448;
  font-size: 17px;
  font-style: normal;
  font-weight: 850;
}

.ymic-header-sector {
  font-size: 15px !important;
  color: #31566a !important;
  font-weight: 800 !important;
}

.ymic-header-main-title {
  letter-spacing: 0 !important;
}

.ymic-header-status {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.ymic-header-status span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.08);
  color: #eef7fb;
  min-height: 34px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 800;
}

.ymic-system-state.online::before,
.ymic-system-state.warning::before,
.ymic-system-state.offline::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--ymic-good);
}

.ymic-system-state.warning::before {
  background: var(--ymic-warn);
}

.ymic-system-state.offline::before {
  background: var(--ymic-bad);
}

.cama-logo-placeholder {
  display: grid;
  place-items: center;
  min-width: 54px;
  min-height: 42px;
  border: 1px dashed rgba(255, 255, 255, 0.45);
  border-radius: 6px;
  color: #f9fafb;
  font-size: 10px;
  font-weight: 800;
  line-height: 1.2;
  padding: 6px;
  text-align: center;
}

.cama-sidebar {
  top: var(--ymic-header-height);
  z-index: 30;
  width: var(--cama-sidebar-width);
  border-right: 1px solid rgba(255, 255, 255, 0.1);
  background: #0a1b2b;
  color: #eef7fb;
  padding: 12px 10px;
  box-shadow: 6px 0 20px rgba(11, 31, 51, 0.14);
}

.cama-sidebar-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.cama-sidebar-toggle,
.cama-mobile-menu-toggle {
  border-color: rgba(255, 255, 255, 0.16);
  background: #123a5a;
  color: #ffffff;
}

.cama-sidebar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.cama-sidebar-logo-slot .cama-logo-wrap {
  display: grid;
  width: 42px;
  height: 38px;
  place-items: center;
}

.cama-logo-sidebar {
  width: 42px;
  max-height: 38px;
}

.cama-sidebar-text strong,
.cama-sidebar-text em {
  color: #eef7fb;
}

.cama-sidebar-text em {
  color: #a8c5d8;
}

.cama-portal-nav {
  display: grid;
  gap: 6px;
}

.cama-portal-group {
  border-radius: 8px;
}

.cama-portal-button,
.cama-portal-links a {
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 38px;
  gap: 10px;
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: #d7e5ef;
  cursor: pointer;
  font: inherit;
  font-size: 13px;
  font-weight: 800;
  padding: 8px;
  text-align: left;
  text-decoration: none;
}

.cama-portal-button:hover,
.cama-portal-links a:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
}

.cama-nav-icon {
  background: rgba(255, 255, 255, 0.09);
  color: #9ed4f1;
  flex: 0 0 28px;
}

.cama-nav-icon.sub {
  background: rgba(43, 125, 168, 0.18);
  color: #cde8f7;
  font-size: 12px;
}

.cama-portal-chevron {
  margin-left: auto;
  transition: transform 160ms ease;
}

.cama-portal-group.open .cama-portal-chevron {
  transform: rotate(90deg);
}

.cama-portal-links {
  display: none;
  gap: 3px;
  padding: 2px 0 4px 12px;
}

.cama-portal-group.open .cama-portal-links {
  display: grid;
}

.sidebar-collapsed .cama-sidebar {
  width: var(--cama-sidebar-collapsed-width) !important;
}

.sidebar-collapsed .cama-sidebar-brand,
.sidebar-collapsed .cama-sidebar-text,
.sidebar-collapsed .cama-nav-label,
.sidebar-collapsed .cama-portal-chevron,
.sidebar-collapsed .cama-portal-links,
.sidebar-collapsed .cama-logo-sidebar {
  display: none;
}

.sidebar-collapsed .cama-sidebar-head,
.sidebar-collapsed .cama-portal-button {
  justify-content: center;
}

.sidebar-collapsed .cama-portal-button {
  padding-inline: 4px;
}

.cama-sidebar-resize {
  background: transparent;
}

.cama-sidebar-resize:hover {
  background: rgba(158, 212, 241, 0.25);
}

.shell {
  width: min(1600px, calc(100vw - var(--cama-sidebar-width) - 48px));
  margin-left: calc(var(--cama-sidebar-width) + 24px);
  margin-right: 24px;
  padding: 20px 0 28px;
}

.analytics-shell,
.wind-rose-shell,
.manager-shell {
  width: calc(100vw - var(--cama-sidebar-width) - 48px);
  max-width: none;
  margin-left: calc(var(--cama-sidebar-width) + 24px);
  margin-right: 24px;
}

.topbar {
  align-items: flex-start;
  margin-bottom: 14px;
}

.topbar h1 {
  color: #122436;
  font-size: 32px;
  letter-spacing: 0;
}

.eyebrow {
  color: var(--ymic-muted);
  font-weight: 900;
  letter-spacing: 0.02em;
}

.top-actions {
  gap: 8px;
}

.button-link,
button {
  border-radius: 6px;
}

.panel,
.metrics article {
  border: 1px solid var(--ymic-line);
  border-radius: 8px;
  background: var(--ymic-panel);
  box-shadow: 0 8px 18px rgba(11, 31, 51, 0.05);
}

.metrics {
  grid-template-columns: repeat(7, minmax(130px, 1fr));
  gap: 10px;
}

.metrics article {
  min-height: 96px;
  padding: 14px;
}

.metrics article span {
  color: var(--ymic-muted);
  font-weight: 800;
}

.metrics article strong {
  color: var(--ymic-navy);
}

.dashboard-layout {
  display: grid;
  grid-template-columns: minmax(520px, 1.45fr) minmax(320px, 0.72fr);
  gap: 12px;
  align-items: stretch;
}

.dashboard-map-panel {
  min-height: 560px;
}

.dashboard-map-panel .map-wrap {
  min-height: 502px;
}

.map-toolbar {
  display: flex;
  gap: 8px;
}

.map-toolbar button {
  min-width: 34px;
  min-height: 30px;
  padding: 4px 8px;
}

.system-side-panel {
  display: grid;
  gap: 12px;
}

.system-health-grid,
.parameter-map-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 14px;
}

.system-health-grid article,
.parameter-map-grid article {
  border: 1px solid var(--ymic-line);
  border-radius: 7px;
  background: #f8fbfd;
  padding: 10px;
}

.system-health-grid span,
.parameter-map-grid span {
  display: block;
  color: var(--ymic-muted);
  font-size: 12px;
  font-weight: 800;
}

.system-health-grid strong,
.parameter-map-grid strong {
  display: block;
  margin-top: 4px;
  color: var(--ymic-navy);
  font-size: 18px;
}

.status-summary-grid {
  padding: 14px;
}

.status-summary-card {
  border-radius: 7px;
}

.map-wrap {
  background: linear-gradient(180deg, #f6fbfe, #e9f1f6);
}

.map-bg {
  fill: #e5f1f7;
}

.yemen-outline {
  fill: #f8fafc;
  stroke: #2b7da8;
  stroke-width: 2.2;
}

.map-marker circle {
  stroke: #ffffff;
  stroke-width: 2;
}

.map-marker.online circle,
.legend-dot.online {
  fill: var(--ymic-good);
}

.map-marker.warning circle,
.legend-dot.warning {
  fill: var(--ymic-warn);
}

.map-marker.offline circle,
.legend-dot.offline {
  fill: var(--ymic-bad);
}

.map-marker.no-data circle,
.legend-dot.no-data,
.map-marker.inactive circle,
.legend-dot.inactive {
  fill: var(--ymic-none);
}

.map-marker text {
  fill: #0b1f33;
  font-size: 13px;
  font-weight: 900;
  paint-order: stroke;
  stroke: #ffffff;
  stroke-width: 3px;
}

.portal-placeholder {
  display: grid;
  min-height: 220px;
  place-items: center;
  border: 1px dashed #9db5c6;
  border-radius: 8px;
  background: #f6fbfe;
  color: #496071;
  font-weight: 900;
  text-align: center;
}

.aviation-dashboard {
  display: grid;
  gap: 12px;
}

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

.aviation-runway-card {
  border-left: 5px solid var(--ymic-sky);
}

.aviation-runway-card.high-risk {
  border-left-color: var(--ymic-bad);
}

.aviation-runway-card.warning {
  border-left-color: var(--ymic-warn);
}

.aviation-metar {
  font-family: Consolas, "Courier New", monospace;
  font-size: 14px;
  font-weight: 700;
  padding: 18px;
}

.metar-line {
  direction: ltr;
  background: #0f172a;
  border-radius: 7px;
  color: #f8fafc;
  font-size: 16px;
  line-height: 1.5;
  padding: 12px;
  white-space: normal;
}

.metar-status-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 10px;
}

.metar-status-grid article {
  border: 1px solid var(--ymic-border);
  border-radius: 7px;
  padding: 8px;
}

.metar-status-grid span,
.metar-note,
.metar-missing {
  color: var(--ymic-muted);
  font-family: Inter, "Segoe UI", sans-serif;
  font-size: 12px;
  font-weight: 700;
}

.metar-status-grid strong {
  color: var(--ymic-text);
  display: block;
  font-family: Inter, "Segoe UI", sans-serif;
  font-size: 13px;
  margin-top: 3px;
}

.metar-note,
.metar-missing {
  margin-top: 9px;
}

.metar-missing {
  color: var(--ymic-warn);
}

.live-aviation-metar-panel {
  overflow: hidden;
}

.live-aviation-metar {
  display: grid;
  gap: 12px;
}

.live-metar-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.live-metar-heading span {
  display: block;
  color: var(--ymic-muted);
  font-size: 12px;
  font-weight: 900;
}

.live-metar-heading strong {
  display: block;
  color: var(--ymic-text);
  font-size: 18px;
  font-weight: 950;
}

.live-metar-heading b {
  border: 1px solid rgba(53, 189, 224, 0.3);
  border-radius: 999px;
  background: rgba(53, 189, 224, 0.12);
  color: #07566d;
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 950;
}

.live-metar-code {
  display: block;
  direction: ltr;
  border: 1px solid rgba(14, 57, 82, 0.2);
  border-radius: 8px;
  background: #071d2a;
  color: #f4fbff;
  padding: 13px;
  font-family: Consolas, "Courier New", monospace;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.55;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.live-metar-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
  gap: 8px;
}

.live-metar-grid article {
  min-width: 0;
  border: 1px solid var(--ymic-border);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.58);
  padding: 10px;
}

.live-metar-grid span {
  display: block;
  color: var(--ymic-muted);
  font-size: 11px;
  font-weight: 850;
}

.live-metar-grid strong {
  display: block;
  margin-top: 4px;
  color: var(--ymic-text);
  font-size: 14px;
  font-weight: 950;
  overflow-wrap: anywhere;
}

.chart-period-warning {
  display: none;
  margin-top: 8px;
  border: 1px solid #f2c56f;
  border-radius: 7px;
  background: #fff8e6;
  color: #7a4b00;
  font-weight: 800;
  padding: 10px 12px;
}

.chart-period-warning.visible {
  display: block;
}

.station-import-layout .portal-form-grid {
  grid-template-columns: repeat(4, minmax(180px, 1fr));
}

@media (max-width: 1180px) {
  .metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .dashboard-layout,
  .aviation-live-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px) {
  body {
    padding-top: calc(var(--ymic-header-height) + 8px);
  }

  .ymic-top-header {
    align-items: center;
    justify-content: center;
    height: auto;
    min-height: var(--ymic-header-height);
    padding-left: 72px;
    padding-right: 16px;
    flex-direction: row;
  }

  .ymic-header-brand {
    justify-content: center;
  }

  .ymic-header-logo-slot {
    left: 12px;
  }

  .ymic-header-text {
    text-align: center;
  }

  .ymic-header-status {
    justify-content: flex-start;
  }

  .cama-sidebar {
    top: 0;
    width: min(84vw, 280px) !important;
  }

  .cama-mobile-menu-toggle {
    display: grid;
  }

  .sidebar-mobile-open .cama-sidebar-overlay {
    display: block;
  }

  .shell,
  .analytics-shell,
  .wind-rose-shell,
  .manager-shell {
    width: min(100% - 20px, 1180px);
    margin: 0 auto;
    padding-top: 18px;
  }

  .metrics,
  .system-health-grid,
  .parameter-map-grid {
    grid-template-columns: 1fr;
  }
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-width: 320px;
  min-height: 100vh;
  background: #eef2f6;
}

.cama-logo {
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
  object-fit: contain;
}

.cama-logo.logo-missing {
  display: none;
}

.cama-header-brand {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  justify-content: flex-start;
  margin-bottom: 12px;
  text-align: left;
}

.cama-logo-header {
  width: 150px;
  height: auto;
  max-height: none;
  flex: 0 0 auto;
  object-fit: contain;
}

.cama-authority {
  display: grid;
  gap: 5px;
  max-width: 440px;
}

.cama-authority strong {
  color: #17202a;
  font-size: 16px;
  line-height: 1.35;
}

.cama-authority span {
  color: #465462;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.3;
  text-align: left;
}

.cama-sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  z-index: 20;
  width: var(--cama-sidebar-width);
  border-right: 1px solid #d8e0e8;
  background: rgba(255, 255, 255, 0.96);
  padding: 12px 10px 18px;
  overflow-y: auto;
  transition: width 160ms ease, transform 160ms ease;
}

.cama-sidebar-toggle,
.cama-mobile-menu-toggle {
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border: 1px solid #cbd6e2;
  border-radius: 7px;
  background: #ffffff;
  color: #17202a;
  cursor: pointer;
  font: 700 22px/1 "Segoe UI", Arial, sans-serif;
}

.cama-sidebar-toggle {
  margin-bottom: 14px;
}

.cama-mobile-menu-toggle {
  display: none;
  position: fixed;
  left: 12px;
  top: 12px;
  z-index: 35;
  box-shadow: 0 8px 24px rgba(23, 32, 42, 0.18);
}

.cama-sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 18;
  border: 0;
  background: rgba(23, 32, 42, 0.42);
  cursor: pointer;
}

.cama-sidebar-brand {
  display: grid;
  gap: 10px;
  color: #17202a;
  text-decoration: none;
}

.cama-logo-sidebar {
  width: 92px;
  max-height: 88px;
}

.cama-sidebar-text {
  display: grid;
  gap: 4px;
}

.cama-sidebar-text strong {
  font-size: 13px;
  line-height: 1.45;
}

.cama-sidebar-text em {
  color: #465462;
  font-size: 12px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.35;
}

.cama-sidebar nav {
  display: grid;
  gap: 6px;
  margin-top: 18px;
}

.cama-sidebar nav a {
  display: flex;
  align-items: center;
  gap: 10px;
  border-radius: 7px;
  color: #25313d;
  font-size: 13px;
  font-weight: 700;
  padding: 8px 9px;
  text-decoration: none;
  min-height: 38px;
}

.cama-sidebar nav a:hover {
  background: #eef4f8;
}

.cama-nav-icon {
  display: grid;
  flex: 0 0 28px;
  width: 28px;
  height: 28px;
  place-items: center;
  border-radius: 6px;
  background: #eef4f8;
  color: #1f6380;
  font-size: 15px;
  font-weight: 900;
}

.cama-nav-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cama-sidebar-resize {
  position: absolute;
  top: 0;
  right: -4px;
  bottom: 0;
  width: 8px;
  cursor: col-resize;
  touch-action: none;
}

.cama-sidebar-resize:hover {
  background: rgba(47, 111, 146, 0.16);
}

.sidebar-resizing {
  cursor: col-resize;
  user-select: none;
}

.sidebar-collapsed .cama-sidebar {
  width: var(--cama-sidebar-collapsed-width) !important;
  padding-inline: 8px;
  overflow-x: visible;
}

.sidebar-collapsed .cama-sidebar-brand {
  justify-items: center;
}

.sidebar-collapsed .cama-sidebar-text,
.sidebar-collapsed .cama-logo-sidebar,
.sidebar-collapsed .cama-nav-label {
  display: none;
}

.sidebar-collapsed .cama-sidebar nav a {
  justify-content: center;
  padding-inline: 4px;
}

.sidebar-collapsed .cama-sidebar-toggle {
  margin-inline: auto;
}

.cama-report-watermark {
  pointer-events: none;
  position: absolute;
  right: 14px;
  bottom: 10px;
  color: rgba(47, 111, 146, 0.12);
  font-size: 12px;
  font-weight: 800;
  max-width: 55%;
  text-align: right;
}

.login-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 28px;
}

.login-panel {
  width: min(460px, 100%);
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #ffffff;
  padding: 26px;
}

.login-brand {
  display: grid;
  gap: 14px;
  justify-items: center;
  margin-bottom: 22px;
  text-align: center;
}

.login-logo {
  width: min(150px, 60vw);
  height: auto;
  max-height: none;
  object-fit: contain;
}

.login-brand strong,
.login-brand span {
  display: block;
  line-height: 1.4;
}

.login-brand strong {
  color: #17202a;
  font-size: 18px;
}

.login-brand span {
  color: #465462;
  font-weight: 700;
}

.login-form {
  display: grid;
  gap: 14px;
}

.login-form label {
  display: grid;
  gap: 6px;
  color: #465462;
  font-weight: 700;
}

.login-form input {
  border: 1px solid #cbd6e2;
  border-radius: 7px;
  color: #17202a;
  font: inherit;
  padding: 10px 12px;
}

.shell {
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
  padding: 28px 0 36px;
}

@media (min-width: 1180px) {
  .shell {
    width: min(1180px, calc(100vw - var(--cama-sidebar-width) - 48px));
    margin-left: calc(var(--cama-sidebar-width) + max(24px, (100vw - var(--cama-sidebar-width) - 1180px) / 2));
    margin-right: 24px;
  }

  .analytics-shell,
  .wind-rose-shell {
    width: calc(100vw - var(--cama-sidebar-width) - 48px);
    margin-left: calc(var(--cama-sidebar-width) + 24px);
    margin-right: 24px;
  }
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 22px;
}

.eyebrow {
  margin: 0 0 4px;
  font-size: 13px;
  color: #586673;
}

h1,
h2 {
  margin: 0;
  letter-spacing: 0;
}

h1 {
  font-size: 34px;
  line-height: 1.1;
}

h2 {
  font-size: 19px;
}

.status {
  min-width: 180px;
  padding: 10px 14px;
  border: 1px solid #bfccd8;
  border-radius: 8px;
  background: #ffffff;
  text-align: center;
  font-weight: 700;
}

.top-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
  max-width: 100%;
}

.status.ok {
  border-color: #4f946a;
  color: #1d6b3a;
  background: #eefaf2;
}

.status.warn {
  border-color: #d29b35;
  color: #7b4c00;
  background: #fff7e6;
}

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

.metrics article,
.panel {
  position: relative;
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #ffffff;
}

.metrics article {
  min-height: 112px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.metrics span,
.panel-head span {
  color: #5c6975;
  font-size: 13px;
}

.metrics strong {
  display: block;
  font-size: 30px;
  line-height: 1.1;
  overflow-wrap: anywhere;
}

.actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 14px 0 20px;
  align-items: center;
}

button {
  border: 1px solid #2f6f92;
  border-radius: 7px;
  background: #2f6f92;
  color: #ffffff;
  font: inherit;
  font-weight: 700;
  padding: 10px 13px;
  cursor: pointer;
}

.button-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 41px;
  border: 1px solid #2f6f92;
  border-radius: 7px;
  background: #2f6f92;
  color: #ffffff;
  font-weight: 700;
  padding: 10px 13px;
  text-decoration: none;
}

.button-link.secondary {
  border-color: #728191;
  background: #ffffff;
  color: #25313d;
}

button:hover {
  background: #255a78;
}

button:disabled {
  cursor: wait;
  opacity: 0.68;
}

.unit-control {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 41px;
  border: 1px solid #cbd6e2;
  border-radius: 7px;
  background: #ffffff;
  color: #33404d;
  font-weight: 700;
  padding: 8px 10px;
}

.unit-control select {
  border: 1px solid #cbd6e2;
  border-radius: 6px;
  background: #ffffff;
  color: #17202a;
  font: inherit;
  padding: 5px 8px;
}

.panel {
  margin-top: 14px;
  overflow: hidden;
}

.aviation-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(140px, 1fr));
  gap: 10px;
  padding: 16px;
}

.aviation-grid article {
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #f8fafc;
  padding: 12px;
}

.aviation-grid span {
  display: block;
  margin-bottom: 6px;
  color: #5c6975;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.aviation-grid strong {
  display: block;
  color: #17202a;
  font-size: 18px;
  line-height: 1.2;
}

.report-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(160px, 1fr));
  gap: 10px;
  padding: 16px;
}

.report-grid article {
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #f8fafc;
  padding: 12px;
}

.report-grid span {
  display: block;
  margin-bottom: 6px;
  color: #5c6975;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.report-grid strong {
  display: block;
  color: #17202a;
  font-size: 20px;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.report-table {
  max-width: 620px;
  margin: 0 16px 16px;
}

.qc-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding: 0 16px 16px;
  color: #33404d;
}

.qc-summary strong,
.qc-summary span {
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #ffffff;
  padding: 8px 10px;
}

.info-center-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(320px, 0.65fr);
  gap: 14px;
  margin-top: 14px;
}

.info-center-grid .panel {
  margin-top: 0;
}

.map-wrap {
  padding: 16px;
}

#yemenMap {
  display: block;
  width: 100%;
  min-height: 360px;
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #f8fafc;
}

.map-bg {
  fill: #eef5f8;
}

.yemen-outline {
  fill: #e1e8dc;
  stroke: #798b75;
  stroke-width: 2;
}

.map-marker circle {
  stroke: #ffffff;
  stroke-width: 2;
}

.map-marker.active circle {
  fill: #2f6f92;
}

.map-marker.inactive circle {
  fill: #9aa7b4;
}

.map-marker text {
  fill: #1f2a35;
  font-size: 13px;
  font-weight: 800;
  paint-order: stroke;
  stroke: #ffffff;
  stroke-width: 3px;
}

.map-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 10px;
  color: #53616e;
  font-size: 12px;
  font-weight: 700;
}

.legend-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-right: 6px;
  border-radius: 50%;
}

.legend-dot.active {
  background: #2f6f92;
}

.legend-dot.inactive {
  background: #9aa7b4;
}

.status-summary-grid {
  display: grid;
  gap: 10px;
  padding: 16px;
}

.status-summary-card {
  display: grid;
  gap: 7px;
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #f8fafc;
  padding: 12px;
}

.status-summary-card span {
  color: #465462;
  font-weight: 700;
}

.detail-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
}

.explorer-controls {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 10px;
  align-items: end;
  padding: 14px 16px;
}

.explorer-controls label {
  display: grid;
  gap: 6px;
  color: #465462;
  font-weight: 700;
}

.explorer-controls input,
.explorer-controls select {
  width: 100%;
  min-height: 40px;
  border: 1px solid #cbd6e2;
  border-radius: 7px;
  background: #ffffff;
  color: #17202a;
  font: inherit;
  padding: 8px 10px;
}

.explorer-controls button {
  min-height: 40px;
}

.explorer-table-wrap {
  max-height: 560px;
  overflow: auto;
}

.explorer-table-wrap th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: #f3f7fa;
}

.pager {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  padding: 12px 16px 16px;
}

.pager span {
  color: #465462;
  font-weight: 700;
}

.detail-controls label {
  color: #465462;
  font-weight: 700;
}

.detail-controls select {
  min-width: min(420px, 100%);
  border: 1px solid #cbd6e2;
  border-radius: 7px;
  background: #ffffff;
  color: #17202a;
  font: inherit;
  padding: 8px 10px;
}

.station-detail-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.station-detail-tabs button {
  border: 1px solid rgba(67, 147, 174, 0.28);
  border-radius: 8px;
  background: rgba(232, 247, 252, 0.78);
  color: #244f63;
  cursor: pointer;
  font-size: 14px;
  font-weight: 900;
  padding: 11px 16px;
}

.station-detail-tabs button.active {
  border-color: #d6b75b;
  background: linear-gradient(135deg, rgba(255, 249, 220, 0.96), rgba(222, 246, 252, 0.94));
  box-shadow: 0 10px 22px rgba(34, 87, 110, 0.12);
  color: #123447;
}

.station-detail-tabs button[hidden],
.microstep-panel[hidden] {
  display: none;
}

.microstep-panel {
  display: grid;
  gap: 16px;
}

.microstep-status-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.microstep-layout {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(280px, 0.8fr);
  gap: 14px;
}

.microstep-card {
  border: 1px solid rgba(99, 156, 177, 0.25);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 14px 28px rgba(26, 78, 96, 0.08);
  padding: 16px;
}

.microstep-card h3 {
  margin: 0 0 12px;
  color: #173f55;
  font-size: 18px;
  font-weight: 950;
}

.check-row {
  align-items: center;
  display: flex !important;
  flex-direction: row !important;
  gap: 10px;
  min-height: 44px;
}

.check-row input {
  width: auto !important;
}

.safety-list {
  display: grid;
  gap: 8px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.safety-list li {
  border: 1px solid rgba(216, 183, 91, 0.38);
  border-radius: 8px;
  background: rgba(255, 249, 220, 0.76);
  color: #37505d;
  font-size: 13px;
  font-weight: 850;
  padding: 10px 12px;
}

.microstep-file-row {
  cursor: pointer;
}

.microstep-file-row.active {
  background: rgba(223, 247, 242, 0.9);
}

.mapping-grid select {
  min-width: 160px;
}

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

.metadata-grid div {
  min-height: 68px;
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #f8fafc;
  padding: 10px 12px;
}

.metadata-grid span {
  display: block;
  margin-bottom: 6px;
  color: #5c6975;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.metadata-grid strong {
  display: block;
  color: #17202a;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.station-kpi-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

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

.runway-live-grid div {
  min-height: 74px;
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #f8fafc;
  padding: 10px 12px;
}

.runway-live-grid span {
  display: block;
  margin-bottom: 6px;
  color: #5c6975;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.runway-live-grid strong {
  display: block;
  color: #17202a;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.live-metar-runway-panel {
  border-color: rgba(245, 217, 103, 0.34) !important;
}

.live-metar-runway-summary {
  display: grid;
  grid-template-columns: minmax(260px, 1.6fr) repeat(3, minmax(160px, 1fr));
  gap: 10px;
  padding: 14px;
}

.live-metar-runway-summary article {
  border: 1px solid rgba(87, 178, 204, 0.26);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.62);
  padding: 12px;
}

.live-metar-runway-summary span {
  display: block;
  color: var(--ymic-muted);
  font-size: 12px;
  font-weight: 850;
  margin-bottom: 6px;
}

.live-metar-runway-summary strong,
.live-metar-runway-summary code {
  color: var(--ymic-navy);
  font-size: 15px;
  font-weight: 900;
}

.live-metar-runway-summary code {
  display: block;
  direction: ltr;
  font-family: Consolas, "Courier New", monospace;
  line-height: 1.45;
  white-space: normal;
}

.risk-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  border-radius: 999px;
  border: 1px solid rgba(45, 79, 96, 0.18);
  box-shadow: 0 8px 18px rgba(21, 56, 74, 0.08);
  color: #123447;
  font-size: 12.5px;
  font-weight: 950;
  letter-spacing: 0;
  line-height: 1.15;
  padding: 6px 11px;
  text-transform: uppercase;
}

.risk-normal {
  background: #dff7f2;
  border-color: #7fc9bc;
  color: #14524b;
}

.risk-caution {
  background: #fff3cf;
  border-color: #e2bd55;
  color: #704c00;
}

.risk-warning {
  background: #ffe5d3;
  border-color: #eba36d;
  color: #7a330d;
}

.risk-moderate-risk {
  background: #ffe1e7;
  border-color: #e996a5;
  color: #8b1d35;
}

.risk-gust-risk {
  background: #e8edff;
  border-color: #9aaee8;
  color: #253f88;
}

.risk-high-risk {
  background: #f7d7dc;
  border-color: #d56f80;
  color: #71192c;
}

.safer-runway-result {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
}

.safer-runway-result strong {
  min-width: 120px;
  border-radius: 8px;
  background: #eaf5ef;
  color: #1d6b3a;
  font-size: 24px;
  padding: 12px 14px;
  text-align: center;
}

.safer-runway-result span {
  color: #33404d;
  font-weight: 700;
}

.risk-grid {
  max-height: 280px;
  overflow: auto;
  padding: 10px;
}

.risk-grid td span {
  display: inline-flex;
  min-width: 58px;
  justify-content: center;
  border: 1px solid rgba(28, 72, 92, 0.14);
  border-radius: 6px;
  color: #123447;
  font-size: 12px;
  font-weight: 900;
  padding: 4px 7px;
}

.analytics-shell {
  width: min(1480px, calc(100% - 32px));
}

@media (min-width: 1180px) {
  .analytics-shell {
    width: min(1480px, calc(100vw - 266px));
  }
}

.analytics-metrics {
  grid-template-columns: 1.1fr 2fr 1fr 1fr;
}

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

.kpi-panel {
  margin-top: 0;
}

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

.mini-stats div {
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #f8fafc;
  padding: 12px;
}

.mini-stats span {
  display: block;
  margin-bottom: 6px;
  color: #5c6975;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.mini-stats strong {
  display: block;
  font-size: 20px;
  line-height: 1.2;
}

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

.chart-box {
  min-height: 280px;
  padding: 12px;
}

.chart-box svg {
  display: block;
  width: 100%;
  height: auto;
}

.chart-box .axis {
  stroke: #94a3b8;
  stroke-width: 1;
}

.chart-box .chart-label {
  fill: #53616e;
  font-size: 11px;
}

.chart-box .bar {
  fill: #2f6f92;
}

.chart-stats {
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.chart-stats strong {
  font-size: 24px;
}

.analytics-chart-grid {
  align-items: stretch;
}

.chart-card {
  overflow: hidden;
}

.chart-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.chart-actions button {
  min-height: 32px;
  padding: 6px 9px;
  font-size: 12px;
}

.svg-chart {
  min-height: 310px;
  padding: 12px;
  overflow-x: auto;
}

.svg-chart svg,
.exportable-chart {
  display: block;
  width: 100%;
  height: auto;
}

.svg-chart .exportable-chart {
  min-width: 640px;
}

.wind-rose-chart .exportable-chart {
  min-width: 360px;
}

.axis {
  stroke: #94a3b8;
  stroke-width: 1;
}

.chart-label {
  fill: #53616e;
  font-size: 11px;
}

.compact-rose .wind-rose-svg {
  max-width: 440px;
}

.hidden {
  display: none !important;
}

.wind-rose-shell {
  width: min(1520px, calc(100% - 32px));
}

.wind-rose-controls {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) repeat(3, 120px) auto auto;
  gap: 10px;
  align-items: end;
  padding: 16px;
}

.wind-rose-controls label {
  display: grid;
  gap: 5px;
  color: #53616e;
  font-size: 12px;
  font-weight: 700;
}

.wind-rose-controls select {
  width: 100%;
  border: 1px solid #cbd6e2;
  border-radius: 6px;
  background: #ffffff;
  color: #17202a;
  font: inherit;
  padding: 9px;
}

.wind-rose-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 14px;
}

.wind-rose-grid .panel {
  margin-top: 0;
}

.rose-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 12px 16px 0;
  color: #53616e;
  font-size: 12px;
  font-weight: 700;
}

.rose-meta span {
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #f8fafc;
  padding: 6px 8px;
}

.wind-rose-chart {
  padding: 12px;
}

.wind-rose-svg {
  display: block;
  width: 100%;
  max-width: 560px;
  margin: 0 auto;
}

.rose-ring {
  fill: none;
  stroke: #d8e0e8;
  stroke-width: 1;
}

.rose-spoke {
  stroke: #edf1f5;
  stroke-width: 1;
}

.rose-label {
  fill: #33404d;
  font-size: 12px;
  font-weight: 700;
}

.rose-ring-label,
.rose-legend {
  fill: #53616e;
  font-size: 11px;
  font-weight: 700;
}

.panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 16px;
  border-bottom: 1px solid #e4ebf1;
}

.table-wrap {
  overflow-x: auto;
}

table {
  width: 100%;
  border-collapse: collapse;
}

th,
td {
  padding: 12px 16px;
  border-bottom: 1px solid #edf1f5;
  text-align: left;
  white-space: nowrap;
}

th {
  font-size: 12px;
  color: #667381;
  text-transform: uppercase;
}

.warnings-list {
  display: grid;
  gap: 10px;
  padding: 16px;
}

.warning-item {
  display: grid;
  grid-template-columns: 160px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 11px 12px;
  border: 1px solid #f0d39b;
  border-radius: 8px;
  background: #fffaf0;
}

.warning-item strong {
  color: #7b4c00;
}

.warning-item.info {
  border-color: #bfd4e6;
  background: #f3f8fc;
}

.warning-item.info strong {
  color: #255a78;
}

.empty {
  padding: 16px;
  color: #64717e;
}

.status-pill {
  display: inline-flex;
  min-width: 116px;
  justify-content: center;
  padding: 5px 9px;
  border: 1px solid #cfd9e3;
  border-radius: 999px;
  background: #f8fafc;
  color: #33404d;
  font-size: 12px;
  font-weight: 700;
}

.manager-shell {
  width: min(1540px, calc(100% - 32px));
}

.manager-grid {
  display: grid;
  gap: 14px;
}

.editable-table th,
.editable-table td {
  padding: 10px;
  vertical-align: top;
}

.editable-table input,
.editable-table select {
  width: 100%;
  min-width: 116px;
  border: 1px solid #cbd6e2;
  border-radius: 6px;
  background: #ffffff;
  color: #17202a;
  font: inherit;
  padding: 8px;
}

.editable-table input.small {
  min-width: 88px;
}

.editable-table input.folder {
  min-width: 190px;
}

.editable-table button {
  min-width: 76px;
}

.editable-table .readonly-cell {
  min-width: 120px;
  color: #33404d;
  font-weight: 700;
}

.manager-message {
  min-height: 24px;
  color: #44515f;
  font-weight: 700;
}

.stations-portal-shell {
  display: grid;
  gap: 14px;
}

.stations-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(300px, 0.75fr);
  gap: 18px;
  align-items: stretch;
  overflow: hidden;
  padding: 22px;
  background:
    radial-gradient(circle at 12% 12%, rgba(94, 207, 226, 0.22), transparent 34%),
    linear-gradient(135deg, rgba(246, 253, 255, 0.98), rgba(226, 246, 251, 0.96));
}

.stations-hero-kicker {
  display: inline-flex;
  margin-bottom: 8px;
  color: #2d6e86;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.stations-hero h2 {
  color: #0d354b;
  font-size: clamp(28px, 4vw, 46px);
  font-weight: 950;
}

.stations-hero p {
  max-width: 760px;
  margin: 10px 0 0;
  color: #496577;
  font-size: 15px;
  font-weight: 750;
  line-height: 1.7;
}

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

.stations-hero-counts article {
  display: grid;
  align-content: center;
  min-height: 118px;
  border: 1px solid rgba(72, 164, 195, 0.24);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.72);
  padding: 14px;
}

.stations-hero-counts span,
.station-directory-card dt {
  color: #5c7180;
  font-size: 12px;
  font-weight: 850;
}

.stations-hero-counts strong {
  color: #123c52;
  font-size: 34px;
  font-weight: 950;
}

.stations-directory {
  overflow: hidden;
}

.station-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
  gap: 12px;
  padding: 16px;
}

.station-directory-card {
  display: grid;
  gap: 12px;
  min-width: 0;
  border: 1px solid rgba(91, 168, 194, 0.24);
  border-left: 5px solid #7aaec2;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.82);
  padding: 16px;
  box-shadow: 0 12px 24px rgba(23, 91, 116, 0.08);
}

body.ymic-lang-ar .station-directory-card {
  border-right: 5px solid #7aaec2;
  border-left-width: 1px;
}

.station-directory-card.online {
  border-left-color: #2b9a70;
}

.station-directory-card.delayed {
  border-left-color: #d3ad4b;
}

.station-directory-card.offline {
  border-left-color: #8b98a5;
}

.station-directory-card.maintenance {
  border-left-color: #4f85b5;
}

body.ymic-lang-ar .station-directory-card.online {
  border-right-color: #2b9a70;
}

body.ymic-lang-ar .station-directory-card.delayed {
  border-right-color: #d3ad4b;
}

body.ymic-lang-ar .station-directory-card.offline {
  border-right-color: #8b98a5;
}

body.ymic-lang-ar .station-directory-card.maintenance {
  border-right-color: #4f85b5;
}

.station-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.station-code,
.station-status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 950;
}

.station-code {
  background: rgba(30, 118, 150, 0.12);
  color: #14536d;
}

.station-status-pill {
  border: 1px solid #cfdce4;
  background: #f5fafc;
  color: #4d5d68;
}

.station-status-pill.online {
  border-color: rgba(43, 154, 112, 0.24);
  background: rgba(43, 154, 112, 0.1);
  color: #1f7857;
}

.station-status-pill.delayed {
  border-color: rgba(211, 173, 75, 0.34);
  background: rgba(255, 247, 222, 0.86);
  color: #826111;
}

.station-directory-card h3 {
  margin: 0;
  color: #12394f;
  font-size: 22px;
  font-weight: 950;
}

.station-directory-card p {
  margin: -4px 0 0;
  color: #5f7280;
  font-weight: 800;
}

.station-directory-card dl {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
}

.station-directory-card dl div {
  min-width: 0;
  border: 1px solid rgba(90, 148, 168, 0.18);
  border-radius: 8px;
  background: rgba(244, 250, 252, 0.82);
  padding: 9px;
}

.station-directory-card dd {
  margin: 4px 0 0;
  color: #18364a;
  font-weight: 950;
  overflow-wrap: anywhere;
}

.station-module-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.station-module-chips span {
  border: 1px solid rgba(90, 148, 168, 0.18);
  border-radius: 999px;
  background: rgba(236, 249, 253, 0.74);
  color: #326278;
  padding: 5px 8px;
  font-size: 11px;
  font-weight: 850;
}

.station-open-link {
  justify-content: center;
  width: 100%;
}

.station-module-panel {
  display: grid;
  gap: 14px;
  padding: 16px;
}

.station-module-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.station-module-heading span {
  color: #39738c;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.station-module-heading h2 {
  color: #12394f;
  font-size: 24px;
  font-weight: 950;
}

.station-module-heading p {
  max-width: 520px;
  margin: 0;
  color: #5c7180;
  font-weight: 800;
  line-height: 1.5;
}

.station-module-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 10px;
}

.station-module-metrics article {
  min-height: 86px;
  border: 1px solid rgba(91, 168, 194, 0.2);
  border-radius: 9px;
  background: rgba(247, 252, 254, 0.9);
  padding: 12px;
}

.station-module-metrics span {
  display: block;
  color: #607584;
  font-size: 12px;
  font-weight: 850;
}

.station-module-metrics strong {
  display: block;
  margin-top: 6px;
  color: #15374a;
  font-size: 18px;
  font-weight: 950;
  overflow-wrap: anywhere;
}

.station-module-table table {
  min-width: 520px;
}

.station-module-table th {
  width: 220px;
  color: #607584;
  text-align: start;
}

.station-module-note {
  margin: 0;
  border: 1px solid rgba(211, 173, 75, 0.28);
  border-radius: 8px;
  background: rgba(255, 249, 225, 0.76);
  color: #435b68;
  padding: 11px 12px;
  font-weight: 800;
}

.station-report-actions {
  justify-content: flex-start;
}

.awos-shell {
  display: grid;
  gap: 14px;
  color: #e9f8ff;
}

.awos-shell::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 14% 14%, rgba(55, 188, 214, 0.24), transparent 34%),
    linear-gradient(135deg, #071927 0%, #0b2a3d 52%, #06121d 100%);
}

.awos-top-panel,
.awos-metar-panel,
.awos-card,
.awos-entry-panel {
  border: 1px solid rgba(132, 215, 235, 0.22);
  border-radius: 10px;
  background: rgba(5, 22, 34, 0.86);
  box-shadow: 0 18px 36px rgba(0, 11, 20, 0.24);
}

.awos-top-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(420px, 0.9fr);
  gap: 18px;
  align-items: stretch;
  padding: 18px;
}

.awos-top-panel .eyebrow {
  color: #8be6f7;
}

.awos-top-panel h1 {
  color: #ffffff;
  font-size: clamp(32px, 4vw, 54px);
  font-weight: 950;
}

.awos-subtitle {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.awos-subtitle span,
.awos-profile-tabs a {
  border: 1px solid rgba(139, 230, 247, 0.18);
  border-radius: 999px;
  background: rgba(139, 230, 247, 0.08);
  color: #c8f4ff;
  padding: 7px 11px;
  font-size: 12px;
  font-weight: 950;
}

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

.awos-header-clock article {
  display: grid;
  align-content: center;
  border: 1px solid rgba(139, 230, 247, 0.16);
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.07);
  padding: 12px;
}

.awos-header-clock span,
.awos-card span,
.awos-text-readout span {
  color: #9bbccd;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.awos-header-clock strong {
  margin-top: 5px;
  color: #ffffff;
  font-size: 17px;
  font-weight: 950;
  overflow-wrap: anywhere;
}

.awos-mode-card strong {
  color: #f5d967;
}

.station-profile-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.station-profile-tabs a {
  text-decoration: none;
}

.station-profile-tabs a.active,
.awos-profile-tabs a.active {
  border-color: rgba(245, 217, 103, 0.72);
  background: rgba(245, 217, 103, 0.16);
  color: #fff2a8;
}

.awos-metar-panel {
  padding: 16px;
}

.awos-metar-panel .panel-head h2 {
  color: #ffffff;
}

.awos-metar-panel .panel-head span {
  color: #f5d967;
  font-weight: 950;
}

.awos-metar-panel code {
  display: block;
  direction: ltr;
  margin-top: 12px;
  border: 1px solid rgba(245, 217, 103, 0.22);
  border-radius: 9px;
  background: #020914;
  color: #ffffff;
  padding: 18px;
  font-family: Consolas, "Courier New", monospace;
  font-size: clamp(20px, 2.8vw, 36px);
  font-weight: 950;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

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

.awos-card {
  display: grid;
  gap: 14px;
  min-width: 0;
  padding: 16px;
}

.awos-card h2 {
  color: #ffffff;
  font-size: 22px;
}

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

.awos-card select,
.awos-form-grid input,
.awos-form-grid select,
.awos-form-grid textarea,
.awos-component-grid select {
  width: 100%;
  border: 1px solid rgba(139, 230, 247, 0.22);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
  font: inherit;
  font-weight: 850;
  padding: 9px 10px;
}

.awos-card option,
.awos-form-grid option {
  background: #0b2638;
  color: #ffffff;
}

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

.awos-wind-display {
  display: grid;
  grid-template-columns: minmax(240px, 0.85fr) minmax(260px, 1fr);
  gap: 14px;
  align-items: center;
}

.awos-wind-card {
  background:
    radial-gradient(circle at 22% 18%, rgba(89, 213, 230, 0.18), transparent 34%),
    linear-gradient(135deg, rgba(5, 35, 52, 0.94), rgba(4, 20, 34, 0.9)) !important;
}

.awos-compass {
  --compass-degree-radius: 88px;
  position: relative;
  display: grid;
  width: min(100%, 320px);
  aspect-ratio: 1;
  place-items: center;
  justify-self: center;
  border: 2px solid rgba(111, 220, 236, 0.34);
  border-radius: 999px;
  background:
    radial-gradient(circle at 50% 50%, rgba(210, 244, 250, 0.1) 0 23%, transparent 24%),
    radial-gradient(circle at 45% 35%, rgba(83, 205, 224, 0.18), transparent 38%),
    radial-gradient(circle at 50% 50%, rgba(19, 99, 128, 0.28), rgba(5, 24, 38, 0.92) 68%),
    conic-gradient(from 0deg, rgba(111, 220, 236, 0.22) 0 1deg, transparent 1deg 29deg, rgba(111, 220, 236, 0.22) 30deg 31deg, transparent 31deg 59deg, rgba(111, 220, 236, 0.22) 60deg 61deg, transparent 61deg 89deg, rgba(111, 220, 236, 0.5) 90deg 91deg, transparent 91deg 119deg, rgba(111, 220, 236, 0.22) 120deg 121deg, transparent 121deg 149deg, rgba(111, 220, 236, 0.22) 150deg 151deg, transparent 151deg 179deg, rgba(111, 220, 236, 0.5) 180deg 181deg, transparent 181deg 209deg, rgba(111, 220, 236, 0.22) 210deg 211deg, transparent 211deg 239deg, rgba(111, 220, 236, 0.22) 240deg 241deg, transparent 241deg 269deg, rgba(111, 220, 236, 0.5) 270deg 271deg, transparent 271deg 299deg, rgba(111, 220, 236, 0.22) 300deg 301deg, transparent 301deg 329deg, rgba(111, 220, 236, 0.22) 330deg 331deg, transparent 331deg 360deg);
  box-shadow:
    inset 0 0 34px rgba(111, 220, 236, 0.12),
    0 18px 34px rgba(0, 9, 18, 0.26);
}

.awos-compass::before {
  content: "";
  position: absolute;
  inset: 13%;
  border: 1px solid rgba(111, 220, 236, 0.2);
  border-radius: inherit;
}

.compass-label {
  position: absolute;
  color: #d7f8ff;
  font-size: 20px;
  font-weight: 950;
  line-height: 1;
  text-shadow: 0 0 12px rgba(139, 230, 247, 0.24);
}

.compass-label.north {
  top: 13px;
  color: #f1d36b;
}

.compass-label.east {
  right: 15px;
}

.compass-label.south {
  bottom: 13px;
}

.compass-label.west {
  left: 15px;
}

.compass-degree-ring {
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: inherit;
  pointer-events: none;
}

.compass-degree {
  position: absolute;
  left: 50%;
  top: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  min-height: 18px;
  border: 1px solid rgba(111, 220, 236, 0.12);
  border-radius: 999px;
  background: rgba(4, 24, 38, 0.18);
  color: rgba(226, 249, 253, 0.68);
  font-family: Consolas, "Courier New", monospace;
  font-size: 10px;
  font-weight: 950;
  line-height: 1;
  opacity: 0.72;
  transform:
    translate(-50%, -50%)
    rotate(var(--angle))
    translateY(calc(var(--compass-degree-radius) * -1))
    rotate(calc(var(--angle) * -1));
}

.compass-tick {
  position: absolute;
  width: 2px;
  height: 18px;
  border-radius: 999px;
  background: rgba(111, 220, 236, 0.46);
  transform-origin: center calc(50% + 128px);
}

.tick-ne { transform: rotate(45deg) translateY(-128px); }
.tick-se { transform: rotate(135deg) translateY(-128px); }
.tick-sw { transform: rotate(225deg) translateY(-128px); }
.tick-nw { transform: rotate(315deg) translateY(-128px); }

.compass-needle {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 2;
  width: 0;
  height: 38%;
  transform-origin: 50% 100%;
  transition: transform 220ms ease;
}

.compass-needle::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 18px;
  height: 100%;
  transform: translateX(-50%);
  clip-path: polygon(50% 0, 100% 72%, 58% 66%, 58% 100%, 42% 100%, 42% 66%, 0 72%);
  background: linear-gradient(180deg, #f1d36b, #d99f27);
  filter: drop-shadow(0 8px 12px rgba(0, 0, 0, 0.26));
}

.compass-needle.empty {
  opacity: 0.28;
}

.compass-center {
  position: relative;
  z-index: 3;
  display: grid;
  width: 38%;
  aspect-ratio: 1;
  place-items: center;
  border: 1px solid rgba(111, 220, 236, 0.28);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(7, 40, 58, 0.96), rgba(3, 18, 31, 0.96));
  color: #ffffff;
  box-shadow: 0 0 0 8px rgba(3, 16, 27, 0.42);
}

.compass-center strong {
  color: #ffffff;
  font-family: Consolas, "Courier New", monospace;
  font-size: clamp(28px, 4.6vw, 52px);
  font-weight: 950;
  line-height: 0.95;
}

.compass-center em {
  color: #f1d36b;
  font-style: normal;
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}

.awos-compass.calm .compass-center {
  border-color: rgba(139, 230, 247, 0.28);
}

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

.awos-wind-readouts article {
  min-width: 0;
  border: 1px solid rgba(111, 220, 236, 0.18);
  border-radius: 9px;
  background: linear-gradient(180deg, rgba(213, 247, 252, 0.08), rgba(5, 31, 48, 0.16));
  padding: 12px;
}

.awos-wind-readouts span {
  display: block;
  color: #9fd4df;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.awos-wind-readouts strong {
  display: block;
  margin-top: 5px;
  color: #f3fcff;
  font-family: Consolas, "Courier New", monospace;
  font-size: clamp(25px, 3vw, 42px);
  font-weight: 950;
  line-height: 1;
}

.awos-wind-readouts em {
  color: #f1d36b;
  font-style: normal;
  font-size: 14px;
}

.awos-big-pair div,
.awos-component-grid article,
.awos-text-readout article {
  min-width: 0;
  border: 1px solid rgba(139, 230, 247, 0.15);
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.06);
  padding: 12px;
}

.awos-big-pair strong {
  display: block;
  margin-top: 4px;
  color: #ffffff;
  font-family: Consolas, "Courier New", monospace;
  font-size: clamp(36px, 5vw, 72px);
  font-weight: 950;
  line-height: 1;
}

.awos-big-pair em,
.awos-component-grid em {
  color: #f5d967;
  font-style: normal;
  font-weight: 950;
}

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

.awos-component-grid strong,
.awos-text-readout strong {
  display: block;
  margin-top: 5px;
  color: #ffffff;
  font-size: 22px;
  font-weight: 950;
  overflow-wrap: anywhere;
}

.awos-text-readout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.awos-entry-panel {
  padding: 16px;
}

.awos-entry-panel .panel-head h2,
.awos-entry-panel .panel-head span {
  color: #ffffff;
}

.awos-form-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(160px, 1fr));
  gap: 10px;
}

.awos-form-grid label {
  display: grid;
  gap: 6px;
  color: #a8c9d8;
  font-size: 12px;
  font-weight: 900;
}

.awos-form-grid .wide {
  grid-column: 1 / -1;
}

.awos-entry-panel .button-row {
  margin-top: 12px;
}

@media (max-width: 900px) {
  .stations-hero {
    grid-template-columns: 1fr;
    padding: 16px;
  }

  .stations-hero-counts {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .station-card-grid {
    grid-template-columns: 1fr;
    padding: 12px;
  }

  .station-module-heading {
    display: grid;
  }

  .awos-top-panel,
  .awos-display-grid,
  .awos-wind-display {
    grid-template-columns: 1fr;
  }

  .awos-header-clock,
  .awos-component-grid,
  .awos-wind-readouts,
  .awos-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .stations-hero-counts,
  .station-directory-card dl,
  .awos-header-clock,
  .awos-big-pair,
  .awos-component-grid,
  .awos-wind-readouts,
  .awos-text-readout,
  .awos-form-grid {
    grid-template-columns: 1fr;
  }

  .awos-compass {
    width: min(100%, 260px);
  }

  .stations-hero-counts article {
    min-height: 82px;
  }

  .station-detail-tabs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .station-detail-tabs button {
    min-width: 0;
    padding-inline: 8px;
    font-size: 12px;
  }
}

.source-controls {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto auto;
  gap: 10px;
  align-items: center;
  padding: 16px;
}

.source-controls input,
.mapping-grid input,
.mapping-grid select,
.column-grid select {
  width: 100%;
  border: 1px solid #cbd6e2;
  border-radius: 6px;
  background: #ffffff;
  color: #17202a;
  font: inherit;
  padding: 9px;
}

.source-table td {
  white-space: normal;
}

.path-cell {
  min-width: 360px;
  max-width: 620px;
  overflow-wrap: anywhere;
  font-size: 12px;
}

.wizard {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  padding: 16px;
  border-bottom: 1px solid #e4ebf1;
}

.wizard-step {
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #f8fafc;
  padding: 12px;
}

.wizard-step strong {
  display: block;
  margin-bottom: 4px;
}

.progress-wrap {
  padding: 16px;
}

.progress-bar {
  width: 100%;
  height: 16px;
  overflow: hidden;
  border: 1px solid #c8d4df;
  border-radius: 999px;
  background: #eef2f6;
}

.progress-fill {
  height: 100%;
  width: 0%;
  background: #2f6f92;
  transition: width 180ms ease;
}

.stats-line {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 10px;
  color: #43505d;
  font-weight: 700;
}

.preview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
  gap: 14px;
  margin-top: 14px;
}

.preview-table-wrap {
  max-height: 380px;
  overflow: auto;
}

.preview-table th,
.preview-table td {
  font-size: 12px;
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.column-grid {
  display: grid;
  gap: 10px;
  padding: 16px;
}

.column-grid label,
.mapping-grid label {
  display: grid;
  gap: 5px;
  color: #53616e;
  font-size: 12px;
  font-weight: 700;
}

.mapping-grid {
  display: grid;
  grid-template-columns: 180px minmax(260px, 1fr) 140px auto;
  gap: 10px;
  align-items: end;
  padding: 16px;
}

.portal-form-grid,
.upload-strip,
.sync-grid {
  display: grid;
  gap: 10px;
  padding: 16px;
}

.portal-form-grid {
  grid-template-columns: repeat(4, minmax(160px, 1fr));
}

.portal-form-grid label,
.upload-strip label {
  display: grid;
  gap: 5px;
  color: #53616e;
  font-size: 12px;
  font-weight: 700;
}

.portal-form-grid .wide {
  grid-column: span 2;
}

.portal-form-grid input,
.portal-form-grid select,
.upload-strip input {
  width: 100%;
  border: 1px solid #cbd6e2;
  border-radius: 6px;
  background: #ffffff;
  color: #17202a;
  font: inherit;
  padding: 9px;
}

.button-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  padding: 0 16px 16px;
}

.button-row select {
  min-width: 280px;
  border: 1px solid #cbd6e2;
  border-radius: 6px;
  background: #ffffff;
  color: #17202a;
  font: inherit;
  padding: 9px;
}

.upload-strip {
  grid-template-columns: minmax(280px, 1fr) repeat(4, auto);
  align-items: center;
}

.sync-grid {
  grid-template-columns: repeat(6, minmax(120px, 1fr));
}

.selected-row {
  background: #eef7fb;
}

.link-button {
  border: 0;
  background: transparent;
  color: #1f6380;
  font: inherit;
  font-weight: 800;
  padding: 0;
  text-align: left;
}

.bid-preview {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 0.7fr);
  gap: 14px;
  margin-top: 14px;
}

.pre-box {
  max-height: 360px;
  overflow: auto;
  margin: 0;
  padding: 14px;
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #f8fafc;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  font: 12px Consolas, "Courier New", monospace;
}

.arabic-doc {
  direction: rtl;
  text-align: right;
  line-height: 1.8;
}

.arabic-doc ol {
  margin: 0;
  padding-right: 22px;
}

@media (max-width: 820px) {
  .microstep-layout,
  .microstep-status-grid {
    grid-template-columns: 1fr;
  }

  .station-detail-tabs button {
    flex: 1 1 220px;
  }

  .cama-sidebar {
    position: fixed;
    width: min(82vw, 280px) !important;
    transform: translateX(-105%);
    border-right: 0;
    border-bottom: 0;
    box-shadow: 12px 0 28px rgba(23, 32, 42, 0.18);
  }

  .sidebar-mobile-open .cama-sidebar {
    transform: translateX(0);
  }

  .cama-mobile-menu-toggle {
    display: grid;
  }

  .sidebar-mobile-open .cama-sidebar-overlay {
    display: block;
  }

  .cama-sidebar-resize {
    display: none;
  }

  .sidebar-collapsed .cama-sidebar-text,
  .sidebar-collapsed .cama-logo-sidebar,
  .sidebar-collapsed .cama-nav-label {
    display: grid;
  }

  .sidebar-collapsed .cama-logo-sidebar {
    display: block;
  }

  .sidebar-collapsed .cama-sidebar nav a,
  .cama-sidebar nav a {
    justify-content: flex-start;
    padding-inline: 9px;
  }

  .cama-sidebar nav {
    grid-template-columns: 1fr;
  }

  .shell,
  .analytics-shell,
  .wind-rose-shell {
    width: min(100% - 20px, 1180px);
    margin: 0 auto;
    padding-top: 68px;
  }

  .cama-header-brand {
    align-items: flex-start;
  }

  .topbar {
    align-items: flex-start;
    flex-direction: column;
  }

  .top-actions {
    align-items: flex-start;
    flex-direction: column;
    width: 100%;
  }

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

  .warning-item {
    grid-template-columns: 1fr;
  }

  .source-controls,
  .mapping-grid,
  .portal-form-grid,
  .upload-strip,
  .sync-grid,
  .preview-grid,
  .bid-preview,
  .wizard,
  .aviation-grid,
  .report-grid,
  .analytics-metrics,
  .analytics-kpi-grid,
  .chart-grid,
  .mini-stats,
  .wind-rose-controls,
  .wind-rose-grid,
  .info-center-grid,
  .metadata-grid,
  .station-kpi-grid,
  .runway-live-grid {
    grid-template-columns: 1fr;
  }

  .detail-controls {
    align-items: stretch;
    flex-direction: column;
  }

  .explorer-controls {
    grid-template-columns: 1fr;
  }

  .safer-runway-result {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 520px) {
  .shell {
    width: min(100% - 20px, 1180px);
    padding-top: 68px;
  }

  h1 {
    font-size: 28px;
  }

  .metrics {
    grid-template-columns: 1fr;
  }

  .actions button {
    width: 100%;
  }

  .cama-sidebar nav {
    grid-template-columns: 1fr;
  }
}

/* Final YMIC UI V1 overrides: keep these last. */
body {
  background: var(--ymic-bg);
  padding-top: var(--ymic-header-height);
}

.ymic-top-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 45;
}

.cama-sidebar {
  top: var(--ymic-header-height);
  width: var(--cama-sidebar-width);
  background: #0a1b2b;
  color: #eef7fb;
}

.cama-sidebar nav {
  display: block;
}

.cama-portal-nav {
  display: grid !important;
}

.shell,
.analytics-shell,
.wind-rose-shell,
.manager-shell {
  width: calc(100vw - var(--cama-sidebar-width) - 48px);
  max-width: none;
  margin-left: calc(var(--cama-sidebar-width) + 24px);
  margin-right: 24px;
}

.dashboard-kpis {
  grid-template-columns: repeat(7, minmax(130px, 1fr));
}

.dashboard-layout {
  display: grid;
  grid-template-columns: minmax(520px, 1.45fr) minmax(320px, 0.72fr);
  gap: 12px;
}

.dashboard-map-panel .map-wrap {
  min-height: 500px;
}

.system-side-panel {
  display: grid;
  gap: 12px;
}

.sidebar-collapsed .cama-sidebar {
  width: var(--cama-sidebar-collapsed-width) !important;
}

.sidebar-collapsed .shell,
.sidebar-collapsed .analytics-shell,
.sidebar-collapsed .wind-rose-shell,
.sidebar-collapsed .manager-shell {
  width: calc(100vw - var(--cama-sidebar-collapsed-width) - 48px);
  margin-left: calc(var(--cama-sidebar-collapsed-width) + 24px);
}

.sidebar-collapsed .cama-sidebar-brand,
.sidebar-collapsed .cama-sidebar-text,
.sidebar-collapsed .cama-nav-label,
.sidebar-collapsed .cama-portal-chevron,
.sidebar-collapsed .cama-portal-links,
.sidebar-collapsed .cama-logo-sidebar {
  display: none !important;
}

.ymic-header-logo-slot .cama-logo-wrap {
  width: 150px !important;
  height: auto !important;
}

.ymic-header-logo-slot .cama-logo-header {
  width: 150px !important;
  max-width: 150px !important;
  height: auto !important;
  max-height: 58px !important;
  object-fit: contain !important;
}

.sidebar-collapsed .cama-sidebar-head,
.sidebar-collapsed .cama-portal-button {
  justify-content: center;
}

.chart-box,
.svg-chart {
  background: #f8fbfd;
  border-radius: 7px;
}

@media (max-width: 1180px) {
  .dashboard-kpis {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .dashboard-layout,
  .aviation-live-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px) {
  .ymic-top-header {
    height: auto;
    min-height: var(--ymic-header-height);
    padding-left: 62px;
  }

  .cama-sidebar {
    top: 0;
    transform: translateX(-105%);
    width: min(84vw, 280px) !important;
  }

  .sidebar-mobile-open .cama-sidebar {
    transform: translateX(0);
  }

  .shell,
  .analytics-shell,
  .wind-rose-shell,
  .manager-shell,
  .sidebar-collapsed .shell,
  .sidebar-collapsed .analytics-shell,
  .sidebar-collapsed .wind-rose-shell,
  .sidebar-collapsed .manager-shell {
    width: min(100% - 20px, 1180px);
    margin: 0 auto;
    padding-top: 18px;
  }

  .dashboard-kpis,
  .system-health-grid,
  .parameter-map-grid {
    grid-template-columns: 1fr;
  }
}
/* Minimal Professional Dashboard layout. Keep this block last. */
.minimal-dashboard > .topbar {
  display: none !important;
}

.minimal-dashboard {
  max-width: none;
  min-width: 0;
  overflow-x: hidden;
}

.minimal-dashboard .dashboard-kpis {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 14px;
}

.minimal-dashboard .dashboard-kpis article {
  min-height: 94px;
  padding: 14px;
}

.minimal-dashboard .dashboard-kpis strong {
  font-size: 24px;
}

.minimal-dashboard .dashboard-map-only {
  display: grid;
  grid-template-columns: 1fr;
}

.minimal-dashboard .dashboard-map-panel {
  min-height: 460px;
}

.minimal-dashboard .dashboard-map-panel .map-wrap {
  min-height: 390px;
  overflow: hidden;
}

.minimal-dashboard .satellite-map-wrap {
  position: relative;
  padding: 0;
  background: #111b1f;
}

.minimal-dashboard .windy-map-wrap {
  padding: 0;
  background: #101820;
}

.windy-live-frame {
  display: block;
  width: 100%;
  min-height: 560px;
  border: 0;
  border-radius: 8px;
  background: #101820;
}

.windy-model.active {
  border-color: #123a5a;
  background: #123a5a;
  color: #ffffff;
}

.map-toolbar select {
  min-height: 30px;
  border: 1px solid #cbd6e2;
  border-radius: 6px;
  background: #ffffff;
  color: #17202a;
  padding: 4px 8px;
  font-size: 12px;
  font-weight: 800;
}

.legend-dot.windy {
  background: #d94f45;
}

.live-airport-weather-panel {
  margin-top: 14px;
}

.airport-weather-showcase {
  margin: 14px;
  padding: 14px;
  border-radius: 8px;
  background: linear-gradient(180deg, #06285a 0%, #082655 52%, #041b3b 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 18px 34px rgba(3, 22, 51, 0.18);
  color: #f8fbff;
}

.airport-selector-head {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-bottom: 10px;
  color: #e7c75b;
  font-size: 15px;
  font-weight: 900;
}

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

.airport-tabs button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-height: 48px;
  border: 1px solid rgba(151, 187, 225, 0.22);
  border-radius: 8px;
  background: rgba(29, 67, 119, 0.82);
  color: #c9d8ef;
  box-shadow: none;
  font-size: 14px;
}

.airport-tabs button::after {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(222, 232, 247, 0.35);
}

.airport-tabs button span {
  font-weight: 900;
}

.airport-tabs button small {
  color: #d7e2f1;
  font-size: 12px;
  font-weight: 800;
}

.airport-tabs button.active {
  border-color: #d5bd57;
  background: rgba(44, 76, 114, 0.94);
  color: #f6d765;
  box-shadow: inset 0 -4px 0 rgba(213, 189, 87, 0.55), 0 8px 20px rgba(0, 0, 0, 0.14);
}

.featured-airport-card {
  position: relative;
  overflow: hidden;
  min-height: 520px;
  border: 1px solid rgba(184, 214, 247, 0.14);
  border-radius: 8px;
  background:
    radial-gradient(circle at 20% 18%, rgba(78, 116, 165, 0.34), transparent 34%),
    linear-gradient(150deg, rgba(43, 72, 112, 0.96), rgba(20, 49, 88, 0.96) 58%, rgba(13, 38, 74, 0.98));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 18px 38px rgba(0, 0, 0, 0.22);
  padding: 28px 32px;
}

.featured-airport-card::before {
  content: "";
  position: absolute;
  inset: 16px;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  pointer-events: none;
}

.featured-loading {
  display: grid;
  min-height: 250px;
  place-items: center;
  color: #d7e2f1;
  font-weight: 900;
}

.featured-airport-top {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: start;
  gap: 18px;
}

.featured-flag {
  display: grid;
  width: 62px;
  height: 62px;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  background: rgba(47, 77, 120, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  font-size: 24px;
}

.featured-airport-top small {
  display: block;
  color: #94a9c6;
  font-family: Consolas, "Courier New", monospace;
  font-size: 16px;
  font-weight: 800;
}

.featured-airport-top strong {
  display: block;
  margin-top: 8px;
  color: #ffffff;
  font-size: 54px;
  font-weight: 400;
  line-height: 1;
}

.featured-airport-top em {
  display: block;
  margin-top: 8px;
  color: #a7b7cd;
  font-family: Consolas, "Courier New", monospace;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
}

.featured-airport-top b {
  border-radius: 8px;
  background: #ffb11f;
  color: #22324e;
  padding: 8px 14px;
  font-size: 15px;
  font-weight: 900;
}

.featured-metar-bulletin {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  gap: 6px;
  max-width: 720px;
  margin: 24px auto 0;
  border: 1px solid rgba(126, 185, 235, 0.28);
  border-radius: 8px;
  background: rgba(7, 32, 70, 0.45);
  padding: 10px 14px;
  text-align: center;
}

.featured-metar-bulletin span {
  color: #e7c75b;
  font-size: 12px;
  font-weight: 900;
}

.featured-metar-bulletin code {
  color: #eef7ff;
  font-family: Consolas, "Courier New", monospace;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.35;
  overflow-wrap: anywhere;
  white-space: normal;
}

.featured-airport-main {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 24px;
  margin-top: 58px;
}

.featured-condition strong {
  display: block;
  max-width: 360px;
  color: #e5eefc;
  font-size: 32px;
  font-weight: 600;
  line-height: 1.45;
}

.featured-condition span {
  display: block;
  margin-top: 12px;
  max-width: 300px;
  color: #9fb1c9;
  font-family: Consolas, "Courier New", monospace;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.25;
}

.featured-temp {
  display: flex;
  align-items: flex-end;
  color: #ffffff;
}

.featured-temp-current {
  display: inline-flex;
  align-items: flex-end;
}

.featured-temp strong {
  font-size: 112px;
  font-weight: 300;
  line-height: 0.9;
}

.featured-temp span {
  margin: 0 8px 8px 0;
  color: #e7c75b;
  font-size: 48px;
  font-weight: 500;
}

.featured-feels-like {
  display: grid;
  gap: 3px;
  margin: 0 14px 10px 0;
  text-align: right;
}

.featured-feels-like span {
  margin: 0 !important;
  color: #bdd4df !important;
  font-size: 13px !important;
  font-weight: 850 !important;
}

.featured-feels-like strong {
  color: #e7c75b !important;
  font-size: 20px !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
}

.featured-sun {
  position: relative;
  z-index: 1;
  display: grid;
  width: 150px;
  height: 150px;
  place-items: center;
  margin: 60px auto 34px;
  border-radius: 999px;
  background: rgba(71, 103, 149, 0.42);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 12px 30px rgba(0, 0, 0, 0.18);
}

.featured-sun span {
  position: relative;
  width: 46px;
  height: 46px;
  border: 9px solid #ffbc1f;
  border-radius: 999px;
}

.featured-sun span::before,
.featured-sun span::after {
  content: "";
  position: absolute;
  inset: -36px;
  background:
    linear-gradient(#ffbc1f, #ffbc1f) 50% 0 / 8px 22px no-repeat,
    linear-gradient(#ffbc1f, #ffbc1f) 50% 100% / 8px 22px no-repeat,
    linear-gradient(90deg, #ffbc1f, #ffbc1f) 0 50% / 22px 8px no-repeat,
    linear-gradient(90deg, #ffbc1f, #ffbc1f) 100% 50% / 22px 8px no-repeat;
}

.featured-sun span::after {
  transform: rotate(45deg);
}

.featured-airport-metrics {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  border: 1px solid rgba(95, 139, 196, 0.3);
  border-radius: 8px;
  background: rgba(16, 52, 102, 0.54);
  padding: 14px;
}

.featured-airport-metrics div {
  min-width: 0;
}

.featured-airport-metrics span {
  display: block;
  color: #91a5bf;
  font-size: 12px;
  font-weight: 800;
}

.featured-airport-metrics strong {
  display: block;
  margin-top: 5px;
  color: #e9f1fd;
  font-size: 14px;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.featured-airport-card.vfr .featured-airport-metrics div:first-child strong {
  color: #27d597;
}

.featured-airport-card.mvfr .featured-airport-metrics div:first-child strong {
  color: #6ed6ff;
}

.featured-airport-card.ifr .featured-airport-metrics div:first-child strong,
.featured-airport-card.lifr .featured-airport-metrics div:first-child strong {
  color: #ff9c9c;
}

.live-airport-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  padding: 14px;
}

.live-airport-card {
  display: grid;
  gap: 10px;
  border: 1px solid #d8e0e8;
  border-left: 5px solid #7d8995;
  border-radius: 8px;
  background: #ffffff;
  padding: 12px;
}

.live-airport-card.vfr {
  border-left-color: #168a50;
}

.live-airport-card.mvfr {
  border-left-color: #2b7da8;
}

.live-airport-card.ifr {
  border-left-color: #c24135;
}

.live-airport-card.lifr {
  border-left-color: #7f1d1d;
}

.live-airport-card span,
.live-airport-card dt {
  color: #607184;
  font-size: 12px;
  font-weight: 800;
}

.live-airport-card strong {
  display: block;
  margin-top: 3px;
  color: #17202a;
  font-size: 15px;
}

.live-airport-card b {
  justify-self: start;
  border-radius: 999px;
  background: #eef4f8;
  color: #17202a;
  padding: 4px 9px;
  font-size: 12px;
}

.live-airport-card.vfr b {
  background: #e7f6ec;
  color: #146b40;
}

.live-airport-card.mvfr b {
  background: #e7f3fa;
  color: #1d668b;
}

.live-airport-card.ifr b,
.live-airport-card.lifr b {
  background: #fff1f1;
  color: #a83232;
}

.live-airport-card dl {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
}

.live-airport-card div {
  min-width: 0;
}

.live-airport-card dd {
  margin: 2px 0 0;
  color: #17202a;
  font-size: 13px;
  font-weight: 800;
  overflow-wrap: anywhere;
}

.live-airport-table-wrap {
  padding: 0 14px 14px;
}

.live-airport-table-wrap code {
  white-space: normal;
  color: #17202a;
  font-family: Consolas, "Courier New", monospace;
  font-size: 12px;
}

.yemen-satellite-map {
  position: relative;
  width: 100%;
  min-height: 500px;
  overflow: hidden;
  border: 1px solid #cbd5df;
  border-radius: 8px;
  background: #152026;
  isolation: isolate;
}

.satellite-tile-layer,
.satellite-marker-layer,
.satellite-vignette,
.satellite-country-outline {
  position: absolute;
  inset: 0;
}

.satellite-tile {
  position: absolute;
  width: 256px;
  height: 256px;
  object-fit: cover;
  filter: saturate(1.08) contrast(1.05);
  user-select: none;
}

.satellite-country-outline {
  z-index: 2;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.satellite-country-outline path {
  fill: rgba(46, 125, 80, 0.12);
  stroke: rgba(255, 255, 255, 0.9);
  stroke-width: 2.2;
  paint-order: stroke;
}

.satellite-vignette {
  z-index: 3;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(8, 18, 22, 0.05), rgba(8, 18, 22, 0.22)),
    inset 0 0 0 999px rgba(0, 0, 0, 0);
  box-shadow: inset 0 0 90px rgba(0, 0, 0, 0.32);
}

.satellite-marker-layer {
  z-index: 4;
}

.satellite-station-marker {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  height: 28px;
  border: 2px solid #ffffff;
  border-radius: 999px;
  color: #ffffff;
  padding: 0 8px;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
  transform: translate(-50%, -50%);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.32);
  cursor: pointer;
}

.satellite-station-marker.online {
  background: #168a50;
}

.satellite-station-marker.warning {
  background: #c89122;
}

.satellite-station-marker.offline {
  background: #b63b3b;
}

.satellite-station-marker.no-data {
  background: #61707f;
}

.satellite-station-marker:focus-visible,
.satellite-station-marker:hover {
  outline: 3px solid rgba(255, 255, 255, 0.45);
  z-index: 6;
}

.satellite-attribution {
  position: absolute;
  right: 10px;
  bottom: 8px;
  z-index: 5;
  border-radius: 5px;
  background: rgba(8, 18, 22, 0.7);
  color: #ffffff;
  padding: 4px 7px;
  font-size: 11px;
  font-weight: 700;
}

.legend-dot.satellite {
  background: #345d3b;
}

.minimal-dashboard .yemen-stations-map-image {
  display: block;
  width: 100%;
  height: auto;
  max-height: 620px;
  object-fit: contain;
  border: 1px solid #cbd5df;
  border-radius: 8px;
  background: #ffffff;
  transition: transform 160ms ease;
}

.minimal-dashboard .map-symbol {
  display: inline-block;
  width: 12px;
  height: 12px;
  margin-right: 5px;
  border: 1px solid #1f2a35;
  vertical-align: -1px;
}

.minimal-dashboard .map-symbol.airport {
  background: #168da0;
}

.minimal-dashboard .map-symbol.lucost {
  background: #f4d6d6;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.minimal-dashboard .map-symbol.met {
  border-radius: 50%;
  background: #2aa845;
}

.heat-index-shell .heat-index-kpis {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.heat-index-shell .heat-explanation {
  display: grid;
  gap: 10px;
  padding: 16px;
  color: #253444;
  line-height: 1.65;
}

.heat-index-shell .heat-explanation p {
  margin: 0;
}

.heat-index-shell .heat-explanation ul {
  margin: 0;
  padding-left: 20px;
}

.heat-risk-pill {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  border-radius: 999px;
  padding: 3px 10px;
  color: #ffffff;
  font-weight: 900;
}

@media (max-width: 1180px) {
  .heat-index-shell .heat-index-kpis {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .heat-index-shell .heat-index-kpis {
    grid-template-columns: 1fr;
  }
}

.minimal-dashboard .dashboard-bottom-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.minimal-dashboard .aviation-grid.compact,
.minimal-dashboard .system-health-grid.compact,
.minimal-dashboard .runway-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.minimal-dashboard .aviation-grid.compact article,
.minimal-dashboard .system-health-grid.compact article,
.minimal-dashboard .runway-summary-grid article {
  min-height: 74px;
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #f8fafc;
  padding: 12px;
}

.minimal-dashboard .runway-summary-grid article.safer {
  grid-column: 1 / -1;
  background: #edf7f0;
}

.minimal-dashboard .runway-summary-grid article.warn {
  border-color: #f2c46d;
  background: #fff8e8;
}

.minimal-dashboard .runway-summary-grid article.high {
  border-color: #e27b7b;
  background: #fff1f1;
}

.minimal-dashboard .runway-summary-grid article.ok {
  border-color: #a8d5b5;
}

.minimal-dashboard .runway-summary-grid span,
.minimal-dashboard .runway-summary-grid small {
  display: block;
  color: #5c6975;
  font-size: 12px;
  font-weight: 800;
}

.minimal-dashboard .runway-summary-grid strong {
  display: block;
  margin: 4px 0;
  color: #17202a;
  font-size: 18px;
}

.minimal-dashboard .cama-report-watermark {
  display: none;
}

.cama-portal-nav {
  gap: 4px !important;
}

.cama-portal-group {
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  padding-bottom: 4px;
}

.cama-portal-button {
  min-height: 42px !important;
}

.cama-portal-links {
  padding-left: 8px !important;
}

.cama-portal-links a {
  color: #d8e7f3 !important;
  opacity: 1 !important;
}

.cama-sidebar-text em {
  display: none;
}

.cama-sidebar {
  overflow-x: hidden !important;
}

.cama-sidebar .cama-logo-placeholder {
  width: 42px !important;
  min-width: 42px !important;
  max-width: 42px !important;
  min-height: 34px !important;
  overflow: hidden;
  font-size: 0 !important;
}

.cama-sidebar .cama-logo-placeholder::after {
  content: "CAMA";
  font-size: 10px;
}

html,
body {
  overflow-x: hidden;
}

@media (max-width: 1180px) {
  .minimal-dashboard .dashboard-kpis,
  .minimal-dashboard .dashboard-bottom-grid,
  .live-airport-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .minimal-dashboard .dashboard-kpis,
  .minimal-dashboard .dashboard-bottom-grid,
  .minimal-dashboard .aviation-grid.compact,
  .minimal-dashboard .system-health-grid.compact,
  .minimal-dashboard .runway-summary-grid,
  .live-airport-grid,
  .live-airport-card dl {
    grid-template-columns: 1fr;
  }
}

.dashboard-commandbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
  border: 1px solid #d6e0e8;
  border-left: 5px solid #2b7da8;
  border-radius: 8px;
  background: #ffffff;
  padding: 16px 18px;
  box-shadow: 0 10px 24px rgba(11, 31, 51, 0.08);
}

.dashboard-commandbar h1 {
  margin: 2px 0 4px;
  color: #10283d;
  font-size: 26px;
  line-height: 1.15;
  letter-spacing: 0;
}

.dashboard-commandbar span {
  color: #607184;
  font-size: 13px;
  font-weight: 700;
}

.dashboard-command-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

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

.portal-strip a {
  display: grid;
  gap: 4px;
  min-height: 86px;
  border: 1px solid #d6e0e8;
  border-radius: 8px;
  background: #ffffff;
  color: #17202a;
  padding: 14px;
  text-decoration: none;
}

.portal-strip a:hover {
  border-color: #8dbed8;
  box-shadow: 0 8px 18px rgba(43, 125, 168, 0.13);
}

.portal-strip span {
  color: #123a5a;
  font-size: 14px;
  font-weight: 900;
}

.portal-strip strong {
  color: #607184;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.35;
}

.latest-bulletins-widget {
  display: grid;
  gap: 14px;
  margin: 18px 0 22px;
  border: 1px solid rgba(87, 178, 204, 0.28);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.58);
  box-shadow: 0 16px 34px rgba(20, 123, 154, 0.1);
  padding: 18px;
}

.latest-bulletins-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.latest-bulletins-head span {
  color: #5c7b86;
  font-size: 12px;
  font-weight: 950;
}

.latest-bulletins-head h2 {
  margin: 2px 0 0;
  color: #0d4254;
  font-size: 22px;
  font-weight: 950;
}

.latest-bulletins-head a {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  border: 1px solid rgba(201, 168, 50, 0.42);
  border-radius: 999px;
  background: rgba(255, 250, 224, 0.74);
  color: #07566d;
  padding: 8px 14px;
  font-size: 12px;
  font-weight: 950;
  text-decoration: none;
}

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

.latest-bulletins-list a,
.latest-bulletins-list article {
  display: grid;
  align-content: start;
  gap: 7px;
  min-height: 128px;
  border: 1px solid rgba(87, 178, 204, 0.22);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.68);
  color: #0d4254;
  padding: 13px;
  text-decoration: none;
}

.latest-bulletins-list span {
  justify-self: start;
  border-radius: 999px;
  background: rgba(224, 247, 251, 0.9);
  color: #087b9a;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 950;
}

.latest-bulletins-list strong {
  color: #0d4254;
  font-size: 13px;
  font-weight: 950;
  line-height: 1.45;
}

.latest-bulletins-list small {
  color: #5c7b86;
  font-size: 11px;
  font-weight: 800;
}

.minimal-dashboard .dashboard-bottom-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

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

.thermal-metric-grid article {
  min-height: 82px;
  border: 1px solid #d8e0e8;
  border-radius: 8px;
  background: #f8fafc;
  padding: 12px;
}

.thermal-metric-grid article.thermal-primary {
  grid-column: 1 / -1;
  border-left-width: 5px;
  background: #ffffff;
}

.thermal-metric-grid span,
.thermal-metric-grid small {
  display: block;
  color: #607184;
  font-size: 12px;
  font-weight: 800;
}

.thermal-metric-grid strong {
  display: block;
  margin: 5px 0;
  color: #17202a;
  font-size: 22px;
  font-weight: 900;
}

.alert-stack {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.alert-item {
  border: 1px solid #e8d096;
  border-left: 5px solid #c89122;
  border-radius: 8px;
  background: #fff8e8;
  padding: 10px 12px;
}

.alert-item.danger {
  border-color: #e8aaaa;
  border-left-color: #c24135;
  background: #fff1f1;
}

.alert-item.ok {
  border-color: #b8dbc5;
  border-left-color: #1f8a5b;
  background: #edf7f0;
}

.alert-item.info {
  border-color: #acd3e6;
  border-left-color: #2b7da8;
  background: #eff8fc;
}

.alert-item strong,
.alert-item span,
.alert-item small {
  display: block;
}

.alert-item strong {
  color: #17202a;
  font-size: 13px;
}

.alert-item span,
.alert-item small {
  color: #607184;
  font-size: 12px;
  font-weight: 700;
  margin-top: 3px;
}

.cama-sidebar-resize {
  width: 9px !important;
  cursor: ew-resize;
}

.cama-sidebar-resize::after {
  content: "";
  display: block;
  width: 3px;
  height: 42px;
  margin: 45vh auto 0;
  border-radius: 999px;
  background: rgba(158, 212, 241, 0.35);
}

@media print {
  body {
    padding-top: 0;
    background: #ffffff;
  }

  .ymic-top-header,
  .cama-sidebar,
  .cama-sidebar-overlay,
  .cama-mobile-menu-toggle,
  .dashboard-command-actions {
    display: none !important;
  }

  .shell,
  .minimal-dashboard,
  .sidebar-collapsed .shell {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .panel,
  .metrics article,
  .portal-strip a,
  .dashboard-commandbar {
    break-inside: avoid;
    box-shadow: none !important;
    background: #ffffff !important;
  }
}

@media (max-width: 1180px) {
  .portal-strip,
  .minimal-dashboard .dashboard-bottom-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dashboard-commandbar {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 720px) {
  .portal-strip,
  .thermal-metric-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-commandbar h1 {
    font-size: 22px;
  }
}

@media (max-width: 820px) {
  body:not(.sidebar-mobile-open) .cama-sidebar {
    display: none !important;
  }

  .sidebar-mobile-open .cama-sidebar {
    display: block !important;
  }

  .shell,
  .analytics-shell,
  .wind-rose-shell,
  .manager-shell,
  .sidebar-collapsed .shell,
  .sidebar-collapsed .analytics-shell,
  .sidebar-collapsed .wind-rose-shell,
  .sidebar-collapsed .manager-shell {
    width: calc(100vw - 36px) !important;
    margin-left: 18px !important;
    margin-right: 18px !important;
  }

  .panel-head,
  .map-toolbar,
  .dashboard-command-actions {
    align-items: flex-start;
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .minimal-dashboard .aviation-grid.compact,
  .minimal-dashboard .system-health-grid.compact,
  .minimal-dashboard .runway-summary-grid,
  .minimal-dashboard .dashboard-kpis,
  .minimal-dashboard .dashboard-bottom-grid {
    grid-template-columns: 1fr !important;
  }

  .minimal-dashboard .aviation-grid.compact article,
  .minimal-dashboard .system-health-grid.compact article,
  .minimal-dashboard .runway-summary-grid article,
  .thermal-metric-grid article {
    min-width: 0;
    width: auto;
  }

  .minimal-dashboard strong,
  .minimal-dashboard span,
  .minimal-dashboard small {
    overflow-wrap: anywhere;
  }

  .ymic-top-header {
    gap: 8px;
    padding-right: 10px !important;
  }

  .ymic-header-logo-slot .cama-logo-wrap,
  .ymic-header-logo-slot .cama-logo-header {
    width: 56px !important;
    max-width: 56px !important;
    max-height: 42px !important;
  }

  .ymic-header-brand {
    max-width: calc(100vw - 88px);
    min-width: 0;
  }

  .ymic-header-text {
    min-width: 0;
  }

  .ymic-header-text strong,
  .ymic-header-text span {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .ymic-header-status {
    display: none;
  }
}

/* Light sky visual theme override. Keep this block last. */
:root {
  --ymic-navy: #07566d;
  --ymic-blue: #0ea5c6;
  --ymic-sky: #38bdf8;
  --ymic-bg: #f1fbff;
  --ymic-panel: #ffffff;
  --ymic-line: #b9e7f7;
  --ymic-muted: #557080;
}

body {
  background: #f1fbff !important;
  color: #143241;
}

.ymic-top-header {
  border-bottom-color: #a7dff3 !important;
  background: linear-gradient(90deg, #e7fbff 0%, #c7f0ff 48%, #b8eaff 100%) !important;
  color: #07566d !important;
  box-shadow: 0 8px 22px rgba(14, 165, 198, 0.16);
}

.ymic-header-text strong,
.ymic-header-text span,
.ymic-header-text em,
.ymic-header-status span,
.ymic-system-state {
  color: #07566d !important;
}

.cama-sidebar {
  border-right-color: #b9e7f7 !important;
  background: #e9faff !important;
  color: #07566d !important;
}

.cama-sidebar-toggle,
.cama-mobile-menu-toggle,
.button-link,
button,
.windy-model.active {
  border-color: #7dd3fc !important;
  background: #b8eaff !important;
  color: #07566d !important;
}

.cama-portal-button,
.cama-portal-links a,
.cama-sidebar-brand,
.cama-sidebar-text strong,
.cama-sidebar-text em {
  color: #07566d !important;
}

.cama-portal-button:hover,
.cama-portal-links a:hover,
.portal-strip a:hover {
  border-color: #7dd3fc !important;
  background: #dff6ff !important;
  color: #064e63 !important;
}

.cama-nav-icon,
.cama-nav-icon.sub {
  background: #d1f3ff !important;
  color: #08799b !important;
}

.dashboard-commandbar {
  border-color: #b9e7f7 !important;
  border-left-color: #38bdf8 !important;
  box-shadow: 0 10px 24px rgba(14, 165, 198, 0.12) !important;
}

.dashboard-commandbar h1,
.topbar h1,
.portal-strip span,
.metrics article strong,
.system-health-grid strong,
.parameter-map-grid strong,
.thermal-metric-grid strong,
.live-airport-card strong,
.live-airport-card dd,
.panel-head h2 {
  color: #07566d !important;
}

.status.ok,
.ymic-system-state.online {
  border-color: #99e6bb !important;
  background: #e7fff1 !important;
  color: #166534 !important;
}

.cama-logo-wrap,
.ymic-header-logo-slot,
.cama-sidebar-logo-slot {
  background: transparent !important;
  box-shadow: none !important;
}

.cama-logo {
  background: transparent !important;
}

.portal-strip a.metar-export-portal {
  position: relative;
  align-content: start;
  border-color: #7dd3fc !important;
  background: #e7fbff !important;
}

.portal-strip a.metar-export-portal::before {
  content: "XL";
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: #b8eaff;
  color: #07566d;
  font-size: 12px;
  font-weight: 900;
}

.portal-strip a.metar-export-portal small,
.portal-strip a.metar-export-portal em {
  display: block;
  color: #07566d;
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.35;
}

.portal-strip a.metar-export-portal em {
  color: #167192;
}

.live-airport-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.live-airport-actions .button-link,
.live-airport-actions button {
  min-height: 38px;
}

.minimal-dashboard .dashboard-map-panel {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.interactive-map-console {
  display: grid;
  gap: 24px;
  margin-bottom: 24px;
  color: #e7edf8;
}

.local-simulation-card,
.weather-control-card {
  border: 1px solid rgba(159, 185, 218, 0.24);
  border-radius: 28px;
  background: rgba(21, 47, 84, 0.94);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 18px 38px rgba(4, 22, 48, 0.18);
}

.local-simulation-card {
  padding: 24px 32px;
  text-align: center;
}

.local-simulation-card strong {
  display: block;
  color: #e3c95a;
  font-size: 22px;
  font-weight: 900;
  line-height: 1.35;
}

.local-simulation-card p {
  max-width: 940px;
  margin: 10px auto 0;
  color: #c5d1e2;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.9;
}

.weather-control-card {
  display: grid;
  gap: 22px;
  padding: 28px 30px;
}

.control-group {
  display: grid;
  gap: 12px;
}

.control-group h2 {
  margin: 0;
  color: #e3c95a;
  font-size: 20px;
  font-weight: 900;
  text-align: right;
}

.control-group h2 span {
  color: #e3c95a;
  font-size: 17px;
}

.segmented-control,
.layer-control {
  display: grid;
  gap: 8px;
  border-radius: 14px;
  background: rgba(5, 20, 45, 0.72);
  padding: 8px;
}

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

.layer-control {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.segmented-control button,
.layer-control button,
.focus-grid button {
  border: 1px solid transparent !important;
  border-radius: 10px !important;
  background: #071733 !important;
  color: #cbd6e6 !important;
  box-shadow: none !important;
  padding: 12px 14px !important;
  font-size: 15px !important;
  font-weight: 900 !important;
}

.segmented-control button.active {
  border-color: rgba(95, 133, 255, 0.5) !important;
  background: #2c4fbd !important;
  color: #ffffff !important;
}

.layer-control button.active,
.focus-grid button.active {
  border-color: #d0b651 !important;
  background: rgba(103, 77, 38, 0.84) !important;
  color: #f5d75a !important;
}

.focus-group h2 {
  color: #c0ccdd;
  font-size: 16px;
  text-align: center;
}

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

.minimal-dashboard .windy-map-wrap {
  position: relative;
  min-height: 640px !important;
  overflow: hidden;
  border: 1px solid rgba(117, 159, 204, 0.24);
  border-radius: 28px;
  background: #071733 !important;
}

.minimal-dashboard .windy-live-frame {
  min-height: 640px;
}

.active-weather-data-card {
  position: absolute;
  z-index: 4;
  top: 28px;
  right: 32px;
  width: min(430px, calc(100% - 64px));
  border-radius: 22px;
  background: rgba(4, 15, 35, 0.91);
  color: #e7edf8;
  padding: 20px 24px;
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.22);
}

.active-weather-data-card strong {
  display: inline-block;
  color: #ffffff;
  font-size: 20px;
  font-weight: 900;
}

.active-weather-data-card b {
  display: inline-block;
  margin-inline-start: 12px;
  border-radius: 8px;
  background: rgba(227, 201, 90, 0.15);
  color: #e3c95a;
  padding: 5px 8px;
  font-family: Consolas, "Courier New", monospace;
  font-size: 14px;
}

.active-weather-data-card span {
  display: block;
  margin-top: 12px;
  color: #c5d1e2;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.7;
}

.active-weather-layer-pill {
  position: absolute;
  z-index: 5;
  top: 26px;
  left: 26px;
  border-radius: 999px;
  background: rgba(4, 15, 35, 0.7);
  color: #ffffff;
  padding: 10px 16px;
  font-size: 14px;
  font-weight: 900;
}

@media (max-width: 900px) {
  .local-simulation-card,
  .weather-control-card,
  .minimal-dashboard .windy-map-wrap {
    border-radius: 22px;
  }

  .local-simulation-card {
    padding: 20px;
  }

  .segmented-control,
  .layer-control,
  .focus-grid {
    grid-template-columns: 1fr 1fr;
  }

  .minimal-dashboard .windy-map-wrap,
  .minimal-dashboard .windy-live-frame {
    min-height: 560px !important;
  }

  .active-weather-data-card {
    right: 18px;
    top: 18px;
    width: min(380px, calc(100% - 36px));
  }
}

@media (max-width: 520px) {
  .interactive-map-console {
    gap: 18px;
  }

  .weather-control-card {
    padding: 18px;
  }

  .segmented-control,
  .layer-control,
  .focus-grid {
    grid-template-columns: 1fr;
  }

  .local-simulation-card strong,
  .control-group h2 {
    font-size: 18px;
  }

  .local-simulation-card p {
    font-size: 14px;
  }

  .active-weather-data-card {
    padding: 16px;
  }
}

@media (max-width: 900px) {
  .airport-weather-showcase {
    margin: 10px;
    padding: 10px;
  }

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

  .featured-airport-card {
    min-height: 500px;
    padding: 22px 18px;
  }

  .featured-airport-top {
    grid-template-columns: auto 1fr;
  }

  .featured-airport-top b {
    grid-column: 1 / -1;
    justify-self: end;
  }

  .featured-airport-top strong {
    font-size: 44px;
  }

  .featured-airport-main {
    grid-template-columns: 1fr;
    justify-items: center;
    margin-top: 42px;
    text-align: center;
  }

  .featured-condition strong,
  .featured-condition span {
    max-width: none;
  }

  .featured-temp strong {
    font-size: 96px;
  }

  .featured-airport-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .airport-tabs {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7px;
  }

  .airport-tabs button {
    min-height: 44px;
    padding: 8px 6px;
    font-size: 12px;
  }

  .airport-tabs button small {
    display: none;
  }

  .featured-flag {
    width: 48px;
    height: 48px;
  }

  .featured-airport-top {
    gap: 12px;
  }

  .featured-airport-top small,
  .featured-airport-top em {
    font-size: 13px;
  }

  .featured-airport-top strong {
    font-size: 38px;
  }

  .featured-condition strong {
    font-size: 25px;
  }

  .featured-temp strong {
    font-size: 82px;
  }

  .featured-temp span {
    font-size: 34px;
  }

  .featured-sun {
    width: 126px;
    height: 126px;
    margin-top: 42px;
  }

  .featured-airport-metrics {
    grid-template-columns: 1fr;
  }
}

.minimal-dashboard .dashboard-commandbar {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  align-items: start !important;
  gap: 14px !important;
  margin: 0 -24px 24px !important;
  border: 0 !important;
  border-bottom: 2px solid #c6eeff !important;
  border-radius: 0 !important;
  background: #ffffff !important;
  box-shadow: none !important;
  padding: 20px 24px 40px !important;
}

.minimal-dashboard.shell {
  padding-top: 0 !important;
}

.minimal-dashboard .dashboard-command-title {
  min-width: 0;
}

.minimal-dashboard .dashboard-command-title .eyebrow,
.minimal-dashboard .dashboard-command-title h1 {
  display: none !important;
}

.minimal-dashboard .dashboard-command-title #dashboardMeta {
  display: none !important;
  min-height: 86px;
  border: 2px solid #9bdcae;
  border-radius: 16px;
  background: #eafff0;
  color: #20582d;
  padding: 24px 28px;
  font-size: 26px;
  font-weight: 900;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.minimal-dashboard .top-airport-weather {
  margin: 0 !important;
  padding: 12px !important;
  border-radius: 16px !important;
}

.minimal-dashboard .top-airport-weather .airport-selector-head {
  justify-content: flex-start;
  margin-bottom: 8px;
  font-size: 13px;
}

.minimal-dashboard .top-airport-weather .airport-tabs {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 10px;
}

.minimal-dashboard .top-airport-weather .airport-tabs button {
  min-height: 34px;
  padding: 6px 8px;
  font-size: 12px;
}

.minimal-dashboard .top-airport-weather .airport-tabs button small {
  font-size: 10px;
}

.minimal-dashboard .top-airport-weather .featured-airport-card {
  min-height: 188px;
  padding: 16px 18px;
}

.minimal-dashboard .top-airport-weather .featured-airport-card::before {
  inset: 8px;
}

.minimal-dashboard .top-airport-weather .featured-airport-top {
  grid-template-columns: auto 1fr auto;
  gap: 12px;
}

.minimal-dashboard .top-airport-weather .featured-flag {
  width: 42px;
  height: 42px;
  font-size: 18px;
}

.minimal-dashboard .top-airport-weather .featured-airport-top small {
  font-size: 12px;
}

.minimal-dashboard .top-airport-weather .featured-airport-top strong {
  margin-top: 3px;
  font-size: 32px;
}

.minimal-dashboard .top-airport-weather .featured-airport-top em {
  margin-top: 3px;
  font-size: 12px;
}

.minimal-dashboard .top-airport-weather .featured-airport-top b {
  padding: 6px 10px;
  font-size: 12px;
}

.minimal-dashboard .top-airport-weather .featured-metar-bulletin {
  max-width: 620px;
  margin-top: 10px;
  padding: 8px 10px;
}

.minimal-dashboard .top-airport-weather .featured-metar-bulletin span {
  font-size: 10px;
}

.minimal-dashboard .top-airport-weather .featured-metar-bulletin code {
  font-size: 12px;
}

.minimal-dashboard .top-airport-weather .featured-airport-main {
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  margin-top: 14px;
}

.minimal-dashboard .top-airport-weather .featured-condition strong {
  max-width: none;
  font-size: 20px;
  line-height: 1.35;
}

.minimal-dashboard .top-airport-weather .featured-condition span {
  margin-top: 4px;
  max-width: none;
  font-size: 12px;
}

.minimal-dashboard .top-airport-weather .featured-temp strong {
  font-size: 62px;
}

.minimal-dashboard .top-airport-weather .featured-temp span {
  margin-bottom: 4px;
  font-size: 28px;
}

.minimal-dashboard .top-airport-weather .featured-temp {
  align-items: center;
  gap: 10px;
}

.minimal-dashboard .top-airport-weather .featured-feels-like {
  margin: 0;
  min-width: 78px;
}

.minimal-dashboard .top-airport-weather .featured-feels-like span {
  margin: 0 !important;
  color: #6c8794 !important;
  font-size: 11px !important;
}

.minimal-dashboard .top-airport-weather .featured-feels-like strong {
  color: #0d4254 !important;
  font-size: 18px !important;
}

.minimal-dashboard .top-airport-weather .featured-sun {
  display: none;
}

.minimal-dashboard .top-airport-weather .featured-airport-metrics {
  grid-template-columns: repeat(5, minmax(72px, 1fr));
  gap: 8px;
  margin-top: 14px;
  padding: 10px;
}

.minimal-dashboard .top-airport-weather .featured-airport-metrics span {
  font-size: 10px;
}

.minimal-dashboard .top-airport-weather .featured-airport-metrics strong {
  font-size: 12px;
}

.minimal-dashboard .dashboard-command-actions {
  display: grid !important;
  grid-template-columns: 1fr;
  gap: 16px !important;
  align-items: stretch !important;
  align-content: start !important;
  justify-content: stretch !important;
}

.minimal-dashboard .dashboard-command-actions #status {
  display: none !important;
}

.minimal-dashboard .dashboard-command-actions button {
  min-height: 86px;
  height: 86px;
  border: 2px solid #86cfff !important;
  border-radius: 12px !important;
  background: #c9ebff !important;
  color: #245775 !important;
  box-shadow: none !important;
  padding: 16px 26px !important;
  font-size: 28px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
}

.minimal-dashboard .dashboard-command-actions button:hover {
  background: #b9e4ff !important;
  border-color: #65bdf5 !important;
}

@media (max-width: 900px) {
  .minimal-dashboard .dashboard-commandbar {
    grid-template-columns: 1fr !important;
    margin: 0 -12px 18px !important;
    padding: 18px 12px 24px !important;
  }

  .minimal-dashboard .dashboard-command-title #dashboardMeta {
    min-height: 74px;
    padding: 18px;
    font-size: 23px;
  }

  .minimal-dashboard .dashboard-command-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .minimal-dashboard .dashboard-command-actions button {
    min-height: 66px;
    padding: 12px !important;
    font-size: 22px !important;
  }
}

@media (max-width: 520px) {
  .minimal-dashboard .dashboard-command-title #dashboardMeta {
    font-size: 18px;
  }

  .minimal-dashboard .dashboard-command-actions button {
    font-size: 18px !important;
  }
}

/* Professional icon scale for the current home page. */
.minimal-dashboard {
  --ymic-icon-nav: 30px;
  --ymic-icon-control: 24px;
  --ymic-icon-portal: 44px;
  --ymic-icon-feature: 40px;
}

.minimal-dashboard .cama-nav-icon,
.minimal-dashboard .cama-nav-icon.sub {
  flex: 0 0 var(--ymic-icon-nav) !important;
  width: var(--ymic-icon-nav) !important;
  height: var(--ymic-icon-nav) !important;
  min-width: var(--ymic-icon-nav) !important;
  border-radius: 9px !important;
  font-size: 14px !important;
  line-height: 1 !important;
}

.minimal-dashboard .portal-strip a {
  position: relative;
  display: grid !important;
  grid-template-columns: var(--ymic-icon-portal) minmax(0, 1fr);
  grid-auto-rows: min-content;
  column-gap: 12px;
  align-content: center;
  min-height: 92px;
  padding: 14px 16px !important;
}

.minimal-dashboard .portal-strip a::before {
  display: grid;
  grid-row: 1 / span 4;
  grid-column: 1;
  place-items: center;
  align-self: center;
  width: var(--ymic-icon-portal);
  height: var(--ymic-icon-portal);
  border-radius: 14px;
  border: 1px solid rgba(45, 147, 191, 0.2);
  background: linear-gradient(180deg, #d9f5ff 0%, #b9eaff 100%);
  color: #07566d;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72), 0 8px 16px rgba(16, 112, 151, 0.12);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0;
  line-height: 1;
}

.minimal-dashboard .portal-strip a:nth-child(1)::before {
  content: "WX";
}

.minimal-dashboard .portal-strip a:nth-child(2)::before {
  content: "08";
}

.minimal-dashboard .portal-strip a:nth-child(3)::before {
  content: "HI";
}

.minimal-dashboard .portal-strip a:nth-child(4)::before {
  content: "REP";
  font-size: 10px;
}

.minimal-dashboard .portal-strip a > span,
.minimal-dashboard .portal-strip a > strong,
.minimal-dashboard .portal-strip a > small,
.minimal-dashboard .portal-strip a > em {
  grid-column: 2;
  min-width: 0;
}

.minimal-dashboard .portal-strip a > span {
  font-size: 13px;
  line-height: 1.2;
}

.minimal-dashboard .portal-strip a > strong {
  font-size: 12px;
  line-height: 1.35;
}

.minimal-dashboard .portal-strip a > small,
.minimal-dashboard .portal-strip a > em {
  font-size: 10px !important;
  line-height: 1.35 !important;
}

.minimal-dashboard .top-airport-weather .featured-flag {
  width: var(--ymic-icon-feature) !important;
  height: var(--ymic-icon-feature) !important;
  min-width: var(--ymic-icon-feature) !important;
  border-radius: 12px !important;
  font-size: 18px !important;
}

.minimal-dashboard .segmented-control button,
.minimal-dashboard .layer-control button,
.minimal-dashboard .focus-grid button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 46px;
  line-height: 1.25;
}

.minimal-dashboard .segmented-control button::before,
.minimal-dashboard .layer-control button::before,
.minimal-dashboard .focus-grid button::before {
  display: inline-grid;
  flex: 0 0 var(--ymic-icon-control);
  width: var(--ymic-icon-control);
  height: var(--ymic-icon-control);
  place-items: center;
  border-radius: 8px;
  background: rgba(185, 234, 255, 0.12);
  color: #f5d75a;
  font-size: 11px;
  font-weight: 950;
  line-height: 1;
}

.minimal-dashboard .windy-model[data-model="ecmwf"]::before {
  content: "E";
}

.minimal-dashboard .windy-model[data-model="gfs"]::before {
  content: "G";
}

.minimal-dashboard .windy-model[data-model="icon"]::before {
  content: "I";
}

.minimal-dashboard .windy-layer-option[data-layer="wind"]::before {
  content: "W";
}

.minimal-dashboard .windy-layer-option[data-layer="rain"]::before {
  content: "R";
}

.minimal-dashboard .windy-layer-option[data-layer="clouds"]::before {
  content: "C";
}

.minimal-dashboard .windy-layer-option[data-layer="temp"]::before {
  content: "T";
}

.minimal-dashboard .windy-layer-option[data-layer="pressure"]::before {
  content: "P";
}

.minimal-dashboard .windy-focus::before {
  content: "PIN";
  font-size: 9px;
}

.minimal-dashboard .active-weather-layer-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
}

.minimal-dashboard .active-weather-layer-pill::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #f5d75a;
  box-shadow: 0 0 0 4px rgba(245, 215, 90, 0.18);
}

@media (max-width: 900px) {
  .minimal-dashboard {
    --ymic-icon-portal: 40px;
    --ymic-icon-control: 22px;
    --ymic-icon-feature: 38px;
  }

  .minimal-dashboard .portal-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .minimal-dashboard .portal-strip a {
    min-height: 86px;
    padding: 12px !important;
  }
}

@media (max-width: 520px) {
  .minimal-dashboard {
    --ymic-icon-portal: 36px;
    --ymic-icon-control: 20px;
    --ymic-icon-feature: 34px;
  }

  .minimal-dashboard .portal-strip {
    grid-template-columns: 1fr;
  }

  .minimal-dashboard .portal-strip a {
    grid-template-columns: var(--ymic-icon-portal) minmax(0, 1fr);
    min-height: 76px;
  }

  .minimal-dashboard .segmented-control button,
  .minimal-dashboard .layer-control button,
  .minimal-dashboard .focus-grid button {
    min-height: 42px;
    font-size: 13px !important;
  }
}

/* Light marine visual system. */
:root {
  --ymic-navy: #07566d;
  --ymic-blue: #0f7f9f;
  --ymic-sky: #35bde0;
  --ymic-bg: #eaf8fb;
  --ymic-panel: rgba(255, 255, 255, 0.84);
  --ymic-line: rgba(87, 178, 204, 0.28);
  --ymic-muted: #4e7280;
  --ymic-marine-text: #0d4254;
  --ymic-marine-soft: #dff7fb;
  --ymic-marine-glass: rgba(255, 255, 255, 0.58);
  --ymic-marine-gold: #c9a832;
}

body {
  background:
    radial-gradient(circle at 12% 0%, rgba(105, 220, 240, 0.28), transparent 36%),
    radial-gradient(circle at 82% 8%, rgba(166, 235, 246, 0.34), transparent 34%),
    linear-gradient(180deg, #f7fdff 0%, #eaf8fb 45%, #dff3f7 100%) !important;
  color: var(--ymic-marine-text) !important;
}

.minimal-dashboard .dashboard-commandbar,
.minimal-dashboard .metrics article,
.minimal-dashboard .portal-strip a,
.local-simulation-card,
.weather-control-card,
.minimal-dashboard .windy-map-wrap {
  border-color: var(--ymic-line) !important;
  background: rgba(255, 255, 255, 0.72) !important;
  box-shadow: 0 16px 34px rgba(20, 123, 154, 0.1) !important;
  backdrop-filter: blur(14px);
}

.minimal-dashboard .dashboard-commandbar {
  border-left-color: #45c5df !important;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.86), rgba(218, 248, 253, 0.74)) !important;
}

.minimal-dashboard .dashboard-commandbar h1,
.minimal-dashboard .metrics article strong,
.minimal-dashboard .portal-strip span,
.minimal-dashboard .portal-strip strong,
.local-simulation-card strong,
.control-group h2,
.control-group h2 span {
  color: var(--ymic-marine-text) !important;
}

.minimal-dashboard .dashboard-commandbar span,
.minimal-dashboard .metrics article span,
.minimal-dashboard .portal-strip a > small,
.minimal-dashboard .portal-strip a > em,
.local-simulation-card p,
.active-weather-data-card span {
  color: var(--ymic-muted) !important;
}

.minimal-dashboard .portal-strip a:hover {
  border-color: rgba(53, 189, 224, 0.62) !important;
  background: rgba(255, 255, 255, 0.9) !important;
  box-shadow: 0 18px 38px rgba(20, 123, 154, 0.16) !important;
}

.minimal-dashboard .portal-strip a::before {
  border-color: rgba(21, 153, 188, 0.24) !important;
  background: rgba(255, 255, 255, 0.22) !important;
  color: #087b9a !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.68), 0 8px 18px rgba(48, 172, 205, 0.1) !important;
}

.minimal-dashboard .top-airport-weather {
  border: 1px solid rgba(87, 178, 204, 0.3) !important;
  background:
    radial-gradient(circle at 8% 0%, rgba(105, 220, 240, 0.24), transparent 32%),
    linear-gradient(150deg, rgba(245, 253, 255, 0.9), rgba(204, 242, 249, 0.86)) !important;
  color: var(--ymic-marine-text) !important;
  box-shadow: 0 18px 36px rgba(20, 123, 154, 0.12) !important;
}

.minimal-dashboard .top-airport-weather .airport-selector-head {
  color: #087b9a !important;
}

.minimal-dashboard .top-airport-weather .airport-tabs button {
  border-color: rgba(36, 159, 190, 0.2) !important;
  background: rgba(255, 255, 255, 0.36) !important;
  color: #386d7d !important;
  box-shadow: none !important;
}

.minimal-dashboard .top-airport-weather .airport-tabs button::after {
  background: rgba(8, 123, 154, 0.28) !important;
}

.minimal-dashboard .top-airport-weather .airport-tabs button small {
  color: #5d8491 !important;
}

.minimal-dashboard .top-airport-weather .airport-tabs button.active {
  border-color: rgba(201, 168, 50, 0.72) !important;
  background: rgba(255, 255, 255, 0.72) !important;
  color: #0d6f8b !important;
  box-shadow: inset 0 -3px 0 rgba(201, 168, 50, 0.42), 0 10px 22px rgba(20, 123, 154, 0.1) !important;
}

.minimal-dashboard .top-airport-weather .featured-airport-card {
  border-color: rgba(87, 178, 204, 0.26) !important;
  background:
    radial-gradient(circle at 10% 12%, rgba(255, 255, 255, 0.78), transparent 36%),
    linear-gradient(145deg, rgba(240, 253, 255, 0.96), rgba(192, 237, 246, 0.88)) !important;
  color: var(--ymic-marine-text) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.76), 0 16px 30px rgba(15, 127, 159, 0.11) !important;
}

.minimal-dashboard .top-airport-weather .featured-airport-card::before {
  border-color: rgba(13, 116, 143, 0.08) !important;
}

.minimal-dashboard .top-airport-weather .featured-flag {
  border-color: rgba(13, 116, 143, 0.14) !important;
  background: rgba(255, 255, 255, 0.22) !important;
  box-shadow: none !important;
}

.minimal-dashboard .top-airport-weather .featured-airport-top small,
.minimal-dashboard .top-airport-weather .featured-airport-top em {
  color: #618493 !important;
}

.minimal-dashboard .top-airport-weather .featured-airport-top strong,
.minimal-dashboard .top-airport-weather .featured-temp strong,
.minimal-dashboard .top-airport-weather .featured-condition strong {
  color: #0d4254 !important;
}

.minimal-dashboard .top-airport-weather .featured-airport-top b {
  background: rgba(201, 168, 50, 0.18) !important;
  color: #876d10 !important;
}

.minimal-dashboard .top-airport-weather .featured-metar-bulletin,
.minimal-dashboard .top-airport-weather .featured-airport-metrics {
  border-color: rgba(44, 171, 204, 0.22) !important;
  background: rgba(255, 255, 255, 0.5) !important;
}

.minimal-dashboard .top-airport-weather .featured-metar-bulletin span,
.minimal-dashboard .top-airport-weather .featured-temp span {
  color: #b3931f !important;
}

.minimal-dashboard .top-airport-weather .featured-metar-bulletin code,
.minimal-dashboard .top-airport-weather .featured-airport-metrics strong {
  color: #0f5368 !important;
}

.minimal-dashboard .top-airport-weather .featured-condition span,
.minimal-dashboard .top-airport-weather .featured-airport-metrics span {
  color: #5f8290 !important;
}

.local-simulation-card,
.weather-control-card {
  background: rgba(237, 251, 254, 0.76) !important;
  color: var(--ymic-marine-text) !important;
}

.segmented-control,
.layer-control {
  background: rgba(202, 239, 247, 0.52) !important;
}

.minimal-dashboard .segmented-control button,
.minimal-dashboard .layer-control button,
.minimal-dashboard .focus-grid button {
  border-color: rgba(36, 159, 190, 0.18) !important;
  background: rgba(255, 255, 255, 0.34) !important;
  color: #2d6577 !important;
}

.minimal-dashboard .segmented-control button::before,
.minimal-dashboard .layer-control button::before,
.minimal-dashboard .focus-grid button::before,
.minimal-dashboard .cama-nav-icon,
.minimal-dashboard .cama-nav-icon.sub {
  border: 1px solid rgba(13, 116, 143, 0.12) !important;
  background: rgba(255, 255, 255, 0.18) !important;
  color: #087b9a !important;
  box-shadow: none !important;
}

.minimal-dashboard .segmented-control button.active,
.minimal-dashboard .layer-control button.active,
.minimal-dashboard .focus-grid button.active {
  border-color: rgba(11, 143, 176, 0.46) !important;
  background: rgba(34, 181, 213, 0.2) !important;
  color: #07566d !important;
}

.minimal-dashboard .segmented-control button.active::before,
.minimal-dashboard .layer-control button.active::before,
.minimal-dashboard .focus-grid button.active::before {
  color: #07566d !important;
  background: rgba(255, 255, 255, 0.26) !important;
}

.minimal-dashboard .windy-map-wrap {
  border-color: rgba(66, 183, 213, 0.36) !important;
  background: #dff7fb !important;
}

.active-weather-data-card {
  border: 1px solid rgba(80, 181, 207, 0.28) !important;
  background: rgba(248, 254, 255, 0.8) !important;
  color: var(--ymic-marine-text) !important;
  box-shadow: 0 16px 32px rgba(20, 123, 154, 0.12) !important;
  backdrop-filter: blur(12px);
}

.active-weather-data-card strong,
.active-weather-data-card b {
  color: var(--ymic-marine-text) !important;
}

.active-weather-data-card b {
  background: rgba(201, 168, 50, 0.16) !important;
  color: #876d10 !important;
}

.active-weather-layer-pill {
  border: 1px solid rgba(255, 255, 255, 0.52) !important;
  background: rgba(255, 255, 255, 0.62) !important;
  color: #07566d !important;
  box-shadow: 0 10px 20px rgba(20, 123, 154, 0.1) !important;
  backdrop-filter: blur(10px);
}

.minimal-dashboard .active-weather-layer-pill::before {
  background: #35bde0 !important;
  box-shadow: 0 0 0 4px rgba(53, 189, 224, 0.18) !important;
}

.cama-sidebar {
  background: rgba(241, 252, 255, 0.92) !important;
  color: var(--ymic-marine-text) !important;
  border-right-color: rgba(66, 183, 213, 0.28) !important;
  box-shadow: 8px 0 28px rgba(20, 123, 154, 0.08) !important;
}

.cama-portal-button,
.cama-portal-links a,
.cama-sidebar-text strong {
  color: var(--ymic-marine-text) !important;
}

.cama-portal-button:hover,
.cama-portal-links a:hover {
  background: rgba(53, 189, 224, 0.12) !important;
  color: #07566d !important;
}

/* Clear distinctive typography. */
:root {
  --ymic-ui-font: "Cairo", "Tajawal", "Segoe UI", Arial, sans-serif;
  --ymic-display-font: "Cooper Black", "Cairo", "Tajawal", "Trebuchet MS", "Segoe UI", Arial, sans-serif;
  --ymic-mono-font: "Cascadia Mono", Consolas, "Courier New", monospace;
}

body,
button,
input,
select,
textarea,
.minimal-dashboard,
.cama-sidebar {
  font-family: var(--ymic-ui-font) !important;
  letter-spacing: 0 !important;
  text-rendering: optimizeLegibility;
}

.minimal-dashboard h1,
.minimal-dashboard h2,
.dashboard-commandbar h1,
.topbar h1,
.portal-strip span,
.local-simulation-card strong,
.control-group h2,
.featured-airport-top strong,
.featured-temp strong {
  font-family: var(--ymic-display-font) !important;
  letter-spacing: 0 !important;
}

.minimal-dashboard h1,
.dashboard-commandbar h1,
.topbar h1 {
  font-weight: 900 !important;
  line-height: 1.12 !important;
}

.portal-strip span,
.local-simulation-card strong,
.control-group h2,
.airport-selector-head,
.airport-tabs button,
.featured-airport-metrics strong,
.featured-metar-bulletin span,
.segmented-control button,
.layer-control button,
.focus-grid button {
  font-weight: 900 !important;
}

.minimal-dashboard p,
.minimal-dashboard span,
.minimal-dashboard small,
.minimal-dashboard em,
.portal-strip strong,
.local-simulation-card p,
.active-weather-data-card span,
.featured-condition span {
  line-height: 1.55;
}

.featured-metar-bulletin code,
.featured-airport-top small,
.featured-airport-top em,
code {
  font-family: var(--ymic-mono-font) !important;
  letter-spacing: 0 !important;
}

.minimal-dashboard .top-airport-weather .featured-airport-top strong {
  font-size: clamp(28px, 4.5vw, 38px) !important;
  font-weight: 900 !important;
  line-height: 1.2 !important;
  padding-bottom: 2px;
}

.minimal-dashboard .top-airport-weather .featured-temp strong {
  font-size: clamp(48px, 8vw, 68px) !important;
  font-weight: 900 !important;
  line-height: 0.95 !important;
}

.minimal-dashboard .dashboard-command-title > .eyebrow,
.minimal-dashboard .dashboard-command-title > h1 {
  display: none !important;
}

.aviation-dashboard .top-actions {
  align-items: stretch;
  gap: 10px;
}

.aviation-dashboard .metar-archive-action {
  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr);
  grid-auto-rows: min-content;
  align-content: center;
  column-gap: 10px;
  min-width: 250px;
  min-height: 72px;
  border-color: rgba(53, 189, 224, 0.42) !important;
  background: rgba(255, 255, 255, 0.46) !important;
  color: #07566d !important;
  box-shadow: 0 12px 26px rgba(20, 123, 154, 0.12) !important;
  backdrop-filter: blur(12px);
}

.aviation-dashboard .metar-archive-action::before {
  content: "XL";
  display: grid;
  grid-row: 1 / span 2;
  grid-column: 1;
  place-items: center;
  align-self: center;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(21, 153, 188, 0.24);
  border-radius: 13px;
  background: rgba(255, 255, 255, 0.24);
  color: #087b9a;
  font-size: 12px;
  font-weight: 950;
}

.aviation-dashboard .metar-archive-action span,
.aviation-dashboard .metar-archive-action small {
  grid-column: 2;
  min-width: 0;
  line-height: 1.25;
}

.aviation-dashboard .metar-archive-action span {
  color: #0d4254;
  font-size: 14px;
  font-weight: 950;
}

.aviation-dashboard .metar-archive-action small {
  color: #4e7280;
  font-size: 11px;
  font-weight: 800;
}

.aviation-dashboard .metar-archive-action:hover {
  border-color: rgba(53, 189, 224, 0.68) !important;
  background: rgba(255, 255, 255, 0.68) !important;
}

@media (max-width: 900px) {
  .aviation-dashboard .top-actions {
    width: 100%;
  }

  .aviation-dashboard .metar-archive-action {
    min-width: 100%;
  }

  .live-metar-heading {
    align-items: flex-start;
    flex-direction: column;
  }

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

.weather-bulletins-page {
  color: var(--ymic-marine-text);
}

.bulletins-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 22px;
  border: 1px solid rgba(87, 178, 204, 0.28);
  border-radius: 18px;
  background:
    radial-gradient(circle at 14% 0%, rgba(105, 220, 240, 0.28), transparent 36%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.86), rgba(218, 248, 253, 0.78));
  padding: 26px;
  box-shadow: 0 18px 38px rgba(20, 123, 154, 0.1);
}

.bulletins-hero h1 {
  margin: 0;
  color: #0d4254;
  font-family: var(--ymic-display-font);
  font-size: clamp(34px, 5vw, 58px);
  line-height: 1.15;
}

.bulletins-hero span {
  display: block;
  margin-top: 8px;
  color: #4e7280;
  font-size: 17px;
  font-weight: 800;
}

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

.bulletin-icon-card {
  display: grid;
  gap: 10px;
  min-height: 250px;
  border: 1px solid rgba(87, 178, 204, 0.28);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.68);
  color: #0d4254;
  padding: 20px;
  text-decoration: none;
  box-shadow: 0 16px 34px rgba(20, 123, 154, 0.1);
  backdrop-filter: blur(14px);
}

.bulletin-icon-card:hover {
  border-color: rgba(53, 189, 224, 0.66);
  background: rgba(255, 255, 255, 0.86);
  transform: translateY(-2px);
}

.bulletin-icon {
  display: grid;
  place-items: center;
  width: 62px;
  height: 62px;
  border: 1px solid rgba(21, 153, 188, 0.24);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.26);
  color: #087b9a;
  font-family: var(--ymic-display-font);
  font-size: 18px;
  font-weight: 950;
}

.bulletin-icon-card small {
  color: #087b9a;
  font-size: 15px;
  font-weight: 950;
}

.bulletin-icon-card strong {
  color: #0d4254;
  font-family: var(--ymic-display-font);
  font-size: 24px;
  line-height: 1.15;
}

.bulletin-icon-card em {
  color: #4e7280;
  font-size: 14px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.6;
}

.bulletins-note {
  margin-top: 18px;
  border-color: rgba(87, 178, 204, 0.28) !important;
  background: rgba(255, 255, 255, 0.66) !important;
}

.bulletins-note p {
  margin: 0;
  padding: 0 18px 18px;
  color: #4e7280;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.8;
}

@media (max-width: 1120px) {
  .bulletins-icon-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .bulletins-hero {
    align-items: stretch;
    flex-direction: column;
  }

  .bulletins-icon-grid {
    grid-template-columns: 1fr;
  }

  .bulletin-icon-card {
    min-height: 190px;
  }
}

/* Dark operational weather bulletins page. */
.bulletins-dark-shell {
  background:
    radial-gradient(circle at 16% 0%, rgba(45, 94, 185, 0.28), transparent 34%),
    radial-gradient(circle at 84% 16%, rgba(22, 112, 170, 0.22), transparent 30%),
    linear-gradient(180deg, #081b47 0%, #09205b 48%, #071744 100%) !important;
  color: #edf6ff !important;
}

.dark-bulletins-page {
  color: #edf6ff;
}

.dark-bulletins-page .cama-report-watermark {
  display: none;
}

.bulletins-command-hero {
  display: grid;
  grid-template-columns: minmax(230px, 0.45fr) minmax(0, 1fr) auto;
  align-items: start;
  gap: 24px;
  margin-bottom: 28px;
  border-bottom: 1px solid rgba(174, 207, 255, 0.16);
  padding: 20px 0 28px;
}

.bulletins-clock-panel {
  display: grid;
  gap: 6px;
  justify-self: start;
  min-width: 230px;
  border: 1px solid rgba(174, 207, 255, 0.12);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.06);
  color: #d8e8ff;
  padding: 14px 18px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.bulletins-clock-panel span,
.bulletins-clock-panel strong,
.bulletins-clock-panel em {
  font-style: normal;
  font-weight: 900;
}

.bulletins-title-block {
  text-align: right;
}

.bulletins-title-block p {
  margin: 0 0 8px;
  color: #d4e5ff;
  font-size: 14px;
  font-weight: 900;
}

.bulletins-title-block h1 {
  margin: 0;
  color: #ffffff;
  font-family: var(--ymic-display-font);
  font-size: clamp(34px, 5vw, 62px);
  font-weight: 950;
  line-height: 1.1;
}

.bulletins-title-block span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  color: #c7d6ed;
  font-size: 14px;
  font-weight: 800;
}

.bulletins-title-block span::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #38e88d;
  box-shadow: 0 0 0 4px rgba(56, 232, 141, 0.13);
}

.bulletins-weather-mark {
  display: grid;
  place-items: center;
  width: 62px;
  height: 62px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.08);
  color: #ffd84b;
  font-size: 34px;
}

.bulletins-report-header {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 14px;
  margin-bottom: 18px;
  color: #eef7ff;
}

.report-icon {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: rgba(255, 214, 75, 0.12);
}

.bulletins-report-header h2 {
  margin: 0;
  color: #ffffff;
  font-size: clamp(20px, 3vw, 32px);
  font-weight: 950;
}

.bulletins-report-header p {
  max-width: 1040px;
  margin: 8px 0 0;
  color: #c6d5ee;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.8;
}

.bulletins-tabs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 8px 0 24px;
  border-bottom: 1px solid rgba(174, 207, 255, 0.16);
  padding-bottom: 8px;
}

.bulletins-tabs a {
  display: grid;
  place-items: center;
  min-height: 44px;
  border-radius: 10px;
  color: #d4e2f7;
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
}

.bulletins-tabs a.active {
  border-bottom: 3px solid #ffe15b;
  color: #ffe15b;
}

.bulletins-tabs a:hover {
  background: rgba(255, 255, 255, 0.07);
}

.whatsapp-feed-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  margin-bottom: 26px;
  border: 1px solid rgba(174, 207, 255, 0.2);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.055);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 18px 34px rgba(0, 0, 0, 0.16);
  padding: 22px;
}

.feed-title {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
}

.feed-db-icon {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  background: rgba(255, 225, 91, 0.13);
  color: #ffe15b;
  font-size: 20px;
}

.feed-title h2 {
  margin: 0;
  color: #ffffff;
  font-size: 20px;
  font-weight: 950;
}

.feed-title p,
.whatsapp-feed-panel small {
  margin: 6px 0 0;
  color: #c6d5ee;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.7;
}

.feed-actions {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  flex-wrap: wrap;
}

.feed-refresh,
.feed-secure,
.feed-live {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 12px;
  font-weight: 950;
  text-decoration: none;
}

.feed-refresh {
  background: #ffe15b;
  color: #18244d;
}

.feed-secure {
  background: rgba(0, 0, 0, 0.28);
  color: #ffffff;
}

.feed-live {
  background: rgba(56, 232, 141, 0.12);
  color: #52f09f;
}

.section-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.section-title-row h2 {
  margin: 0;
  color: #ffe15b;
  font-size: 18px;
  font-weight: 950;
}

.section-title-row span {
  color: #aebfe0;
  font-size: 12px;
  font-weight: 900;
}

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

.bulletin-preview-card {
  display: grid;
  gap: 12px;
  color: #f5f8ff;
  text-decoration: none;
}

.bulletin-preview-card strong {
  color: #ffffff;
  font-size: 15px;
  font-weight: 950;
}

.bulletin-preview-card small {
  color: #b9c9e6;
  font-size: 12px;
  font-weight: 800;
}

.bulletin-preview {
  position: relative;
  overflow: hidden;
  display: grid;
  align-content: start;
  gap: 8px;
  aspect-ratio: 1.32 / 1;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(213, 226, 238, 0.72)),
    #dce9f2;
  color: #24344c;
  padding: 14px;
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.18);
}

.bulletin-preview::after {
  content: "YMIC";
  position: absolute;
  left: 12px;
  bottom: 10px;
  color: rgba(36, 52, 76, 0.18);
  font-weight: 950;
}

.bulletin-preview span {
  color: #24344c;
  font-size: 12px;
  font-weight: 950;
}

.bulletin-preview b {
  color: #6d5d1c;
  font-size: 11px;
}

.bulletin-preview i {
  display: block;
  height: 9px;
  border-radius: 999px;
  background: rgba(48, 73, 103, 0.22);
}

.grid-preview {
  grid-template-columns: repeat(2, 1fr);
}

.grid-preview span,
.grid-preview b {
  grid-column: 1 / -1;
}

.text-preview p,
.map-preview p {
  margin: 12px 0 0;
  border-radius: 10px;
  background: rgba(49, 102, 154, 0.14);
  color: #365778;
  padding: 10px;
  font-size: 12px;
  font-weight: 950;
  text-align: center;
}

.map-preview {
  background:
    radial-gradient(circle at 62% 48%, rgba(255, 255, 255, 0.72), transparent 22%),
    linear-gradient(135deg, #b9d9de, #6e9da7) !important;
}

@media (max-width: 1180px) {
  .bulletins-command-hero,
  .whatsapp-feed-panel {
    grid-template-columns: 1fr;
  }

  .bulletins-tabs,
  .bulletins-showcase-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .bulletins-tabs,
  .bulletins-showcase-grid {
    grid-template-columns: 1fr;
  }

  .bulletins-clock-panel {
    justify-self: stretch;
  }
}

/* Marine version of the weather bulletins page. */
.bulletins-marine-shell {
  background:
    radial-gradient(circle at 14% 0%, rgba(105, 220, 240, 0.28), transparent 34%),
    radial-gradient(circle at 82% 12%, rgba(166, 235, 246, 0.34), transparent 32%),
    linear-gradient(180deg, #f7fdff 0%, #eaf8fb 45%, #dff3f7 100%) !important;
  color: #0d4254 !important;
}

.marine-bulletins-page {
  color: #0d4254;
}

.marine-bulletins-page .bulletins-command-hero {
  border-bottom-color: rgba(87, 178, 204, 0.28);
}

.marine-bulletins-page .bulletins-clock-panel,
.marine-bulletins-page .whatsapp-feed-panel,
.marine-bulletins-page .bulletin-preview-card,
.marine-bulletins-page .bulletins-report-header,
.marine-bulletins-page .bulletins-tabs a {
  color: #0d4254;
}

.marine-bulletins-page .bulletins-clock-panel {
  border-color: rgba(87, 178, 204, 0.28);
  background: rgba(255, 255, 255, 0.58);
  color: #0d4254;
  box-shadow: 0 12px 26px rgba(20, 123, 154, 0.08);
}

.marine-bulletins-page .bulletins-title-block p,
.marine-bulletins-page .bulletins-title-block span,
.marine-bulletins-page .bulletins-report-header p,
.marine-bulletins-page .feed-title p,
.marine-bulletins-page .whatsapp-feed-panel small,
.marine-bulletins-page .section-title-row span,
.marine-bulletins-page .bulletin-preview-card small {
  color: #4e7280;
}

.marine-bulletins-page .bulletins-title-block h1,
.marine-bulletins-page .bulletins-report-header h2,
.marine-bulletins-page .feed-title h2,
.marine-bulletins-page .bulletin-preview-card strong {
  color: #0d4254;
}

.marine-bulletins-page .bulletins-title-block span::before {
  background: #24c58f;
  box-shadow: 0 0 0 4px rgba(36, 197, 143, 0.14);
}

.marine-bulletins-page .bulletins-weather-mark,
.marine-bulletins-page .report-icon,
.marine-bulletins-page .feed-db-icon {
  background: rgba(255, 255, 255, 0.42);
  color: #087b9a;
}

.marine-bulletins-page .bulletins-report-header,
.marine-bulletins-page .whatsapp-feed-panel {
  border: 1px solid rgba(87, 178, 204, 0.28);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.64);
  box-shadow: 0 16px 34px rgba(20, 123, 154, 0.1);
  padding: 22px;
  backdrop-filter: blur(14px);
}

.marine-bulletins-page .bulletins-report-header {
  margin-bottom: 18px;
}

.marine-bulletins-page .bulletins-tabs {
  border-bottom-color: rgba(87, 178, 204, 0.28);
}

.marine-bulletins-page .bulletins-tabs a {
  background: rgba(255, 255, 255, 0.34);
  border: 1px solid rgba(87, 178, 204, 0.18);
}

.marine-bulletins-page .bulletins-tabs a.active {
  border-bottom-color: #c9a832;
  color: #07566d;
  background: rgba(255, 255, 255, 0.72);
}

.marine-bulletins-page .bulletins-tabs a:hover {
  background: rgba(255, 255, 255, 0.76);
}

.marine-bulletins-page .feed-refresh {
  background: #c9ebff;
  color: #07566d;
  border: 1px solid rgba(53, 189, 224, 0.36);
}

.marine-bulletins-page .feed-secure {
  background: rgba(255, 255, 255, 0.52);
  color: #0d4254;
}

.marine-bulletins-page .feed-live {
  background: rgba(36, 197, 143, 0.12);
  color: #147a62;
}

.marine-bulletins-page .section-title-row h2 {
  color: #087b9a;
}

.marine-bulletins-page .bulletin-preview {
  border-color: rgba(87, 178, 204, 0.28);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(219, 247, 252, 0.78)),
    #e7fbff;
  box-shadow: 0 16px 34px rgba(20, 123, 154, 0.12);
}

.marine-bulletins-page .map-preview {
  background:
    radial-gradient(circle at 62% 48%, rgba(255, 255, 255, 0.82), transparent 22%),
    linear-gradient(135deg, #c9f2f7, #8ed9e6) !important;
}

.rss-sync-button {
  border: 0;
  cursor: pointer;
}

.rss-sync-button:disabled {
  cursor: wait;
  opacity: 0.68;
}

.bulletin-filter-bar {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  flex-wrap: wrap;
}

.bulletin-filter-bar button {
  min-height: 38px;
  border: 1px solid rgba(87, 178, 204, 0.28);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.54);
  color: #0d4254;
  cursor: pointer;
  padding: 8px 13px;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0;
}

.bulletin-filter-bar button.active,
.bulletin-filter-bar button:hover {
  border-color: rgba(201, 168, 50, 0.7);
  background: rgba(255, 250, 224, 0.9);
  color: #07566d;
  box-shadow: 0 10px 22px rgba(201, 168, 50, 0.12);
}

.rss-bulletin-card {
  overflow: hidden;
  display: grid;
  grid-template-rows: minmax(170px, auto) 1fr;
  min-height: 420px;
  border: 1px solid rgba(87, 178, 204, 0.28);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 34px rgba(20, 123, 154, 0.12);
  backdrop-filter: blur(14px);
}

.rss-bulletin-card.marine {
  border-color: rgba(28, 148, 184, 0.42);
}

.rss-bulletin-card.warning {
  border-color: rgba(210, 88, 70, 0.46);
}

.rss-bulletin-card.daily {
  border-color: rgba(36, 197, 143, 0.42);
}

.rss-bulletin-card.seasonal {
  border-color: rgba(201, 168, 50, 0.48);
}

.rss-bulletin-image {
  overflow: hidden;
  display: grid;
  place-items: center;
  min-height: 170px;
  background:
    linear-gradient(135deg, rgba(207, 244, 251, 0.8), rgba(255, 255, 255, 0.58)),
    #dff7fb;
}

.rss-bulletin-image img {
  width: 100%;
  height: 100%;
  min-height: 170px;
  object-fit: cover;
}

.rss-bulletin-placeholder {
  display: grid;
  place-items: center;
  width: 104px;
  height: 104px;
  border: 1px solid rgba(87, 178, 204, 0.26);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.54);
  color: #087b9a;
  font-size: 18px;
  font-weight: 950;
}

.rss-bulletin-body {
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 18px;
}

.rss-bulletin-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: #4e7280;
  font-size: 12px;
  font-weight: 900;
}

.rss-bulletin-meta span {
  border: 1px solid rgba(201, 168, 50, 0.34);
  border-radius: 999px;
  background: rgba(255, 250, 224, 0.74);
  color: #826812;
  padding: 5px 10px;
}

.rss-bulletin-card h3 {
  margin: 0;
  color: #0d4254;
  font-size: 18px;
  font-weight: 950;
  line-height: 1.45;
}

.rss-bulletin-card p {
  margin: 0;
  color: #4e7280;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.8;
}

.rss-bulletin-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 4px;
}

.rss-bulletin-actions a {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  border: 1px solid rgba(87, 178, 204, 0.3);
  border-radius: 12px;
  color: #07566d;
  background: rgba(223, 247, 251, 0.74);
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 950;
  text-decoration: none;
}

.rss-bulletin-actions a:hover {
  border-color: rgba(201, 168, 50, 0.62);
  background: rgba(255, 250, 224, 0.82);
}

.rss-empty-card {
  grid-column: 1 / -1;
  display: grid;
  gap: 8px;
  border: 1px dashed rgba(87, 178, 204, 0.38);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.62);
  color: #0d4254;
  padding: 26px;
  text-align: center;
}

.rss-empty-card strong {
  font-size: 18px;
  font-weight: 950;
}

.rss-empty-card span {
  color: #4e7280;
  font-size: 13px;
  font-weight: 800;
}

.bulletin-toast {
  position: fixed;
  right: max(18px, env(safe-area-inset-right));
  bottom: max(22px, env(safe-area-inset-bottom));
  z-index: 120;
  transform: translateY(16px);
  border: 1px solid rgba(201, 168, 50, 0.48);
  border-radius: 16px;
  background: rgba(255, 250, 224, 0.94);
  color: #07566d;
  box-shadow: 0 18px 36px rgba(20, 123, 154, 0.18);
  opacity: 0;
  padding: 14px 18px;
  font-size: 14px;
  font-weight: 950;
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
}

.bulletin-toast.show {
  transform: translateY(0);
  opacity: 1;
}

html[data-ymic-theme="dark"] .bulletin-filter-bar button,
html[data-ymic-theme="dark"] .rss-bulletin-card,
html[data-ymic-theme="dark"] .rss-empty-card {
  border-color: rgba(147, 221, 242, 0.22);
  background: rgba(8, 31, 60, 0.72);
  color: #eaf8ff;
}

html[data-ymic-theme="dark"] .rss-bulletin-card h3,
html[data-ymic-theme="dark"] .rss-empty-card strong {
  color: #f5fbff;
}

html[data-ymic-theme="dark"] .rss-bulletin-card p,
html[data-ymic-theme="dark"] .rss-empty-card span,
html[data-ymic-theme="dark"] .rss-bulletin-meta {
  color: #b8d8e7;
}

html[data-ymic-theme="dark"] .rss-bulletin-image {
  background:
    linear-gradient(135deg, rgba(21, 85, 112, 0.82), rgba(8, 31, 60, 0.72)),
    #123f57;
}

html[data-ymic-theme="dark"] .rss-bulletin-actions a {
  border-color: rgba(147, 221, 242, 0.24);
  background: rgba(147, 221, 242, 0.12);
  color: #eaf8ff;
}

/* System theme switcher and global appearance modes. */
.ymic-theme-switcher {
  display: none;
  align-items: center;
  gap: 4px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  padding: 3px;
}

.ymic-theme-button {
  display: inline-grid;
  place-items: center;
  min-width: 38px;
  min-height: 28px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: currentColor;
  cursor: pointer;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: 0;
}

.ymic-theme-button:hover {
  background: rgba(255, 255, 255, 0.14);
}

.ymic-theme-button.active {
  background: #ffffff;
  color: #07566d;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.16);
}

.ymic-floating-theme-toggle {
  position: fixed;
  right: 0;
  top: 50%;
  z-index: 80;
  display: grid;
  place-items: center;
  width: 58px;
  height: 92px;
  border: 1px solid rgba(53, 189, 224, 0.24);
  border-right: 0;
  border-radius: 28px 0 0 28px;
  background: rgba(255, 255, 255, 0.18) !important;
  box-shadow: 0 16px 32px rgba(20, 123, 154, 0.16);
  backdrop-filter: blur(18px);
  cursor: pointer;
  transform: translateY(-50%);
}

.ymic-floating-theme-toggle:hover {
  background: rgba(255, 255, 255, 0.32) !important;
  transform: translateY(-50%) translateX(-4px);
}

.ymic-theme-orbit {
  position: relative;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 34% 32%, rgba(255, 255, 255, 0.72), transparent 25%),
    rgba(255, 255, 255, 0.16);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.28),
    0 10px 20px rgba(20, 123, 154, 0.14);
}

.ymic-theme-sun,
.ymic-theme-moon {
  position: absolute;
  inset: 9px;
  border-radius: 999px;
  transition: opacity 0.22s ease, transform 0.22s ease;
}

.ymic-theme-sun {
  background: #ffd45a;
  box-shadow:
    0 -13px 0 -9px #ffd45a,
    0 13px 0 -9px #ffd45a,
    13px 0 0 -9px #ffd45a,
    -13px 0 0 -9px #ffd45a,
    9px 9px 0 -9px #ffd45a,
    -9px -9px 0 -9px #ffd45a,
    9px -9px 0 -9px #ffd45a,
    -9px 9px 0 -9px #ffd45a;
}

.ymic-theme-moon {
  background: #dff8ff;
  box-shadow: inset -8px 0 0 #173341;
  opacity: 0;
  transform: rotate(-18deg) scale(0.62);
}

html[data-ymic-theme="dark"] .ymic-theme-sun {
  opacity: 0;
  transform: rotate(28deg) scale(0.62);
}

html[data-ymic-theme="dark"] .ymic-theme-moon {
  opacity: 1;
  transform: rotate(-18deg) scale(1);
}

html[data-ymic-theme="dark"] .ymic-floating-theme-toggle {
  border-color: rgba(124, 211, 230, 0.2) !important;
  background: rgba(4, 14, 20, 0.42) !important;
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.26);
}

html[data-ymic-theme="dark"] .ymic-theme-orbit {
  background:
    radial-gradient(circle at 68% 24%, rgba(124, 211, 230, 0.34), transparent 24%),
    rgba(255, 255, 255, 0.08);
}

html[data-ymic-theme="light"] {
  color-scheme: light;
  --ymic-bg: #f6fcff;
  --ymic-panel: rgba(255, 255, 255, 0.82);
  --ymic-line: #cdeaf2;
  --ymic-muted: #54717c;
}

html[data-ymic-theme="light"] body {
  background:
    radial-gradient(circle at 18% 0%, rgba(116, 224, 242, 0.22), transparent 34%),
    linear-gradient(180deg, #f8feff 0%, #ecfaff 48%, #e4f5f9 100%) !important;
  color: #0d4254 !important;
}

html[data-ymic-theme="light"] .ymic-top-header {
  border-bottom-color: rgba(67, 184, 214, 0.24);
  background: rgba(235, 250, 255, 0.9) !important;
  color: #0d4254 !important;
  box-shadow: 0 10px 26px rgba(20, 123, 154, 0.12);
  backdrop-filter: blur(16px);
}

html[data-ymic-theme="light"] .ymic-header-text strong,
html[data-ymic-theme="light"] .ymic-header-text span,
html[data-ymic-theme="light"] .ymic-header-text em,
html[data-ymic-theme="light"] .ymic-header-status span {
  color: #0d4254;
}

html[data-ymic-theme="light"] .ymic-header-status span,
html[data-ymic-theme="light"] .ymic-theme-switcher {
  border-color: rgba(53, 189, 224, 0.28);
  background: rgba(255, 255, 255, 0.58);
}

html[data-ymic-theme="light"] .cama-sidebar {
  border-right-color: rgba(66, 183, 213, 0.28) !important;
  background: rgba(241, 252, 255, 0.94) !important;
  color: #0d4254 !important;
  box-shadow: 8px 0 28px rgba(20, 123, 154, 0.08) !important;
}

html[data-ymic-theme="light"] .cama-sidebar-toggle,
html[data-ymic-theme="light"] .cama-mobile-menu-toggle,
html[data-ymic-theme="light"] .cama-portal-button,
html[data-ymic-theme="light"] .cama-portal-links a {
  border-color: rgba(53, 189, 224, 0.26) !important;
  background: rgba(255, 255, 255, 0.54) !important;
  color: #0d4254 !important;
}

html[data-ymic-theme="light"] .cama-portal-button:hover,
html[data-ymic-theme="light"] .cama-portal-links a:hover {
  background: rgba(53, 189, 224, 0.14) !important;
}

html[data-ymic-theme="light"] .shell,
html[data-ymic-theme="light"] .analytics-shell,
html[data-ymic-theme="light"] .wind-rose-shell,
html[data-ymic-theme="light"] .manager-shell,
html[data-ymic-theme="light"] .minimal-dashboard {
  color: #0d4254 !important;
}

html[data-ymic-theme="light"] .topbar,
html[data-ymic-theme="light"] .dashboard-commandbar,
html[data-ymic-theme="light"] .panel,
html[data-ymic-theme="light"] .metrics article,
html[data-ymic-theme="light"] .portal-strip a,
html[data-ymic-theme="light"] .weather-control-card,
html[data-ymic-theme="light"] .local-simulation-card,
html[data-ymic-theme="light"] .featured-airport-card,
html[data-ymic-theme="light"] .whatsapp-feed-panel,
html[data-ymic-theme="light"] .bulletins-report-header {
  border-color: rgba(87, 178, 204, 0.28) !important;
  background: rgba(255, 255, 255, 0.72) !important;
  color: #0d4254 !important;
  box-shadow: 0 16px 34px rgba(20, 123, 154, 0.1) !important;
}

html[data-ymic-theme="light"] h1,
html[data-ymic-theme="light"] h2,
html[data-ymic-theme="light"] strong {
  color: #0d4254;
}

html[data-ymic-theme="light"] p,
html[data-ymic-theme="light"] span,
html[data-ymic-theme="light"] small,
html[data-ymic-theme="light"] em {
  color: inherit;
}

html[data-ymic-theme="dark"] {
  color-scheme: dark;
  --ymic-bg: #07151d;
  --ymic-panel: rgba(16, 35, 45, 0.86);
  --ymic-line: rgba(124, 211, 230, 0.22);
  --ymic-muted: #9bb6c2;
  --ymic-marine-text: #d9f7ff;
}

html[data-ymic-theme="dark"] body,
html[data-ymic-theme="dark"] .bulletins-marine-shell {
  background:
    radial-gradient(circle at 16% 0%, rgba(42, 189, 218, 0.2), transparent 34%),
    radial-gradient(circle at 84% 12%, rgba(80, 128, 185, 0.16), transparent 30%),
    linear-gradient(180deg, #061017 0%, #0b1c25 48%, #07141c 100%) !important;
  color: #d9f7ff !important;
}

html[data-ymic-theme="dark"] .ymic-top-header {
  border-bottom-color: rgba(124, 211, 230, 0.16);
  background: rgba(5, 16, 24, 0.94) !important;
  color: #e5fbff !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.34);
  backdrop-filter: blur(16px);
}

html[data-ymic-theme="dark"] .ymic-header-text strong,
html[data-ymic-theme="dark"] .ymic-header-text span,
html[data-ymic-theme="dark"] .ymic-header-text em,
html[data-ymic-theme="dark"] .ymic-header-status span {
  color: #e5fbff;
}

html[data-ymic-theme="dark"] .ymic-header-status span,
html[data-ymic-theme="dark"] .ymic-theme-switcher {
  border-color: rgba(124, 211, 230, 0.2);
  background: rgba(255, 255, 255, 0.06);
}

html[data-ymic-theme="dark"] .ymic-theme-button.active {
  background: #7cd3e6;
  color: #04141b;
}

html[data-ymic-theme="dark"] .cama-sidebar {
  border-right-color: rgba(124, 211, 230, 0.16) !important;
  background: rgba(6, 17, 25, 0.96) !important;
  color: #d9f7ff !important;
  box-shadow: 10px 0 30px rgba(0, 0, 0, 0.28) !important;
}

html[data-ymic-theme="dark"] .cama-sidebar-toggle,
html[data-ymic-theme="dark"] .cama-mobile-menu-toggle,
html[data-ymic-theme="dark"] .cama-portal-button,
html[data-ymic-theme="dark"] .cama-portal-links a {
  border-color: rgba(124, 211, 230, 0.16) !important;
  background: rgba(255, 255, 255, 0.06) !important;
  color: #d9f7ff !important;
}

html[data-ymic-theme="dark"] .cama-portal-button:hover,
html[data-ymic-theme="dark"] .cama-portal-links a:hover {
  background: rgba(124, 211, 230, 0.13) !important;
}

html[data-ymic-theme="dark"] .shell,
html[data-ymic-theme="dark"] .analytics-shell,
html[data-ymic-theme="dark"] .wind-rose-shell,
html[data-ymic-theme="dark"] .manager-shell,
html[data-ymic-theme="dark"] .minimal-dashboard,
html[data-ymic-theme="dark"] .weather-bulletins-page,
html[data-ymic-theme="dark"] .marine-bulletins-page {
  color: #d9f7ff !important;
}

html[data-ymic-theme="dark"] .topbar,
html[data-ymic-theme="dark"] .dashboard-commandbar,
html[data-ymic-theme="dark"] .panel,
html[data-ymic-theme="dark"] .metrics article,
html[data-ymic-theme="dark"] .portal-strip a,
html[data-ymic-theme="dark"] .weather-control-card,
html[data-ymic-theme="dark"] .local-simulation-card,
html[data-ymic-theme="dark"] .featured-airport-card,
html[data-ymic-theme="dark"] .whatsapp-feed-panel,
html[data-ymic-theme="dark"] .bulletins-report-header,
html[data-ymic-theme="dark"] .bulletins-clock-panel,
html[data-ymic-theme="dark"] .bulletins-tabs a,
html[data-ymic-theme="dark"] .bulletin-preview {
  border-color: rgba(124, 211, 230, 0.18) !important;
  background: rgba(14, 31, 42, 0.82) !important;
  color: #d9f7ff !important;
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.26) !important;
}

html[data-ymic-theme="dark"] .windy-map-wrap,
html[data-ymic-theme="dark"] .map-wrap {
  border-color: rgba(124, 211, 230, 0.18) !important;
  background: #0d222d !important;
}

html[data-ymic-theme="dark"] h1,
html[data-ymic-theme="dark"] h2,
html[data-ymic-theme="dark"] h3,
html[data-ymic-theme="dark"] strong,
html[data-ymic-theme="dark"] .portal-strip span,
html[data-ymic-theme="dark"] .portal-strip strong,
html[data-ymic-theme="dark"] .bulletins-title-block h1,
html[data-ymic-theme="dark"] .feed-title h2,
html[data-ymic-theme="dark"] .section-title-row h2 {
  color: #e5fbff !important;
}

html[data-ymic-theme="dark"] p,
html[data-ymic-theme="dark"] span,
html[data-ymic-theme="dark"] small,
html[data-ymic-theme="dark"] em,
html[data-ymic-theme="dark"] .dashboard-commandbar span,
html[data-ymic-theme="dark"] .metrics article span,
html[data-ymic-theme="dark"] .bulletins-title-block p,
html[data-ymic-theme="dark"] .bulletins-title-block span,
html[data-ymic-theme="dark"] .feed-title p,
html[data-ymic-theme="dark"] .whatsapp-feed-panel small,
html[data-ymic-theme="dark"] .section-title-row span {
  color: #a9cbd6 !important;
}

html[data-ymic-theme="dark"] button,
html[data-ymic-theme="dark"] select,
html[data-ymic-theme="dark"] input,
html[data-ymic-theme="dark"] textarea,
html[data-ymic-theme="dark"] .segmented-control button,
html[data-ymic-theme="dark"] .layer-control button,
html[data-ymic-theme="dark"] .focus-grid button,
html[data-ymic-theme="dark"] .airport-tabs button {
  border-color: rgba(124, 211, 230, 0.18) !important;
  background: rgba(255, 255, 255, 0.07) !important;
  color: #e5fbff !important;
}

html[data-ymic-theme="dark"] button.active,
html[data-ymic-theme="dark"] .segmented-control button.active,
html[data-ymic-theme="dark"] .layer-control button.active,
html[data-ymic-theme="dark"] .focus-grid button.active,
html[data-ymic-theme="dark"] .airport-tabs button.active {
  border-color: rgba(124, 211, 230, 0.42) !important;
  background: rgba(124, 211, 230, 0.18) !important;
  color: #ffffff !important;
}

html[data-ymic-theme] .ymic-theme-button span {
  color: inherit !important;
}

html[data-ymic-theme="dark"] .ymic-theme-button.active {
  background: #7cd3e6 !important;
  color: #04141b !important;
}

html[data-ymic-theme="dark"] .active-weather-data-card,
html[data-ymic-theme="dark"] .active-weather-layer-pill,
html[data-ymic-theme="dark"] .featured-airport-metrics,
html[data-ymic-theme="dark"] .featured-metar-bulletin {
  border-color: rgba(124, 211, 230, 0.18) !important;
  background: rgba(4, 14, 20, 0.78) !important;
  color: #e5fbff !important;
}

@media (max-width: 720px) {
  .ymic-theme-switcher {
    order: 10;
    width: 100%;
    justify-content: center;
  }

  .ymic-theme-button {
    flex: 1 1 0;
  }
}

/* Professional marine sidebar navigation. */
.ymic-floating-theme-toggle {
  display: none !important;
}

.cama-sidebar {
  --sidebar-deep: #033348;
  --sidebar-mid: #05546d;
  --sidebar-cyan: #21c7df;
  --sidebar-cyan-soft: rgba(113, 224, 239, 0.16);
  --sidebar-ink: #f4fbff;
  --sidebar-muted: rgba(229, 246, 255, 0.76);
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  overflow: hidden auto !important;
  border-right: 1px solid rgba(141, 229, 241, 0.16) !important;
  background:
    radial-gradient(circle at 18% 0%, rgba(113, 224, 239, 0.22), transparent 30%),
    radial-gradient(circle at 92% 22%, rgba(36, 147, 178, 0.24), transparent 34%),
    linear-gradient(180deg, var(--sidebar-deep) 0%, var(--sidebar-mid) 52%, #022c40 100%) !important;
  color: var(--sidebar-ink) !important;
  padding: 18px 12px 16px !important;
  box-shadow: 10px 0 28px rgba(3, 24, 47, 0.24) !important;
  scrollbar-color: rgba(151, 232, 242, 0.38) transparent;
  scrollbar-width: thin;
}

.cama-sidebar-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  margin: 0 0 8px !important;
  padding: 8px !important;
  border: 1px solid rgba(151, 232, 242, 0.16) !important;
  border-radius: 10px !important;
  background: rgba(0, 23, 38, 0.2) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

.cama-sidebar-toggle {
  display: grid !important;
  place-items: center !important;
  width: 40px !important;
  height: 40px !important;
  border: 0 !important;
  border-radius: 8px !important;
  background: transparent !important;
  color: var(--sidebar-ink) !important;
  font-size: 26px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  box-shadow: none !important;
}

.cama-sidebar-toggle:hover {
  background: rgba(255, 255, 255, 0.08) !important;
}

.cama-sidebar-theme-toggle {
  flex: 0 0 auto !important;
  display: grid !important;
  place-items: center !important;
  width: 54px !important;
  height: 54px !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  border-radius: 12px !important;
  background: rgba(246, 253, 255, 0.94) !important;
  box-shadow: 0 10px 20px rgba(0, 16, 28, 0.18) !important;
  backdrop-filter: blur(14px);
}

.cama-sidebar-theme-toggle .ymic-theme-orbit {
  width: 34px;
  height: 34px;
  background: transparent;
  box-shadow: none;
}

.cama-sidebar-theme-toggle .ymic-theme-sun {
  background: #0a3d68;
  box-shadow:
    0 -15px 0 -10px #0a3d68,
    0 15px 0 -10px #0a3d68,
    15px 0 0 -10px #0a3d68,
    -15px 0 0 -10px #0a3d68,
    10px 10px 0 -10px #0a3d68,
    -10px -10px 0 -10px #0a3d68,
    10px -10px 0 -10px #0a3d68,
    -10px 10px 0 -10px #0a3d68;
}

.cama-sidebar-theme-toggle .ymic-theme-moon {
  background: #0a3d68;
  box-shadow: inset -8px 0 0 #ffffff;
}

.cama-portal-nav.ymic-sidebar-menu,
.cama-sidebar .cama-portal-nav {
  display: grid !important;
  gap: 5px !important;
  margin: 0 !important;
  padding: 0 !important;
  direction: rtl;
}

.cama-portal-group {
  display: grid !important;
  gap: 4px !important;
}

.cama-portal-button,
.cama-portal-link,
.cama-sidebar .cama-portal-links a {
  display: grid !important;
  grid-template-columns: 28px minmax(0, 1fr) 18px !important;
  align-items: center !important;
  gap: 10px !important;
  min-height: 46px !important;
  width: 100% !important;
  border: 1px solid rgba(255, 255, 255, 0) !important;
  border-radius: 8px !important;
  background: transparent !important;
  color: var(--sidebar-muted) !important;
  padding: 0 10px !important;
  text-align: right !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

.cama-portal-group.single .cama-portal-button {
  grid-template-columns: 28px minmax(0, 1fr) !important;
}

.cama-portal-group.single .cama-portal-chevron,
.cama-portal-group.single .cama-portal-links {
  display: none !important;
}

.cama-portal-button:hover,
.cama-portal-link:hover,
.cama-sidebar .cama-portal-links a:hover {
  border-color: rgba(151, 232, 242, 0.14) !important;
  background: rgba(255, 255, 255, 0.07) !important;
  color: var(--sidebar-ink) !important;
}

.cama-portal-button.active,
.cama-portal-link.active {
  position: relative;
  border-color: rgba(245, 217, 103, 0.78) !important;
  background:
    linear-gradient(90deg, rgba(33, 199, 223, 0.24), rgba(33, 199, 223, 0.1)),
    rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 0 0 2px rgba(245, 217, 103, 0.12),
    0 10px 22px rgba(0, 30, 52, 0.18) !important;
}

.cama-portal-button:active,
.cama-portal-link:active,
.cama-sidebar .cama-portal-links a:active {
  border-color: rgba(245, 217, 103, 0.86) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 0 0 2px rgba(245, 217, 103, 0.16) !important;
}

.cama-portal-button:focus-visible,
.cama-portal-link:focus-visible,
.cama-sidebar .cama-portal-links a:focus-visible {
  outline: none !important;
  border-color: rgba(245, 217, 103, 0.86) !important;
  box-shadow: 0 0 0 3px rgba(245, 217, 103, 0.18) !important;
}

.cama-portal-button.active::before,
.cama-portal-link.active::before {
  content: "";
  position: absolute;
  inset: 8px auto 8px 7px;
  width: 3px;
  border-radius: 999px;
  background: #e3c94b;
  box-shadow: 0 0 0 3px rgba(227, 201, 75, 0.12);
}

.cama-nav-icon,
.cama-nav-icon.sub {
  display: grid !important;
  place-items: center !important;
  width: 28px !important;
  height: 28px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: currentColor !important;
  font-size: 0 !important;
  box-shadow: none !important;
}

.cama-nav-icon svg {
  width: 22px;
  height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.1;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: 0.94;
}

.cama-nav-label {
  overflow: hidden;
  color: currentColor !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  line-height: 1.2 !important;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cama-portal-chevron {
  display: inline-block !important;
  color: currentColor !important;
  font-size: 18px !important;
  opacity: 0.9;
  transform: rotate(0deg) !important;
}

body:not(.sidebar-collapsed) .cama-portal-group:not(.single) .cama-portal-chevron {
  display: inline-block !important;
}

.cama-portal-group.open .cama-portal-chevron {
  transform: rotate(180deg) !important;
}

.cama-portal-links {
  display: none !important;
  gap: 4px !important;
  padding: 2px 24px 6px 0 !important;
}

.cama-portal-group.open .cama-portal-links:not(:empty) {
  display: grid !important;
}

.cama-sidebar .cama-portal-links a {
  grid-template-columns: 24px minmax(0, 1fr) 0 !important;
  min-height: 38px !important;
  border-radius: 8px !important;
  color: rgba(237, 246, 255, 0.78) !important;
  padding-inline: 10px !important;
}

.cama-sidebar-status {
  display: grid;
  gap: 8px;
  margin-top: auto;
  border: 1px solid rgba(151, 232, 242, 0.14);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.04)),
    rgba(2, 20, 41, 0.4);
  color: #ffffff;
  padding: 13px 12px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), 0 10px 22px rgba(0, 0, 0, 0.14);
}

.cama-sidebar-status span {
  color: rgba(234, 246, 255, 0.82) !important;
  font-size: 12px;
  font-weight: 800;
}

.cama-sidebar-status strong {
  color: #ffffff !important;
  font-family: var(--ymic-mono-font, Consolas, monospace);
  font-size: 14px;
  font-weight: 900;
  direction: ltr;
  text-align: left;
}

.cama-sidebar-status em {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #dcefff !important;
  font-size: 12px;
  font-style: normal;
  font-weight: 850;
}

.cama-sidebar-status i {
  display: inline-block;
  width: 11px;
  height: 11px;
  border-radius: 999px;
  background: #3ad264;
  box-shadow: 0 0 0 4px rgba(58, 210, 100, 0.14);
}

.cama-sidebar-resize {
  opacity: 0.18;
}

.sidebar-collapsed .cama-sidebar {
  padding-inline: 9px !important;
}

.sidebar-collapsed .cama-sidebar-theme-toggle,
.sidebar-collapsed .cama-sidebar-status {
  display: none !important;
}

.sidebar-collapsed .cama-portal-button,
.sidebar-collapsed .cama-portal-link {
  grid-template-columns: 1fr !important;
  justify-items: center !important;
  padding: 0 !important;
}

.sidebar-collapsed .cama-nav-label,
.sidebar-collapsed .cama-portal-chevron,
.sidebar-collapsed .cama-portal-links {
  display: none !important;
}

html[data-ymic-theme="light"] .cama-sidebar,
html[data-ymic-theme="dark"] .cama-sidebar {
  background:
    radial-gradient(circle at 18% 0%, rgba(113, 224, 239, 0.22), transparent 30%),
    radial-gradient(circle at 92% 22%, rgba(36, 147, 178, 0.24), transparent 34%),
    linear-gradient(180deg, #033348 0%, #05546d 52%, #022c40 100%) !important;
  color: #f2f8ff !important;
}

html[data-ymic-theme="light"] .cama-portal-button,
html[data-ymic-theme="light"] .cama-portal-link,
html[data-ymic-theme="light"] .cama-sidebar .cama-portal-links a,
html[data-ymic-theme="dark"] .cama-portal-button,
html[data-ymic-theme="dark"] .cama-portal-link,
html[data-ymic-theme="dark"] .cama-sidebar .cama-portal-links a {
  background: transparent !important;
  color: rgba(237, 246, 255, 0.78) !important;
}

html[data-ymic-theme="light"] .cama-portal-button.active,
html[data-ymic-theme="light"] .cama-portal-link.active,
html[data-ymic-theme="dark"] .cama-portal-button.active,
html[data-ymic-theme="dark"] .cama-portal-link.active {
  border-color: rgba(245, 217, 103, 0.78) !important;
  background:
    linear-gradient(90deg, rgba(33, 199, 223, 0.24), rgba(33, 199, 223, 0.1)),
    rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 0 0 2px rgba(245, 217, 103, 0.12),
    0 10px 22px rgba(0, 30, 52, 0.18) !important;
}

/* Keep the top title centered after all theme overrides. */
.ymic-top-header {
  justify-content: center !important;
}

.ymic-header-brand {
  justify-content: center !important;
  width: 100% !important;
  max-width: none !important;
}

.ymic-header-text {
  text-align: center !important;
  max-width: min(980px, calc(100vw - 180px)) !important;
}

.ymic-header-text strong,
.ymic-header-text span {
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: normal !important;
}

.ymic-header-authority {
  color: #102f43 !important;
  font-size: 18px !important;
  font-weight: 900 !important;
}

.ymic-header-sector {
  color: #31566a !important;
  font-size: 15px !important;
  font-weight: 800 !important;
}

.ymic-header-main-title {
  color: #082844 !important;
  font-size: 34px !important;
  font-weight: 950 !important;
}

.ymic-header-logo-slot {
  position: absolute !important;
  right: 24px !important;
  left: auto !important;
}

.ymic-header-station-slot {
  position: absolute !important;
  left: 18px !important;
  right: auto !important;
  bottom: 0 !important;
  width: 190px !important;
  height: 112px !important;
  overflow: hidden !important;
  pointer-events: none !important;
  filter: drop-shadow(0 8px 16px rgba(22, 75, 94, 0.16)) !important;
}

.ymic-header-station-slot img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: 38% 56% !important;
  mix-blend-mode: normal !important;
  opacity: 1 !important;
}

@media (max-width: 820px) {
  .ymic-top-header {
    align-items: center !important;
    padding-left: 16px !important;
    padding-right: 72px !important;
  }

  .ymic-header-logo-slot {
    right: 12px !important;
    left: auto !important;
  }

  .ymic-header-station-slot {
    left: 8px !important;
    width: 104px !important;
    height: 82px !important;
    opacity: 1 !important;
  }

  .ymic-header-text {
    max-width: calc(100vw - 190px) !important;
  }

  .ymic-header-authority {
    font-size: 13px !important;
  }

  .ymic-header-sector {
    font-size: 12px !important;
  }

  .ymic-header-main-title {
    font-size: 21px !important;
  }

  .live-metar-runway-summary {
    grid-template-columns: 1fr !important;
  }
}

/* Final responsive and PWA layer for phones, tablets, and installed app mode. */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  width: 100%;
  max-width: 100%;
  min-height: 100svh;
  overflow-x: hidden;
}

img,
svg,
canvas,
iframe,
video {
  max-width: 100%;
}

table {
  max-width: 100%;
}

.ymic-install-app-button {
  position: fixed;
  right: max(14px, env(safe-area-inset-right));
  bottom: max(18px, env(safe-area-inset-bottom));
  z-index: 130;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 44px;
  border: 1px solid rgba(245, 217, 103, 0.74);
  border-radius: 999px;
  background: rgba(7, 86, 109, 0.84);
  color: #ffffff;
  box-shadow: 0 14px 30px rgba(2, 44, 64, 0.24);
  cursor: pointer;
  padding: 9px 13px;
  font-size: 13px;
  font-weight: 950;
  backdrop-filter: blur(14px);
}

.ymic-install-app-button svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2.3;
}

@media (display-mode: standalone) {
  .ymic-install-app-button {
    display: none !important;
  }
}

@media (max-width: 1180px) {
  :root {
    --ymic-header-height: 104px;
  }

  .shell,
  .analytics-shell,
  .wind-rose-shell,
  .manager-shell,
  .minimal-dashboard,
  .sidebar-collapsed .shell,
  .sidebar-collapsed .analytics-shell,
  .sidebar-collapsed .wind-rose-shell,
  .sidebar-collapsed .manager-shell {
    width: min(100%, calc(100vw - 32px)) !important;
    max-width: none !important;
    margin-right: auto !important;
    margin-left: auto !important;
    padding-right: max(14px, env(safe-area-inset-right)) !important;
    padding-left: max(14px, env(safe-area-inset-left)) !important;
  }

  .dashboard-layout,
  .dashboard-bottom-grid,
  .aviation-grid,
  .system-health-grid,
  .runway-summary-grid,
  .sync-grid,
  .station-grid,
  .kpi-grid,
  .manager-grid,
  .wind-rose-controls,
  .chart-controls,
  .data-source-grid,
  .bid-grid,
  .heat-index-grid,
  .bulletins-showcase-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .latest-bulletins-list {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .minimal-dashboard .dashboard-kpis,
  .metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .minimal-dashboard .top-airport-weather .airport-tabs,
  .minimal-dashboard .top-airport-weather .featured-airport-metrics,
  .airport-tabs,
  .focus-grid,
  .layer-control,
  .segmented-control {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 900px) {
  :root {
    --ymic-header-height: 92px;
    --cama-sidebar-width: min(84vw, 320px);
  }

  body {
    padding-top: calc(var(--ymic-header-height) + env(safe-area-inset-top)) !important;
  }

  .ymic-top-header {
    height: calc(var(--ymic-header-height) + env(safe-area-inset-top)) !important;
    padding-top: max(10px, env(safe-area-inset-top)) !important;
    padding-bottom: 10px !important;
    padding-right: 60px !important;
    padding-left: 96px !important;
  }

  .ymic-header-text {
    gap: 2px !important;
    max-width: 100% !important;
  }

  .ymic-header-authority {
    font-size: clamp(11px, 3vw, 14px) !important;
    line-height: 1.25 !important;
  }

  .ymic-header-sector {
    font-size: clamp(10px, 2.8vw, 12px) !important;
  }

  .ymic-header-main-title {
    font-size: clamp(17px, 5vw, 24px) !important;
    line-height: 1.12 !important;
  }

  .ymic-header-logo-slot {
    right: 10px !important;
  }

  .ymic-header-logo-slot .cama-logo-wrap,
  .ymic-header-logo-slot img {
    width: 46px !important;
    height: 46px !important;
    max-width: 46px !important;
    max-height: 46px !important;
  }

  .ymic-header-station-slot {
    left: 6px !important;
    width: 84px !important;
    height: 70px !important;
  }

  .cama-mobile-menu-toggle {
    position: fixed !important;
    top: max(12px, env(safe-area-inset-top)) !important;
    right: 12px !important;
    z-index: 90 !important;
    display: grid !important;
    place-items: center !important;
    width: 44px !important;
    height: 44px !important;
    border: 1px solid rgba(245, 217, 103, 0.58) !important;
    border-radius: 14px !important;
    background: rgba(5, 84, 109, 0.84) !important;
    color: #ffffff !important;
    box-shadow: 0 10px 24px rgba(2, 44, 64, 0.18) !important;
    font-size: 22px !important;
    backdrop-filter: blur(14px) !important;
  }

  .cama-sidebar {
    position: fixed !important;
    top: 0 !important;
    bottom: 0 !important;
    left: 0 !important;
    z-index: 100 !important;
    width: min(84vw, 320px) !important;
    max-width: 320px !important;
    transform: translateX(-108%) !important;
    transition: transform 180ms ease !important;
    padding-top: max(18px, env(safe-area-inset-top)) !important;
    padding-bottom: max(16px, env(safe-area-inset-bottom)) !important;
    border-radius: 0 24px 24px 0 !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
  }

  .sidebar-mobile-open .cama-sidebar {
    transform: translateX(0) !important;
  }

  .cama-sidebar-overlay {
    position: fixed !important;
    inset: 0 !important;
    z-index: 95 !important;
    display: none !important;
    border: 0 !important;
    background: rgba(2, 28, 42, 0.42) !important;
    backdrop-filter: blur(3px) !important;
  }

  .sidebar-mobile-open .cama-sidebar-overlay {
    display: block !important;
  }

  .cama-sidebar-resize {
    display: none !important;
  }

  .sidebar-collapsed .cama-sidebar,
  .sidebar-collapsed .cama-sidebar-theme-toggle,
  .sidebar-collapsed .cama-sidebar-status,
  .sidebar-collapsed .cama-portal-links {
    display: initial;
  }

  .sidebar-collapsed .cama-nav-label,
  .sidebar-collapsed .cama-portal-chevron {
    display: inline-flex !important;
  }

  .sidebar-collapsed .cama-portal-links {
    display: grid !important;
  }

  .sidebar-collapsed .cama-sidebar-theme-toggle,
  .sidebar-collapsed .cama-sidebar-status {
    display: grid !important;
  }

  .sidebar-collapsed .cama-portal-button,
  .sidebar-collapsed .cama-portal-link,
  .cama-portal-button,
  .cama-portal-link {
    grid-template-columns: 28px minmax(0, 1fr) 18px !important;
    justify-items: stretch !important;
  }

  .minimal-dashboard .dashboard-commandbar,
  .bulletins-command-hero,
  .whatsapp-feed-panel,
  .runway-detail-grid,
  .live-metar-runway-summary,
  .thermal-layout,
  .chart-layout,
  .data-explorer-layout {
    grid-template-columns: 1fr !important;
  }

  .minimal-dashboard .portal-strip,
  .bulletins-tabs,
  .bulletins-showcase-grid,
  .latest-bulletins-list,
  .minimal-dashboard .dashboard-kpis,
  .metrics,
  .dashboard-layout,
  .dashboard-bottom-grid,
  .aviation-grid,
  .system-health-grid,
  .runway-summary-grid,
  .sync-grid,
  .station-grid,
  .kpi-grid,
  .manager-grid,
  .wind-rose-controls,
  .chart-controls,
  .data-source-grid,
  .bid-grid,
  .heat-index-grid {
    grid-template-columns: 1fr !important;
  }

  .minimal-dashboard .top-airport-weather .airport-tabs,
  .minimal-dashboard .top-airport-weather .featured-airport-metrics,
  .airport-tabs,
  .focus-grid,
  .layer-control,
  .segmented-control {
    grid-template-columns: 1fr !important;
  }

  .minimal-dashboard .top-airport-weather .featured-airport-top,
  .minimal-dashboard .top-airport-weather .featured-airport-main,
  .featured-airport-top,
  .featured-airport-main {
    grid-template-columns: 1fr !important;
    text-align: center !important;
  }

  .minimal-dashboard .top-airport-weather .featured-temp {
    justify-self: center !important;
  }

  .minimal-dashboard .top-airport-weather .featured-temp strong {
    font-size: clamp(42px, 17vw, 72px) !important;
  }

  .dashboard-commandbar,
  .panel,
  .metrics article,
  .latest-bulletins-widget,
  .weather-control-card,
  .featured-airport-card,
  .bulletins-report-header,
  .whatsapp-feed-panel,
  .rss-bulletin-card {
    border-radius: 14px !important;
  }

  .map-wrap,
  .windy-map-wrap,
  .minimal-dashboard .dashboard-map-panel .map-wrap {
    min-height: 420px !important;
    height: min(68vh, 560px) !important;
  }

  .windy-live-frame {
    min-height: 420px !important;
  }

  .active-weather-data-card {
    inset: 12px auto auto 12px !important;
    width: min(330px, calc(100vw - 58px)) !important;
  }

  .live-airport-table,
  .data-table,
  .table-wrap,
  .preview-table {
    display: block !important;
    width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .live-airport-table table,
  .data-table table,
  .table-wrap table,
  .preview-table table {
    min-width: 720px !important;
  }
}

@media (max-width: 560px) {
  :root {
    --ymic-header-height: 84px;
  }

  .ymic-top-header {
    padding-right: 58px !important;
    padding-left: 14px !important;
  }

  .ymic-header-station-slot {
    display: none !important;
  }

  .ymic-header-logo-slot .cama-logo-wrap,
  .ymic-header-logo-slot img {
    width: 40px !important;
    height: 40px !important;
  }

  .ymic-header-authority {
    font-size: 11px !important;
  }

  .ymic-header-sector {
    font-size: 10px !important;
  }

  .ymic-header-main-title {
    font-size: clamp(16px, 5.5vw, 20px) !important;
  }

  .shell,
  .analytics-shell,
  .wind-rose-shell,
  .manager-shell,
  .minimal-dashboard,
  .sidebar-collapsed .shell,
  .sidebar-collapsed .analytics-shell,
  .sidebar-collapsed .wind-rose-shell,
  .sidebar-collapsed .manager-shell {
    width: 100% !important;
    padding-right: 10px !important;
    padding-left: 10px !important;
  }

  .dashboard-commandbar,
  .metrics article,
  .panel,
  .latest-bulletins-widget,
  .weather-control-card,
  .bulletins-report-header,
  .whatsapp-feed-panel {
    padding: 14px !important;
  }

  .minimal-dashboard .portal-strip a {
    min-height: 72px !important;
  }

  .minimal-dashboard .top-airport-weather .featured-airport-card {
    padding: 16px !important;
  }

  .featured-metar-bulletin code,
  code {
    white-space: pre-wrap !important;
    overflow-wrap: anywhere !important;
  }

  .map-wrap,
  .windy-map-wrap,
  .minimal-dashboard .dashboard-map-panel .map-wrap {
    min-height: 360px !important;
    height: 62vh !important;
  }

  .active-weather-data-card {
    position: absolute !important;
    inset: 10px 10px auto 10px !important;
    width: auto !important;
  }

  .ymic-install-app-button b {
    display: none;
  }

  .ymic-install-app-button {
    width: 46px;
    justify-content: center;
    padding: 9px;
  }
}

@media (min-width: 901px) and (max-width: 1366px) {
  .shell,
  .analytics-shell,
  .wind-rose-shell,
  .manager-shell,
  .minimal-dashboard {
    width: calc(100vw - var(--cama-sidebar-width) - 28px) !important;
    margin-left: calc(var(--cama-sidebar-width) + 14px) !important;
    margin-right: 14px !important;
  }

  .minimal-dashboard .dashboard-kpis {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 900px) {
  body:not(.sidebar-mobile-open) .cama-sidebar {
    display: flex !important;
    transform: translateX(-108%) !important;
  }

  body.sidebar-mobile-open .cama-sidebar,
  .sidebar-mobile-open .cama-sidebar {
    display: flex !important;
    transform: translateX(0) !important;
  }

  body:not(.sidebar-mobile-open) .cama-sidebar-overlay {
    display: none !important;
  }

  body.sidebar-mobile-open .cama-sidebar-overlay,
  .sidebar-mobile-open .cama-sidebar-overlay {
    display: block !important;
  }
}

/* 25-second premium entry animation for mobile and installed app sessions. */
.ymic-intro-lock {
  overflow: hidden !important;
}

.ymic-entry-intro {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 8%, rgba(104, 225, 240, 0.32), transparent 32%),
    radial-gradient(circle at 82% 18%, rgba(245, 217, 103, 0.2), transparent 30%),
    linear-gradient(180deg, #eafbff 0%, #bfeef7 38%, #07566d 100%);
  color: #ffffff;
  padding: max(18px, env(safe-area-inset-top)) max(18px, env(safe-area-inset-right)) max(18px, env(safe-area-inset-bottom)) max(18px, env(safe-area-inset-left));
  opacity: 1;
  transition: opacity 560ms ease, transform 560ms ease;
}

.ymic-entry-intro.closing {
  transform: scale(1.02);
  opacity: 0;
  pointer-events: none;
}

.ymic-intro-sky {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.ymic-intro-sky span {
  position: absolute;
  display: block;
  width: 42vmax;
  height: 42vmax;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.28), transparent 62%);
  animation: ymicIntroDrift 25s linear infinite;
}

.ymic-intro-sky span:nth-child(1) {
  top: -12vmax;
  right: -10vmax;
}

.ymic-intro-sky span:nth-child(2) {
  bottom: 4vmax;
  left: -16vmax;
  animation-delay: -7s;
}

.ymic-intro-sky span:nth-child(3) {
  top: 34%;
  left: 58%;
  width: 24vmax;
  height: 24vmax;
  animation-delay: -14s;
}

.ymic-intro-radar {
  position: absolute;
  width: min(86vmin, 640px);
  aspect-ratio: 1;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 999px;
  background:
    conic-gradient(from 0deg, rgba(245, 217, 103, 0.34), transparent 20%, transparent 100%),
    repeating-radial-gradient(circle, rgba(255, 255, 255, 0.18) 0 1px, transparent 1px 58px);
  filter: blur(0.1px);
  opacity: 0.68;
  animation: ymicIntroRadar 6.2s linear infinite;
}

.ymic-intro-card {
  position: relative;
  z-index: 2;
  display: grid;
  justify-items: center;
  width: min(92vw, 620px);
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.08)),
    rgba(3, 51, 72, 0.66);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 30px 80px rgba(0, 32, 54, 0.34);
  padding: clamp(24px, 5vw, 46px);
  text-align: center;
  backdrop-filter: blur(20px);
  animation: ymicIntroCard 900ms cubic-bezier(0.2, 0.85, 0.2, 1) both;
}

.ymic-intro-logo-ring {
  position: relative;
  display: grid;
  place-items: center;
  width: clamp(128px, 34vw, 210px);
  height: clamp(128px, 34vw, 210px);
  margin-bottom: clamp(16px, 4vw, 26px);
}

.ymic-intro-logo-ring::before,
.ymic-intro-logo-ring::after,
.ymic-intro-orbit {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 999px;
  border: 1px solid rgba(245, 217, 103, 0.42);
  box-shadow: 0 0 38px rgba(245, 217, 103, 0.16);
}

.ymic-intro-logo-ring::before {
  animation: ymicIntroPulse 2.8s ease-in-out infinite;
}

.ymic-intro-logo-ring::after {
  inset: 13%;
  border-color: rgba(104, 225, 240, 0.42);
  animation: ymicIntroPulse 2.8s ease-in-out infinite reverse;
}

.ymic-intro-orbit.orbit-one {
  inset: -8%;
  border-style: dashed;
  animation: ymicIntroSpin 16s linear infinite;
}

.ymic-intro-orbit.orbit-two {
  inset: 22%;
  border-style: dotted;
  animation: ymicIntroSpin 10s linear infinite reverse;
}

.ymic-intro-logo-ring img {
  position: relative;
  z-index: 2;
  width: 74%;
  height: 74%;
  object-fit: contain;
  filter: drop-shadow(0 12px 22px rgba(0, 24, 42, 0.32));
  animation: ymicIntroLogo 3.8s ease-in-out infinite;
}

.ymic-intro-copy {
  display: grid;
  gap: 9px;
}

.ymic-intro-copy span {
  color: rgba(245, 217, 103, 0.95);
  font-size: clamp(13px, 3.2vw, 17px);
  font-weight: 950;
}

.ymic-intro-copy h1 {
  margin: 0;
  color: #ffffff;
  font-family: var(--ymic-display-font, "Segoe UI", Arial, sans-serif);
  font-size: clamp(28px, 8vw, 54px);
  font-weight: 950;
  line-height: 1.08;
  text-shadow: 0 10px 26px rgba(0, 32, 54, 0.28);
}

.ymic-intro-copy p {
  max-width: 540px;
  margin: 0 auto;
  color: rgba(236, 250, 255, 0.86);
  font-size: clamp(13px, 3.3vw, 16px);
  font-weight: 800;
  line-height: 1.75;
}

.ymic-intro-status {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  width: 100%;
  margin-top: clamp(18px, 4vw, 28px);
}

.ymic-intro-status div {
  display: grid;
  gap: 3px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 15px;
  background: rgba(255, 255, 255, 0.1);
  padding: 11px 8px;
}

.ymic-intro-status b {
  color: #ffffff;
  font-size: 13px;
  font-weight: 950;
}

.ymic-intro-status span {
  color: rgba(218, 245, 252, 0.76);
  font-size: 11px;
  font-weight: 850;
}

.ymic-intro-progress {
  overflow: hidden;
  width: 100%;
  height: 8px;
  margin-top: 20px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
}

.ymic-intro-progress i {
  display: block;
  width: 0%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #68e1f0, #f5d967, #ffffff);
  box-shadow: 0 0 18px rgba(245, 217, 103, 0.5);
  animation: ymicIntroProgress 25s linear forwards;
}

.ymic-intro-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  width: 100%;
  margin-top: 13px;
  color: rgba(236, 250, 255, 0.82);
  font-size: 13px;
  font-weight: 900;
}

.ymic-intro-footer strong {
  min-width: 38px;
  color: #f5d967;
  direction: ltr;
  font-family: var(--ymic-mono-font, Consolas, monospace);
  font-size: 18px;
  font-weight: 950;
}

.ymic-intro-skip {
  min-height: 44px;
  margin-top: 18px;
  border: 1px solid rgba(245, 217, 103, 0.72);
  border-radius: 999px;
  background: rgba(245, 217, 103, 0.92);
  color: #043348;
  cursor: pointer;
  padding: 10px 22px;
  font-size: 13px;
  font-weight: 950;
  box-shadow: 0 12px 24px rgba(0, 32, 54, 0.16);
}

.ymic-intro-waves {
  position: absolute;
  inset: auto 0 0;
  height: 32vh;
  pointer-events: none;
}

.ymic-intro-waves span {
  position: absolute;
  right: -10%;
  bottom: -18%;
  width: 120%;
  height: 44%;
  border-radius: 50% 50% 0 0;
  background: rgba(255, 255, 255, 0.14);
  animation: ymicIntroWave 9s ease-in-out infinite;
}

.ymic-intro-waves span:nth-child(2) {
  bottom: -8%;
  background: rgba(104, 225, 240, 0.18);
  animation-delay: -3s;
}

.ymic-intro-waves span:nth-child(3) {
  bottom: 2%;
  background: rgba(5, 84, 109, 0.18);
  animation-delay: -6s;
}

@keyframes ymicIntroProgress {
  from { width: 0%; }
  to { width: 100%; }
}

@keyframes ymicIntroSpin {
  to { transform: rotate(360deg); }
}

@keyframes ymicIntroPulse {
  0%, 100% { transform: scale(0.94); opacity: 0.52; }
  50% { transform: scale(1.04); opacity: 1; }
}

@keyframes ymicIntroLogo {
  0%, 100% { transform: translateY(0) scale(1); }
  50% { transform: translateY(-5px) scale(1.025); }
}

@keyframes ymicIntroRadar {
  to { transform: rotate(360deg); }
}

@keyframes ymicIntroDrift {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50% { transform: translate3d(4vw, 3vh, 0) scale(1.08); }
}

@keyframes ymicIntroWave {
  0%, 100% { transform: translateX(0) translateY(0); }
  50% { transform: translateX(5%) translateY(-8%); }
}

@keyframes ymicIntroCard {
  from {
    transform: translateY(22px) scale(0.96);
    opacity: 0;
  }
  to {
    transform: translateY(0) scale(1);
    opacity: 1;
  }
}

@media (max-width: 560px) {
  .ymic-entry-intro {
    padding: max(14px, env(safe-area-inset-top)) 12px max(14px, env(safe-area-inset-bottom));
  }

  .ymic-intro-card {
    width: min(94vw, 390px);
    border-radius: 24px;
    padding: 24px 17px;
  }

  .ymic-intro-status {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 7px;
  }

  .ymic-intro-status div {
    border-radius: 12px;
    padding: 9px 5px;
  }

  .ymic-intro-copy p {
    max-width: 320px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ymic-intro-sky span,
  .ymic-intro-radar,
  .ymic-intro-logo-ring::before,
  .ymic-intro-logo-ring::after,
  .ymic-intro-orbit,
  .ymic-intro-logo-ring img,
  .ymic-intro-waves span {
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
  }
}

/* Sidebar language switcher and bilingual layout direction. */
.cama-sidebar-language {
  display: grid;
  gap: 8px;
  border: 1px solid rgba(151, 232, 242, 0.16);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.07);
  padding: 10px;
  color: rgba(244, 251, 255, 0.9);
}

.cama-sidebar-language > span {
  font-size: 12px;
  font-weight: 900;
}

.cama-language-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}

.cama-language-options button {
  min-height: 34px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(244, 251, 255, 0.88);
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

.cama-language-options button.active,
.cama-language-options button:focus-visible {
  outline: none;
  border-color: rgba(245, 217, 103, 0.9);
  background: rgba(245, 217, 103, 0.18);
  color: #ffffff;
  box-shadow: 0 0 0 2px rgba(245, 217, 103, 0.12);
}

html[dir="rtl"],
body.ymic-lang-ar {
  direction: rtl;
}

html[dir="ltr"],
body.ymic-lang-en {
  direction: ltr;
}

body.ymic-lang-en .cama-portal-nav,
body.ymic-lang-en .cama-portal-button,
body.ymic-lang-en .cama-portal-link,
body.ymic-lang-en .cama-sidebar .cama-portal-links a {
  direction: ltr !important;
  text-align: left !important;
}

body.ymic-lang-ar .cama-portal-nav,
body.ymic-lang-ar .cama-portal-button,
body.ymic-lang-ar .cama-portal-link,
body.ymic-lang-ar .cama-sidebar .cama-portal-links a {
  direction: rtl !important;
  text-align: right !important;
}

body.ymic-lang-en .cama-portal-button,
body.ymic-lang-en .cama-portal-link,
body.ymic-lang-en .cama-sidebar .cama-portal-links a {
  grid-template-columns: 28px minmax(0, 1fr) 18px !important;
}

body.ymic-lang-ar .cama-portal-button,
body.ymic-lang-ar .cama-portal-link,
body.ymic-lang-ar .cama-sidebar .cama-portal-links a {
  grid-template-columns: 28px minmax(0, 1fr) 18px !important;
}

body.ymic-lang-en .cama-portal-links {
  padding: 2px 0 6px 24px !important;
}

body.ymic-lang-ar .cama-portal-links {
  padding: 2px 24px 6px 0 !important;
}

body.ymic-lang-en .cama-sidebar-status strong {
  text-align: left;
}

body.ymic-lang-ar .cama-sidebar-status strong {
  text-align: right;
}

@media (min-width: 901px) {
  body.ymic-lang-ar .cama-sidebar {
    right: 0 !important;
    left: auto !important;
    border-right: 0 !important;
    border-left: 1px solid rgba(141, 229, 241, 0.16) !important;
    box-shadow: -10px 0 28px rgba(3, 24, 47, 0.24) !important;
  }

  body.ymic-lang-en .cama-sidebar {
    left: 0 !important;
    right: auto !important;
    border-left: 0 !important;
    border-right: 1px solid rgba(141, 229, 241, 0.16) !important;
    box-shadow: 10px 0 28px rgba(3, 24, 47, 0.24) !important;
  }

  body.ymic-lang-ar .shell,
  body.ymic-lang-ar .analytics-shell,
  body.ymic-lang-ar .wind-rose-shell,
  body.ymic-lang-ar .manager-shell,
  body.ymic-lang-ar .minimal-dashboard {
    width: calc(100vw - var(--cama-sidebar-width) - 48px) !important;
    margin-right: calc(var(--cama-sidebar-width) + 24px) !important;
    margin-left: 24px !important;
  }

  body.ymic-lang-en .shell,
  body.ymic-lang-en .analytics-shell,
  body.ymic-lang-en .wind-rose-shell,
  body.ymic-lang-en .manager-shell,
  body.ymic-lang-en .minimal-dashboard {
    width: calc(100vw - var(--cama-sidebar-width) - 48px) !important;
    margin-left: calc(var(--cama-sidebar-width) + 24px) !important;
    margin-right: 24px !important;
  }

  body.ymic-lang-ar.sidebar-collapsed .shell,
  body.ymic-lang-ar.sidebar-collapsed .analytics-shell,
  body.ymic-lang-ar.sidebar-collapsed .wind-rose-shell,
  body.ymic-lang-ar.sidebar-collapsed .manager-shell,
  body.ymic-lang-ar.sidebar-collapsed .minimal-dashboard {
    width: calc(100vw - var(--cama-sidebar-collapsed-width) - 48px) !important;
    margin-right: calc(var(--cama-sidebar-collapsed-width) + 24px) !important;
    margin-left: 24px !important;
  }

  body.ymic-lang-en.sidebar-collapsed .shell,
  body.ymic-lang-en.sidebar-collapsed .analytics-shell,
  body.ymic-lang-en.sidebar-collapsed .wind-rose-shell,
  body.ymic-lang-en.sidebar-collapsed .manager-shell,
  body.ymic-lang-en.sidebar-collapsed .minimal-dashboard {
    width: calc(100vw - var(--cama-sidebar-collapsed-width) - 48px) !important;
    margin-left: calc(var(--cama-sidebar-collapsed-width) + 24px) !important;
    margin-right: 24px !important;
  }
}

@media (max-width: 900px) {
  body.ymic-lang-ar .cama-mobile-menu-toggle {
    right: 12px !important;
    left: auto !important;
  }

  body.ymic-lang-en .cama-mobile-menu-toggle {
    left: 12px !important;
    right: auto !important;
  }

  body.ymic-lang-ar:not(.sidebar-mobile-open) .cama-sidebar {
    right: 0 !important;
    left: auto !important;
    transform: translateX(108%) !important;
  }

  body.ymic-lang-en:not(.sidebar-mobile-open) .cama-sidebar {
    left: 0 !important;
    right: auto !important;
    transform: translateX(-108%) !important;
  }

  body.ymic-lang-ar.sidebar-mobile-open .cama-sidebar,
  body.ymic-lang-en.sidebar-mobile-open .cama-sidebar {
    transform: translateX(0) !important;
  }

  body.ymic-lang-ar.sidebar-mobile-open .cama-sidebar {
    right: 0 !important;
    left: auto !important;
  }

  body.ymic-lang-en.sidebar-mobile-open .cama-sidebar {
    left: 0 !important;
    right: auto !important;
  }

  body.ymic-lang-ar .ymic-top-header {
    padding-right: 58px !important;
    padding-left: 14px !important;
  }

  body.ymic-lang-en .ymic-top-header {
    padding-left: 58px !important;
    padding-right: 14px !important;
  }
}

/* Final responsive organization pass: keep every page fitted to the viewport. */
html,
body {
  max-width: 100%;
  overflow-x: hidden !important;
}

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

img,
svg,
video,
canvas,
iframe {
  max-width: 100%;
}

.shell,
.analytics-shell,
.wind-rose-shell,
.manager-shell,
.minimal-dashboard,
.dashboard-commandbar,
.portal-strip,
.latest-bulletins-widget,
.dashboard-layout,
.panel,
.featured-airport-card,
.featured-metar-bulletin,
.featured-airport-metrics,
.weather-control-card,
.map-wrap,
.windy-map-wrap {
  min-width: 0 !important;
  max-width: 100% !important;
}

.minimal-dashboard {
  display: grid !important;
  gap: clamp(14px, 2vw, 22px) !important;
}

.dashboard-commandbar {
  overflow: hidden !important;
  padding: clamp(14px, 2.2vw, 24px) !important;
}

.dashboard-command-title,
.airport-weather-showcase,
.featured-airport-card {
  width: 100% !important;
}

.airport-tabs,
.portal-strip,
.dashboard-kpis,
.latest-bulletins-list,
.focus-grid,
.layer-control,
.segmented-control {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 150px), 1fr)) !important;
}

.minimal-dashboard .top-airport-weather .airport-tabs {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 132px), 1fr)) !important;
}

.minimal-dashboard .top-airport-weather .featured-airport-main,
.featured-airport-main {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: clamp(12px, 2vw, 24px) !important;
}

.featured-condition,
.featured-temp,
.featured-temp-current,
.featured-feels-like,
.featured-airport-top > div {
  min-width: 0 !important;
}

.featured-condition strong,
.featured-condition span,
.featured-airport-top strong,
.featured-airport-top em,
.featured-metar-bulletin code,
.featured-airport-metrics strong,
.portal-strip strong,
.portal-strip span {
  overflow-wrap: anywhere !important;
}

.featured-temp strong {
  font-size: clamp(48px, 9vw, 112px) !important;
}

.minimal-dashboard .top-airport-weather .featured-temp strong {
  font-size: clamp(42px, 10vw, 64px) !important;
}

.featured-temp span {
  font-size: clamp(22px, 4.5vw, 48px) !important;
}

.featured-feels-like strong {
  font-size: clamp(15px, 2.4vw, 20px) !important;
}

.featured-airport-metrics,
.minimal-dashboard .top-airport-weather .featured-airport-metrics {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 104px), 1fr)) !important;
}

.featured-airport-metrics div {
  padding-inline: 2px;
}

.portal-strip a {
  min-width: 0 !important;
}

.map-wrap,
.windy-map-wrap,
.minimal-dashboard .dashboard-map-panel .map-wrap {
  width: 100% !important;
  overflow: hidden !important;
}

.windy-live-frame {
  width: 100% !important;
}

.live-airport-table-wrap,
.table-wrap {
  max-width: 100% !important;
  overflow-x: auto !important;
}

@media (min-width: 901px) {
  body.ymic-lang-ar .shell,
  body.ymic-lang-ar .analytics-shell,
  body.ymic-lang-ar .wind-rose-shell,
  body.ymic-lang-ar .manager-shell,
  body.ymic-lang-ar .minimal-dashboard,
  body.ymic-lang-en .shell,
  body.ymic-lang-en .analytics-shell,
  body.ymic-lang-en .wind-rose-shell,
  body.ymic-lang-en .manager-shell,
  body.ymic-lang-en .minimal-dashboard {
    max-width: calc(100vw - var(--cama-sidebar-width) - 48px) !important;
  }
}

@media (max-width: 900px) {
  .shell,
  .analytics-shell,
  .wind-rose-shell,
  .manager-shell,
  .minimal-dashboard,
  .sidebar-collapsed .shell,
  .sidebar-collapsed .analytics-shell,
  .sidebar-collapsed .wind-rose-shell,
  .sidebar-collapsed .manager-shell {
    width: 100% !important;
    max-width: 100vw !important;
    margin: 0 !important;
    padding-inline: clamp(10px, 3vw, 16px) !important;
  }

  .dashboard-commandbar,
  .latest-bulletins-widget,
  .weather-control-card,
  .panel {
    border-radius: 12px !important;
  }

  .minimal-dashboard .top-airport-weather .featured-airport-main,
  .featured-airport-main {
    grid-template-columns: 1fr !important;
    text-align: center !important;
  }

  .featured-condition {
    text-align: center !important;
  }

  .featured-temp {
    justify-content: center !important;
  }

  .featured-feels-like {
    text-align: center !important;
  }

  .featured-airport-top {
    grid-template-columns: auto minmax(0, 1fr) !important;
  }

  .featured-airport-top b {
    grid-column: 1 / -1;
    justify-self: center;
  }
}

@media (max-width: 560px) {
  .airport-tabs,
  .portal-strip,
  .dashboard-kpis,
  .latest-bulletins-list,
  .featured-airport-metrics,
  .minimal-dashboard .top-airport-weather .featured-airport-metrics {
    grid-template-columns: 1fr 1fr !important;
  }

  .featured-airport-metrics {
    gap: 7px !important;
    padding: 9px !important;
  }

  .featured-airport-metrics span {
    font-size: 9px !important;
  }

  .featured-airport-metrics strong {
    font-size: 11px !important;
  }

  .featured-metar-bulletin code {
    font-size: 11px !important;
  }

  .map-wrap,
  .windy-map-wrap,
  .minimal-dashboard .dashboard-map-panel .map-wrap {
    min-height: 320px !important;
    height: 58vh !important;
  }
}

/* Compact sidebar fit pass. */
.cama-sidebar {
  gap: 8px !important;
  padding: 14px 10px 12px !important;
}

.cama-sidebar-head {
  min-height: 48px !important;
  margin-bottom: 4px !important;
  padding: 6px !important;
}

.cama-sidebar-toggle {
  width: 38px !important;
  height: 38px !important;
  font-size: 22px !important;
}

.cama-sidebar-theme-toggle {
  width: 46px !important;
  height: 46px !important;
  border-radius: 10px !important;
}

.cama-sidebar-theme-toggle .ymic-theme-orbit {
  width: 28px !important;
  height: 28px !important;
}

.cama-sidebar .cama-portal-nav {
  gap: 3px !important;
}

.cama-portal-group {
  gap: 2px !important;
}

.cama-portal-button,
.cama-portal-link,
.cama-sidebar .cama-portal-links a {
  min-height: 40px !important;
  grid-template-columns: 24px minmax(0, 1fr) 16px !important;
  gap: 8px !important;
  border-radius: 7px !important;
  padding-inline: 8px !important;
}

.cama-sidebar .cama-portal-links a {
  min-height: 34px !important;
  grid-template-columns: 22px minmax(0, 1fr) 0 !important;
}

.cama-nav-icon,
.cama-nav-icon.sub {
  width: 24px !important;
  height: 24px !important;
}

.cama-nav-icon svg {
  width: 19px !important;
  height: 19px !important;
}

.cama-nav-label {
  font-size: 13px !important;
  font-weight: 820 !important;
}

.cama-sidebar-language,
.cama-sidebar-status {
  border-radius: 8px !important;
  padding: 9px !important;
}

.cama-sidebar-language {
  gap: 6px !important;
}

.cama-language-options {
  gap: 5px !important;
}

.cama-language-options button {
  min-height: 30px !important;
  font-size: 11px !important;
}

.cama-sidebar-status {
  gap: 5px !important;
}

.cama-sidebar-status span,
.cama-sidebar-status em {
  font-size: 11px !important;
}

.cama-sidebar-status strong {
  font-size: 12px !important;
}

.sidebar-collapsed .cama-sidebar-language,
.sidebar-collapsed .cama-sidebar-status {
  display: none !important;
}

@media (min-width: 901px) {
  body:not(.sidebar-collapsed) .cama-sidebar {
    width: min(var(--cama-sidebar-width), 218px) !important;
  }
}

@media (max-width: 900px) {
  .cama-sidebar {
    width: min(78vw, 286px) !important;
    max-width: calc(100vw - 54px) !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    padding: max(10px, env(safe-area-inset-top)) 9px max(10px, env(safe-area-inset-bottom)) !important;
    border-radius: 0 !important;
  }

  .cama-sidebar-head {
    position: sticky;
    top: 0;
    z-index: 2;
    background: rgba(0, 35, 52, 0.72) !important;
    backdrop-filter: blur(14px);
  }

  .cama-sidebar-resize {
    display: none !important;
  }

  .cama-portal-button,
  .cama-portal-link,
  .cama-sidebar .cama-portal-links a {
    min-height: 39px !important;
  }

  .cama-portal-links {
    padding-top: 1px !important;
    padding-bottom: 4px !important;
  }

  body.ymic-lang-ar:not(.sidebar-mobile-open) .cama-sidebar {
    transform: translateX(calc(100% + 18px)) !important;
  }

  body.ymic-lang-en:not(.sidebar-mobile-open) .cama-sidebar {
    transform: translateX(calc(-100% - 18px)) !important;
  }

  body.ymic-lang-ar.sidebar-mobile-open .cama-sidebar {
    right: 0 !important;
    left: auto !important;
  }

  body.ymic-lang-en.sidebar-mobile-open .cama-sidebar {
    left: 0 !important;
    right: auto !important;
  }
}

@media (max-width: 420px) {
  .cama-sidebar {
    width: min(82vw, 270px) !important;
    max-width: calc(100vw - 44px) !important;
  }

  .cama-nav-label {
    font-size: 12px !important;
  }

  .cama-sidebar-status {
    margin-top: 4px !important;
  }
}

/* Simplified AWOS display pass: calmer maritime layout for operations screens. */
.awos-shell {
  gap: 10px !important;
}

.awos-top-panel,
.awos-metar-panel,
.awos-card,
.awos-entry-panel {
  border-color: rgba(126, 216, 232, 0.18) !important;
  border-radius: 8px !important;
  background: rgba(6, 29, 45, 0.88) !important;
  box-shadow: 0 10px 22px rgba(0, 12, 22, 0.18) !important;
}

.awos-top-panel {
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.65fr) !important;
  gap: 12px !important;
  padding: 14px !important;
}

.awos-top-panel h1 {
  font-size: clamp(27px, 3vw, 40px) !important;
}

.awos-subtitle {
  gap: 6px !important;
  margin-top: 8px !important;
}

.awos-subtitle span,
.awos-profile-tabs a {
  border-radius: 7px !important;
  background: rgba(98, 205, 225, 0.09) !important;
  padding: 6px 9px !important;
  font-size: 11px !important;
}

.awos-profile-tabs {
  gap: 5px !important;
  overflow-x: auto;
  padding-bottom: 2px;
}

.awos-profile-tabs a {
  white-space: nowrap;
}

.awos-header-clock {
  gap: 8px !important;
}

.awos-header-clock article {
  min-height: 74px;
  border-radius: 7px !important;
  background: rgba(214, 247, 252, 0.06) !important;
  padding: 10px !important;
}

.awos-header-clock strong {
  font-size: 14px !important;
}

.awos-metar-panel {
  padding: 12px !important;
}

.awos-metar-panel code {
  margin-top: 8px !important;
  border-radius: 7px !important;
  background: rgba(2, 12, 22, 0.94) !important;
  padding: 13px !important;
  font-size: clamp(17px, 2.1vw, 26px) !important;
  line-height: 1.35 !important;
}

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

.awos-wind-card {
  grid-column: 1 / -1;
}

.awos-card {
  gap: 10px !important;
  padding: 13px !important;
}

.awos-card h2 {
  font-size: 18px !important;
}

.awos-card-head {
  gap: 10px !important;
}

.awos-card-head select {
  max-width: 150px;
}

.awos-wind-display {
  grid-template-columns: 250px minmax(0, 1fr) !important;
  gap: 12px !important;
}

.awos-compass {
  width: min(100%, 238px) !important;
  border-width: 1px !important;
}

.compass-label {
  font-size: 16px !important;
}

.compass-center {
  width: 36% !important;
  box-shadow: 0 0 0 6px rgba(3, 16, 27, 0.34) !important;
}

.compass-center strong {
  font-size: clamp(25px, 3.4vw, 42px) !important;
}

.awos-wind-readouts {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
}

.awos-wind-readouts article,
.awos-big-pair div,
.awos-component-grid article,
.awos-text-readout article {
  border-radius: 7px !important;
  background: rgba(214, 247, 252, 0.055) !important;
  padding: 10px !important;
}

.awos-wind-readouts strong,
.awos-component-grid strong,
.awos-text-readout strong {
  font-size: clamp(19px, 2vw, 28px) !important;
}

.awos-big-pair {
  grid-template-columns: repeat(auto-fit, minmax(135px, 1fr)) !important;
  gap: 8px !important;
}

.awos-big-pair strong {
  font-size: clamp(30px, 3.8vw, 52px) !important;
}

.awos-component-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
}

.awos-text-readout {
  gap: 8px !important;
}

.awos-entry-panel {
  padding: 12px !important;
  background: rgba(6, 29, 45, 0.7) !important;
}

.awos-form-grid {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)) !important;
  gap: 8px !important;
}

.awos-form-grid input,
.awos-form-grid select,
.awos-form-grid textarea,
.awos-card select,
.awos-component-grid select {
  border-radius: 7px !important;
  background: rgba(230, 250, 253, 0.08) !important;
  padding: 8px 9px !important;
}

@media (max-width: 1100px) {
  .awos-top-panel,
  .awos-display-grid,
  .awos-wind-display {
    grid-template-columns: 1fr !important;
  }

  .awos-wind-readouts,
  .awos-component-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 560px) {
  .awos-header-clock,
  .awos-wind-readouts,
  .awos-component-grid,
  .awos-text-readout {
    grid-template-columns: 1fr !important;
  }

  .awos-compass {
    width: min(100%, 220px) !important;
    --compass-degree-radius: 80px;
  }
}

/* AWOS aviation light theme. */
body:has(.awos-shell) {
  background:
    radial-gradient(circle at 10% 8%, rgba(111, 220, 236, 0.24), transparent 34%),
    linear-gradient(180deg, #f6fdff 0%, #e8f8fc 48%, #f7fbfd 100%) !important;
  color: #102f43 !important;
}

.awos-shell {
  color: #102f43 !important;
}

.awos-shell::before {
  background:
    radial-gradient(circle at 14% 10%, rgba(100, 205, 226, 0.18), transparent 32%),
    linear-gradient(180deg, #f8fdff 0%, #e8f8fc 58%, #f6fbfd 100%) !important;
}

.awos-top-panel,
.awos-metar-panel,
.awos-card,
.awos-entry-panel {
  border-color: rgba(88, 151, 177, 0.22) !important;
  background: rgba(255, 255, 255, 0.9) !important;
  box-shadow: 0 10px 24px rgba(26, 90, 116, 0.1) !important;
}

.awos-top-panel h1,
.awos-card h2,
.awos-metar-panel .panel-head h2,
.awos-entry-panel .panel-head h2 {
  color: #12384f !important;
}

.awos-top-panel .eyebrow,
.awos-header-clock span,
.awos-card span,
.awos-text-readout span,
.awos-wind-readouts span,
.awos-form-grid label {
  color: #527184 !important;
}

.awos-subtitle span,
.awos-profile-tabs a {
  border-color: rgba(64, 154, 187, 0.2) !important;
  background: rgba(215, 246, 252, 0.72) !important;
  color: #1f6079 !important;
}

.station-profile-tabs a.active,
.awos-profile-tabs a.active {
  border-color: rgba(203, 164, 57, 0.58) !important;
  background: rgba(255, 248, 220, 0.94) !important;
  color: #6b5214 !important;
}

.awos-header-clock article,
.awos-wind-readouts article,
.awos-big-pair div,
.awos-component-grid article,
.awos-text-readout article {
  border-color: rgba(88, 151, 177, 0.18) !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(240, 250, 253, 0.9)) !important;
}

.awos-header-clock strong,
.awos-wind-readouts strong,
.awos-big-pair strong,
.awos-component-grid strong,
.awos-text-readout strong {
  color: #12384f !important;
}

.awos-mode-card strong,
.awos-metar-panel .panel-head span,
.awos-big-pair em,
.awos-component-grid em,
.awos-wind-readouts em {
  color: #a67a15 !important;
}

.awos-metar-panel code {
  border-color: rgba(64, 154, 187, 0.22) !important;
  background: #f8fdff !important;
  color: #0b2f45 !important;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.74);
}

.awos-wind-card {
  background:
    radial-gradient(circle at 22% 18%, rgba(106, 216, 233, 0.2), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(235, 249, 253, 0.92)) !important;
}

.awos-compass {
  border-color: rgba(67, 154, 187, 0.34) !important;
  background:
    radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.8) 0 23%, transparent 24%),
    radial-gradient(circle at 45% 35%, rgba(110, 219, 235, 0.2), transparent 38%),
    radial-gradient(circle at 50% 50%, rgba(236, 250, 253, 0.95), rgba(218, 243, 249, 0.92) 68%),
    conic-gradient(from 0deg, rgba(67, 154, 187, 0.28) 0 1deg, transparent 1deg 29deg, rgba(67, 154, 187, 0.28) 30deg 31deg, transparent 31deg 59deg, rgba(67, 154, 187, 0.28) 60deg 61deg, transparent 61deg 89deg, rgba(67, 154, 187, 0.5) 90deg 91deg, transparent 91deg 119deg, rgba(67, 154, 187, 0.28) 120deg 121deg, transparent 121deg 149deg, rgba(67, 154, 187, 0.28) 150deg 151deg, transparent 151deg 179deg, rgba(67, 154, 187, 0.5) 180deg 181deg, transparent 181deg 209deg, rgba(67, 154, 187, 0.28) 210deg 211deg, transparent 211deg 239deg, rgba(67, 154, 187, 0.28) 240deg 241deg, transparent 241deg 269deg, rgba(67, 154, 187, 0.5) 270deg 271deg, transparent 271deg 299deg, rgba(67, 154, 187, 0.28) 300deg 301deg, transparent 301deg 329deg, rgba(67, 154, 187, 0.28) 330deg 331deg, transparent 331deg 360deg) !important;
  box-shadow:
    inset 0 0 28px rgba(67, 154, 187, 0.08),
    0 12px 24px rgba(26, 90, 116, 0.12) !important;
}

.awos-compass::before {
  border-color: rgba(67, 154, 187, 0.22) !important;
}

.compass-label {
  color: #1e647e !important;
  text-shadow: none !important;
}

.compass-degree {
  border-color: rgba(67, 154, 187, 0.12) !important;
  background: rgba(255, 255, 255, 0.5) !important;
  color: rgba(45, 115, 140, 0.62) !important;
}

.compass-label.north,
.compass-center em {
  color: #a67a15 !important;
}

.compass-tick {
  background: rgba(67, 154, 187, 0.5) !important;
}

.compass-center {
  border-color: rgba(67, 154, 187, 0.26) !important;
  background: linear-gradient(180deg, #ffffff, #eaf8fb) !important;
  color: #12384f !important;
  box-shadow: 0 0 0 6px rgba(218, 243, 249, 0.72) !important;
}

.compass-center strong {
  color: #12384f !important;
}

.compass-needle::before {
  background: linear-gradient(180deg, #d8a72d, #b78516) !important;
  filter: drop-shadow(0 6px 10px rgba(76, 53, 8, 0.18)) !important;
}

.awos-card select,
.awos-form-grid input,
.awos-form-grid select,
.awos-form-grid textarea,
.awos-component-grid select {
  border-color: rgba(88, 151, 177, 0.28) !important;
  background: #ffffff !important;
  color: #12384f !important;
}

.awos-card option,
.awos-form-grid option {
  background: #ffffff !important;
  color: #12384f !important;
}

/* AWOS unit labels above values. */
.awos-big-pair div,
.awos-component-grid article,
.awos-wind-readouts article {
  display: grid !important;
  align-content: start !important;
  gap: 4px !important;
}

.awos-big-pair div > span,
.awos-component-grid article > span,
.awos-wind-readouts article > span {
  order: 0 !important;
}

.awos-big-pair div > em,
.awos-component-grid article > em,
.awos-wind-readouts article > em {
  order: 1 !important;
  display: inline-flex !important;
  width: max-content !important;
  min-height: 18px !important;
  align-items: center !important;
  border: 1px solid rgba(216, 167, 45, 0.18) !important;
  border-radius: 999px !important;
  background: rgba(255, 246, 205, 0.84) !important;
  color: #b78516 !important;
  padding: 2px 7px !important;
  font-size: 12px !important;
  font-style: normal !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
}

.awos-big-pair div > strong,
.awos-component-grid article > strong,
.awos-wind-readouts article > strong {
  order: 2 !important;
  margin-top: 0 !important;
}

.compass-center {
  gap: 2px !important;
}

.compass-center em {
  order: 0 !important;
  display: inline-flex !important;
  border-radius: 999px !important;
  background: rgba(255, 246, 205, 0.84) !important;
  color: #b78516 !important;
  padding: 2px 7px !important;
  font-size: 11px !important;
  line-height: 1 !important;
}

.compass-center strong {
  order: 1 !important;
}

/* Remove yellow accents from AWOS light theme. */
.awos-mode-card strong,
.awos-metar-panel .panel-head span,
.awos-big-pair em,
.awos-component-grid em,
.awos-wind-readouts em,
.compass-label.north,
.compass-center em {
  color: #287c96 !important;
}

.awos-big-pair div > em,
.awos-component-grid article > em,
.awos-wind-readouts article > em,
.compass-center em {
  border-color: rgba(67, 154, 187, 0.16) !important;
  background: rgba(218, 246, 252, 0.84) !important;
  color: #287c96 !important;
}

.compass-needle::before {
  background: linear-gradient(180deg, #4fb6cc, #247c97) !important;
  filter: drop-shadow(0 6px 10px rgba(21, 91, 112, 0.18)) !important;
}

.station-profile-tabs a.active,
.awos-profile-tabs a.active {
  border-color: rgba(67, 154, 187, 0.34) !important;
  background: rgba(218, 246, 252, 0.94) !important;
  color: #1f6079 !important;
}
