html, body {
background: white;
padding: 0;
height: 100%;
margin: 0;
display: flex;
flex-direction: column;
font-family: "Source Sans 3", Arial, sans-serif;
font-size: 15px;
}

* {
box-sizing: border-box;
}

a {
  text-decoration: none;
  color: inherit;
}









header {
  width: 100%;
  position: relative;
  z-index: 1;
  background: #ffffff;
}

header.header-index {
  background: none;
}

#headerLotiq {
  width: 100%;
  height: 50px;
  border-bottom: #c7c7c7 solid 1px;
  position: relative;
  z-index: 21;
  display: flex;
}

#headerLotiq.headerLotiq-index {
  border-bottom: none;
}

#headerLotiq.headerLotiq-index,
#headerLotiq.headerLotiq-index a,
#headerLotiq.headerLotiq-index span,
#headerLotiq.headerLotiq-index i,
#headerLotiq.headerLotiq-index #user {
  color: #ffffff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
}















/*-------------------------------------------------------------------------------------------vrchny header--------------------------------------------------------------------------------*/
#user {
  color: black;
  font-size: 18px;
}

#logo-new {
  height: 26px;
}

#headerLotiq {
  width: 100%;
  height: 50px;
  border-bottom: #c7c7c7 solid 1px;
}

#headerLotiq-1 {
  width: 50px;
  height: 100%;
  font-family: inherit;
  display: flex;
  align-items: center;
  justify-content: center;
}

#headerLotiq-2 {
  width: 120px;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

#headerLotiq-3log {
  width: calc(100% - 170px);
  height: 100%;
  font-family: inherit;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

#headerLotiq-3nolog {
  width: calc(100% - 270px);
  height: 100%;
  font-family: inherit;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

#headerLotiq-4log {
  display: none;
}

#headerLotiq-4nolog {
  display: none;
}

#headerLotiq-5log {
  width: 50px;
  height: 100%;
  font-family: inherit;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 10px;
}

#headerLotiq-5nolog {
  width: 150px;
  height: 100%;
  font-family: inherit;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

#headerLotiq-3log span,
#headerLotiq-4log span,
#headerLotiq-5log span,
#headerLotiq-3nolog span,
#headerLotiq-4nolog span,
#headerLotiq-5nolog span {
  padding: 10px;
}

#headerLotiq.headerLotiq-index,
#headerLotiq.headerLotiq-index a,
#headerLotiq.headerLotiq-index #user {
  color: white;
  text-shadow: 0 1px 2px rgba(0,0,0,0.6);
}

@media screen and (max-width: 1152px) {
  #headerLotiq-3log,
  #headerLotiq-3nolog {
    display: none;
  }

  #headerLotiq-4log {
    width: calc(100% - 220px);
    height: 100%;
    font-family: inherit;
    display: flex;
    align-items: center;
    justify-content: flex-end;
  }

  #headerLotiq-4nolog {
    width: calc(100% - 320px);
    height: 100%;
    font-family: inherit;
    display: flex;
    align-items: center;
    justify-content: flex-end;
  }
}

/*-------------------------------------------------------------------------------------------koniec vrchny header--------------------------------------------------------------------------------*/















/*-------------------------------------------------------------------------------------------img sekcia na index.php--------------------------------------------------------------------------------*/

.header01 {
  position: relative;
  width: 100%;
  height: 350px;
  overflow: hidden;
  margin-top: -50px;
  margin-bottom: 0;
}

.header01_img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  left: 0;
  top: 0;
  display: block;
  filter: brightness(0.7);
  transform: none;
}

.intro1 {
  font-size: 26px;
  font-weight: bold;
}

.header-search {
  position: absolute;
  top: 58%;
  left: 50%;
  width: min(600px, 90%);
  transform: translate(-50%, -50%);
}

.header-search-text {
  width: 100%;
  min-height: 58px;
  margin: auto;
  font-size: 38px;
  color: white;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 1);
  font-weight: 900;
  text-align: center;
}

.header-search1 {
  width: 100%;
  height: 80px;
  margin: auto;
}

.header-search1-1 {
  width: 100%;
  height: 30px;
}

.header-search1-1-1 {
  width: 100px;
  height: 100%;
  float: left;
  background: white;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.header-search1-1-2 {
  width: 100px;
  height: 100%;
  float: left;
  background: #0045b6;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.header-search1-2s {
  display: flex;
  width: 100%;
  height: 45px;
  background: white;
}

.header-search1-2-1 {
  width: calc(100% - 48px);
  height: 100%;
  float: left;
  color: gray;
  padding: 0 0 0 20px;
  border: none;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: left;
  text-align: center;
}


.header-search1-2-2 {
  width: 48px;
  height: 100%;
  float: left;
  background: #0045b6;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.header-search1-2-2 i {
  font-size: 20px;
  color: white;
}

@media screen and (max-width: 1024px) {
  .header01 {
    height: 350px;
    margin-top: -50px;
  }

  .header-search {
    top: 58%;
  }

  .intro1 {
    font-size: 24px;
  }
}

@media screen and (max-width: 800px) {
  .header01 {
    height: 335px;
    margin-top: -50px;
  }

  .header-search {
    top: 58%;
  }

  .header-search-text {
    min-height: 54px;
    font-size: 32px;
    padding: 3px 0;
  }

  .intro1 {
    font-size: 22px;
  }
}

@media screen and (max-width: 640px) {
  .header01 {
    height: 320px;
    margin-top: -50px;
  }

  .header-search {
    top: 58%;
    width: 90%;
  }

  .header-search-text {
    width: 100%;
    min-height: 50px;
    margin: auto;
    font-size: 28px;
    padding: 2px 0;
  }

  .header-search1 {
    width: 100%;
    height: 76px;
    margin: auto;
  }

  .header-search1-1 {
    width: 100%;
    height: 30px;
  }

  .header-search1-1-1 {
    width: 96px;
    height: 100%;
    float: left;
    background: white;
  }

  .header-search1-1-2 {
    width: 96px;
    height: 100%;
    float: left;
    background: #0045b6;
    color: white;
  }

  .header-search1-2s {
    width: 100%;
    height: 43px;
    background: white;
  }

  .header-search1-2-1 {
    width: calc(100% - 48px);
    height: 100%;
    float: left;
    color: gray;
    padding: 0 0 0 16px;
    font-size: 14px;
  }

  .header-search1-2-2 {
    width: 48px;
    height: 100%;
    float: left;
    background: #0045b6;
  }

  .intro1 {
    font-size: 20px;
  }
}

@media screen and (max-width: 420px) {
  .header01 {
    height: 280px;
    margin-top: -50px;
  }

  .header-search {
    top: 58%;
  }

  .header-search-text {
    font-size: 28px;
  }
}
/*-------------------------------------------------------------------------------------------koniec img sekcia na index.php--------------------------------------------------------------------------------*/











/*-------------------------------------------------------------------------------------------------- BOČNÉ PANELY -----------------------------------------------------------------------------------------*/
.lotiq-side-overlay {
  height: 100%;
  width: 0;
  position: fixed;
  top: 0;
  background: #ffffff;
  overflow-x: hidden;
  transition: width 0.35s ease;
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.22);
}

.lotiq-side-overlay-right {
  z-index: 10;
  right: 0;
  border-left: 1px solid #e4ebf6;
}

.lotiq-side-overlay-left {
  z-index: 9;
  left: 0;
  border-right: 1px solid #e4ebf6;
}

.lotiq-side-backdrop {
  height: 100%;
  width: 0;
  position: fixed;
  top: 0;
  background: rgba(16, 24, 39, 0.66);
  transition: opacity 0.2s ease;
  opacity: 0.7;
}

.lotiq-side-backdrop-right {
  z-index: 9;
  right: 0;
}

