html,
body {
  height: 100%;
}



* {
  margin: 0;
  outline: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  font-family: "Roboto", sans-serif;
  font-size: 11pt;
}

@font-face {
  font-family: 'Accuratist';
  src: url('/fonts/Accuratist.otf') format('opentype'),
    url('/fonts/Accuratist.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

:root {
  --fon-plashek-stvet: rgb(26 26 26 / 20%);
  --fon-plashek-razmitie: blur(5px);
  --nz-position: relative;
  --vc-position: relative;
  --vc-background-color: var(--fon-plashek-stvet);
  --nz-background-color: var(--fon-plashek-stvet);
  --vc-width: 100%;
  --vc-height: 1px;
  --vc-z-index: 48px;
  --tg-safe-area-inset-top: 0px;
  --tg-safe-area-inset-bottom: 0px;
  --menuapp-padding-top: 0px;
  --menuapp-padding-left: 0px;
  --menuapp-padding-right: 0px;
}

body {
  background-color: #141414;
  color: rgb(207 207 207);
}

.app {
  justify-content: space-evenly;
  align-content: stretch;
  align-items: stretch;
  height: 100%;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto 1fr auto;
  grid-column-gap: 0px;
  grid-row-gap: 0;
}

.nmenu *, ._cli {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
}

.pl_verh {
  --vc-position: absolute;
  --nz-position: absolute;
}

.pl_verh .centrapp {
  --menuapp-padding-top: calc(var(--vc-height) + var(--tg-safe-area-inset-top) + var(--tg-content-safe-area-inset-top));
  --menuapp-padding-left: var(--tg-safe-area-inset-left);
  --menuapp-padding-right: var(--tg-safe-area-inset-right);
}

.verhappcont {
  backdrop-filter: blur(10px);
  background-color: var(--vc-background-color);
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: 1fr;
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  backdrop-filter: var(--fon-plashek-razmitie);
  position: var(--vc-position);
  width: var(--vc-width);
  height: calc(var(--vc-height) + var(--tg-safe-area-inset-top));
  padding-top: var(--tg-safe-area-inset-top);
  z-index: 1;
}




.verhappcont .shap {
  display: flex;
  align-items: center;
}

.nizrappcont {
  z-index: 1;
  width: var(--vc-width);
  padding-bottom: var(--tg-safe-area-inset-bottom);
  position: var(--nz-position);
  bottom: 0px;
  background-color: var(--nz-background-color);
  backdrop-filter: var(--fon-plashek-razmitie);

}

.centrapp {
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: 1fr;
  grid-column-gap: 0px;
  grid-row-gap: 10px;
}

.centrapp .contentapp {
  flex-grow: 1;
  position: relative;
  box-shadow: #2d2e2f 0px 0px 0px 1px;
  background: #1a1a1a;
  overflow: hidden;
}

.centrapp .menuapp {
  width: calc(180px + var(--menuapp-padding-left));
  background-color: #141414;
  display: flex;
  flex-direction: column;
  flex-direction: column;
  flex-wrap: nowrap;
  align-items: stretch;
  padding-top: var(--menuapp-padding-top);
  padding-left: var(--menuapp-padding-left);
  padding-right: var(--menuapp-padding-right);
  z-index: 2;
}

.openm {
  display: none;
}

.centrapp .menuapp.hide {
  width: 43px;
}

.menuapp.hide .punkttext {
  display: none;
}

.menuapp.hide .punkt>span {
  margin-right: 0;
}

.menuapp.hide .openm {
  display: block;
}

.menuapp.hide .closem {
  display: none;
}

.menuapp.non {
  width: 0px !important;
  padding: 0px !important;
}

.nizmenuapp {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-evenly;
  grid-column-gap: 4pt;
  width: 100%;
  height: 100%;
  min-height: 56px;
}

.maplibregl-ctrl-top-right {
  top: calc(var(--tg-safe-area-inset-top) + 45px) !important;
}

.maplibregl-ctrl-group {
  background-color: var(--vc-background-color) !important;
  border-radius: 13px !important;
  backdrop-filter: blur(5px);
}

.maplibregl-ctrl button.maplibregl-ctrl-zoom-in .maplibregl-ctrl-icon * {
  fill: #000000;
}


.nizmenuapp .punkt {
  display: flex;
  height: 35pt;
  min-width: 45pt;
  flex-direction: column;
  align-items: center;
  justify-content: space-evenly;
  cursor: pointer;
  border-radius: unset;
  padding: unset;
  filter: drop-shadow(0px 0px 3px #0000005d);
}

.nizmenuapp .punkt>div {
  font-size: 9pt;

}

.nizmenuapp .punkt .punkticon {
  flex-grow: 1;
  display: flex;
  align-items: center;
}


.nizmenuapp .punkt .punkticon svg {
  height: 24px;
  width: 24px;
  fill: rgb(207 207 207);
}

.nizmenuapp .punkt:hover,
.nizmenuapp .punkt.active {
  background-color: unset;
  color: rgb(1, 130, 211);

  svg {
    fill: rgb(1, 130, 211);
  }

}

.punkt {

  height: 46px;
  cursor: pointer;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  padding: 0 6px;

}

.punkt>div {

  font-size: 16px;
  font-weight: 400;
}

.punkt>span {
  margin-right: 10px;
  color: #0073b8;
  font-size: 32px;
}

.punkt:hover,
.punkt.active {
  background-color: rgba(255, 255, 255, 0.08);
}

.punktr {
  flex-grow: 1;
}

html,
body {
  margin: 0;
  height: 100%;
}

#map {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100%;
  border-color: #000;
  overflow: hidden;
}

.ol-viewport {
  overflow: hidden;
}

.logo {
  height: 100%;
  padding: 0 7px;
  display: flex;
  flex-direction: row;
  justify-content: center;
}




._fsp_logo {
  font-family: Accuratist;
  font-size: 60px;
  line-height: 1;
  display: flex;
  align-content: center;
  align-items: center;
  height: 100%;
  width: 164px;
}

._fsp_logo * {
  font-size: 35px;
}

._fsp_logo>.so {
  background: linear-gradient(-9deg, #5a93c5, #2873b4, #5a93c5);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
}

._fsp_logo>.po {
  background: linear-gradient(-9deg, #cdcdcd, #b5b5b5, #cdcdcd);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
}

.login {
  display: flex;
  align-items: center;
}

.form_search {
  border-radius: 8px;
  background-color: #353434;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-evenly;
  align-items: stretch;
  width: 200px;
}

.form_search:hover {
  background-color: #3d3d3d;
}

.shap form {
  display: block;
  width: 100%;
  height: auto;
}

.form_search input {
  border-bottom-right-radius: 0;
  border-top-right-radius: 0;
  outline: 0;
  box-shadow: none;
  background-color: rgba(0, 0, 0, 0);
  border: 0;
  color: #a7a7a7;
  height: 32px;
  flex-grow: 1;
  font-size: 16px;
  font-stretch: 100%;
  padding: 0 9px;
  width: 100%;
}

.form_search button {
  background-color: rgba(0, 0, 0, 0);
  color: #a7a7a7;
  border: 0;
  display: flex;
  flex-direction: row;
  align-content: center;
  justify-content: center;
  align-items: center;
  width: 32px;
  padding-top: 3px;
  cursor: pointer;
}

.tabler {
  position: relative;
  border-radius: 8px;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 32px 1fr 24px;
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  height: 100%;
}

.tabler table {
  position: relative;
}

.tablerH {
  color: #fff;
  height: 32px;
  display: flex;
  align-content: stretch;
  align-items: center;
  padding: 0 9px;
  background: #242424;
  position: relative;
  box-shadow: #2d2e2f 0px 0px 0px 1px;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-evenly;
}

.tablerH1 {
  flex-grow: 1;
}

.tablerH2 {
  display: flex;
  align-content: center;
  align-items: center;
  color: #00a906;
  cursor: pointer;
}

.tablerH2:hover {
  background: #333333;
}

.tablerB {
  flex-grow: 1;
}

.tablerF {
  color: #fff;
  height: 24px;
  display: flex;
  align-content: center;
  align-items: center;
  padding: 0 9px;
  background: #242424;
  position: relative;
  box-shadow: #2d2e2f 0px 0px 0px 1px;
  font-size: 12px;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-evenly;
}

.tablerF1 {}

.tablerF2 {
  text-align: center;
  flex-grow: 1;
}

.tablerF3 {}

.Itemlist {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 150px));
  grid-auto-rows: minmax(100px, auto);
  grid-column-gap: 9px;
  grid-row-gap: 14px;
  padding: 6px;
  align-items: start;
  position: absolute;
  width: 100%;
  grid-auto-columns: 150px;
  justify-content: space-around;
}

.Itemlist .Item {
  box-shadow: #2d2e2f 0px 0px 0px 1px;
  border-radius: 8px;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 150px minmax(auto, 1fr);
  position: relative;
  z-index: 2;
  overflow: hidden;
  background: #242424;
  height: 100%;
}

.ItemLogoMo {
  box-shadow: #2d2e2f 0px 0px 0px 1px;
  background-color: #fff;
  display: flex;
  align-content: center;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 3;
  color: #1a1a1a;
  border-radius: 8px;
  background-size: 80%;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  /*background-repeat-x: no-repeat;
  background-repeat-y: no-repeat;*/
}

.ItemNameMo {
  min-height: 33px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.ItemNameMo {}

.ItemNameStr {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: space-evenly;
}

.ItemSim {
  width: 25px;
  height: 15px;
  border: 1px solid #454748;
  border-radius: 2px;
  position: absolute;
  top: 2px;
  right: 2px;
  top: 5px;
  right: 5px;
}

.ItemSim::before {
  content: "";
  display: block;
  height: 3px;
  width: 6px;
  background: #242424;
  position: absolute;
  border-top: 1px solid #454748;
  bottom: -2px;
  left: -2px;
  transform: rotateZ(36deg);
}

.ItemSimka {
  font-size: 16px;
}

.ItemSimCard {
  width: 85.6em;
  height: 53.98em;
  font-size: 2.5px;
  background-color: #fff;
  border-radius: 8px;
  position: relative;
}

.ItemSimCardMini {
  width: 25em;
  height: 15em;
  font-size: 2.5px;
  background-color: #7e7e7e;
  border-radius: 3px;
  box-shadow: #2d2e2f 0px 0px 0px 1px;
  position: relative;
  margin-top: 16.5em;
  font-size: 2.5px;
}

.ItemSimCardpol {
  display: flex;
  height: 100%;
  width: 100%;
}

.ItemSimLogo {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}

.ItemSimLogoi {
  flex-grow: 1;
  background-size: 65%;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}

.ItemSimChip {
  width: 32em;
  font-size: 2.5px;
}

.ItemSimNomer {
  height: 16em;
  font-size: 2.5px;
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
  align-items: center;
}

.ItemSimNomer>div {
  font-size: 10px;
  color: #000;
}

.ItemSimCardMini:before {
  position: absolute;
  width: 1em;
  height: 0.4em;
  top: 2.73em;
  left: -0.35em;
  transform: rotate(46deg);
  content: "";
  background-color: var(--before-background, #fff);
  font-size: 12px;
  border-top: 0.1em solid #2d2e2f;
}

.Itemlist:has(.ItemSimka) {
  font-size: 2.5px;
  grid-template-columns: repeat(auto-fit, minmax(100px, 85.6em));
}

.Itemlist:has(.ItemTreck) {
  /*font-size: 2.5px;*/
  grid-template-columns: repeat(auto-fit, minmax(100px, 200px));
}

.Itemlist:has(.ItemTarif)>.Item {
  font-size: 2.5px;
  grid-template-rows: 100px minmax(auto, 1fr);
}

.Itemlist:has(.ItemSimka)>.Item {
  grid-template-rows: 135px minmax(auto, 1fr);
}

.Itemlist:has(.ItemSimka) .ItemNameMo {
  min-height: 33px;
}

.ItemNameStr .ItemNameMo {
  min-height: 33px;
}

.Item.On {
  box-shadow: #09822b 0px 0px 0px 1px;
}

.Item.Off {
  box-shadow: #8b1e1e 0px 0px 0px 1px;
}

.menub {
  position: absolute;
  top: 3px;
  right: 3px;
  display: grid;
  grid-template-columns: repeat(auto-fill, 28px);
  grid-column-gap: 5px;
  grid-row-gap: 7px;
  min: auto;
  grid-auto-flow: column;
  justify-content: end;
}

.menub>* {
  cursor: pointer;
  border-radius: 8px;
  padding: 2px;
}

.menub>*:hover {
  background-color: #3737378c;
}

.sckolls {
  overflow-y: auto;
  position: relative;
}

._cli,
.punkt,
.menub {
  -webkit-touch-callout: none;
  /* iOS Safari */
  -webkit-user-select: none;
  /* Safari */
  -khtml-user-select: none;
  /* Konqueror HTML */
  -moz-user-select: none;
  /* Old versions of Firefox */
  -ms-user-select: none;
  /* Internet Explorer/Edge */
  user-select: none;
  /* Non-prefixed version, currently
                                  supported by Chrome, Edge, Opera and Firefox */
}

.ol-control button {
  font-size: 24px;
}

._cmenu,
._cme {
  /*position: relative;*/
}

.plivun {
  position: fixed;
  top: 1px;
}

.ui-dialog {
  margin: 0 !important;
  padding: 0 !important;
  background-color: #141414 !important;
  color: #a7a7a7 !important;
  border: 0 !important;
  box-shadow: #2d2e2f 0px 0px 0px 1px !important;
  flex-direction: column;
}

.ui-dialo * {
  font-weight: lighter;
}

.ui-dialog .ui-dialog-title {
  font-weight: lighter;
}

.ui-dialog .ui-dialog-titlebar {
  color: #fff;
  height: 35px;
  display: flex;
  align-content: stretch;
  align-items: center;
  padding: 0 9px !important;
  background: #242424;
  position: relative;
  box-shadow: #2d2e2f 0px 0px 0px 1px;
  border: 0;
}

.ui-dialog .ui-dialog-content {
  flex-grow: 1 !important;
  padding: 0 !important;
  color: #fff !important;
  position: relative !important;
}

.ui-dialog {
  position: fixed;
  display: grid;
  grid-template-rows: 35px 1fr 40px;
}

.ui-dialog .ui-dialog-buttonpane {
  margin: 0 !important;
  padding: 0 !important;
  box-shadow: #2d2e2f 0px 0px 0px 1px !important;
  padding: 0 9px !important;
  background: #242424;
  border: 0 !important;
}

.ui-dialog .ui-dialog-buttonpane button {
  margin: 0 !important;
  padding: 4px 9px !important;
}

.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset {
  float: right;
  width: 100%;
  height: 33px;
  padding: 4px 0 !important;
  display: grid;
  grid-template-columns: repeat(auto-fill, auto);
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  min: auto;
  grid-auto-flow: column;
  justify-content: end;
}

.form {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(49%, 1fr));
  grid-auto-rows: auto;
  grid-column-gap: 8px;
  grid-row-gap: 25px;
  padding: 22px 8px;
  align-items: start;
  position: absolute;
  width: 100%;
  justify-content: space-around;
}

.formya {
  width: 100%;
  padding: 20px 5px 5px;
  position: relative;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
}

.formya .map,
.formya ._map {
  height: 250px;
  width: 100%;
}

.formya ._map {
  border-radius: 8px;
  overflow: hidden;
}

.divradio {
  width: 100%;
  position: relative;
  justify-content: space-between;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(129px, 1fr));
  grid-column-gap: 3px px;
  grid-row-gap: 6px;
}

.divradio input {
  display: none;
}

.formya .divradio label {
  position: relative;
  color: #383838;
  left: 13px;
  left: 0;
}

.divradio .ui-state-active,
.divradio .ui-widget-content .ui-state-active,
.divradio .ui-widget-header .ui-state-active,
.divradio a.ui-button:active,
.divradio .ui-button:active,
.divradio .ui-button.ui-state-active:hover {
  border: 1px solid #0073b8 !important;
  background: #0073b8 !important;
  font-weight: normal !important;
  color: #fff !important;
}

.formya input,
.formya select {
  /*width: 100%;*/
  font-size: 20px;
  background: transparent;
  border: none;
  outline: none;
  color: #fff;
  height: 30px !important;
  border-radius: 8px;
  border: 1px solid #ffffff30;
  padding: 5px 9px 7px;
  box-sizing: border-box;
  font-size: 13px !important;
  background-color: #292929;
  position: relative;
  z-index: 7;
  flex-grow: 1;
  margin-left: 5px;
}

.formya select {
  cursor: pointer;
}

.formya input:hover {}

.formya input[type="checkbox"] {
  position: relative;
  cursor: pointer;
  z-index: 0;
  width: 1px;
  left: 2px;
  max-width: 27px;
}

.formya input[type="checkbox"]:before {
  content: "";
  display: block;
  position: absolute;
  width: 30px;
  height: 30px;
  top: 0;
  left: -2px;
  border-radius: 8px;
  background-color: white;
  border: 1px solid #ffffff30;
  background-color: #292929;
}

.formya input[type="checkbox"]:checked:after {
  content: "";
  display: block;
  width: 8px;
  height: 17px;
  border: solid white;
  border-width: 0 2px 2px 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 4px;
  left: 10px;
}

.formya label {
  display: block;
  position: absolute;
  top: 0;
  color: #8b8b8b;
  left: 13px;
  font-size: 15px;
}

.formya.filess {
  grid-row: span 2;
  height: 100%;
}

.formyaf {
  width: 100%;
  font-size: 20px;
  background: transparent;
  border: none;
  outline: none;
  color: #fff;
  border-radius: 8px;
  border: 1px solid #ffffff30;
  padding: 5px 9px 7px;
  box-sizing: border-box;
  font-size: 13px;
  background-color: #292929;
  position: relative;
  z-index: 7;
  height: 100%;
  width: 100%;
  height: 250px;
  vertical-align: top;
  background-size: contain;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}

.formya.filess input[type="file"] {
  display: none;
}

.formya .minicolors-swatch::after {
  box-shadow: none;
}

.formya .minicolors-swatch::after {
  box-shadow: none;
}

.formya .minicolors-theme-default .minicolors-swatch {
  z-index: 7;
  border-radius: 7px;
  border: 0;
  top: 1px;
  left: 1px;
  width: 25px;
  height: 28px;
}

.formya .minicolors-swatch-color {
  border-radius: 7px 0px 0px 7px;
}

.minicolors-theme-default.minicolors {
  width: 100%;
  display: block !important;
}

.minicolors-theme-default .minicolors-input {
  width: 100% !important;
  padding-left: 32px !important;
}

.datalist {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(380px, 49.3%));
  grid-column-gap: 3px;
  grid-row-gap: 6px;
  width: 100%;
  justify-content: space-between;
}

.datalist>div {
  display: flex;
  width: 100%;
}

.datalist .names {
  padding-top: 2px;
  font-weight: 500;
}

.datalist .znach {
  padding: 2px 0 0 3px;
}

.online {
  color: #179d00;
}

.offline {
  color: #9d0000;
}