/* [next]/internal/font/google/ibm_plex_sans_19c00c22.module.css [app-client] (css) */
@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/7fea77d1d19108bf-s.0xyeb7czu1stb.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/1bcd0e671759a44c-s.0vnh8.d8wxa2x.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/e15f58668ad64cb8-s.0~.8lt~vdqmc3.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/90c51ce8fb754fe8-s.00z~hoalba5dm.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/57215795b8570f5c-s.0vwgtotjdgnhr.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/03fc1b4a8d284b5e-s.p.09.f.n_ccld80.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/7fea77d1d19108bf-s.0xyeb7czu1stb.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/1bcd0e671759a44c-s.0vnh8.d8wxa2x.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/e15f58668ad64cb8-s.0~.8lt~vdqmc3.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/90c51ce8fb754fe8-s.00z~hoalba5dm.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/57215795b8570f5c-s.0vwgtotjdgnhr.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/03fc1b4a8d284b5e-s.p.09.f.n_ccld80.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/7fea77d1d19108bf-s.0xyeb7czu1stb.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/1bcd0e671759a44c-s.0vnh8.d8wxa2x.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/e15f58668ad64cb8-s.0~.8lt~vdqmc3.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/90c51ce8fb754fe8-s.00z~hoalba5dm.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/57215795b8570f5c-s.0vwgtotjdgnhr.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: IBM Plex Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/03fc1b4a8d284b5e-s.p.09.f.n_ccld80.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: IBM Plex Sans Fallback;
  src: local(Arial);
  ascent-override: 101.32%;
  descent-override: 27.18%;
  line-gap-override: 0.0%;
  size-adjust: 101.17%;
}

.ibm_plex_sans_19c00c22-module__6r45Sq__className {
  font-family: IBM Plex Sans, IBM Plex Sans Fallback;
  font-style: normal;
}

.ibm_plex_sans_19c00c22-module__6r45Sq__variable {
  --font-body: "IBM Plex Sans", "IBM Plex Sans Fallback";
}

/* [next]/internal/font/google/space_grotesk_a86eaa83.module.css [app-client] (css) */
@font-face {
  font-family: Space Grotesk;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/32687112bd2dd8db-s.0gspg~~t9nou8.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Space Grotesk;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/28868e710e86be81-s.0rx81dn62y51_.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Space Grotesk;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/0c89a48fa5027cee-s.p.0rd3rjvnnhw7n.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Space Grotesk;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../media/32687112bd2dd8db-s.0gspg~~t9nou8.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Space Grotesk;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../media/28868e710e86be81-s.0rx81dn62y51_.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Space Grotesk;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../media/0c89a48fa5027cee-s.p.0rd3rjvnnhw7n.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Space Grotesk Fallback;
  src: local(Arial);
  ascent-override: 89.71%;
  descent-override: 26.62%;
  line-gap-override: 0.0%;
  size-adjust: 109.69%;
}

.space_grotesk_a86eaa83-module__dyT-lq__className {
  font-family: Space Grotesk, Space Grotesk Fallback;
  font-style: normal;
}

.space_grotesk_a86eaa83-module__dyT-lq__variable {
  --font-heading: "Space Grotesk", "Space Grotesk Fallback";
}

/* [project]/node_modules/.pnpm/leaflet@1.9.4/node_modules/leaflet/dist/leaflet.css [app-client] (css) */
.leaflet-pane, .leaflet-tile, .leaflet-marker-icon, .leaflet-marker-shadow, .leaflet-tile-container, .leaflet-pane > svg, .leaflet-pane > canvas, .leaflet-zoom-box, .leaflet-image-layer, .leaflet-layer {
  position: absolute;
  top: 0;
  left: 0;
}

.leaflet-container {
  overflow: hidden;
}

.leaflet-tile, .leaflet-marker-icon, .leaflet-marker-shadow {
  -webkit-user-select: none;
  user-select: none;
  -webkit-user-drag: none;
}

.leaflet-tile::selection {
  background: none;
}

.leaflet-safari .leaflet-tile {
  image-rendering: -webkit-optimize-contrast;
}

.leaflet-safari .leaflet-tile-container {
  -webkit-transform-origin: 0 0;
  width: 1600px;
  height: 1600px;
}

.leaflet-marker-icon, .leaflet-marker-shadow {
  display: block;
}

.leaflet-container .leaflet-overlay-pane svg {
  max-width: none !important;
  max-height: none !important;
}

.leaflet-container .leaflet-marker-pane img, .leaflet-container .leaflet-shadow-pane img, .leaflet-container .leaflet-tile-pane img, .leaflet-container img.leaflet-image-layer, .leaflet-container .leaflet-tile {
  width: auto;
  padding: 0;
  max-width: none !important;
  max-height: none !important;
}

.leaflet-container img.leaflet-tile {
  mix-blend-mode: plus-lighter;
}

.leaflet-container.leaflet-touch-zoom {
  -ms-touch-action: pan-x pan-y;
  touch-action: pan-x pan-y;
}

.leaflet-container.leaflet-touch-drag {
  -ms-touch-action: pinch-zoom;
  touch-action: none;
  touch-action: pinch-zoom;
}

.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom {
  -ms-touch-action: none;
  touch-action: none;
}

.leaflet-container {
  -webkit-tap-highlight-color: transparent;
}

.leaflet-container a {
  -webkit-tap-highlight-color: #33b5e566;
}

.leaflet-tile {
  filter: inherit;
  visibility: hidden;
}

.leaflet-tile-loaded {
  visibility: inherit;
}

.leaflet-zoom-box {
  box-sizing: border-box;
  z-index: 800;
  width: 0;
  height: 0;
}

.leaflet-overlay-pane svg {
  -moz-user-select: none;
}

.leaflet-pane {
  z-index: 400;
}

.leaflet-tile-pane {
  z-index: 200;
}

.leaflet-overlay-pane {
  z-index: 400;
}

.leaflet-shadow-pane {
  z-index: 500;
}

.leaflet-marker-pane {
  z-index: 600;
}

.leaflet-tooltip-pane {
  z-index: 650;
}

.leaflet-popup-pane {
  z-index: 700;
}

.leaflet-map-pane canvas {
  z-index: 100;
}

.leaflet-map-pane svg {
  z-index: 200;
}

.leaflet-vml-shape {
  width: 1px;
  height: 1px;
}

.lvml {
  behavior: url("#default#VML");
  display: inline-block;
  position: absolute;
}

.leaflet-control {
  z-index: 800;
  pointer-events: visiblePainted;
  pointer-events: auto;
  position: relative;
}

.leaflet-top, .leaflet-bottom {
  z-index: 1000;
  pointer-events: none;
  position: absolute;
}

.leaflet-top {
  top: 0;
}

.leaflet-right {
  right: 0;
}

.leaflet-bottom {
  bottom: 0;
}

.leaflet-left {
  left: 0;
}

.leaflet-control {
  float: left;
  clear: both;
}

.leaflet-right .leaflet-control {
  float: right;
}

.leaflet-top .leaflet-control {
  margin-top: 10px;
}

.leaflet-bottom .leaflet-control {
  margin-bottom: 10px;
}

.leaflet-left .leaflet-control {
  margin-left: 10px;
}

.leaflet-right .leaflet-control {
  margin-right: 10px;
}

.leaflet-fade-anim .leaflet-popup {
  opacity: 0;
  transition: opacity .2s linear;
}

.leaflet-fade-anim .leaflet-map-pane .leaflet-popup {
  opacity: 1;
}

.leaflet-zoom-animated {
  transform-origin: 0 0;
}

svg.leaflet-zoom-animated {
  will-change: transform;
}

.leaflet-zoom-anim .leaflet-zoom-animated {
  -webkit-transition: -webkit-transform .25s cubic-bezier(0, 0, .25, 1);
  -moz-transition: -moz-transform .25s cubic-bezier(0, 0, .25, 1);
  transition: transform .25s cubic-bezier(0, 0, .25, 1);
}

.leaflet-zoom-anim .leaflet-tile, .leaflet-pan-anim .leaflet-tile {
  transition: none;
}

.leaflet-zoom-anim .leaflet-zoom-hide {
  visibility: hidden;
}

.leaflet-interactive {
  cursor: pointer;
}

.leaflet-grab {
  cursor: -webkit-grab;
  cursor: -moz-grab;
  cursor: grab;
}

.leaflet-crosshair, .leaflet-crosshair .leaflet-interactive {
  cursor: crosshair;
}

.leaflet-popup-pane, .leaflet-control {
  cursor: auto;
}

.leaflet-dragging .leaflet-grab, .leaflet-dragging .leaflet-grab .leaflet-interactive, .leaflet-dragging .leaflet-marker-draggable {
  cursor: move;
  cursor: -webkit-grabbing;
  cursor: -moz-grabbing;
  cursor: grabbing;
}

.leaflet-marker-icon, .leaflet-marker-shadow, .leaflet-image-layer, .leaflet-pane > svg path, .leaflet-tile-container {
  pointer-events: none;
}

.leaflet-marker-icon.leaflet-interactive, .leaflet-image-layer.leaflet-interactive, .leaflet-pane > svg path.leaflet-interactive, svg.leaflet-image-layer.leaflet-interactive path {
  pointer-events: visiblePainted;
  pointer-events: auto;
}