.lotiq-side-backdrop-left {
  z-index: 4;
  left: 0;
}

.lotiq-side-inner {
  width: 100%;
  min-width: 300px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.lotiq-side-header {
  min-height: 64px;
  padding: 12px 14px;
  border-bottom: 1px solid #e4ebf6;
  background: #ffffff;
  display: flex;
  align-items: center;
  gap: 12px;
}

.lotiq-side-header-left {
  justify-content: flex-start;
}

.lotiq-side-header-right {
  justify-content: space-between;
}

.lotiq-side-logo-wrap {
  height: 40px;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.lotiq-side-logo-wrap img {
  height: 30px;
  max-width: 150px;
  display: block;
}

.lotiq-side-title {
  font-size: 16px;
  font-weight: 900;
  color: #101827;
  line-height: 1.1;
}

.lotiq-side-close {
  width: 38px;
  min-width: 38px;
  height: 38px;
  border-radius: 12px;
  background: #f5f8ff;
  border: 1px solid #e4ebf6;
  color: #172b4d;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 700;
  line-height: 1;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.lotiq-side-close:hover {
  background: #ffe7e7;
  border-color: #ffc3c3;
  color: #b00000;
}

.lotiq-side-content {
  width: 100%;
  padding: 12px;
  overflow-y: auto;
  overflow-x: hidden;
}

.lotiq-side-section-title {
  margin: 18px 8px 8px 8px;
  padding: 0;
  color: #0045b6;
  font-size: 13px;
  font-weight: 900;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.lotiq-side-link {
  width: 100%;
  min-height: 42px;
  padding: 0 10px;
  border-radius: 12px;
  text-decoration: none;
  color: #172b4d;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  transition: background 0.15s ease, color 0.15s ease, transform 0.15s ease;
}

.lotiq-side-link:hover {
  background: #f5f8ff;
  color: #0045b6;
}

.lotiq-side-link-warning {
  color: #8a5a22;
}

.lotiq-side-link-warning:hover {
  background: #fff4e7;
  color: #b85c00;
}

.lotiq-side-badge {
  min-height: 22px;
  padding: 4px 8px;
  margin-left: 8px;
  border-radius: 999px;
  font-size: 11px;
  color: #b85c00;
  background: #fff1df;
  border: 1px solid #ffd8a6;
  font-weight: 900;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
}

.no-scroll {
  overflow: hidden;
}

/*-------------------------------------------------------------------------------------------------- BOČNÉ PANELY -----------------------------------------------------------------------------------------*/

















.bodyLotiq {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 10px;
}


.lotiq-page-heading {
  width: 100%;
  margin: 14px 0 10px 0;
  padding: 14px 18px;
  background: #ffffff;
  border: 1px solid #e4ebf6;
  border-radius: 16px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06);

    display: grid;
    grid-template-columns: 38px minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
}

.lotiq-page-heading-icon {
  width: 42px;
  height: 42px;
  border-radius: 13px;
  background: linear-gradient(135deg, #003b99, #0068ff);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
}

.lotiq-page-heading-layout {

}

.lotiq-page-heading-title {
  font-size: 20px;
  font-weight: 900;
  color: #101827;
  line-height: 1.1;
}

.lotiq-page-heading-subtitle {
  margin-top: 4px;
  font-size: 13px;
  color: #637083;
  font-weight: 700;
}

.lotiq-page-heading-back {
  min-height: 38px;
  padding: 0 15px;
  border-radius: 999px;
  background: #0045b6;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  font-size: 13px;
  font-weight: 950;
  text-decoration: none;
  white-space: nowrap;
}

@media (max-width: 680px) {
  .lotiq-page-heading-back {
    grid-column: 1 / -1;
    justify-self: stretch;
    width: 100%;
    box-sizing: border-box;
    min-height: 38px;
    padding: 0 13px;
    font-size: 12px;
  }
}

.lotiq-card {
  background: #ffffff;
  border: 1px solid #e4ebf6;
  border-radius: 18px;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.08);
  overflow: hidden;
  margin-bottom: 20px;
}

.lotiq-card-header {
  background: linear-gradient(135deg, #101827, #0045b6);
  color: #ffffff;
  padding: 22px;
  display: flex;
  justify-content: space-between;
  gap: 15px;
  align-items: flex-start;
  flex-wrap: wrap;
}

.lotiq-card-heading-layout {

}

.lotiq-card-title {
  font-size: 24px;
  font-weight: 900;
  margin-bottom: 7px;
}

.lotiq-card-subtitle {
  font-size: 14px;
  opacity: 0.9;
}

.lotiq-card-header-badge {
  min-height: 30px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.28);
  color: #ffffff;
  font-size: 12px;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}

.lotiq-card-content {
  padding: 10px;
  background: #ffffff;
}

.lotiq-card-content-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 390px;
  gap: 16px;
}

.lotiq-card-content-grid-left,
.lotiq-card-content-grid-right {
  min-width: 0;
}

.lotiq-card-content-grid-right-sticky {
  position: sticky;
  top: 0;
}

@media (max-width: 1180px) {
  .lotiq-card-content-grid {
    grid-template-columns: 1fr;
  }

  .lotiq-card-content-grid-right-sticky {
    position: static;
  }
}

.lotiq-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.lotiq-fieldset {
  border-radius: 16px;
  padding: 10px;
  margin: 10px 0;
  position: relative;
}

.lotiq-fieldset legend {
  padding: 0 8px;
  font-weight: 900;
  font-size: 15px;
}

.lotiq-fieldset-primary {
  border: 1px solid #cfe0fb;
  background: linear-gradient(180deg, #f7fbff 0%, #ffffff 100%);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.7);
}

.lotiq-fieldset-primary legend {
  color: #0045b6;
}

.lotiq-fieldset-warning {
  border: 1px solid #f1d8bc;
  background: linear-gradient(180deg, #fffaf4 0%, #ffffff 100%);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.7);
}

.lotiq-fieldset-warning legend {
  color: #b85c00;
}

.lotiq-fieldset-text {
  font-size: 14px;
  color: #526276;
  line-height: 1.5;
  margin-bottom: 14px;
}

.lotiq-fieldset-flex {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.lotiq-fieldset-flex > div {
  width: 100%;
}

@media (max-width: 768px) {
  .lotiq-fieldset-flex {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1050px) {
  .lotiq-grid-2 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .lotiq-page-heading-icon {
    width: 38px;
    height: 38px;
    border-radius: 12px;
    font-size: 18px;
  }

  .lotiq-page-heading-title {
    font-size: 18px;
  }

  .lotiq-page-heading-subtitle {
    font-size: 12px;
  }

  .lotiq-card-header {
    padding: 17px;
  }

  .lotiq-card-title {
    font-size: 20px;
  }

  .lotiq-card-header-badge {
    width: 100%;
    justify-content: center;
  }
}

.lotiq-header-badge {
  min-height: 30px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.28);
  color: #ffffff;
  font-size: 12px;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}

@media (max-width: 768px) {
  .lotiq-header-badge {
    display: none;
  }
}

.localityGrid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}

.localityItem {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid #e0e8f5;
  border-radius: 10px;
  background: #f7faff;
}

.localityItem span {
  font-size: 12px;
  color: #637083;
  font-weight: 800;
}

.localityItem strong {
  font-size: 14px;
  color: #172b4d;
  font-weight: 900;
  text-align: right;
  white-space: nowrap;
}













.selectLandBox {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.selectLandBoxMenu {
  width: 100%;
  min-height: 46px;
  border: 1px solid #d8e4f3;
  border-radius: 12px;
  background: #ffffff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  color: #172b4d;
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
}

.selectLandBoxMenu:hover {
  background: #f5f8ff;
  border-color: #0045b6;
  transform: translateY(-1px);
}

.selectLandBoxMenuDisabled {
  background: #f7f7f7;
  color: #a4acb8;
  border-color: #e1e1e1;
  cursor: default;
}

.selectLandBoxMenuDisabled:hover {
  background: #f7f7f7;
  border-color: #e1e1e1;
  transform: none;
}

.selectLandBoxMenuTitle {
  font-size: 14px;
  font-weight: 900;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.selectLandBoxMenuArrow {
  font-size: 17px;
  font-weight: 900;
  color: #0045b6;
  flex: 0 0 auto;
}

.selectLandBoxMenuDisabled .selectLandBoxMenuArrow {
  color: #c3c3c3;
}

@media (max-width: 768px) {
  .selectLandBoxMenu {
    min-height: 44px;
  }

  .selectLandBoxMenuTitle {
    font-size: 13px;
  }
}

.selectedItem {
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid #e0e8f5;
  border-radius: 10px;
  background: #f7faff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 6px;
}

.selectedLabel {
  font-size: 12px;
  color: #637083;
  font-weight: 900;
}

.selectedValue {
  font-size: 14px;
  color: #172b4d;
  font-weight: 900;
  text-align: right;
}

@media (max-width: 768px) {
  .selectedValue {
    text-align: left;
    margin-top: 4px;
  }
}
















.popup-overlay {
  position: fixed;
  inset: 0;
  z-index: 10020;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(15, 23, 42, 0.56);
  backdrop-filter: blur(3px);
}

.popup-overlay.show {
  display: flex;
}

.popup-modal {
  width: min(420px, 100%);
  position: relative;
  border-radius: 22px;
  background: #ffffff;
  color: #172b4d;
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.28);
  border: 1px solid rgba(215, 230, 251, 0.95);
  padding: 24px 20px 20px;
  text-align: center;
}

.popup-modal-icon {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  margin: 0 auto 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #edf5ff;
  color: #0068ff;
  font-size: 22px;
}

.popup-modal-title {
  font-size: 18px;
  line-height: 1.25;
  font-weight: 900;
  margin-bottom: 9px;
}

.popup-modal-text {
  max-width: 340px;
  margin: 0 auto;
  color: #526276;
  font-size: 14px;
  line-height: 1.45;
  font-weight: 700;
}

.popup-modal-actions {
  margin-top: 18px;
  display: flex;
  justify-content: center;
}

.popup-modal-button {
  width: 100%;
  min-height: 46px;
  padding: 12px 18px;
  border-radius: 999px;
  background: #0068ff;
  color: #ffffff;
  text-decoration: none;
  font-size: 14px;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  box-shadow: 0 10px 22px rgba(0, 104, 255, 0.23);
}

.popup-modal-button:hover {
  background: #004fc4;
  color: #ffffff;
}

.popup-modal-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 999px;
  background: #f1f5f9;
  color: #526276;
  font-size: 18px;
  font-weight: 900;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.popup-modal-close:hover {
  background: #e5ecf5;
  color: #172b4d;
}

@media (max-width: 768px) {
  .popup-overlay {
    align-items: flex-start;
    padding: 74px 14px 18px;
  }

  .popup-modal {
    padding: 22px 16px 16px;
    border-radius: 20px;
  }

  .popup-modal-title {
    font-size: 17px;
  }

  .popup-modal-text {
    font-size: 13px;
  }
}









































/* ==================================================================
   01. HLAVNÝ MAPOVÝ LAYOUT
   - celá stránka mapy
   - horný header
   - spodná časť: mapa vľavo + pravý panel
================================================================== */

/* Celý wrapper mapovej stránky */
.lotiqMapLayout {
  width: 100%;
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* Header v rámci mapového layoutu */
.lotiqMapLayout .lotiqMapHeader {
  flex: 0 0 auto;
}

/* Riadok s mapou a pravým panelom */
.lotiqMapLayout .lotiqMap {
  width: 100%;
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: row;
  overflow: hidden;
}

/* Ľavá strana - samotná Google mapa */
.lotiqMapLayout #lotiqMapLeft {
  height: 100%;
  flex: 1 1 auto;
  min-width: 0;
  position: relative;
  overflow: hidden;
}

/* Pravá strana - bočný panel so zoznamom/detailmi */
.lotiqMapLayout #lotiqMapRight {
  width: 530px;
  flex: 0 0 530px;
  padding: 0 6px 0 6px;
  height: 100%;
  overflow: hidden;
  background: #f5f8ff;
  border-left: 1px solid #d8e1ee;
}

/* Užší pravý panel na menších desktopoch/tabletoch */
@media screen and (max-width: 1100px) and (min-width: 801px) {
  .lotiqMapLayout #lotiqMapRight {
    width: 430px;
    flex: 0 0 430px;
  }
}

/* Mobilný layout - pravý panel sa skryje, mapa zaberie celú šírku */
@media screen and (max-width: 800px) {
  .lotiqMapLayout .lotiqMap {
    display: block;
    width: 100% !important;
    overflow: hidden !important;
  }

  .lotiqMapLayout #lotiqMapLeft {
    width: 100% !important;
    max-width: 100% !important;
    height: 100%;
    display: block;
    flex: 1 1 100% !important;
  }

  .lotiqMapLayout #lotiqMapRight {
    display: none !important;
    width: 0 !important;
    max-width: 0 !important;
    height: 0 !important;
    flex: 0 0 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
  }
}


/* ==================================================================
   02. GOOGLE MAP UI
   - zvýraznenie aktívneho typu mapy
================================================================== */

/* Aktívne tlačidlo typu mapy v Google Maps ovládaní */
.gm-style-mtc button.active-map {
  background: #0045b6 !important;
  color: white !important;
}


/* ==================================================================
   03. HORNÝ HEADER MAPY
   - vrchný prázdny pás
   - spodný prázdny pás
   - zatiaľ iba layoutová záloha
================================================================== */

/* Celý header nad mapou */
.lotiqMapHeader {
  background: #ffffff;
  border-top: 1px solid #e5e9f0;
  border-bottom: 1px solid #d8e1ee;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
  overflow: hidden;
}

/* Horný riadok headera */
.lotiqMapHeaderTop {
  min-height: 46px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 7px 10px;
  background: #ffffff;
  border-bottom: 1px solid #edf1f6;
}

/* Spodný riadok headera */
.lotiqMapHeaderBottom {
  min-height: 46px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 10px;
  background: #f7f9fc;
}

.lotiqMapHeaderBottomMargue {
  overflow: hidden;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
}

.lotiqMapHeaderBottomMargueText {
  display: inline-block;
  will-change: transform;
  font-weight: 900;
  color: #172b4d;
  font-size: 15px;
}





/* ==================================================================
   04. PRAVÝ PANEL
   - desktopový panel
   - jeho vnútorný scrollovací obsah
================================================================== */

/* Scrollovací obsah pravého panelu */
#dataTable {
  height: 100%;
  overflow-y: auto;
  padding: 10px;
}

