*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;width:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;-webkit-text-size-adjust:100%;text-size-adjust:100%}
/* Прибираємо подвійний тап-зум і сірий тап-хайлайт на елементах інтерфейсу */
button,select,#panel,#info-popup,#right-controls{touch-action:manipulation;-webkit-tap-highlight-color:transparent}
#map{position:absolute;top:0;left:0;right:0;bottom:0}
#ui{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:10}

#panel{position:absolute;top:12px;left:12px;width:300px;background:rgba(10,12,20,0.88);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.1);border-radius:14px;color:#fff;pointer-events:all;overflow:visible;transition:transform .3s ease;z-index:30}
#panel.collapsed #panel-body{display:none}
#panel-header{position:relative;padding:14px 16px;display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none;border-bottom:1px solid rgba(255,255,255,0.07)}
#panel-header h1{font-size:15px;font-weight:600;letter-spacing:-.2px;flex:1}
#panel-toggle{width:28px;height:28px;border-radius:8px;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.06);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:rgba(255,255,255,0.7);transition:all .2s;flex-shrink:0}
#panel-toggle:hover{background:rgba(255,255,255,0.12)}
#panel-body{padding:14px 16px 16px;max-height:calc(100vh - 100px);overflow-y:auto}

.search-wrap{position:relative;flex:1;min-width:0}
#search{width:100%;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);border-radius:9px;padding:9px 32px 9px 34px;color:#fff;font-size:13px;outline:none;transition:border-color .2s}
#search-clear{display:none;position:absolute;right:8px;top:50%;transform:translateY(-50%);width:20px;height:20px;border:none;border-radius:50%;background:rgba(255,255,255,0.12);color:rgba(255,255,255,0.7);font-size:15px;line-height:1;cursor:pointer;align-items:center;justify-content:center;padding:0}
#search-clear:hover{background:rgba(255,255,255,0.22);color:#fff}
#search:not(:placeholder-shown)+#search-clear{display:flex}
#search::placeholder{color:rgba(255,255,255,0.35)}
#search:focus{border-color:rgba(99,179,237,0.6)}
.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:14px;color:rgba(255,255,255,0.35);pointer-events:none}
#search-results{display:none;background:rgba(10,12,20,0.97);border:1px solid rgba(255,255,255,0.1);border-radius:10px;overflow:hidden;max-height:240px;overflow-y:auto;position:absolute;top:100%;left:0;right:0;margin-top:6px;z-index:50;box-shadow:0 8px 24px rgba(0,0,0,0.4)}
.search-item{padding:9px 12px;cursor:pointer;font-size:12px;border-bottom:1px solid rgba(255,255,255,0.05);display:flex;align-items:flex-start;gap:8px}
.search-item:last-child{border-bottom:none}
.search-item:hover{background:rgba(255,255,255,0.07)}
.search-item-name{color:#fff;line-height:1.4}
.search-item-tag{color:rgba(255,255,255,0.4);font-size:10px;display:block;margin-top:1px}

.section-label{font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:8px;margin-top:12px}
.section-label:first-child{margin-top:0}
#quick-list{max-height:112px;overflow-y:auto;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);border-radius:9px;padding:2px 10px}
#quick-list::-webkit-scrollbar{width:5px}
#quick-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.15);border-radius:3px}

.layer-row{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,0.04)}
.layer-row:last-child{border-bottom:none}
.layer-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.layer-name{font-size:13px;color:rgba(255,255,255,0.8);flex:1}
.tog-wrap{position:relative;width:36px;height:20px;cursor:pointer;flex-shrink:0}
.tog-wrap input{opacity:0;width:0;height:0;position:absolute}
.tog-track{position:absolute;inset:0;border-radius:10px;background:rgba(255,255,255,0.12);transition:background .2s;pointer-events:none}
.tog-wrap input:checked+.tog-track{background:#3b82f6}
.tog-thumb{position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .2s;pointer-events:none}
.tog-wrap input:checked~.tog-thumb{transform:translateX(16px)}

.view-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:4px}
.view-btn{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:8px;color:rgba(255,255,255,0.75);font-size:11px;padding:8px 6px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all .2s;pointer-events:all;line-height:1.3;text-align:center}
.view-btn:hover{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.2)}
.view-btn.active{background:rgba(59,130,246,0.25);border-color:rgba(59,130,246,0.5);color:#93c5fd}

.daynight-wrap{display:flex;gap:6px;margin-top:4px}
.dn-btn{flex:1;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:8px;color:rgba(255,255,255,0.75);font-size:11px;padding:7px 4px;cursor:pointer;text-align:center;transition:all .2s;pointer-events:all}
.dn-btn:hover{background:rgba(255,255,255,0.1)}
.dn-btn.active{background:rgba(250,204,21,0.15);border-color:rgba(250,204,21,0.4);color:#fde68a}
.dn-btn.night.active{background:rgba(99,102,241,0.2);border-color:rgba(99,102,241,0.4);color:#c4b5fd}
.dn-btn.sat.active{background:rgba(52,211,153,0.15);border-color:rgba(52,211,153,0.4);color:#6ee7b7}

#style-select{width:100%;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:8px;color:#fff;font-size:12px;padding:8px 30px 8px 10px;cursor:pointer;outline:none;appearance:none;-webkit-appearance:none;pointer-events:all;transition:border-color .2s;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.5)' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}
#style-select:hover{border-color:rgba(255,255,255,0.25)}
#style-select:focus{border-color:rgba(99,179,237,0.6)}
#style-select option{background:#0e1018;color:#fff}

/* Заблокована кнопка шару (напр. немає 3D будівель у стилі) */
.view-btn:disabled{opacity:.35;cursor:not-allowed;background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.08);color:rgba(255,255,255,0.5)}
.view-btn:disabled.active{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.08);color:rgba(255,255,255,0.5)}

#right-controls{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:6px;pointer-events:all;z-index:20}
.ctrl-btn{width:40px;height:40px;background:rgba(10,12,20,0.92);border:1px solid rgba(255,255,255,0.1);border-radius:10px;color:rgba(255,255,255,0.8);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s,border-color .2s;line-height:1}
.ctrl-btn:focus{outline:none}
/* hover-підсвітку лишаємо лише на пристроях з мишею (на тачі :hover «залипає» і кнопка ставала прозорою) */
@media (hover:hover){
  .ctrl-btn:hover{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.2)}
  /* Для світлих стилів карти при наведенні — чорний текст і чорна обводка */
  body.light-map .ctrl-btn:hover{background:#fff;color:#000;border-color:#000}
}
/* На тачі при натисканні даємо короткий темний відгук, фон не світлішає */
.ctrl-btn:active{background:rgba(10,12,20,0.95);border-color:rgba(255,255,255,0.25)}
.ctrl-sep{height:1px;background:rgba(255,255,255,0.1);margin:0 4px}
.ctrl-logo{width:24px;height:24px;object-fit:contain;display:block;pointer-events:none}
/* Іконки в кнопках — єдиний моностиль (білий контур currentColor) */
.ctrl-btn svg{width:20px;height:20px;display:block;pointer-events:none}
/* Кнопки-перемикачі шарів (3D будівлі / Відділення) у правій панелі */
.ctrl-btn.layer-toggle.active{background:rgba(10,12,20,0.92);border-color:rgba(59,130,246,0.9);color:#60a5fa;box-shadow:inset 0 0 0 1px rgba(59,130,246,0.55)}
/* Неактивний шар: звичайний тёмний бокс з білою іконкою (як решта кнопок) */
.ctrl-btn.layer-toggle:not(.active){color:rgba(255,255,255,0.8)}
.ctrl-btn.layer-toggle:disabled{color:rgba(255,255,255,0.22);cursor:not-allowed}
/* Чорно-біла іконка відділень */
.mono-emoji{filter:grayscale(1);display:inline-block;pointer-events:none}

#info-popup{position:absolute;bottom:50px;left:50%;transform:translateX(-50%);background:rgba(10,12,20,0.72);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.07);border-radius:8px;padding:10px 14px;color:#fff;pointer-events:all;width:340px;display:none;z-index:20}
#info-popup.visible{display:block}
#info-close{position:absolute;top:10px;right:10px;width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,0.1);border:none;color:rgba(255,255,255,0.6);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}
#info-close:hover{background:rgba(255,255,255,0.2)}
.info-tag{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;padding:2px 7px;border-radius:5px;background:rgba(59,130,246,0.2);color:#93c5fd;flex-shrink:0}
.info-main{display:flex;gap:10px;align-items:center}
#info-logo{width:44px;height:44px;flex-shrink:0;border-radius:8px;object-fit:cover;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1)}
.info-text{flex:1;min-width:0;padding-right:24px}
#info-desc{font-size:13px;font-weight:600;color:#fff;line-height:1.35}
.info-footer{display:flex;align-items:center;gap:10px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,0.08)}
#info-coords{font-size:10px;color:rgba(255,255,255,0.3);font-family:monospace;white-space:nowrap;margin-left:auto}
#info-route{display:none;font-size:13px;font-weight:600;color:#93c5fd;white-space:nowrap}

#loading{position:absolute;inset:0;background:rgb(8,10,18);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100;transition:opacity .6s}
#loading.done{opacity:0;pointer-events:none}
.loader-ring{width:48px;height:48px;border:3px solid rgba(255,255,255,0.08);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:18px}
.loader-wrap{position:relative;width:48px;height:48px;margin-bottom:18px;display:flex;align-items:center;justify-content:center}
.loader-wrap .loader-ring{margin-bottom:0}
#load-pct{position:absolute;color:#fff;font-size:12px;font-weight:600;letter-spacing:-.3px;font-variant-numeric:tabular-nums}
@keyframes spin{to{transform:rotate(360deg)}}
#loading strong{color:#fff;font-size:16px;font-weight:500;display:block;margin-bottom:6px;letter-spacing:-.2px}
#loading p{color:rgba(255,255,255,0.4);font-size:13px}

#status-bar{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);background:rgba(10,12,20,0.72);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.07);border-radius:8px;padding:5px 12px;color:rgba(255,255,255,0.4);font-size:11px;pointer-events:none;font-family:monospace;white-space:nowrap}

.maplibregl-popup-content{background:rgba(10,12,20,0.93)!important;border:1px solid rgba(255,255,255,0.12)!important;border-radius:10px!important;color:#fff!important;font-size:13px!important;padding:10px 14px!important;backdrop-filter:blur(8px)!important}
.maplibregl-popup-tip{border-top-color:rgba(10,12,20,0.93)!important;border-bottom-color:rgba(10,12,20,0.93)!important}
.maplibregl-ctrl-attrib{font-size:10px!important;background:rgba(0,0,0,0.4)!important;color:rgba(255,255,255,0.35)!important;border-radius:4px!important}
.maplibregl-ctrl-attrib a{color:rgba(255,255,255,0.45)!important}
.maplibregl-canvas{outline:none}

@media(max-width:520px){
  #panel{top:8px;left:8px;right:58px;width:auto}
  #panel-body{padding:10px 12px 12px}
  .section-label{margin-top:9px;margin-bottom:5px}
  .view-grid{margin-top:2px}
  #right-controls{top:auto;bottom:60px;right:10px}
  #info-popup{left:8px;right:58px;width:auto;transform:none;min-width:unset;max-width:unset;bottom:72px;padding:10px 12px;border-radius:10px}
  #quick-list{max-height:84px}
  #info-popup .info-main{gap:9px}
  #info-popup #info-logo{width:40px;height:40px;border-radius:8px}
  #info-popup .info-tag{font-size:9px;padding:2px 6px}
  #info-popup .info-text{padding-right:20px}
  #info-popup #info-desc{font-size:12px;line-height:1.3}
  #info-popup .info-footer{margin-top:6px;padding-top:6px;gap:8px}
  #info-popup #info-route{font-size:12px}
  #info-popup #info-coords{display:none}
  #info-close{top:7px;right:7px;width:20px;height:20px;font-size:11px}
  #status-bar{left:8px;right:58px;transform:none;bottom:44px;font-size:9px;padding:4px 8px;white-space:normal;text-align:center}
  /* Інфо про карту — під плашкою координат, тієї ж ширини, зі скругленням як у zoom */
  .maplibregl-ctrl-bottom-right{left:8px;right:58px}
  .maplibregl-ctrl-bottom-right .maplibregl-ctrl-attrib{width:100%;box-sizing:border-box;margin:0 0 8px;padding:4px 8px;border-radius:10px!important;font-size:9px!important;text-align:center}
}

/* Анимация пульсации для досок с QR-кодом */
.qr-marker {
  position: relative;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.qr-dot {
  width: 14px;
  height: 14px;
  background-color: #ef4444; /* Красный цвет */
  border-radius: 50%;
  border: 2px solid #fff;
  box-shadow: 0 2px 6px rgba(0,0,0,0.5);
  z-index: 2;
}
.qr-pulse {
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: rgba(239, 68, 68, 0.35);
  border: 2px solid rgba(239, 68, 68, 0.95);
  border-radius: 50%;
  z-index: 1;
  animation: pulse-ring 2s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
}
.qr-pulse.delay { animation-delay: 1s; }
@keyframes pulse-ring {
  0% { transform: scale(0.8); opacity: 1; }
  100% { transform: scale(4); opacity: 0; }
}

/* Пульсуюче коло на вибраному відділенні */
.sel-marker {
  position: relative;
  width: 26px;
  height: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}
.sel-pulse {
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: rgba(239, 68, 68, 0.3);
  border: 2px solid rgba(239, 68, 68, 0.95);
  border-radius: 50%;
  z-index: 1;
  animation: pulse-ring 2s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
}
.sel-pulse.delay { animation-delay: 1s; }

/* Маркер людини "Ви знаходитесь тут" (position.png) */
.person-marker {
  width: 38px;
  height: auto;
  display: block;
  cursor: pointer;
  pointer-events: auto;
  filter: drop-shadow(0 3px 5px rgba(0,0,0,0.45));
}

/* Попап "Ви знаходитесь тут" — в стиле плашки координат (#status-bar) */
.qr-popup .maplibregl-popup-content {
  background: rgba(10,12,20,0.72) !important;
  backdrop-filter: blur(8px) !important;
  border: 1px solid rgba(255,255,255,0.07) !important;
  border-radius: 8px !important;
  padding: 7px 14px 7px 12px !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.35) !important;
  min-width: unset;
  white-space: nowrap;
}
.qr-popup .maplibregl-popup-tip {
  border-top-color: rgba(10,12,20,0.72) !important;
  border-bottom-color: rgba(10,12,20,0.72) !important;
}

.qr-popup .info-close {
  position: absolute;
  top: 4px;
  right: 5px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.35);
  font-size: 11px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
}
.qr-popup .info-close:hover {
  color: rgba(255,255,255,0.7);
}

.qr-popup .info-title {
  font-size: 11px;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
  font-family: monospace;
  margin-bottom: 2px;
  padding-right: 14px;
}
.qr-popup .info-desc {
  font-size: 10px;
  color: rgba(255,255,255,0.4);
  font-family: monospace;
  line-height: 1.3;
}

/* Підказка про геолокацію (немає позиції / відмовлено в доступі) */
#geo-hint {
  position: fixed;
  left: 50%;
  bottom: 64px;
  transform: translateX(-50%) translateY(10px);
  max-width: 80vw;
  padding: 9px 16px;
  background: rgba(10,12,20,0.82);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  color: rgba(255,255,255,0.9);
  font-size: 13px;
  line-height: 1.35;
  text-align: center;
  box-shadow: 0 6px 22px rgba(0,0,0,0.4);
  opacity: 0;
  pointer-events: none;
  transition: opacity .35s ease, transform .35s ease;
  z-index: 1000;
}
#geo-hint.visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ── Оптимізації для Safari (WebKit) ───────────────────────────────────────
   У Safari backdrop-filter і repaint полупрозорих елементів перераховуються
   на кожному кадрі анімації камери — це дає підтормажування при прокладанні
   маршруту. Тут прибираємо найдорожче саме під Safari (Chrome не зачіпається). */

/* Промоутимо маркери та пульсацію в окремі GPU-шари, щоб MapLibre
   переставляв їх трансформом без перемальовування вмісту. */
.maplibregl-marker { will-change: transform; }
.qr-pulse, .sel-pulse { will-change: transform, opacity; }

/* Попапи прив'язані до карти й рухаються кожен кадр — у Safari blur на них
   найдорожчий. Замінюємо на щільніший непрозорий фон без backdrop-filter. */
.is-safari .maplibregl-popup-content {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  background: rgba(10,12,20,0.96) !important;
}
.is-safari .qr-popup .maplibregl-popup-content {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  background: rgba(10,12,20,0.92) !important;
}