.leaflet-container {
  outline-offset: 1px;
  background: #ddd;
}

.leaflet-container a {
  color: #0078a8;
}

.leaflet-zoom-box {
  background: #ffffff80;
  border: 2px dotted #38f;
}

.leaflet-container {
  font-family: Helvetica Neue, Arial, Helvetica, sans-serif;
  font-size: .75rem;
  line-height: 1.5;
}

.leaflet-bar {
  border-radius: 4px;
  box-shadow: 0 1px 5px #000000a6;
}

.leaflet-bar a {
  text-align: center;
  color: #000;
  background-color: #fff;
  border-bottom: 1px solid #ccc;
  width: 26px;
  height: 26px;
  line-height: 26px;
  text-decoration: none;
  display: block;
}

.leaflet-bar a, .leaflet-control-layers-toggle {
  background-position: 50%;
  background-repeat: no-repeat;
  display: block;
}

.leaflet-bar a:hover, .leaflet-bar a:focus {
  background-color: #f4f4f4;
}

.leaflet-bar a:first-child {
  border-top-left-radius: 4px;
  border-top-right-radius: 4px;
}

.leaflet-bar a:last-child {
  border-bottom: none;
  border-bottom-right-radius: 4px;
  border-bottom-left-radius: 4px;
}

.leaflet-bar a.leaflet-disabled {
  cursor: default;
  color: #bbb;
  background-color: #f4f4f4;
}

.leaflet-touch .leaflet-bar a {
  width: 30px;
  height: 30px;
  line-height: 30px;
}

.leaflet-touch .leaflet-bar a:first-child {
  border-top-left-radius: 2px;
  border-top-right-radius: 2px;
}

.leaflet-touch .leaflet-bar a:last-child {
  border-bottom-right-radius: 2px;
  border-bottom-left-radius: 2px;
}

.leaflet-control-zoom-in, .leaflet-control-zoom-out {
  text-indent: 1px;
  font: bold 18px Lucida Console, Monaco, monospace;
}

.leaflet-touch .leaflet-control-zoom-in, .leaflet-touch .leaflet-control-zoom-out {
  font-size: 22px;
}

.leaflet-control-layers {
  background: #fff;
  border-radius: 5px;
  box-shadow: 0 1px 5px #0006;
}

.leaflet-control-layers-toggle {
  background-image: url("../media/layers.1220hx8ja1.sy.png");
  width: 36px;
  height: 36px;
}

.leaflet-retina .leaflet-control-layers-toggle {
  background-image: url("../media/layers-2x.0olxl6i2vnf_c.png");
  background-size: 26px 26px;
}

.leaflet-touch .leaflet-control-layers-toggle {
  width: 44px;
  height: 44px;
}

.leaflet-control-layers .leaflet-control-layers-list, .leaflet-control-layers-expanded .leaflet-control-layers-toggle {
  display: none;
}

.leaflet-control-layers-expanded .leaflet-control-layers-list {
  display: block;
  position: relative;
}

.leaflet-control-layers-expanded {
  color: #333;
  background: #fff;
  padding: 6px 10px 6px 6px;
}

.leaflet-control-layers-scrollbar {
  padding-right: 5px;
  overflow: hidden scroll;
}

.leaflet-control-layers-selector {
  margin-top: 2px;
  position: relative;
  top: 1px;
}

.leaflet-control-layers label {
  font-size: 1.08333em;
  display: block;
}

.leaflet-control-layers-separator {
  border-top: 1px solid #ddd;
  height: 0;
  margin: 5px -10px 5px -6px;
}

.leaflet-default-icon-path {
  background-image: url("../media/marker-icon.0i9~u_difxrfa.png");
}

.leaflet-container .leaflet-control-attribution {
  background: #fffc;
  margin: 0;
}

.leaflet-control-attribution, .leaflet-control-scale-line {
  color: #333;
  padding: 0 5px;
  line-height: 1.4;
}

.leaflet-control-attribution a {
  text-decoration: none;
}

.leaflet-control-attribution a:hover, .leaflet-control-attribution a:focus {
  text-decoration: underline;
}

.leaflet-attribution-flag {
  width: 1em;
  height: .6669em;
  vertical-align: baseline !important;
  display: inline !important;
}

.leaflet-left .leaflet-control-scale {
  margin-left: 5px;
}

.leaflet-bottom .leaflet-control-scale {
  margin-bottom: 5px;
}

.leaflet-control-scale-line {
  white-space: nowrap;
  box-sizing: border-box;
  text-shadow: 1px 1px #fff;
  background: #fffc;
  border: 2px solid #777;
  border-top: none;
  padding: 2px 5px 1px;
  line-height: 1.1;
}

.leaflet-control-scale-line:not(:first-child) {
  border-top: 2px solid #777;
  border-bottom: none;
  margin-top: -2px;
}

.leaflet-control-scale-line:not(:first-child):not(:last-child) {
  border-bottom: 2px solid #777;
}

.leaflet-touch .leaflet-control-attribution, .leaflet-touch .leaflet-control-layers, .leaflet-touch .leaflet-bar {
  box-shadow: none;
}

.leaflet-touch .leaflet-control-layers, .leaflet-touch .leaflet-bar {
  background-clip: padding-box;
  border: 2px solid #0003;
}

.leaflet-popup {
  text-align: center;
  margin-bottom: 20px;
  position: absolute;
}

.leaflet-popup-content-wrapper {
  text-align: left;
  border-radius: 12px;
  padding: 1px;
}

.leaflet-popup-content {
  min-height: 1px;
  margin: 13px 24px 13px 20px;
  font-size: 1.08333em;
  line-height: 1.3;
}

.leaflet-popup-content p {
  margin: 1.3em 0;
}

.leaflet-popup-tip-container {
  pointer-events: none;
  width: 40px;
  height: 20px;
  margin-top: -1px;
  margin-left: -20px;
  position: absolute;
  left: 50%;
  overflow: hidden;
}

.leaflet-popup-tip {
  pointer-events: auto;
  width: 17px;
  height: 17px;
  margin: -10px auto 0;
  padding: 1px;
  transform: rotate(45deg);
}

.leaflet-popup-content-wrapper, .leaflet-popup-tip {
  color: #333;
  background: #fff;
  box-shadow: 0 3px 14px #0006;
}

.leaflet-container a.leaflet-popup-close-button {
  text-align: center;
  color: #757575;
  background: none;
  border: none;
  width: 24px;
  height: 24px;
  font: 16px / 24px Tahoma, Verdana, sans-serif;
  text-decoration: none;
  position: absolute;
  top: 0;
  right: 0;
}

.leaflet-container a.leaflet-popup-close-button:hover, .leaflet-container a.leaflet-popup-close-button:focus {
  color: #585858;
}

.leaflet-popup-scrolled {
  overflow: auto;
}

.leaflet-oldie .leaflet-popup-content-wrapper {
  -ms-zoom: 1;
}

.leaflet-oldie .leaflet-popup-tip {
  -ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";
  width: 24px;
  filter: progid:DXImageTransform.Microsoft.Matrix(M11=.707107, M12=.707107, M21=-.707107, M22=.707107);
  margin: 0 auto;
}

.leaflet-oldie .leaflet-control-zoom, .leaflet-oldie .leaflet-control-layers, .leaflet-oldie .leaflet-popup-content-wrapper, .leaflet-oldie .leaflet-popup-tip {
  border: 1px solid #999;
}

.leaflet-div-icon {
  background: #fff;
  border: 1px solid #666;
}

.leaflet-tooltip {
  color: #222;
  white-space: nowrap;
  -webkit-user-select: none;
  user-select: none;
  pointer-events: none;
  background-color: #fff;
  border: 1px solid #fff;
  border-radius: 3px;
  padding: 6px;
  position: absolute;
  box-shadow: 0 1px 3px #0006;
}

.leaflet-tooltip.leaflet-interactive {
  cursor: pointer;
  pointer-events: auto;
}

.leaflet-tooltip-top:before, .leaflet-tooltip-bottom:before, .leaflet-tooltip-left:before, .leaflet-tooltip-right:before {
  pointer-events: none;
  content: "";
  background: none;
  border: 6px solid #0000;
  position: absolute;
}

.leaflet-tooltip-bottom {
  margin-top: 6px;
}

.leaflet-tooltip-top {
  margin-top: -6px;
}

.leaflet-tooltip-bottom:before, .leaflet-tooltip-top:before {
  margin-left: -6px;
  left: 50%;
}

.leaflet-tooltip-top:before {
  border-top-color: #fff;
  margin-bottom: -12px;
  bottom: 0;
}

.leaflet-tooltip-bottom:before {
  border-bottom-color: #fff;
  margin-top: -12px;
  margin-left: -6px;
  top: 0;
}

.leaflet-tooltip-left {
  margin-left: -6px;
}

.leaflet-tooltip-right {
  margin-left: 6px;
}

.leaflet-tooltip-left:before, .leaflet-tooltip-right:before {
  margin-top: -6px;
  top: 50%;
}

.leaflet-tooltip-left:before {
  border-left-color: #fff;
  margin-right: -12px;
  right: 0;
}

.leaflet-tooltip-right:before {
  border-right-color: #fff;
  margin-left: -12px;
  left: 0;
}