/* Vnútorný wrapper obsahu pravého panelu */
#lotiqMapRightInfo {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.lotiqMapRightTabInfo {
  background: #ffffff;
  border: 1px solid #e1e9f5;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.05);
}

.lotiqMapRightTabInfo-1 {
  min-height: 46px;
  padding: 10px 12px;
  background: #ffffff;
  border-bottom: 1px solid #edf1f6;
  color: #172b4d;
  font-size: 14px;
  line-height: 1.15;
  font-weight: 900;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.lotiqMapRightTabInfo-1 span {
  min-width: 30px;
  height: 26px;
  padding: 0 9px;
  border-radius: 999px;
  background: #e7f0ff;
  color: #0045b6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 900;
  flex: 0 0 auto;
}

@media (max-width: 768px) {
  .lotiqMapRightTabInfo {
    border-radius: 13px;
  }

  .lotiqMapRightTabInfo-1 {
    min-height: 44px;
    padding: 9px 10px;
    font-size: 13px;
  }
}

.lotiqMapEmptyState {
  min-height: 74px;
  border: 1px dashed #cfdbea;
  border-radius: 12px;
  background: #f7faff;
  color: #637083;
  font-size: 13px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 12px;
}

.lotiqMapHeaderAdType {
  min-width: 0;
  width: fit-content;
  max-width: 100%;
  min-height: 25px;
  margin-top: 3px;
  padding: 3px 9px 3px 5px;
  border: 1px solid #d8e4f3;
  border-radius: 999px;
  background: #eef5ff;
  color: #0045b6;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  line-height: 1.15;
  font-weight: 900;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.lotiqMapHeaderAdType img {
  width: 18px;
  height: 18px;
  object-fit: contain;
  flex: 0 0 auto;
}

.lotiqMapHeaderAdType span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (max-width: 768px) {
  .lotiqMapHeaderAdType {
    min-height: 23px;
    padding: 3px 8px 3px 5px;
    font-size: 11px;
  }

  .lotiqMapHeaderAdType img {
    width: 16px;
    height: 16px;
  }
}

@media (max-width: 480px) {
  .lotiqMapHeaderAdType {
    max-width: 190px;
  }
}

.lotiqMapNoticeOverlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 99990;
  background: rgba(15, 23, 42, 0.18);
  backdrop-filter: blur(1px);
}

.lotiqMapNotice {
  position: fixed;
  top: 82px;
  left: 50%;
  z-index: 99991;
  width: calc(100% - 28px);
  max-width: 560px;
  padding: 14px 16px;
  border-radius: 16px;
  background: #ffffff;
  border: 1px solid #dbe6f5;
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.22);
  transform: translate(-50%, -18px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
  box-sizing: border-box;
}

.lotiqMapNotice.show {
  opacity: 1;
  transform: translate(-50%, 0);
  pointer-events: auto;
}

.lotiqMapNoticeInner {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  align-items: center;
  gap: 11px;
}

.lotiqMapNoticeIcon {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  font-weight: 900;
  flex: 0 0 auto;
}

.lotiqMapNotice.ok .lotiqMapNoticeIcon {
  background: #e8f8ed;
  color: #128a36;
}

.lotiqMapNotice.warn .lotiqMapNoticeIcon {
  background: #fff4dc;
  color: #b26400;
}

.lotiqMapNotice.error .lotiqMapNoticeIcon {
  background: #ffe8e8;
  color: #d00000;
}

.lotiqMapNoticeText {
  min-width: 0;
  color: #172b4d;
  font-size: 14px;
  line-height: 1.35;
  font-weight: 850;
}

.lotiqMapNoticeClose {
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 999px;
  background: #eef3fb;
  color: #172b4d;
  font-size: 15px;
  font-weight: 900;
  cursor: pointer;
}

.lotiqMapNoticeClose:hover {
  background: #dfe9f8;
}

@media (max-width: 768px) {
  .lotiqMapNotice {
    top: 72px;
    border-radius: 14px;
  }

  .lotiqMapNoticeText {
    font-size: 13px;
  }
}

@media (max-width: 480px) {
  .lotiqMapNoticeInner {
    grid-template-columns: 30px minmax(0, 1fr) auto;
    gap: 9px;
  }

  .lotiqMapNoticeIcon {
    width: 30px;
    height: 30px;
    font-size: 15px;
  }

  .lotiqMapNoticeClose {
    width: 30px;
    height: 30px;
  }
}


#tbl {
  display: grid;
  grid-template-columns: repeat(2, minmax(260px, 1fr));
  gap: 12px;
  align-items: start;
}

@media (max-width: 1152px) {
  #tbl {
    grid-template-columns: 1fr;
  }
}

.lotiqMapNvLotItem {
  border: 1px solid #dce5f2;
  border-radius: 12px;
  background: #ffffff;
  padding: 10px;
  cursor: pointer;
  transition: all 0.16s ease;
  margin-bottom: 7px;
}

.lotiqMapNvLotItem:hover,
.lotiqMapNvLotItem.is-hovered {
  border-color: #9bb8e8;
  background: #f7faff;
}

.lotiqMapNvLotItem.is-active-from-map {
  border-color: #0045b6;
  background: #eef5ff;
  box-shadow: 0 0 0 2px rgba(0, 69, 182, 0.12);
}

.lotiqMapNvLotItem.is-active-from-map .nvMapLotLabel {
  color: #0045b6;
}

.lotiqMapStatsRow {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: nowrap;
  min-width: 0;
}

.lotiqMapStatBadge {
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  background: #e7f0ff;
  color: #0045b6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 950;
  white-space: nowrap;
  flex: 0 0 auto;
}

@media (max-width: 760px) {
  .lotiqMapStatsRow {
    width: 100%;
    max-width: 100%;
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto;
    overflow-y: hidden;
    gap: 6px;
    padding-bottom: 1px;
    scrollbar-width: none;
  }

  .lotiqMapStatsRow::-webkit-scrollbar {
    display: none;
  }

  .lotiqMapStatBadge {
    width: auto;
    min-width: max-content;
    min-height: 28px;
    padding: 0 10px;
    font-size: 11px;
    flex: 0 0 auto;
  }

  .lotiqMapStatBadge i {
    font-size: 11px;
    flex-shrink: 0;
  }
}

.lotiqMapBlockBox {
  border: 1px solid #dce5f2;
  border-radius: 18px;
  background: linear-gradient(135deg, #f3f7ff, #ffffff);
  padding: 26px;
  text-align: center;
}

.lotiqMapBlockBoxRed {
  border: 2px solid #dc2626;
  background: linear-gradient(135deg, #fff1f2, #ffffff);
}

.lotiqMapBlockIcon {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  background: #0045b6;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  margin-bottom: 12px;
}

.lotiqMapBlockBoxRed .lotiqMapBlockIcon {
  background: #dc2626;
}

.lotiqMapBlockTitle {
  color: #172b4d;
  font-size: 20px;
  line-height: 1.3;
  font-weight: 950;
  margin-bottom: 8px;
}

.lotiqMapBlockBoxRed .lotiqMapBlockTitle {
  color: #991b1b;
}

.lotiqMapBlockText {
  color: #526276;
  font-size: 14px;
  line-height: 1.6;
  font-weight: 800;
  margin-bottom: 15px;
}

.lotiqMapBlockBoxRed .lotiqMapBlockText {
  color: #7f1d1d;
}

.lotiqMapBlockBtn {
  min-height: 42px;
  border-radius: 999px;
  padding: 0 18px;
  background: #0045b6;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 950;
  text-decoration: none;
}

.lotiqMapBlockBoxRed .lotiqMapBlockBtn {
  background: #dc2626;
}

.hdMapMarkerPopup {
  max-width: 310px;
  color: #172b4d;
  font-size: 13px;
  line-height: 1.45;
}

.hdMapMarkerPopupTitle {
  color: #166534;
  font-size: 15px;
  font-weight: 950;
  margin-bottom: 7px;
}

.hdMapMarkerPopupLine {
  margin-top: 0px;
}

.hdMapMarkerPopupLine b {
  color: #172b4d;
  font-weight: 950;
}

.hdMapMarkerPopupActions {
  margin-top: 10px;
}

.hdMapMarkerPopupBtn {
  min-height: 36px;
  border-radius: 999px;
  padding: 0 13px;
  background: #0045b6;
  color: #ffffff !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  font-size: 12px;
  font-weight: 950;
  text-decoration: none !important;
  border: 1px solid #0045b6;
  cursor: pointer;
}























/* ==================================================================
   05. MOBILNÉ TLAČIDLO
   - zobrazí sa až keď sa skryje pravý panel
   - otvára mobilný popup so skopírovaným obsahom pravého panelu
================================================================== */

/* Tlačidlo na otvorenie mobilného panelu */
#mobileListBtn {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: nowrap;
  white-space: nowrap;
  height: 42px;
  max-height: 42px;
  border: 0;
  border-radius: 12px;
  background: #0045b6;
  color: #ffffff;
  font-weight: 900;
  box-shadow: 0 8px 18px rgba(0, 69, 182, 0.28);
}

/* Ikona v mobilnom tlačidle */
#mobileListBtn svg {
  width: 20px;
  height: 20px;
  min-width: 20px;
  max-width: 20px;
  min-height: 20px;
  max-height: 20px;
  flex: 0 0 20px;
  display: block;
  fill: currentColor;
}