@media print {
  .leaflet-control {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
}

/* [project]/apps/web/src/app/globals.css [app-client] (css) */
:root {
  --color-bg: #0b0f14;
  --color-bg-secondary: #111827;
  --color-surface: #161f2b;
  --color-surface-elevated: #1e293b;
  --color-surface-strong: #243244;
  --color-line: #2a3647;
  --color-line-strong: #334155;
  --color-text: #f8fafc;
  --color-text-secondary: #cbd5e1;
  --color-text-muted: #94a3b8;
  --color-orange: #f60;
  --color-orange-deep: #e65c00;
  --color-orange-soft: #ff9a52;
  --color-orange-glow: #ff66002e;
  --color-success: #4ade80;
  --color-warning: #fbbf24;
  --color-danger: #f87171;
  --shadow-soft: 0 20px 48px #02061757;
  --shadow-lifted: 0 28px 80px #02061780;
  --shadow-accent: 0 18px 48px #f603;
  --radius-panel: 24px;
  --radius-control: 18px;
}

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

html {
  --lightningcss-light: ;
  --lightningcss-dark: initial;
  color-scheme: dark;
  background: linear-gradient(#10161f 0%, #0b0f14 42% 100%);
  min-height: 100%;
}

body {
  min-height: 100vh;
  color: var(--color-text);
  font-family: var(--font-body), sans-serif;
  background: linear-gradient(#10161ff5 0%, #0b0f14 30%);
  margin: 0;
  overflow-x: hidden;
}

main, section, div {
  min-width: 0;
}

a {
  color: inherit;
  text-decoration: none;
}

button, input {
  font: inherit;
}

img {
  max-width: 100%;
}

h1, h2, h3, h4, strong {
  font-family: var(--font-heading), sans-serif;
  color: var(--color-text);
}

h1, h2, h3, h4, p {
  margin-top: 0;
}

p, li, small {
  line-height: 1.65;
}

p, li {
  color: var(--color-text-secondary);
}

small {
  color: var(--color-text-muted);
}

::selection {
  color: var(--color-text);
  background: #ff66004d;
}

.site-frame {
  isolation: isolate;
  min-height: 100vh;
  position: relative;
}

.site-frame--live-map {
  flex-direction: column;
  display: flex;
  overflow: hidden;
}

.site-frame:before {
  content: "";
  z-index: -2;
  pointer-events: none;
  background: radial-gradient(circle at 50% -10%, #ffffff09, #0000 34%), radial-gradient(circle at 18% 8%, #ff66000b, #0000 22%);
  position: fixed;
  inset: 0;
}

.site-frame:after {
  content: "";
  z-index: -1;
  pointer-events: none;
  opacity: .06;
  background-image: linear-gradient(#94a3b814 1px, #0000 1px), linear-gradient(90deg, #94a3b814 1px, #0000 1px);
  background-size: 88px 88px;
  position: fixed;
  inset: 0;
  -webkit-mask-image: linear-gradient(#000 0%, #00000073 32%, #0000 82%);
  mask-image: linear-gradient(#000 0%, #00000073 32%, #0000 82%);
}

.site-frame--pilot:before {
  background: radial-gradient(circle at 50% -12%, #ffffff0a, #0000 32%), radial-gradient(circle at 78% 0, #ff66000d, #0000 20%);
}

.page-shell {
  width: min(100% - 2rem, 1120px);
  margin: 0 auto;
}

.page-shell--wide {
  width: min(100% - 2rem, 1240px);
}

.page-shell--narrow {
  width: min(100% - 2rem, 780px);
}

.live-map-shell {
  flex: 1;
  min-height: 0;
  padding: .2rem .85rem .85rem;
  display: flex;
}

.site-header {
  z-index: 30;
  background: linear-gradient(#0b0f14eb, #0b0f1480 78%, #0000);
  padding: .9rem 0 .75rem;
  position: sticky;
  top: 0;
}

.site-header__inner {
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  box-shadow: var(--shadow-soft), inset 0 1px 0 #ffffff0a;
  background: linear-gradient(#ffffff0a, #0000 36%), #111827c7;
  border: 1px solid #2a3647e0;
  border-radius: 24px;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.2rem;
  display: flex;
}

.brand-mark {
  flex-shrink: 0;
  align-items: center;
  gap: .95rem;
  display: inline-flex;
}

.brand-mark__badge {
  background: linear-gradient(135deg, #ffffff1f, transparent 28%),
    linear-gradient(135deg, var(--color-orange), var(--color-orange-deep));
  min-width: 3.25rem;
  color: var(--color-text);
  letter-spacing: .1em;
  text-transform: uppercase;
  box-shadow: var(--shadow-accent), inset 0 1px 0 #ffffff29;
  border: 1px solid #ffffff14;
  border-radius: 18px;
  justify-content: center;
  align-items: center;
  padding: .8rem .95rem;
  font-weight: 700;
  display: inline-flex;
}

.brand-mark__icon {
  filter: drop-shadow(0 4px 14px #0f172a33);
  flex-shrink: 0;
  width: 1.72rem;
  height: 1.72rem;
  display: block;
}

.brand-mark__text {
  flex-direction: column;
  gap: .15rem;
  display: flex;
}

.brand-mark__text strong {
  letter-spacing: -.02em;
  font-size: 1rem;
}

.brand-mark__text small {
  color: var(--color-text-muted);
}

.site-nav {
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: .45rem;
  display: flex;
}

.site-nav__link, .site-header__login {
  border: 1px solid #0000;
  border-radius: 16px;
  justify-content: center;
  align-items: center;
  min-height: 2.85rem;
  padding: .72rem 1rem;
  transition: transform .2s, color .2s, border-color .2s, background-color .2s, box-shadow .2s;
  display: inline-flex;
}

.site-nav__link {
  color: var(--color-text-muted);
}

.site-nav__link:hover, .site-header__login:hover {
  transform: translateY(-1px);
}

.site-nav__link:hover {
  color: var(--color-text);
  background: #ffffff0a;
  border-color: #334155d1;
}

.site-nav__link--active {
  color: #fff2e8;
  background: linear-gradient(135deg, #ff660038, #e65c0014), #ffffff05;
  border-color: #ff660052;
  box-shadow: 0 0 0 1px #ff660014, inset 0 1px #ffffff0f;
}

.site-header__login {
  background: linear-gradient(135deg, #ffffff1f, transparent 22%),
    linear-gradient(135deg, var(--color-orange), var(--color-orange-deep));
  color: var(--color-text);
  box-shadow: var(--shadow-accent);
  border-color: #ff660047;
  flex-shrink: 0;
  font-weight: 700;
}

.pilot-chip {
  background: linear-gradient(135deg, #ff66001f, #111827d1 56%), #111827cc;
  border: 1px solid #334155e0;
  border-radius: 18px;
  align-items: center;
  gap: .9rem;
  padding: .35rem .4rem .35rem 1rem;
  display: inline-flex;
  box-shadow: inset 0 1px #ffffff0a;
}

.pilot-chip strong {
  margin-bottom: .08rem;
  display: block;
}

.pilot-chip small {
  color: var(--color-text-muted);
}

.pilot-chip .button {
  width: auto;
}

.disclaimer-banner {
  box-shadow: var(--shadow-soft);
  background: linear-gradient(135deg, #ff660014, #111827f5 52%), #111827f0;
  border: 1px solid #ff66002e;
  border-radius: 20px;
  gap: .35rem;
  margin: 1.2rem 0 0;
  padding: 1rem 1.15rem 1rem 1.35rem;
  display: grid;
  position: relative;
  overflow: hidden;
}

.disclaimer-banner:before {
  content: "";
  background: linear-gradient(180deg, var(--color-orange), #f603);
  width: 4px;
  position: absolute;
  inset: 0 auto 0 0;
}

.disclaimer-banner strong {
  color: var(--color-orange-soft);
}

.disclaimer-banner p {
  color: var(--color-text-secondary);
  margin: 0;
}

.disclaimer-banner--compact {
  margin-bottom: 1.6rem;
}

.surface-card, .empty-state, .error-state, .loading-state, .page-hero {
  border-radius: var(--radius-panel);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  background: linear-gradient(#ffffff0a, #0000 18%), linear-gradient(#202937fa, #141c28f5);
  border: 1px solid #2a3647e6;
  position: relative;
  overflow: hidden;
  box-shadow: 0 24px 54px #02061757, inset 0 1px #ffffff0d, inset 0 -1px #0f172aa6;
}

.surface-card:before, .page-hero:before, .empty-state:before, .error-state:before, .loading-state:before {
  content: "";
  background: linear-gradient(90deg, #fff3, #0000 68%);
  height: 1px;
  position: absolute;
  inset: 0 0 auto;
}

.surface-card:after, .page-hero:after, .empty-state:after, .error-state:after, .loading-state:after {
  content: "";
  opacity: .28;
  background: linear-gradient(90deg, #ffffff0f, #0000 58%);
  height: 1px;
  position: absolute;
  inset: auto 1.2rem .95rem;
}

.surface-card {
  padding: 1.75rem;
  transition: transform .25s, border-color .25s, box-shadow .25s;
}

.surface-card:hover {
  border-color: #ffffff14;
  transform: translateY(-2px);
  box-shadow: 0 30px 70px #0206176b, inset 0 1px #ffffff0d, inset 0 -1px #0f172ab8;
}

.hero__copy:hover, .hero__aside:hover, .page-hero:hover, .not-found-card:hover {
  transform: none;
}

.surface-card h2, .content-section h2, .section-heading h2 {
  letter-spacing: -.03em;
  margin-bottom: .8rem;
  font-size: clamp(1.5rem, 3vw, 2.2rem);
}

.hero, .content-grid, .panel-grid, .card-grid, .stats-grid, .two-column, .dashboard-grid {
  gap: 1.25rem;
  display: grid;
}

.hero {
  grid-template-columns: minmax(0, 1.38fr) minmax(310px, .62fr);
  margin-bottom: 2rem;
}

.hero__copy, .hero__aside {
  min-height: 100%;
}

.hero__copy {
  background: linear-gradient(#262f3efa, #131b27f5);
  align-content: start;
  gap: .25rem;
  padding: 2.6rem;
  display: grid;
}

.hero__aside {
  background: linear-gradient(#1d2633fa, #0f151ffa);
  border-color: #ffffff0f;
  align-content: start;
  padding: 2rem;
  display: grid;
}

.hero__aside p, .hero__aside li, .hero__aside small {
  color: var(--color-text-secondary);
}

.hero h1, .page-hero h1, .not-found-card h1 {
  letter-spacing: -.05em;
  max-width: 12ch;
  margin-bottom: 1rem;
  font-size: clamp(2.6rem, 5vw, 4.8rem);
  line-height: .98;
}

.hero__subtitle, .page-hero p {
  max-width: 72ch;
  color: var(--color-text-secondary);
  font-size: 1.05rem;
}

.hero__actions, .inline-actions {
  flex-wrap: wrap;
  gap: .8rem;
  margin-top: 1.8rem;
  display: flex;
}

.hero-aside-content {
  gap: .9rem;
  display: grid;
}

.hero-aside-content h2 {
  letter-spacing: -.03em;
  margin: 0;
  font-size: 1.7rem;
}

.hero-summary-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .9rem;
  display: grid;
}

.hero-summary-card {
  background: linear-gradient(#ffffff06, #0000 32%), #0b0f1442;
  border: 1px solid #3d4a5bd1;
  border-radius: 18px;
  padding: 1.05rem 1.05rem 1rem;
  box-shadow: inset 0 1px #ffffff08;
}

.hero-summary-card span {
  color: var(--color-text-muted);
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: .32rem;
  font-size: .75rem;
  font-weight: 700;
  display: block;
}

.hero-summary-card strong {
  font-size: 1.5rem;
  line-height: 1.1;
  display: block;
}

.hero-summary-card small {
  margin-top: .2rem;
  display: block;
}

.hero-aside-note {
  margin: 0;
}

.page-hero {
  background: linear-gradient(#222c3afa, #121823f5);
  gap: .95rem;
  margin: 0 0 1.8rem;
  padding: 2rem 2.1rem 2.15rem;
  display: grid;
}

.section-eyebrow {
  width: fit-content;
  color: var(--color-orange-soft);
  letter-spacing: .16em;
  text-transform: uppercase;
  background: #ff660014;
  border: 1px solid #ff66002e;
  border-radius: 999px;
  align-items: center;
  gap: .65rem;
  padding: .42rem .78rem;
  font-size: .74rem;
  font-weight: 700;
  display: inline-flex;
}

.section-eyebrow:before {
  content: "";
  background: var(--color-orange);
  border-radius: 999px;
  flex-shrink: 0;
  width: .42rem;
  height: .42rem;
  box-shadow: 0 0 0 6px #ff66001f;
}

.section-heading {
  margin-bottom: .8rem;
}

.content-section {
  gap: .9rem;
  display: grid;
}

.content-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-bottom: 2rem;
}

.panel-grid, .card-grid, .dashboard-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 1.6rem;
}

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

.dashboard-grid > * {
  grid-column: span 6;
}

.dashboard-grid > :last-child {
  grid-column: span 12;
}

.card-grid > *, .content-grid > *, .panel-grid > *, .two-column > *, .dashboard-grid > * {
  min-width: 0;
}

.card-grid .surface-card, .panel-grid .surface-card, .two-column .surface-card, .dashboard-grid .surface-card {
  height: 100%;
}

.stats-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin: 1.85rem 0 2.35rem;
}

.two-column {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 1.6rem;
}

.section-band {
  margin-top: 2.2rem;
}

.section-band:first-of-type {
  margin-top: 0;
}

.section-band__header {
  justify-content: space-between;
  align-items: end;
  gap: 1rem;
  margin-bottom: 1rem;
  display: flex;
}

.section-band__header h2 {
  letter-spacing: -.03em;
  margin: 0;
  font-size: clamp(1.45rem, 2.5vw, 2rem);
}

.section-band__header p {
  max-width: 38rem;
  color: var(--color-text-muted);
  margin: 0;
}

.stat-card {
  background: linear-gradient(#27313ffa, #161e2af7), #111827f5;
  border-color: #3d4a5bd6;
  padding: 1.55rem 1.45rem 1.35rem;
}

.stat-card:after {
  content: "";
  opacity: .9;
  background: linear-gradient(90deg, #ff66009e, #ff66000a);
  height: 2px;
  position: absolute;
  bottom: 1.15rem;
  left: 1.45rem;
  right: 1.45rem;
}

.stat-card strong {
  margin-bottom: .45rem;
  font-size: clamp(1.9rem, 4vw, 2.8rem);
  line-height: 1.04;
  display: block;
}

.stat-card span {
  color: var(--color-text-muted);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .82rem;
  font-weight: 700;
}

.dashboard-stats-grid .stat-card {
  min-height: 11.25rem;
}

.stat-card small {
  color: var(--color-text-secondary);
  margin-top: .8rem;
  display: block;
}

.definition-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .95rem;
  margin-top: 1.15rem;
  display: grid;
}

.definition-grid > div {
  background: #0b0f1452;
  border: 1px solid #334155d6;
  border-radius: 18px;
  padding: .95rem 1rem;
  box-shadow: inset 0 1px #ffffff05;
}

.definition-grid span {
  color: var(--color-text-muted);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .78rem;
  font-weight: 700;
  display: block;
}

.definition-grid strong {
  margin-top: .24rem;
  font-size: 1rem;
  line-height: 1.35;
  display: block;
}

.live-map-layout {
  grid-template-columns: minmax(0, 1.45fr) minmax(320px, .75fr);
  align-items: start;
  gap: 1.25rem;
  display: grid;
}

.live-map-sidebar {
  gap: 1.25rem;
  display: grid;
}

.live-map-card {
  align-content: start;
  gap: 1.15rem;
  display: grid;
}

.live-map-card--map {
  padding: 1.35rem;
}

.live-map-card__header {
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  display: flex;
}

.live-map-card__header h2, .live-map-card h2 {
  letter-spacing: -.03em;
  margin: 0;
  font-size: 1.55rem;
}

.live-map-card__header p, .live-map-card p {
  color: var(--color-text-muted);
  margin: 0;
}

.live-map-card__refresh {
  min-width: 9.5rem;
}

.live-map-canvas-wrap {
  background: linear-gradient(#1e293bf0, #0b0f14f0), #0f172ad1;
  border: 1px solid #334155d6;
  border-radius: 24px;
  min-height: 35rem;
  position: relative;
  overflow: hidden;
}

.live-map-canvas {
  width: 100%;
  min-height: 35rem;
}

.live-map-overlay {
  z-index: 5;
  place-items: center;
  padding: .5rem;
  display: grid;
  position: absolute;
  inset: 1rem;
}

.live-map-summary-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem;
  display: grid;
}

.live-map-summary-item {
  background: #0b0f1457;
  border: 1px solid #334155d6;
  border-radius: 18px;
  padding: .95rem 1rem;
}

.live-map-summary-item span {
  color: var(--color-text-muted);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .76rem;
  font-weight: 700;
  display: block;
}

.live-map-summary-item strong {
  letter-spacing: -.03em;
  margin-top: .25rem;
  font-size: 1.4rem;
  display: block;
}

.live-map-note {
  font-size: .95rem;
}

.live-map-note--accent {
  color: var(--color-text-secondary);
}

.live-map-route-caption {
  color: #c7e9ff;
  margin-top: .55rem;
}

.live-map-inline-error {
  color: #fecaca;
  background: #7f1d1d2e;
  border: 1px solid #f8717147;
  border-radius: 16px;
  padding: .9rem 1rem;
  font-size: .94rem;
}

.live-map-legend {
  gap: .9rem;
  display: grid;
}

.live-map-legend__item {
  align-items: flex-start;
  gap: .8rem;
  display: flex;
}

.live-map-legend__item strong, .live-map-flight-item__header strong {
  display: block;
}

.live-map-legend__item small, .live-map-flight-item__header small {
  color: var(--color-text-muted);
}

.live-phase-dot, .live-phase-pill {
  border: 1px solid #0000;
  border-radius: 999px;
  align-items: center;
  gap: .45rem;
  display: inline-flex;
}

.live-phase-dot {
  flex-shrink: 0;
  width: .95rem;
  height: .95rem;
  margin-top: .2rem;
}

.live-map-route-swatch {
  background: linear-gradient(90deg, #7dd3fc75, #7dd3fc);
  border-radius: 999px;
  flex-shrink: 0;
  width: 2.2rem;
  height: .36rem;
  margin-top: .5rem;
  display: inline-flex;
  box-shadow: 0 0 18px #7dd3fc3d;
}

.live-phase-pill {
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: .42rem .8rem;
  font-size: .74rem;
  font-weight: 700;
}

.live-phase--parked {
  color: #fecaca;
  background: #ef444424;
  border-color: #f8717147;
}

.live-phase--pushback {
  color: #fdba74;
  background: #f9731624;
  border-color: #f973164d;
}

.live-phase--taxi {
  color: #fde68a;
  background: #f59e0b24;
  border-color: #f59e0b4d;
}

.live-phase--airborne {
  color: #bbf7d0;
  background: #22c55e24;
  border-color: #22c55e47;
}

.live-map-flight-list {
  gap: .9rem;
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
}

.live-map-flight-item {
  background: linear-gradient(#1e293b57, #0b0f143d), #0f172a3d;
  border: 1px solid #334155d1;
  border-radius: 18px;
  padding: 1rem 1.05rem;
}

.live-map-flight-item__header {
  justify-content: space-between;
  align-items: flex-start;
  gap: .8rem;
  display: flex;
}

.live-map-flight-item__meta {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
  margin-top: .85rem;
  display: grid;
}

.live-map-flight-item__meta span, .live-map-popup__metrics span {
  color: var(--color-text-muted);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .72rem;
  font-weight: 700;
  display: block;
}

.live-map-flight-item__meta strong, .live-map-popup__metrics strong {
  margin-top: .2rem;
  display: block;
}

.live-map-popup .leaflet-popup-content-wrapper {
  color: var(--color-text);
  background: linear-gradient(#1e293bfa, #0f172afa), #0f172afa;
  border: 1px solid #334155f0;
  border-radius: 18px;
  box-shadow: 0 26px 52px #02061773, inset 0 1px #ffffff0a;
}

.live-map-popup .leaflet-popup-tip {
  background: #0f172afa;
}

.live-map-popup .leaflet-popup-content {
  min-width: 12.5rem;
  margin: 0;
}

.live-map-popup__content {
  gap: .85rem;
  padding: 1rem;
  display: grid;
}

.live-map-popup__content h3 {
  margin: 0;
  font-size: 1.05rem;
}

.live-map-popup__metrics {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
  display: grid;
}

.ops-card {
  align-content: start;
  gap: 1rem;
  display: grid;
}

.ops-card h2, .ops-card h3 {
  letter-spacing: -.03em;
  margin: 0;
  font-size: clamp(1.25rem, 2.2vw, 1.85rem);
}

.ops-card p {
  margin: 0;
}

.ops-card--highlight {
  background: linear-gradient(135deg, #ff66001f, #1f2937f0 44%), linear-gradient(#27313ffa, #141c28f5);
  border-color: #ff66003d;
  box-shadow: 0 26px 68px #0206176b, 0 0 0 1px #ff66000f, inset 0 1px #ffffff0d;
}

.ops-card--full {
  grid-column: span 2;
}

.ops-card__header {
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  display: flex;
}

.ops-meta-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem;
  display: grid;
}

.ops-meta-item {
  background: #0b0f1452;
  border: 1px solid #334155d6;
  border-radius: 18px;
  gap: .3rem;
  padding: .95rem 1rem;
  display: grid;
  box-shadow: inset 0 1px #ffffff05;
}

.ops-meta-item span {
  color: var(--color-text-muted);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .76rem;
  font-weight: 700;
}

.ops-meta-item strong {
  font-size: .98rem;
  line-height: 1.35;
}

.panel-note {
  background: #0b0f1447;
  border: 1px solid #334155d6;
  border-radius: 18px;
  padding: .95rem 1rem;
}

.panel-note p {
  margin: 0;
}

.status-list {
  gap: .8rem;
  display: grid;
}

.status-list__item {
  background: #0b0f144d;
  border: 1px solid #334155d6;
  border-radius: 18px;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  padding: .95rem 1rem;
  display: flex;
}

.status-list__item > span:first-child {
  color: var(--color-text-secondary);
  font-weight: 600;
}

.list-clean {
  gap: .75rem;
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
}

.list-clean li {
  padding-left: 1.35rem;
  position: relative;
}

.list-clean li:before {
  content: "";
  background: var(--color-orange);
  border-radius: 999px;
  width: .5rem;
  height: .5rem;
  position: absolute;
  top: .72rem;
  left: 0;
  box-shadow: 0 0 0 6px #ff66001f;
}

.button {
  cursor: pointer;
  letter-spacing: .01em;
  border: 1px solid #334155e6;
  border-radius: 16px;
  justify-content: center;
  align-items: center;
  gap: .45rem;
  min-height: 3rem;
  padding: .8rem 1.2rem;
  font-weight: 700;
  transition: transform .2s, box-shadow .2s, border-color .2s, background-color .2s, color .2s;
  display: inline-flex;
}

.button:hover:not(:disabled) {
  transform: translateY(-1px);
}

.button:disabled {
  opacity: .6;
  cursor: not-allowed;
}

.button--primary {
  background: linear-gradient(135deg, #ffffff29, transparent 24%),
    linear-gradient(135deg, var(--color-orange), var(--color-orange-deep));
  color: var(--color-text);
  box-shadow: var(--shadow-accent);
  border-color: #ff660057;
}

.button--secondary {
  color: var(--color-text);
  background: linear-gradient(#ffffff08, #0000 30%), #1e293bd6;
}

.button--ghost {
  color: var(--color-text-secondary);
  background: #ffffff08;
}

.button--secondary:hover:not(:disabled), .button--ghost:hover:not(:disabled) {
  box-shadow: var(--shadow-soft);
  border-color: #ff66002e;
}

.button--primary:hover:not(:disabled) {
  box-shadow: 0 22px 48px #ff660042;
}

.button:focus-visible, .site-nav__link:focus-visible, .site-header__login:focus-visible, .field input:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px #ff66002e;
}

.badge {
  letter-spacing: .04em;
  border: 1px solid #0000;
  border-radius: 999px;
  justify-content: center;
  align-items: center;
  min-height: 2rem;
  padding: .25rem .72rem;
  font-size: .8rem;
  font-weight: 700;
  display: inline-flex;
  box-shadow: inset 0 1px #ffffff0d;
}

.badge--neutral {
  color: var(--color-text-secondary);
  background: #94a3b814;
  border-color: #94a3b829;
}

.badge--info {
  color: var(--color-orange-soft);
  background: #ff66001f;
  border-color: #ff660038;
}

.badge--success {
  color: var(--color-success);
  background: #4ade801a;
  border-color: #4ade8033;
}

.badge--warning {
  color: var(--color-warning);
  background: #fbbf241a;
  border-color: #fbbf2438;
}

.badge--danger {
  color: var(--color-danger);
  background: #f871711a;
  border-color: #f8717133;
}

.empty-state, .error-state, .loading-state {
  text-align: left;
  gap: .7rem;
  padding: 1.6rem;
  display: grid;
}

.empty-state__action, .error-state__action {
  margin-top: .35rem;
}

.error-state {
  background: linear-gradient(#7f1d1d2e, #0000 42%), linear-gradient(#1e293bf5, #161f2bf5);
  border-color: #f871712e;
}

.loading-state {
  grid-auto-flow: column;
  justify-content: center;
  align-items: center;
  padding: 2rem;
}

.loading-state__spinner {
  border: 2px solid #ff66002e;
  border-top-color: var(--color-orange);
  border-radius: 999px;
  width: 1rem;
  height: 1rem;
  animation: .7s linear infinite spin;
}

.table-shell {
  background: linear-gradient(#ffffff06, #0000 22%), #0b0f145c;
  border: 1px solid #344152d6;
  border-radius: 20px;
  overflow-x: auto;
  box-shadow: inset 0 1px #ffffff06, inset 0 -1px #0f172a80;
}

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

.data-table th, .data-table td {
  vertical-align: top;
  text-align: left;
  border-bottom: 1px solid #2a3647bd;
  padding: 1rem 1.05rem;
}

.data-table th:first-child, .data-table td:first-child {
  padding-left: 1.2rem;
}

.data-table th:last-child, .data-table td:last-child {
  padding-right: 1.2rem;
}

.data-table th {
  color: var(--color-text-muted);
  letter-spacing: .14em;
  text-transform: uppercase;
  background: #0b0f148f;
  font-size: .74rem;
  font-weight: 700;
}

.data-table td {
  color: var(--color-text-secondary);
}

.data-table tbody tr {
  transition: background-color .2s;
}

.data-table tbody tr:nth-child(2n) td {
  background: #ffffff05;
}

.data-table tbody tr:hover td {
  background: #ffffff08;
}

.data-table tbody tr:last-child td {
  border-bottom: 0;
}

.table-primary, .table-secondary, .table-badge-stack {
  gap: .24rem;
  display: grid;
}

.table-primary strong, .table-secondary strong {
  font-size: .98rem;
}

.table-primary span, .table-secondary span, .table-badge-stack small {
  color: var(--color-text-muted);
}

.table-inline-link {
  color: var(--color-orange-soft);
  font-weight: 700;
  transition: color .2s;
}

.table-inline-link:hover {
  color: var(--color-text);
}

.table-muted {
  color: var(--color-text-muted);
}

.table-cell-actions {
  width: 220px;
}

.table-action-group {
  flex-wrap: wrap;
  align-items: flex-start;
  gap: .75rem;
  display: flex;
}

.action-stack {
  gap: .5rem;
  min-width: min(100%, 180px);
  display: grid;
}

.action-stack .button {
  width: 100%;
}

.inline-feedback {
  margin: 0;
  font-size: .82rem;
  font-weight: 600;
  line-height: 1.45;
}

.inline-feedback--success {
  color: var(--color-success);
}

.inline-feedback--danger {
  color: var(--color-danger);
}

.auth-card, .not-found-card {
  max-width: none;
}

.auth-card {
  min-height: 100%;
}

.auth-form {
  gap: 1rem;
  margin-top: 1.15rem;
  display: grid;
}

.field {
  gap: .45rem;
  display: grid;
}

.field-group {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .9rem;
  display: grid;
}

.field label {
  color: var(--color-text-secondary);
  font-size: .92rem;
  font-weight: 600;
}

.field input {
  min-height: 3.1rem;
  color: var(--color-text);
  background: #0b0f148f;
  border: 1px solid #2a3647f2;
  border-radius: 16px;
  padding: .85rem .95rem;
  transition: border-color .2s, box-shadow .2s, background-color .2s;
  box-shadow: inset 0 1px #ffffff05;
}

.field input::placeholder {
  color: var(--color-text-muted);
}

.field input:focus {
  background: #111827d1;
  border-color: #ff660070;
  outline: none;
}

.form-error {
  color: #fecaca;
  background: #7f1d1d2e;
  border: 1px solid #f8717138;
  border-radius: 16px;
  margin: 0;
  padding: .8rem .95rem;
  font-weight: 600;
}

.profile-card {
  gap: 1.1rem;
  display: grid;
}

.profile-card__header {
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  display: flex;
}

.profile-card__identity {
  text-align: right;
  background: linear-gradient(135deg, #ff660029, #1e293be0 52%), #111827db;
  border: 1px solid #ff660038;
  border-radius: 18px;
  padding: 1rem 1.1rem;
  box-shadow: inset 0 1px #ffffff0d;
}

.profile-card__identity strong {
  font-size: 1.45rem;
  line-height: 1.1;
  display: block;
}

.profile-card__identity span {
  color: var(--color-text-secondary);
}

.profile-card__actions {
  justify-content: flex-start;
  display: flex;
}

.simbrief-card__note {
  color: var(--color-text-secondary);
  margin: 0;
  line-height: 1.7;
}

.simbrief-ofp-card__route {
  margin-top: 1.15rem;
}

.simbrief-ofp-card__route p {
  color: var(--color-text-secondary);
  word-break: break-word;
  margin: 0;
}

.site-footer {
  background: linear-gradient(#0b0f1400, #0b0f14b3 16%, #0b0f14f5);
  border-top: 1px solid #2a3647bd;
  margin-top: 4.2rem;
  padding: 2.75rem 0 3rem;
}

.site-footer__inner {
  grid-template-columns: minmax(0, 1.35fr) auto;
  align-items: start;
  gap: 1.5rem;
  display: grid;
}

.site-footer strong {
  font-size: 1.02rem;
  display: block;
}

.site-footer p {
  max-width: 36rem;
  margin: .55rem 0 0;
}

.site-footer__links {
  color: var(--color-text-muted);
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .8rem 1rem;
  display: flex;
}

.site-footer__links a {
  transition: color .2s;
}

.site-footer__links a:hover {
  color: var(--color-text);
}

.site-footer__legal {
  max-width: 46rem;
  color: var(--color-text-muted);
  margin-top: .95rem;
  font-size: .92rem;
  display: block;
}

.not-found-card {
  text-align: center;
  max-width: 760px;
  margin: 3.8rem auto;
  padding: 2.4rem;
}

.not-found-card .section-eyebrow {
  margin-inline: auto;
}

.not-found-card .button {
  margin-top: 1rem;
}

.site-header--compact {
  background: linear-gradient(#0b0f148f, #0b0f1414 86%, #0000);
  padding: .14rem 0 .08rem;
}

.site-header__inner--compact {
  background: linear-gradient(#ffffff0a, #0000 36%), #0c11188a;
  border-radius: 16px;
  padding: .5rem .72rem;
  box-shadow: 0 10px 28px #02061729, inset 0 1px #ffffff0a;
}

.site-header--compact .site-nav__link, .site-header--compact .site-header__login {
  border-radius: 13px;
  min-height: 2.15rem;
  padding: .42rem .72rem;
}

.site-header--compact .brand-mark__badge {
  border-radius: 14px;
  min-width: 2.65rem;
  padding: .56rem .72rem;
}

.site-header__login--compact {
  box-shadow: 0 8px 18px #ff66001f;
}

.site-header--compact .brand-mark__text strong {
  font-size: .92rem;
}

.site-header--compact .brand-mark__text small {
  font-size: .74rem;
}

.site-header--compact .site-nav {
  gap: .26rem;
}

.live-map-page {
  flex: 1;
  width: 100%;
  min-height: 0;
  margin-top: 0;
  display: flex;
}

.live-map-experience {
  flex: 1;
  min-height: 0;
  display: flex;
  position: relative;
}

.live-map-stage {
  isolation: isolate;
  background: linear-gradient(#ffffff09, #0000 18%), linear-gradient(#141c27fa, #090d12fa);
  border: 1px solid #334155d6;
  border-radius: 32px;
  flex: 1;
  min-height: max(40rem, 100vh - 5.25rem);
  position: relative;
  overflow: hidden;
  box-shadow: 0 32px 84px #0206176b, inset 0 1px #ffffff0a;
}

.live-map-stage:before, .live-map-stage:after {
  content: "";
  z-index: 1;
  pointer-events: none;
  position: absolute;
  left: 0;
  right: 0;
}

.live-map-stage:before {
  background: linear-gradient(#060a0fa8, #0000);
  height: 9.5rem;
  top: 0;
}

.live-map-stage:after {
  background: linear-gradient(#0000, #060a0fb3);
  height: 7.5rem;
  bottom: 0;
}

.live-map-experience--immersive .live-map-stage {
  min-height: max(42rem, 100vh - 4.7rem);
}

.live-map-canvas-shell {
  z-index: 0;
  background: radial-gradient(circle at 50% 10%, #ffffff08, #0000 24%), #0f172a;
  border: 1px solid #3341559e;
  border-radius: 28px;
  position: absolute;
  inset: 1rem;
  overflow: hidden;
  box-shadow: inset 0 1px #ffffff08, inset 0 0 0 1px #0b0f142e;
}

.live-map-canvas {
  width: 100%;
  height: 100%;
}

.live-map-canvas.leaflet-container {
  font-family: var(--font-body), sans-serif;
  background: radial-gradient(circle at 50% 10%, #ffffff09, #0000 24%), #0f172a;
}

.live-map-scene-layout {
  z-index: 1200;
  pointer-events: none;
  grid-template-columns: minmax(18rem, 23rem) minmax(18.5rem, 20.5rem);
  justify-content: space-between;
  gap: 1rem;
  display: grid;
  position: absolute;
  inset: 1rem;
}

.live-map-scene-layout--map-only {
  grid-template-columns: minmax(18rem, 23rem);
}

.live-map-scene-layout__left {
  flex-direction: column;
  gap: .85rem;
  max-width: 23rem;
  min-height: 0;
  display: flex;
}

.live-map-scene-layout__left > *, .live-map-scene-layout__right {
  pointer-events: auto;
}

.live-map-scene-stack {
  align-content: start;
  gap: .75rem;
  display: grid;
}

.live-map-brief, .live-map-toolbar {
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  background: linear-gradient(#ffffff0a, #0000 30%), #0a0e146b;
  border: 1px solid #334155b8;
  box-shadow: 0 12px 28px #02061729, inset 0 1px #ffffff0a;
}

.live-map-brief {
  border-radius: 20px;
  gap: .55rem;
  padding: .9rem .98rem;
  display: grid;
}

.live-map-brief__copy {
  gap: .35rem;
  display: grid;
}

.live-map-brief__copy h1 {
  letter-spacing: -.045em;
  margin: 0;
  font-size: clamp(1.32rem, 2vw, 1.85rem);
  line-height: .98;
}

.live-map-brief__copy p {
  max-width: 20rem;
  color: var(--color-text-secondary);
  margin: 0;
  font-size: .88rem;
}

.live-map-toolbar {
  border-radius: 18px;
  flex-wrap: wrap;
  gap: .52rem;
  padding: .72rem .78rem;
  display: flex;
}

.live-map-control-button {
  width: auto;
  min-height: 2.4rem;
  box-shadow: none;
  border-radius: 14px;
  padding: .56rem .8rem;
}

.live-map-experience--immersive .live-map-brief {
  padding: .8rem .88rem;
}

.live-map-experience--immersive .live-map-brief__copy h1 {
  font-size: clamp(1.18rem, 1.8vw, 1.55rem);
}

.live-map-scene-notice {
  width: min(22rem, 100%);
  margin-top: auto;
}

.live-map-scene-notice .empty-state, .live-map-scene-notice .error-state {
  background: linear-gradient(#202937e6, #141c28db), #111827d1;
  border-radius: 20px;
  box-shadow: 0 18px 40px #02061733, inset 0 1px #ffffff0a;
}

.live-map-hud {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .6rem;
  display: grid;
}

.live-map-hud__chip {
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  background: linear-gradient(#ffffff0b, #0000 30%), #0a0e1485;
  border: 1px solid #334155ad;
  border-radius: 16px;
  min-width: 0;
  padding: .72rem .84rem;
  box-shadow: 0 12px 28px #02061724, inset 0 1px #ffffff0a;
}

.live-map-hud__chip span {
  color: var(--color-text-muted);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .72rem;
  font-weight: 700;
  display: block;
}

.live-map-hud__chip strong {
  margin-top: .24rem;
  font-size: .92rem;
  line-height: 1.35;
  display: block;
}

.live-map-overlay {
  z-index: 1250;
  pointer-events: none;
  display: grid;
  position: absolute;
  inset: 0;
}

.live-map-overlay--centered .empty-state, .live-map-overlay--centered .error-state, .live-map-overlay--centered .loading-state {
  pointer-events: auto;
  background: linear-gradient(#202937f5, #141c28f0), #111827e6;
  width: min(30rem, 100% - 2rem);
}

.live-map-scene-layout__right {
  grid-template-rows: auto auto minmax(0, 1fr);
  justify-self: end;
  gap: .85rem;
  width: clamp(18.5rem, 22vw, 20.5rem);
  min-height: 0;
  display: grid;
}

.live-map-overlay-panel {
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  background: linear-gradient(#ffffff0d, #0000 28%), #0b0f1485;
  border: 1px solid #334155b8;
  border-radius: 20px;
  gap: 1rem;
  min-height: 0;
  padding: .95rem 1rem 1rem;
  display: grid;
  box-shadow: 0 12px 28px #02061724, inset 0 1px #ffffff0a;
}

.live-map-overlay-panel__head {
  gap: .55rem;
  display: grid;
}

.live-map-overlay-panel__head .section-eyebrow {
  padding: .34rem .68rem;
  font-size: .67rem;
}

.live-map-overlay-panel__head h2 {
  letter-spacing: -.03em;
  margin: 0;
  font-size: 1.18rem;
}

.live-map-overlay-panel--traffic {
  min-height: 0;
}

.live-map-overlay-panel--traffic .live-map-flight-list {
  min-height: 0;
  max-height: none;
  padding-right: .18rem;
  overflow: auto;
}

.live-map-summary-grid {
  gap: .75rem;
}

.live-map-summary-item {
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  background: #0b0f145c;
  border-color: #334155b3;
  padding: .9rem .95rem;
}

.live-map-note {
  margin: 0;
}

.live-map-route-caption {
  color: #c7e9ff;
  margin: 0;
}

.live-map-inline-error {
  margin: 0;
}

.live-map-legend {
  gap: .8rem;
}

.live-map-flight-item {
  background: linear-gradient(#1e293b6b, #0b0f144d), #0f172a3d;
  border-color: #334155bd;
  transition: transform .2s, border-color .2s, background-color .2s;
}

.live-map-flight-item:hover {
  background: linear-gradient(#1e293b80, #0b0f145c), #0f172a52;
  border-color: #ffffff14;
  transform: translateY(-1px);
}

.live-map-aircraft-icon {
  filter: drop-shadow(0 10px 20px #02061761);
}

.live-map-route-line {
  filter: drop-shadow(0 0 12px #7dd3fc29);
}

.live-map-canvas .leaflet-control-zoom a {
  color: var(--color-text);
  background: #0f172aeb;
  border-color: #334155e6;
}

.live-map-canvas .leaflet-control-zoom a:hover {
  color: var(--color-text);
  background: #1e293bfa;
}

.live-map-canvas .leaflet-control-attribution {
  color: var(--color-text-muted);
  background: #0b0f14d1;
  border-top-left-radius: 14px;
}

.live-map-canvas .leaflet-control-attribution a {
  color: var(--color-text-secondary);
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

@media (max-width: 1120px) {
  .site-header__inner {
    flex-wrap: wrap;
  }

  .site-footer__inner {
    grid-template-columns: 1fr;
  }

  .site-footer__links {
    justify-content: flex-start;
  }

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

  .site-header--compact .brand-mark__text small {
    display: none;
  }
}

@media (max-width: 900px) {
  .hero, .content-grid, .panel-grid, .card-grid, .two-column, .dashboard-grid, .definition-grid, .live-map-layout, .live-map-summary-grid, .live-map-flight-item__meta, .live-map-popup__metrics, .field-group {
    grid-template-columns: 1fr;
  }

  .live-map-stage {
    border-radius: 28px;
    min-height: max(34rem, 100vh - 4.5rem);
  }

  .live-map-experience--immersive .live-map-stage {
    min-height: max(35rem, 100vh - 4.1rem);
  }

  .live-map-scene-layout {
    grid-template-rows: auto minmax(0, 1fr);
    grid-template-columns: 1fr;
    align-content: stretch;
    gap: .85rem;
    inset: .85rem;
  }

  .live-map-scene-layout--map-only {
    grid-template-columns: 1fr;
  }

  .live-map-scene-layout__left {
    gap: .75rem;
    max-width: none;
  }

  .live-map-toolbar {
    padding: .68rem .72rem;
  }

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

  .live-map-overlay--centered {
    padding: 1rem;
  }

  .live-map-scene-layout__right {
    grid-template-rows: repeat(3, minmax(min-content, max-content));
    width: auto;
    max-height: min(48vh, 28rem);
    overflow: auto;
  }

  .live-map-overlay-panel {
    border-radius: 20px;
  }

  .live-map-overlay-panel--traffic .live-map-flight-list {
    max-height: 14rem;
  }

  .live-map-scene-notice {
    width: min(24rem, 100%);
  }

  .site-header--compact .site-nav {
    display: none;
  }

  .site-header--compact .site-header__inner {
    justify-content: space-between;
  }

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

  .live-map-card__header, .live-map-flight-item__header {
    flex-direction: column;
  }

  .live-map-canvas-wrap, .live-map-canvas {
    min-height: 26rem;
  }

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

  .profile-card__header {
    flex-direction: column;
  }

  .profile-card__identity {
    text-align: left;
  }

  .ops-card--full {
    grid-column: span 1;
  }

  .ops-card__header, .status-list__item {
    flex-direction: column;
  }

  .ops-meta-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .page-shell, .page-shell--wide, .page-shell--narrow {
    width: min(100% - 1.2rem, 1240px);
  }

  .site-header {
    padding-top: .7rem;
  }

  .site-header__inner {
    border-radius: 20px;
    padding: .95rem;
  }

  .stats-grid, .hero-summary-grid {
    grid-template-columns: 1fr;
  }

  .hero__copy, .hero__aside, .surface-card, .empty-state, .error-state, .loading-state, .page-hero {
    border-radius: 22px;
  }

  .hero__copy, .hero__aside, .page-hero, .surface-card, .empty-state, .error-state {
    padding: 1.35rem;
  }

  .hero h1, .page-hero h1, .not-found-card h1 {
    font-size: 2.35rem;
  }

  .site-nav {
    justify-content: flex-start;
    width: 100%;
  }

  .site-nav__link, .site-header__login, .button {
    justify-content: center;
    width: 100%;
  }

  .site-header--compact .site-nav__link, .site-header--compact .site-header__login, .live-map-toolbar .button {
    width: auto;
  }

  .pilot-chip {
    justify-content: space-between;
    width: 100%;
  }

  .live-map-brief__copy h1 {
    font-size: 1.44rem;
  }

  .live-map-brief__copy p {
    font-size: .88rem;
  }

  .live-map-hud {
    grid-template-columns: 1fr;
    gap: .55rem;
  }
}

.site-frame--live-map {
  overflow: clip;
}

.live-map-shell {
  padding: 0 0 2.4rem;
  display: block;
}

.live-map-page {
  width: min(100% - 2rem, 1260px);
  margin: 0 auto;
  padding-top: .65rem;
  display: block;
}

.live-map-experience {
  width: min(100%, 1180px);
  margin: 0 auto;
}

.live-map-experience--immersive {
  z-index: 2000;
  background: #0b0f14;
  width: 100vw;
  max-width: none;
  margin: 0;
  padding: 0;
  position: fixed;
  inset: 0;
}

.live-map-stage {
  min-height: unset;
  border-radius: 32px;
  height: auto;
  padding: 1.1rem;
}

.live-map-experience--immersive .live-map-stage {
  height: 100vh;
  min-height: 100vh;
  box-shadow: none;
  background: #0b0f14;
  border: 0;
  border-radius: 0;
  padding: 0;
}

.live-map-stage:before {
  background: linear-gradient(#060a0f80, #0000);
  height: 6rem;
}

.live-map-stage:after {
  background: linear-gradient(#0000, #060a0f94);
  height: 4.5rem;
}

.live-map-experience--immersive .live-map-stage:before, .live-map-experience--immersive .live-map-stage:after {
  display: none;
}

.live-map-stage__header {
  z-index: 2;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 1rem;
  margin-bottom: 1rem;
  display: grid;
  position: relative;
}

.live-map-experience--immersive .live-map-stage__header {
  z-index: 8;
  pointer-events: none;
  grid-template-columns: 1fr auto;
  margin-bottom: 0;
  position: absolute;
  top: 1rem;
  left: 1rem;
  right: 1rem;
}

.live-map-brief {
  border-radius: 22px;
  padding: 1rem 1.08rem;
}

.live-map-brief__copy h1 {
  font-size: clamp(1.4rem, 2vw, 2rem);
}

.live-map-brief__copy p {
  max-width: 34rem;
  font-size: .92rem;
}

.live-map-toolbar {
  border-radius: 20px;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .55rem;
  max-width: 34rem;
  padding: .78rem .82rem;
  display: flex;
}

.live-map-experience--immersive .live-map-brief {
  display: none;
}

.live-map-experience--immersive .live-map-toolbar {
  pointer-events: auto;
  background: linear-gradient(#ffffff0b, #0000 30%), #0a0e1485;
  max-width: max-content;
  margin-left: auto;
}

.live-map-control-button {
  min-height: 2.48rem;
  padding: .58rem .84rem;
}

.live-map-control-slot {
  flex: none;
  display: inline-flex;
}

.live-map-control-slot--refresh {
  flex: 0 0 11rem;
  width: 11rem;
  min-width: 11rem;
}

.live-map-control-slot--refresh > .button {
  white-space: nowrap;
  width: 100%;
  min-width: 11rem;
  height: 2.48rem;
  min-height: 2.48rem;
  padding: .58rem .84rem;
  line-height: 1;
}

.live-map-control-slot--refresh > .button, .live-map-control-slot--refresh > .button:hover, .live-map-control-slot--refresh > .button:active, .live-map-control-slot--refresh > .button:focus-visible, .live-map-control-slot--refresh > .button[aria-disabled="true"], .live-map-control-slot--refresh > .button[aria-disabled="true"]:hover, .live-map-control-slot--refresh > .button[aria-disabled="true"]:active, .live-map-control-slot--refresh > .button[aria-disabled="true"]:focus-visible {
  min-width: 11rem;
  height: 2.48rem;
  min-height: 2.48rem;
  padding: .58rem .84rem;
}

.live-map-control-slot--refresh > .button[aria-disabled="true"] {
  cursor: pointer;
  opacity: 1;
}

.live-map-stage__body {
  z-index: 2;
  grid-template-columns: minmax(0, 1fr) minmax(18.75rem, 21rem);
  align-items: stretch;
  gap: 1rem;
  display: grid;
  position: relative;
}

.live-map-stage__body--map-only {
  grid-template-columns: minmax(0, 1fr);
}

.live-map-experience--immersive .live-map-stage__body, .live-map-experience--immersive .live-map-stage__body--map-only {
  z-index: 4;
  display: block;
  position: absolute;
  inset: 0;
}

.live-map-map-panel {
  background: linear-gradient(#ffffff08, #0000 20%), linear-gradient(#161f2bf2, #0b0f14f0);
  border: 1px solid #334155b8;
  border-radius: 28px;
  min-height: clamp(29rem, 58vh, 36rem);
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 48px #02061738, inset 0 1px #ffffff0a;
}

.live-map-experience--immersive .live-map-map-panel {
  height: 100vh;
  min-height: 100vh;
  box-shadow: none;
  background: #0b0f14;
  border: 0;
  border-radius: 0;
}

.live-map-canvas-shell {
  border-radius: inherit;
  box-shadow: none;
  border: 0;
  position: absolute;
  inset: 0;
}

.live-map-experience--immersive .live-map-canvas-shell {
  border-radius: 0;
}

.live-map-hud {
  z-index: 2;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
  display: grid;
  position: absolute;
  bottom: 1rem;
  left: 1rem;
  right: 1rem;
}

.live-map-experience--immersive .live-map-hud {
  z-index: 7;
  width: min(42rem, 100vw - 2rem);
  bottom: 1rem;
  left: 1rem;
  right: auto;
}

.live-map-hud__chip {
  min-width: 0;
}

.live-map-hud__chip--route {
  grid-column: auto;
}

.live-map-sidebar {
  align-content: start;
  gap: .95rem;
  min-height: 0;
  display: grid;
}

.live-map-experience--immersive .live-map-sidebar {
  z-index: 7;
  width: min(21rem, 100vw - 2rem);
  max-height: calc(100vh - 2rem);
  position: absolute;
  top: 1rem;
  bottom: 1rem;
  right: 1rem;
}

.live-map-overlay {
  z-index: 3;
  inset: 0;
}

.live-map-overlay--centered {
  place-items: center;
  padding: 1.2rem;
}

.live-map-overlay--centered .empty-state, .live-map-overlay--centered .error-state, .live-map-overlay--centered .loading-state {
  width: min(30rem, 100% - 2.4rem);
}

.live-map-overlay--notice {
  place-items: center;
  padding: 1.2rem;
}

.live-map-overlay--notice .empty-state, .live-map-overlay--notice .error-state {
  width: min(30rem, 100% - 2.4rem);
}

.live-map-overlay-panel {
  border-radius: 22px;
}

.live-map-overlay-panel--traffic .live-map-flight-list {
  max-height: clamp(14rem, 32vh, 22rem);
}

.live-map-experience--immersive .live-map-overlay-panel--traffic .live-map-flight-list {
  max-height: 100%;
}

html.live-map-immersive-active, body.live-map-immersive-active {
  overflow: hidden;
}

body.live-map-immersive-active .site-header {
  opacity: 0;
  pointer-events: none;
  transform: translateY(-120%);
}

body.live-map-immersive-active .live-map-shell {
  padding: 0;
}

body.live-map-immersive-active .live-map-page {
  width: 100%;
  padding-top: 0;
}

@media (max-width: 900px) {
  .live-map-page {
    width: min(100% - 1.2rem, 1260px);
    padding-top: .45rem;
  }

  .live-map-experience, .live-map-experience--immersive {
    width: 100%;
  }

  .live-map-stage {
    border-radius: 28px;
    padding: .9rem;
  }

  .live-map-stage__header {
    grid-template-columns: 1fr;
    gap: .85rem;
  }

  .live-map-toolbar {
    justify-content: flex-start;
    max-width: none;
  }

  .live-map-stage__body, .live-map-stage__body--map-only {
    grid-template-columns: 1fr;
  }

  .live-map-map-panel {
    min-height: clamp(27rem, 58vh, 34rem);
  }

  .live-map-experience--immersive .live-map-map-panel {
    height: 100vh;
    min-height: 100vh;
  }

  .live-map-sidebar {
    max-height: none;
  }

  .live-map-experience--immersive .live-map-stage__header {
    grid-template-columns: 1fr;
    top: .85rem;
    left: .85rem;
    right: .85rem;
  }

  .live-map-experience--immersive .live-map-toolbar {
    justify-content: flex-start;
    max-width: none;
    margin-left: 0;
  }

  .live-map-experience--immersive .live-map-sidebar {
    width: auto;
    max-height: min(48vh, 24rem);
    inset: auto .85rem .85rem;
  }

  .live-map-experience--immersive .live-map-hud {
    width: auto;
    bottom: calc(min(48vh, 24rem) + 1.35rem);
    left: .85rem;
    right: .85rem;
  }

  .live-map-overlay-panel--traffic .live-map-flight-list {
    max-height: 14rem;
  }

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

  .live-map-hud__chip--route {
    grid-column: 1 / -1;
  }
}

@media (max-width: 720px) {
  .live-map-page {
    width: min(100% - 1rem, 1260px);
  }

  .live-map-stage {
    border-radius: 24px;
    padding: .78rem;
  }

  .live-map-brief, .live-map-toolbar, .live-map-map-panel, .live-map-overlay-panel {
    border-radius: 18px;
  }

  .live-map-map-panel {
    min-height: 24rem;
  }

  .live-map-experience--immersive .live-map-stage__header {
    top: .7rem;
    left: .7rem;
    right: .7rem;
  }

  .live-map-experience--immersive .live-map-sidebar {
    bottom: .7rem;
    left: .7rem;
    right: .7rem;
  }

  .live-map-experience--immersive .live-map-hud {
    bottom: calc(min(48vh, 24rem) + 1.15rem);
    left: .7rem;
    right: .7rem;
  }

  .live-map-hud {
    grid-template-columns: 1fr;
    gap: .55rem;
    bottom: .78rem;
    left: .78rem;
    right: .78rem;
  }

  .live-map-hud__chip--route {
    grid-column: auto;
  }

  .live-map-toolbar .button {
    width: auto;
  }

  .live-map-control-slot--refresh {
    flex-basis: 10.6rem;
    width: 10.6rem;
    min-width: 10.6rem;
  }

  .live-map-control-slot--refresh > .button {
    min-width: 10.6rem;
    height: 2.48rem;
    min-height: 2.48rem;
  }
}

/*# sourceMappingURL=%5Broot-of-the-server%5D__0~mofxa._.css.map*/