/* ==================================================================
   06. MOBILNÝ POPUP
   - vysúva sa zdola
   - zatvára sa späť dole
   - používa transform, nie display none/block
================================================================== */

/* Celý mobilný popup mimo obrazovky */
#mobilePopup {
  display: block;
  position: fixed;
  inset: 0;
  z-index: 99999;
  overflow: auto;
  background: #f5f8ff;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(100%);
  transition:
    transform 0.38s cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0s linear 0.38s;
  will-change: transform;
}

/* Aktívny mobilný popup - vysunutý na obrazovku */
#mobilePopup.active {
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition:
    transform 0.38s cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0s linear 0s;
}

/* Horné zatváracie tlačidlo mobilného popupu */
#mobilePopupClose {
  min-height: 44px;
  padding: 0 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #101827, #0045b6);
  border-bottom: 1px solid #d8e1ee;
  color: white;
  font-size: 15px;
  line-height: 1;
  font-weight: 900;
  cursor: pointer;
  position: sticky;
  top: 0;
  z-index: 2;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.12);
}

/* Obsah mobilného popupu */
#dataTableMobile {
  padding: 10px;
  background: #f5f8ff;
}


/* ==================================================================
   07. MOBILNÉ BREAKPOINTY
   - pri 800px sa skryje pravý panel a zobrazí mobilné tlačidlo
   - breakpoint je rovnaký ako pri skrytí pravého panelu
================================================================== */

@media (max-width: 800px) {
  .lotiqMapHeaderTop {
    min-height: 44px;
    padding: 6px 8px;
    gap: 8px;
  }

  .lotiqMapHeaderBottom {
    min-height: 44px;
    padding: 6px 8px;
    gap: 8px;
  }

  .lotiqMapHeaderBottomMargueText {
    font-size: 14px;
  }

  #dataTable {
    padding: 8px;
  }

  #mobileListBtn {
    position: fixed;
    left: 50%;
    right: auto;
    bottom: calc(18px + env(safe-area-inset-bottom));
    display: inline-flex;
    width: auto;
    max-width: calc(100% - 24px);
    height: 42px;
    max-height: 42px;
    font-size: 15px;
    padding: 0 18px;

    transform: translateX(-50%);
  }
}

/* Menšie mobily */
@media (max-width: 480px) {
  .lotiqMapHeaderTop {
    min-height: 42px;
  }

  .lotiqMapHeaderBottom {
    min-height: 42px;
  }

  .lotiqMapHeaderBottomMargueText {
    font-size: 13px;
  }

  #mobileListBtn {
    font-size: 14px;
  }
}

.lotiqMapSideCard {
  background: #ffffff;
  border: 1px solid #e1e9f5;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.05);
}

.lotiqMapSideCardHeader {
  min-height: 46px;
  padding: 10px 12px;
  background: #ffffff;
  border-bottom: 1px solid #edf1f6;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

@media (max-width: 768px) {
  .lotiqMapSideCard {
    border-radius: 13px;
  }

  .lotiqMapSideCardHeader {
    min-height: 44px;
    padding: 9px 10px;
  }
}

.lotiqMapSideTitle {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}

.lotiqMapSideTitleMain {
  font-size: 14px;
  line-height: 1.15;
  font-weight: 900;
  color: #172b4d;
  display: flex;
  align-items: center;
  gap: 7px;
}

.lotiqMapSideTitleMain i {
  color: #0045b6;
}

.lotiqMapSideTitleSub {
  font-size: 11px;
  line-height: 1.2;
  font-weight: 800;
  color: #6c7c91;
}

@media (max-width: 480px) {
  .lotiqMapSideTitleMain {
    font-size: 13px;
  }

  .lotiqMapSideTitleSub {
    font-size: 10px;
  }
}

.lotiqMapSideBody {
  padding: 10px;
}

@media (max-width: 768px) {
  .lotiqMapSideBody {
    padding: 9px;
  }
}

#buyMapPage #lotiqMapRight {
  width: 650px;
  flex: 0 0 650px;
}

@media (max-width: 1152px) {
  #buyMapPage #lotiqMapRight {
    width: 380px;
    flex: 0 0 380px;
  }
}



















.mapPagination {
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid #e0e8f5;
}

.mapPaginationBtn {
  min-height: 32px;
  padding: 0 11px;
  border: 1px solid #d8e4f3;
  border-radius: 999px;
  background: #e7f0ff;
  color: #0045b6;
  font-size: 12px;
  line-height: 1;
  font-weight: 900;
  cursor: pointer;
}

.mapPaginationBtn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.mapPaginationInfo {
  color: #65758b;
  font-size: 12px;
  font-weight: 900;
  text-align: center;
}









.mapWmsDebug {
  margin-top: 10px;
  border: 1px solid #d8e4f3;
  border-radius: 10px;
  overflow: hidden;
  background: #ffffff;
}

.mapWmsDebugTitle {
  padding: 8px 9px;
  background: #eef3fb;
  color: #172b4d;
  font-size: 12px;
  font-weight: 900;
}

.mapWmsDebugRow {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  gap: 8px;
  padding: 6px 9px;
  border-top: 1px solid #eef3f9;
  font-size: 11px;
  line-height: 1.25;
}

.mapWmsDebugKey {
  color: #65758b;
  font-weight: 900;
  word-break: break-word;
}

.mapWmsDebugValue {
  color: #101827;
  font-weight: 800;
  word-break: break-word;
}














.mapWmsMessage {
  display: none;
  margin-top: 9px;
  border-radius: 12px;
  padding: 10px;
  color: #ffffff;
  font-size: 13px;
  line-height: 1.35;
  font-weight: 900;
}

.mapWmsMessageOk {
  background: #16a34a;
}

.mapWmsMessageUpdate {
  background: #0284c7;
}

.mapWmsMessageWarn {
  background: #f59e0b;
  color: #101827;
}

.mapWmsMessageError {
  background: #dc2626;
}


















.buyMapAdvCard {
  min-width: 0;
  background: #ffffff;
  border: 1px solid #dce5f2;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.40);
  transition: box-shadow 0.18s ease, transform 0.18s ease, border-color 0.18s ease;
}

.buyMapAdvCard:hover {
  border-color: #bfd0e8;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.46);
  transform: translateY(-1px);
}

.buyMapAdvCardTopovana {
  box-shadow:
    0 0 0 2px rgba(245, 179, 1, 0.75),
    0 10px 22px rgba(245, 179, 1, 0.18) !important;
}

.buyMapAdvImage {
  position: relative;
  height: 170px;
  background-size: cover;
  background-position: center;
  background-color: #e7edf7;
  overflow: hidden;
}

.buyMapAdvImage::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(15, 23, 42, 0.10), rgba(15, 23, 42, 0.02) 45%, rgba(15, 23, 42, 0.22));
  pointer-events: none;
  z-index: 1;
}

.buyMapAdvBadgeRow {
  position: absolute;
  top: 8px;
  left: 8px;
  right: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  z-index: 3;
}

.buyMapAdvBadge {
  max-width: 100%;
  min-height: 23px;
  padding: 0 9px;
  border-radius: 999px;
  background: #8b13d3;
  color: #ffffff;
  font-size: 11px;
  line-height: 23px;
  font-weight: 900;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.buyMapAdvTopBadge {
  min-height: 23px;
  padding: 0 9px;
  border-radius: 999px;
  background: linear-gradient(135deg, #fff7cf, #ffe28a);
  border: 1px solid #f5d36b;
  color: #6f5400;
  font-size: 11px;
  line-height: 21px;
  font-weight: 900;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.18);
}

.buyMapAdvTopBadge span:first-child {
  font-size: 13px;
  line-height: 1;
}

.buyMapAdvFavoriteWrap {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 5;
}

.buyMapAdvSliderBtn {
  position: absolute;
  top: 50%;
  width: 29px;
  height: 36px;
  border: 0;
  border-radius: 10px;
  background: rgba(16, 24, 39, 0.58);
  color: #ffffff;
  font-size: 25px;
  line-height: 1;
  font-weight: 900;
  cursor: pointer;
  transform: translateY(-50%);
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
}

.buyMapAdvSliderBtn:hover {
  background: rgba(16, 24, 39, 0.82);
}

.buyMapAdvSliderPrev {
  left: 7px;
}

.buyMapAdvSliderNext {
  right: 7px;
}

.buyMapAdvPhotoCount {
  position: absolute;
  right: 8px;
  bottom: 8px;
  min-height: 21px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(16, 24, 39, 0.76);
  color: #ffffff;
  font-size: 11px;
  line-height: 21px;
  font-weight: 900;
  z-index: 3;
}

.buyMapAdvMapFocusLink {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 31px;
  height: 31px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 3px 10px rgba(15, 23, 42, 0.20);
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.buyMapAdvMapFocus {
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: #0045b6;
  position: relative;
}

.buyMapAdvMapFocus::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #ffffff;
  transform: translate(-50%, -50%);
}

.buyMapAdvLink {
  display: block;
  color: inherit;
  text-decoration: none;
}

.buyMapAdvBody {
  padding: 5px 10px 10px 10px;
  background: #ffffff;
}

.buyMapAdvTypeLine {
  color: #0045b6;
  font-size: 12px;
  line-height: 1.15;
  font-weight: 900;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.buyMapAdvPriceRow {
  min-width: 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 7px;
}

.buyMapAdvPrice {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  color: #101827;
  font-size: 18px;
  line-height: 1.05;
  font-weight: 900;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.buyMapAdvPrice img {
  width: 40px;
  height: 40px;
  min-width: 40px;
  object-fit: contain;
  display: block;
}

.buyMapAdvMeter {
  flex: 0 0 auto;
  color: #65758b;
  font-size: 11px;
  line-height: 1.15;
  font-weight: 900;
  white-space: nowrap;
  padding-top: 2px;
}

.buyMapAdvMetaRow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 7px;
  color: #26384f;
  font-size: 12px;
  line-height: 1.15;
  font-weight: 850;
}

.buyMapAdvMetaRow div {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.buyMapAdvArea {
  min-width: 0;
}

.buyMapAdvLocation {
  color: #65758b;
  font-size: 12px;
  line-height: 1.15;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.indexBuyMapAdvGrid {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

@media (max-width: 1100px) {
  .indexBuyMapAdvGrid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .indexBuyMapAdvGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
}

@media (max-width: 780px) {
  .buyMapAdvImage {
    height: 155px;
  }
}

@media (max-width: 600px) {
  .indexBuyMapAdvGrid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 520px) {
  .buyMapAdvImage {
    height: 180px;
  }
}

.buyMapAdvVisitCount {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-height: 24px;
  padding: 3px 9px;
  border-radius: 999px;
  background: #eef5ff;
  color: #0045b6;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
}

.buyMapAdvVisitCount i {
  font-size: 12px;
}

























.sellLotFieldInfo {
  margin-top: 6px;
  color: #6b7280;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.35;
}



#pricePerM2 {
  min-height: 42px;
  width: 100%;
  padding: 11px 12px;
  background: #f3f6fb;
  border: 1px solid #d8e2ef;
  border-radius: 10px;
  color: #172b4d;
  font-size: 15px;
  font-weight: 900;
  line-height: 1.2;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sellLotActions .sellLotFieldInfo {
  margin-top: 8px;
  padding: 0 2px;
}

fieldset .flex > div .sellLotFieldInfo {
  margin-bottom: 4px;
}

@media (max-width: 768px) {
  .sellLotFieldInfo {
    font-size: 11px;
  }
}

.sellLotParcelsFieldset {
  padding: 14px;
}

.sellLotParcelsTable {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sellLotParcelsHead {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 140px;
  gap: 10px;
  padding: 0 12px 4px 12px;
  color: #526276;
  font-size: 11px;
  font-weight: 900;
  line-height: 1.15;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.sellLotParcelsBody {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sellLotParcelRow {
  min-height: 46px;
  padding: 10px 12px;
  background: #ffffff;
  border: 1px solid #dbe6f4;
  border-radius: 12px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 140px;
  align-items: center;
  gap: 10px;
  box-shadow: 0 3px 10px rgba(15, 23, 42, 0.035);
}

.sellLotParcelName {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 7px;
  color: #10213f;
  font-size: 13px;
  font-weight: 900;
  line-height: 1.2;
}

.sellLotParcelType {
  min-width: 24px;
  height: 24px;
  padding: 0 7px;
  border-radius: 999px;
  background: #e8f0ff;
  color: #0045b6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 900;
  flex: 0 0 auto;
}

.sellLotParcelNumber {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sellLotParcelArea {
  color: #10213f;
  font-size: 13px;
  font-weight: 900;
  line-height: 1.2;
  text-align: right;
  white-space: nowrap;
}

.sellLotParcelArea span {
  color: #6b778c;
  font-size: 11px;
  font-weight: 900;
}

@media (max-width: 520px) {
  .sellLotParcelsFieldset {
    padding: 12px;
  }

  .sellLotParcelsHead {
    grid-template-columns: minmax(0, 1fr) 140px;
    padding: 0 10px 3px 10px;
    font-size: 10px;
  }

  .sellLotParcelRow {
    grid-template-columns: minmax(0, 1fr) 140px;
    min-height: 44px;
    padding: 9px 10px;
    border-radius: 11px;
  }

  .sellLotParcelName {
    font-size: 12px;
    gap: 6px;
  }

  .sellLotParcelType {
    min-width: 22px;
    height: 22px;
    padding: 0 6px;
    font-size: 10px;
  }

  .sellLotParcelArea {
    font-size: 12px;
  }

  .sellLotParcelArea span {
    font-size: 10px;
  }
}











/* --- Fullscreen overlay – stredná zelená --- */
#loading-screen {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: linear-gradient(135deg, #7cbf7c 0%, #66bb6a 40%, #4caf50 70%, #a5d6a7 100%);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 99999;
  transition: opacity 0.8s ease;
  overflow: hidden;
}

#loading-screen.hide {
  opacity: 0;
  pointer-events: none;
}

/* --- content --- */
.loading-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  transform: translateY(-20px);
}

/* --- logo --- */
.loading-logo {
  width: 120px;
  height: 120px;
  animation: pulse 2s ease-in-out infinite;
  margin-bottom: 25px;
  object-fit: contain;
}

.loading-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: brightness(0);
}

@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.08); }
}

/* --- progress bar --- */
.loading-bar-container {
  width: 220px;
  height: 4px;
  background: #e8f5e9;
  overflow: hidden;
  border-radius: 4px;
  margin-bottom: 20px;
  position: relative;
}

.loading-bar {
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, #388e3c, #81c784, #388e3c);
  border-radius: 4px;
  animation: smoothSlide 1.8s ease-in-out infinite;
}

@keyframes smoothSlide {
  0% { transform: translateX(0); }
  50% { transform: translateX(100%); }
  100% { transform: translateX(200%); }
}

/* --- text --- */
.loading-text {
  font-size: 17px;
  color: #173d1a; /* dosť tmavé na kontrast, ale nie čierne */
  font-weight: 700;
  animation: textPulse 2s ease-in-out infinite;
}

@keyframes textPulse {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-1px); }
}

.loading-percent {
  margin-top: 8px;
  font-size: 15px;
  font-weight: 700;
  color: #0045b6;
  text-align: center;
}

#loadingProgressBar {
  width: 0%;
  transition: width 0.25s ease;
}

.lotiqMapHelpText {
  color: #526276;
  font-size: 11px;
  line-height: 1.55;
  font-weight: 700;
}

.lotiqMapHelpText p {
  margin: 0 0 8px 0;
}

.lotiqMapHelpText p:last-child {
  margin-bottom: 0;
}








.lotiqMapHeaderTitleBoxIcon {
  width: 38px;
  height: 38px;
  min-width: 38px;
  border-radius: 12px;
  background: #e7f0ff;
  border: 1px solid #d8e4f3;
  color: #0045b6;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lotiqMapHeaderTitleBoxIcon img {
  max-width: 26px;
  max-height: 26px;
  display: block;
}

@media (max-width: 768px) {
  .lotiqMapHeaderTitleBoxIcon {
    width: 34px;
    height: 34px;
    min-width: 34px;
    border-radius: 11px;
  }

  .lotiqMapHeaderTitleBoxIcon img {
    max-width: 23px;
    max-height: 23px;
  }
}









.lotiqMapHeaderTitleBox {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 11px;
}

.lotiqMapHeaderTitleBoxText {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}


.lotiqMapHeaderTitleBoxTextLabel {
  font-size: 10px;
  line-height: 1;
  font-weight: 900;
  color: #65758b;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.lotiqMapHeaderTitleBoxTextLabel2 {
  min-width: 0;
  max-width: 100%;
  font-size: 15px;
  line-height: 1.15;
  font-weight: 900;
  color: #101827;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.lotiqMapLotsList {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

@media (max-width: 768px) {
  .lotiqMapHeaderTitleBoxTextLabel {
    font-size: 9px;
  }

  .lotiqMapHeaderTitleBoxTextLabel2 {
    font-size: 14px;
  }
}

@media (max-width: 480px) {
  .lotiqMapHeaderTitleBoxTextLabel2 {
    font-size: 13px;
  }
}

.lotiqMapTopButton {
  min-height: 36px;
  padding: 0 13px;
  border: 0;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: background 0.15s ease, box-shadow 0.15s ease;
  background: #0045b6;
  color: #ffffff;
}

@media (max-width: 768px) {
  .lotiqMapTopButton {
    min-height: 34px;
    padding: 0 11px;
    font-size: 12px;
    border-radius: 9px;
  }
}

@media (max-width: 480px) {
  .lotiqMapTopButton {
    min-height: 32px;
    padding: 0 10px;
    font-size: 12px;
  }
}

.lotiqMapCounter {
  min-width: 30px;
  height: 26px;
  padding: 0 9px;
  border-radius: 999px;
  background: #e7f0ff;
  color: #0045b6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 900;
  flex: 0 0 auto;
}

.pop {
width: auto;
height: auto;
font-size: 13px;
border: none;
}

.pop:hover {
color:  green;
}

.buttonpop {
background: blue;
color: white;
padding: 4px 8px;
margin: 10px 0 0 0;
border-radius: 4px;
}

.bkg-blue {
background: #0045b6;
color: white;
}

.bkg-blue:disabled {
background: #b2b2b2;
color: black;
}

.bkg-green {
background: #a2d716;
}

.bkg-orange {
background: #ef7000;
}

.bkg-red {
background: #dd4343;
color: white;
}

.bkg-gray {
background: #8d8d8d;
color: white;
}





























































.lotiqMapLotItem {
  min-height: 40px;
  padding: 5px 10px;
  border-radius: 12px;
  border: 1px solid #e0e8f5;
  background: #f7faff;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  cursor: default;
  transition: background 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
}

.lotiqMapLotItem:hover,
.lotiqMapLotItem.is-hovered {
  background: #fff5df;
  border-color: #ffc767;
  transform: translateY(-1px);
}

.lotiqMapLotParcel {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.lotiqMapLotLabel {
  font-size: 14px;
  font-weight: 900;
  color: #172b4d;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.lotiqMapLotArea {
  font-size: 13px;
  font-weight: 900;
  color: #172b4d;
  white-space: nowrap;
  text-align: right;
}

@media (max-width: 768px) {
  .lotiqMapLotItem {
    min-height: 46px;
    padding: 8px 9px;
  }

  .lotiqMapLotLabel {
    font-size: 13px;
  }

  .lotiqMapLotArea {
    font-size: 12px;
  }
}



























.parcelHoverControl {
  position: absolute;
  top: 58px;
  left: 8px;
  width: 295px;
  max-width: calc(100% - 16px);
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(210, 220, 235, 0.95);
  border-radius: 12px;
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.16);
  overflow: hidden;
  font-family: Arial, sans-serif;
  pointer-events: none;
  z-index: 5;
}

.parcelHoverHead {
  padding: 9px 11px;
  background: #f7f9fc;
  border-bottom: 1px solid #e5edf8;
  color: #172b4d;
  font-size: 13px;
  font-weight: 900;
}

.parcelHoverBody {
  padding: 9px 11px 10px 11px;
  color: #24364f;
  font-size: 12px;
  font-weight: 700;
}

.parcelHoverRow {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  border-bottom: 1px solid #eef3f9;
  padding: 4px 0;
}

.parcelHoverRow:last-child {
  border-bottom: 0;
}

.parcelHoverLabel {
  color: #68788f;
  font-weight: 800;
}

.parcelHoverValue {
  color: #172b4d;
  font-weight: 900;
  text-align: right;
}


@media (max-width: 768px) {
  .parcelHoverControl {
    top: 52px;
    left: 6px;
    width: 270px;
    max-width: calc(100% - 12px);
  }

}

@media (max-width: 480px) {
  .parcelHoverControl {
    top: 46px;
    left: 6px;
    width: 245px;
  }
}



.lotiqMapHeaderActionsTop {
  display: flex;
  align-items: center;
  gap: 8px;
}

.lotiqMapHeaderActionsBottom {
  display: flex;
  align-items: center;
  gap: 8px;
}

.lotiqMapMobileActionSelect {
  display: none;
  height: 38px;
  border: 0;
  border-radius: 9px;
  background: #0045b6;
  color: #ffffff;
  font-size: 14px;
  font-weight: 800;
  padding: 0 36px 0 12px;
  outline: none;
  cursor: pointer;
  max-width: 220px;
}

.lotiqMapMobileActionSelect option {
  background: #ffffff;
  color: #111827;
  font-weight: 700;
}

.mapWmsStatOk {
  color: #159947;
  font-weight: 900;
}

.mapWmsStatWarn {
  color: #b45309;
  font-weight: 900;
}

.mapWmsStatBad {
  color: #dc2626;
  font-weight: 900;
}

@media screen and (max-width: 800px) {
  .lotiqMapHeaderBottom {
    gap: 8px;
  }

  .lotiqMapHeaderActionsBottom {
    display: none;
  }

  .lotiqMapMobileActionSelect {
    display: block;
    flex: 0 0 auto;
  }

  .lotiqMapHeaderBottomMargue {
    min-width: 0;
    flex: 1 1 auto;
  }
}





























.introBox {
  border: 1px solid #dce5f2;
  border-radius: 18px;
  background: linear-gradient(135deg, #f3f7ff, #ffffff);
  padding: 18px;
  margin-bottom: 18px;
}

.introTitle {
  color: #172b4d;
  font-size: 20px;
  line-height: 1.25;
  font-weight: 900;
  margin-bottom: 8px;
}

.introText {
  color: #53657d;
  font-size: 14px;
  line-height: 1.65;
  font-weight: 650;
}

.searchGrid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.searchCard {
  min-height: 245px;
  border: 1px solid #dce5f2;
  border-radius: 18px;
  background: #ffffff;
  padding: 18px;
  color: inherit;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
  transition: all 0.18s ease;
}

.searchCard:hover {
  border-color: #0068ff;
  box-shadow: 0 10px 26px rgba(0, 69, 182, 0.14);
  transform: translateY(-2px);
}

.searchCard::after {
  content: "";
  position: absolute;
  right: -38px;
  bottom: -42px;
  width: 140px;
  height: 140px;
  border-radius: 999px;
  background: rgba(0, 104, 255, 0.07);
  pointer-events: none;
}

.searchCardTop {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  position: relative;
  z-index: 2;
}

.searchIcon {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  background: #eef5ff;
  color: #0045b6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 23px;
  flex-shrink: 0;
}

.searchNumber {
  min-width: 34px;
  height: 34px;
  border-radius: 999px;
  background: #0045b6;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 900;
}

.searchTitle {
  color: #172b4d;
  font-size: 18px;
  line-height: 1.25;
  font-weight: 900;
  margin-bottom: 9px;
  position: relative;
  z-index: 2;
}

.searchText {
  color: #65758b;
  font-size: 13px;
  line-height: 1.58;
  font-weight: 700;
  margin-bottom: 16px;
  position: relative;
  z-index: 2;
}

.searchButton {
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: #0045b6;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 900;
  margin-top: auto;
  width: fit-content;
  position: relative;
  z-index: 2;
}

.searchCard:hover .searchButton {
  background: #0068ff;
}

.searchCardMap {
  background: linear-gradient(135deg, #ffffff, #f7fbff);
}

.searchCardMap .searchIcon {
  background: #e9f8ef;
  color: #087333;
}

.searchCardMap .searchNumber {
  background: #087333;
}

.searchCardMap .searchButton {
  background: #087333;
}

.searchCardMap:hover .searchButton {
  background: #0a8b40;
}

.nvBottomNotice {
  margin-top: 18px;
  border: 1px solid #f5d36b;
  border-radius: 16px;
  background: #fff9e8;
  padding: 14px 16px;
  color: #735f21;
  font-size: 13px;
  line-height: 1.55;
  font-weight: 750;
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.nvBottomNotice i {
  color: #7a5a00;
  font-size: 18px;
  margin-top: 1px;
}

@media (max-width: 980px) {
  .searchGrid {
    grid-template-columns: 1fr;
  }

  .searchCard {
    min-height: auto;
  }
}

@media (max-width: 620px) {
  .introBox {
    padding: 16px;
  }

  .introTitle {
    font-size: 18px;
  }

  .searchCard {
    padding: 16px;
  }

  .searchIcon {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    font-size: 20px;
  }

  .searchTitle {
    font-size: 17px;
  }
}



















  .nvLoginOverlay {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: rgba(15, 23, 42, 0.62);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px;
    box-sizing: border-box;
  }

  .nvLoginOverlay.active {
    display: flex;
  }

  .nvLoginPopup {
    width: 100%;
    max-width: 420px;
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 20px 60px rgba(15, 23, 42, 0.28);
    padding: 24px;
    text-align: center;
    position: relative;
    box-sizing: border-box;
  }

  .nvLoginPopupClose {
    position: absolute;
    top: 11px;
    right: 11px;
    width: 34px;
    height: 34px;
    border: 0;
    border-radius: 999px;
    background: #f1f5f9;
    color: #172b4d;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 15px;
  }

  .nvLoginPopupClose:hover {
    background: #e2e8f0;
  }

  .nvLoginPopupIcon {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    background: #eef5ff;
    color: #0045b6;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    margin-bottom: 13px;
  }

  .nvLoginPopupTitle {
    color: #172b4d;
    font-size: 21px;
    line-height: 1.25;
    font-weight: 950;
    margin-bottom: 8px;
  }

  .nvLoginPopupText {
    color: #53657d;
    font-size: 14px;
    line-height: 1.55;
    font-weight: 750;
    margin-bottom: 18px;
  }

  .nvLoginPopupActions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    flex-wrap: wrap;
  }

  .nvLoginPopupBtn {
    min-height: 40px;
    padding: 0 16px;
    border-radius: 999px;
    background: #0045b6;
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 950;
    text-decoration: none;
  }

  .nvLoginPopupBtn:hover {
    background: #0068ff;
    color: #ffffff;
  }

  .nvLoginPopupCancel {
    min-height: 40px;
    padding: 0 16px;
    border-radius: 999px;
    border: 1px solid #ccd8ea;
    background: #ffffff;
    color: #172b4d;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 950;
    cursor: pointer;
  }

  .nvLoginPopupCancel:hover {
    border-color: #0068ff;
    color: #0045b6;
    background: #f3f7ff;
  }

  @media (max-width: 520px) {
    .nvLoginPopup {
      padding: 22px 16px;
    }

    .nvLoginPopupActions {
      display: grid;
      grid-template-columns: 1fr;
    }

    .nvLoginPopupBtn,
    .nvLoginPopupCancel {
      width: 100%;
    }
  }
















  .mapSettingsPanel {
  margin-top: 10px;
  border: 1px solid #dce5f2;
  border-radius: 16px;
  background: #ffffff;
  overflow: hidden;
}

.mapSettingsToggle {
  width: 100%;
  border: 0;
  background: #f7faff;
  color: #172b4d;
  padding: 11px 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 950;
  cursor: pointer;
}

.mapSettingsBody {
  display: none;
  padding: 12px;
  border-top: 1px solid #dce5f2;
}

.mapSettingsBody.is-open {
  display: block;
}

.mapSettingsNotice {
  border-radius: 12px;
  padding: 5px 10px;
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 900;
}

.mapSettingsNotice.ok {
  background: #dcfce7;
  color: #166534;
}

.mapSettingsNotice.error {
  background: #fee2e2;
  color: #991b1b;
}

.mapSettingsGrid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}

.mapSettingsField {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border: 1px solid #e4ebf5;
  background: #ffffff;
  border-radius: 12px;
  padding: 0px 10px;
}

.mapSettingsLabel {
  color: #334155;
  font-size: 12px;
  line-height: 1.2;
  font-weight: 900;
}

.mapSettingsInput {
  width: 44px;
  height: 30px;
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
}

.mapSettingsNumber {
  width: 74px;
  height: 32px;
  border: 1px solid #dce5f2;
  border-radius: 10px;
  padding: 0 8px;
  color: #172b4d;
  font-size: 12px;
  font-weight: 900;
}

.mapSettingsActions {
  margin-top: 10px;
  display: flex;
  justify-content: flex-end;
}

.mapSettingsBtn {
  border: 0;
  border-radius: 12px;
  background: #0045b6;
  color: #ffffff;
  padding: 9px 13px;
  font-size: 12px;
  line-height: 1;
  font-weight: 950;
  cursor: pointer;
}