/* ════════════════════════════════════════════════════════════════
   app.css — Interaktivní mapa obce Bolatice
   ════════════════════════════════════════════════════════════════ */

/* ── DESIGN SYSTEM ── */
:root {
  --bg:      #0d1117;
  /* iOS safe area insets */
  --safe-b:  env(safe-area-inset-bottom, 0px);
  --safe-t:  env(safe-area-inset-top, 0px);
  --surface: #161b27;
  --surf2:   #1e2436;
  --surf3:   #252c42;
  --border:  #2a3352;
  --accent:  #3b82f6;
  --acc2:    #7c3aed;
  --acc3:    #0ea5e9;
  --orange:  #f97316;
  --green:   #10b981;
  --text:    #e2e8f0;
  --muted:   #7c8aaa;
  --dim:     #4a5470;
  --gastro:  #f97316;
  --sport:   #10b981;
  --urad:    #3b82f6;
  --zdravi:  #06b6d4;
  --sluzby:  #8b5cf6;
  --obchod:  #f59e0b;
  --r:  10px;
  --sh: 0 4px 24px rgba(0,0,0,.65);
  --sh2: 0 2px 10px rgba(0,0,0,.4);
  --mob-peek: 105px;  /* výška peek části mobilního bottom sheetu */
  --mob-peek-safe: calc(105px + env(safe-area-inset-bottom, 0px));
  --mob-peek-safe: calc(105px + env(safe-area-inset-bottom, 0px));  /* iPhone notch */
  --hdr: 50px;        /* výška headeru */
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }
button, [role="button"] { touch-action: manipulation; cursor: pointer; }
html, body {
  height: 100%;
  font-family: 'DM Sans', sans-serif;
  background: var(--bg);
  color: var(--text);
  overflow: hidden;
}

/* ── LAYOUT ── */
/* ── Layout ─────────────────────────────────────────────────────── */
#app  { display: flex; flex-direction: column; height: 100vh; }

/* tilt-wrap: obal mapy — flex:1 výška, bez overflow:hidden (jinak leaflet-rotate ořezává vrstvy) */
#tilt-wrap {
  flex: 1;
  position: relative;
  z-index: 1;
}
/* #map uvnitř tilt-wrap — vždy vyplní celý tilt-wrap */
#map {
  position: absolute;
  inset: 0;
}

/* ════════════════════════════════════════════════════════════════
   LOADING
   ════════════════════════════════════════════════════════════════ */
#loading {
  position: fixed; inset: 0; background: var(--bg); z-index: 9999;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 12px;
  transition: opacity .4s;
}
#loading.out { opacity: 0; pointer-events: none; }
.ld-ring {
  width: 36px; height: 36px;
  border: 3px solid var(--border); border-top-color: var(--accent);
  border-radius: 50%; animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.ld-txt  { font-family: 'Syne', sans-serif; font-weight: 700; font-size: 1.1rem; }
.ld-sub  { font-size: .73rem; color: var(--muted); }

/* ════════════════════════════════════════════════════════════════
   HEADER
   ════════════════════════════════════════════════════════════════ */
header {
  display: flex; align-items: center;
  padding: 0 12px; height: var(--hdr); flex-shrink: 0;
  background: var(--surface); border-bottom: 1px solid var(--border);
  z-index: 1100; gap: 8px; position: relative;
}
.logo {
  font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.08rem;
  letter-spacing: -.5px; display: flex; align-items: center; gap: 8px;
  white-space: nowrap; flex: 1;
  transition: opacity .2s;
}
.logo:hover { opacity: .85; }
.logo-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 8px var(--accent);
  animation: blink 2.5s ease-in-out infinite; flex-shrink: 0;
}
@keyframes blink { 0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.65)} }
.logo-sub { font-weight: 400; color: var(--muted); font-size: .76rem; }

#tile-sw {
  display: flex; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; flex-shrink: 0;
}
/* Desktop: tile-sw absolutně na střed headeru */
@media (min-width: 769px) {
  #tile-sw {
    position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  }
}
.tbtn {
  padding: 5px 10px; font-family: 'DM Sans', sans-serif; font-size: .72rem;
  font-weight: 500; cursor: pointer; border: none; transition: all .18s;
  display: flex; align-items: center; gap: 4px; white-space: nowrap;
}
.tbtn + .tbtn { border-left: 1px solid var(--border); }
.tbtn.off { background: var(--surf2); color: var(--muted); transition: all .25s ease; }
.tbtn.off:hover { background: var(--surf3); color: var(--text); }
.tbtn.on  { background: linear-gradient(135deg, var(--accent), #6366f1); color: #fff; box-shadow: 0 0 12px -2px rgba(59,130,246,.5); transition: all .25s ease; }
.tbtn.on:hover { filter: brightness(1.12); }

.hbtn {
  width: 32px; height: 32px; border-radius: 7px; flex-shrink: 0;
  border: 1px solid var(--border); background: var(--surf2);
  color: var(--muted); cursor: pointer; font-size: .88rem;
  display: flex; align-items: center; justify-content: center; transition: all .18s;
}
.hbtn:hover, .hbtn.on { background: var(--accent); border-color: var(--accent); color: #fff; }

/* ════════════════════════════════════════════════════════════════
   MOBILE SEARCH (below header)
   ════════════════════════════════════════════════════════════════ */
#mob-search {
  position: absolute; top: var(--hdr); left: 0; right: 0;
  z-index: 1200; background: var(--surface);
  border-bottom: 1px solid var(--border);
  transform: translateY(-100%); opacity: 0;
  transition: transform .22s cubic-bezier(.4,0,.2,1), opacity .22s;
  pointer-events: none;
  max-height: calc(50vh);
  display: flex; flex-direction: column;
}
#mob-search.open {
  transform: translateY(0); opacity: 1; pointer-events: auto;
}
#mob-search-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.mob-si { color: var(--dim); font-size: .8rem; flex-shrink: 0; }
#mob-search-inp {
  flex: 1; padding: 7px 8px; background: var(--surf2);
  border: 1px solid var(--border); border-radius: 7px;
  color: var(--text); font-family: inherit; font-size: .81rem;
  outline: none; transition: border-color .18s;
}
#mob-search-inp:focus { border-color: var(--accent); }
.mob-sx {
  width: 28px; height: 28px; border-radius: 6px;
  border: 1px solid var(--border); background: var(--surf2);
  color: var(--muted); cursor: pointer; font-size: .8rem;
  display: flex; align-items: center; justify-content: center; transition: all .15s;
}
.mob-sx:hover { background: var(--surf3); color: var(--text); }
#mob-results { overflow-y: auto; padding: 4px 8px 8px; }

/* ════════════════════════════════════════════════════════════════
   SIDEBAR — Desktop (left panel)
   ════════════════════════════════════════════════════════════════ */
#sidebar {
  position: absolute; top: var(--hdr); left: 0; bottom: 0; width: 285px;
  z-index: 1000; background: var(--surface); border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  transform: translateX(0); transition: transform .26s cubic-bezier(.4,0,.2,1);
}
#sidebar.closed { transform: translateX(-100%); }

#sb-handle {
  position: absolute; top: 66px; left: 293px; z-index: 1050;
  width: 20px; height: 40px; background: var(--surface);
  border: 1px solid var(--border); border-left: none;
  border-radius: 0 7px 7px 0; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--muted); font-size: .58rem;
  transition: left .26s cubic-bezier(.4,0,.2,1);
}
#sb-handle.closed { left: 8px; }
#sb-handle:hover  { color: var(--text); background: var(--surf2); }

/* Mobilní drag handle — skryt na desktopu */
#mob-bs-top { display: none; }

/* Search bar */
.sb-head {
  padding: 11px 13px 9px;
  border-bottom: 1px solid var(--border); flex-shrink: 0;
  display: flex; flex-direction: column; gap: 0;
}
.sb-lbl  {
  font-size: .6rem; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--muted); margin-bottom: 6px; text-align: left; display: block;
}
.sb-search { position: relative; }
.sb-search input {
  width: 100%; padding: 7px 10px 7px 30px;
  background: var(--surf2); border: 1px solid var(--border);
  border-radius: 7px; color: var(--text); font-family: inherit;
  font-size: .81rem; outline: none;
  transition: border-color .2s, box-shadow .2s, background .2s;
}
.sb-search input:hover {
  border-color: var(--accent);
  background: var(--surf3);
}
.sb-search input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(59,130,246,.18);
  background: var(--surf3);
}
.sb-search input::placeholder { color: var(--dim); }
.sb-si {
  position: absolute; left: 9px; top: 50%; transform: translateY(-50%);
  color: var(--dim); font-size: .75rem; pointer-events: none;
}

.sb-clear {
  position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
  background: none; border: none; color: var(--dim); font-size: .7rem;
  cursor: pointer; padding: 2px 4px; border-radius: 4px;
  display: none; transition: color .15s;
}
.sb-search input:not(:placeholder-shown) ~ .sb-clear { display: block; }
.sb-clear:hover { color: var(--text); }

/* Scroll oblast */
#sb-scroll { flex: 1; overflow-y: auto; overflow-x: hidden; }
#sb-scroll::-webkit-scrollbar       { width: 3px; }
#sb-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

.sb-sec   { padding: 7px 11px 4px; border-top: 1px solid var(--border); }
.sb-sec-l { font-size: .6rem; letter-spacing: 1.3px; text-transform: uppercase; color: var(--dim); margin-bottom: 5px; }

/* Stav skryté sekce */
.sec-hidden { display: none !important; }

/* ════════════════════════════════════════════════════════════════
   IS DMVS SEKCE
   ════════════════════════════════════════════════════════════════ */
#qgis-sec {
  display: none; border-bottom: 1px solid var(--border);
  animation: slideDown .22s ease;
}
@keyframes slideDown { from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)} }
#qgis-sec.visible { display: block; }

.qgis-hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 13px 6px;
}
.qgis-hdr-lbl {
  font-size: .6rem; letter-spacing: 1.3px; text-transform: uppercase;
  color: var(--acc2); display: flex; align-items: center; gap: 5px;
}
.qgis-hdr-cnt {
  font-size: .62rem; color: var(--muted);
  background: rgba(124,58,237,.12); padding: 1px 6px; border-radius: 10px;
}
#qgis-list { padding: 0 8px 6px; }

.qgis-empty {
  margin: 4px 0 8px; padding: 10px 12px;
  background: rgba(124,58,237,.07); border: 1px solid rgba(124,58,237,.2);
  border-radius: 7px; font-size: .73rem; color: var(--muted); line-height: 1.5;
}
.qgis-empty code { color: var(--acc2); font-size: .68rem; }

.ql-grp {
  font-size: .58rem; letter-spacing: 1.2px; text-transform: uppercase;
  color: var(--dim); padding: 8px 4px 4px; margin-top: 2px;
}
.ql-row {
  display: flex; align-items: center; gap: 8px; padding: 5px 6px;
  border-radius: 7px; cursor: pointer; transition: background .13s;
}
.ql-row:hover { background: var(--surf2); }
.ql-sw { width: 10px; height: 10px; border-radius: 3px; flex-shrink: 0; opacity: .4; transition: opacity .18s; }
.ql-row.layer-on .ql-sw { opacity: 1; }
.ql-nm { flex: 1; font-size: .78rem; font-weight: 500; transition: color .15s; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ql-nm.dim { color: var(--muted); }

/* Opacity slider — skrytý dokud vrstva není zapnutá */
.ql-opacity {
  display: none;
  align-items: center; gap: 7px;
  padding: 2px 6px 6px 28px; font-size: .62rem; color: var(--dim);
  animation: fadeIn .18s ease;
}
.ql-opacity.show { display: flex; }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
.ql-opacity input[type=range] {
  flex: 1; height: 3px; accent-color: var(--acc2); cursor: pointer;
}

/* Toggle switch */
.tog { width: 28px; height: 15px; border-radius: 8px; background: var(--border); position: relative; transition: background .18s; flex-shrink: 0; }
.tog::after { content:''; position:absolute; top:2px; left:2px; width:11px; height:11px; border-radius:50%; background:var(--muted); transition:all .18s; }
.tog.on { background: var(--acc2); }
.tog.on::after { left: 15px; background: #fff; }
.tog.sm { width: 24px; height: 13px; }
.tog.sm::after { width: 9px; height: 9px; }
.tog.sm.on::after { left: 13px; }

/* Pokročilý režim — fixní dole */
#sb-adv-wrap {
  flex-shrink: 0; padding: 8px 10px;
  border-top: 1px solid var(--border); background: var(--surface);
}
#adv-btn {
  width: 100%; padding: 8px; border-radius: 8px;
  border: 1px solid var(--border); background: var(--surf2);
  color: var(--muted); font-family: inherit; font-size: .76rem;
  cursor: pointer; display: flex; align-items: center; justify-content: space-between;
  gap: 6px; transition: all .18s;
}
#adv-btn:hover { border-color: var(--acc2); color: var(--text); }
#adv-btn.on    { border-color: var(--acc2); color: var(--text); background: rgba(124,58,237,.1); }
#adv-pill {
  font-size: .6rem; font-weight: 700; letter-spacing: .8px;
  padding: 2px 7px; border-radius: 20px; background: var(--border); color: var(--dim);
}
#adv-btn.on #adv-pill { background: var(--acc2); color: #fff; }

/* ════════════════════════════════════════════════════════════════
   KATEGORIE CHIPS
   ════════════════════════════════════════════════════════════════ */
.cat-chip {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 9px; border-radius: 8px; cursor: pointer;
  transition: background .18s, border-color .18s, box-shadow .18s, opacity .18s;
  user-select: none; margin-bottom: 3px;
  border: 1px solid transparent;
}
.cat-chip:hover {
  background: var(--surf2);
  box-shadow: 0 0 0 1px color-mix(in srgb, currentColor 25%, transparent);
}
.cat-chip.active {
  border-color: currentColor;
  background: color-mix(in srgb, currentColor 8%, transparent);
  box-shadow: 0 0 12px -4px currentColor;
}
.cat-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; background: currentColor; transition: all .22s; opacity: .3; transform: scale(.85); }
.cat-chip:hover .cat-dot { opacity: .65; transform: scale(1); }
.cat-chip.active .cat-dot { opacity: 1; transform: scale(1); box-shadow: 0 0 8px currentColor; animation: dotPulse 2.2s ease-in-out infinite; }
.cat-chip-lbl { font-size: .84rem; font-weight: 600; flex: 1; letter-spacing: -.1px; }
.cat-chip:hover .cat-chip-lbl { color: var(--text); }
.cat-chip.active .cat-chip-lbl { color: currentColor; }
.cat-cnt { font-size: .68rem; color: var(--muted); background: var(--bg); padding: 2px 6px; border-radius: 20px; }
.cat-arr { color: var(--dim); font-size: .6rem; transition: transform .18s; }
.cat-chip.dimmed       { opacity: .35; }
.cat-chip.dimmed:hover { opacity: .7; }

.sub-wrap {
  padding: 0 0 0 28px;
  max-height: 0; overflow: hidden;
  transition: max-height .28s cubic-bezier(.4,0,.2,1), padding .28s ease;
}
.sub-wrap.x {
  max-height: min(280px, calc(100vh - 340px)); overflow-y: auto;
  padding: 2px 0 6px 28px;
  scrollbar-width: thin; scrollbar-color: var(--border) transparent;
}
.sub-wrap.x::-webkit-scrollbar { width: 3px; }
.sub-wrap.x::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }
.sub-chip {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 8px; border-radius: 6px; cursor: pointer;
  font-size: .77rem; font-weight: 500; color: var(--muted);
  transition: background .15s, color .15s, box-shadow .15s, border-color .15s;
  margin-bottom: 2px; border: 1px solid transparent;
}
.sub-chip:hover {
  background: color-mix(in srgb, currentColor 8%, transparent);
  color: currentColor;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, currentColor 30%, transparent);
}
.sub-chip.active {
  color: currentColor; border-color: currentColor;
  background: color-mix(in srgb, currentColor 10%, transparent);
  box-shadow: inset 0 0 8px -3px currentColor;
}
.sub-chip.active .sub-dot { opacity: 1; box-shadow: 0 0 6px currentColor; transform: scale(1.2); }
.sub-dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; flex-shrink: 0; opacity: .35; transition: all .18s; transform: scale(.85); }
.sub-chip:hover .sub-dot { opacity: .7; transform: scale(1); }

/* Výsledky */
.res-hdr { padding: 6px 13px 3px; font-size: .6rem; letter-spacing: 1.2px; text-transform: uppercase; color: var(--dim); border-top: 1px solid var(--border); }
#res-list { padding: 2px 8px 8px; }
.res-row { display: flex; align-items: center; gap: 7px; padding: 7px 6px; border-radius: 7px; cursor: pointer; transition: background .15s, box-shadow .15s; margin-bottom: 2px; border: 1px solid transparent; }
.res-row:hover { background: var(--surf2); box-shadow: 0 0 0 1px var(--border); }
.res-ico  { width: 27px; height: 27px; border-radius: 7px; display: flex; align-items: center; justify-content: center; font-size: .82rem; flex-shrink: 0; }
.res-info { flex: 1; min-width: 0; }
.res-name { font-size: .79rem; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.res-sub  { font-size: .67rem; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ════════════════════════════════════════════════════════════════
   POPUPY — IS DMVS budovy
   ════════════════════════════════════════════════════════════════ */
.leaflet-popup-content-wrapper {
  background: var(--surface) !important; border: 1px solid var(--border) !important;
  border-radius: var(--r) !important; box-shadow: var(--sh) !important; padding: 0 !important;
  min-width: 220px !important;
  max-width: min(280px, calc(100vw - 32px)) !important;
  overflow: hidden !important;
}
.leaflet-popup-content {
  margin: 0 !important;
  width: 240px !important;
  max-width: min(260px, calc(100vw - 40px)) !important;
  font-family: 'DM Sans', sans-serif !important;
}
.leaflet-popup-tip     { background: var(--surface) !important; }
.leaflet-popup-close-button { color: var(--muted) !important; top: 6px !important; right: 8px !important; font-size: 1rem !important; }

.bpop         { padding: 11px 13px 4px; color: var(--text); }
.bpop-badge   { display: inline-block; font-size: .62rem; font-weight: 700; letter-spacing: .7px; text-transform: uppercase; padding: 2px 7px; border-radius: 4px; margin-bottom: 5px; }
.bpop-title   { font-family: 'Syne', sans-serif; font-weight: 700; font-size: .88rem; margin-bottom: 4px; color: var(--text); }
.bpop-div     { height: 1px; background: var(--border); margin: 5px 0; }
.bpop-row     { display: flex; align-items: flex-start; gap: 6px; margin-bottom: 4px; font-size: .75rem; color: var(--text); }
.bpop-i       { color: var(--muted); width: 14px; flex-shrink: 0; text-align: center; }
.bpop-id-wrap { margin-top: 4px; font-size: .7rem; }
.bpop-id-wrap summary { cursor: pointer; color: var(--muted); list-style: none; display: flex; align-items: center; gap: 4px; }
.bpop-id-wrap summary::-webkit-details-marker { display: none; }
.bpop-id-wrap summary::before { content:'▶'; font-size:.5rem; transition:transform .15s; }
.bpop-id-wrap[open] summary::before { transform: rotate(90deg); }
.bpop-id-val { font-family: monospace; font-size: .62rem; color: var(--dim); background: var(--surf2); padding: 3px 7px; border-radius: 4px; margin-top: 3px; word-break: break-all; letter-spacing: .5px; border: 1px solid var(--border); }
.bpop-foot   { padding: 8px 12px 10px; border-top: 1px solid var(--border); display: flex; gap: 5px; }
.bpop-btn    { flex: 1; padding: 5px 8px; border-radius: 6px; text-align: center; border: 1px solid var(--border); background: var(--surf2); color: var(--text); font-family: inherit; font-size: .7rem; cursor: pointer; transition: all .14s; white-space: nowrap; }
.bpop-btn-maps { display: flex; align-items: center; justify-content: center; gap: 5px; }
.bpop-btn:hover { background: var(--accent); border-color: var(--accent); }

/* ── POI popup ── */
.ppop-photo   {
  width: 100%; max-height: 180px; min-height: 80px;
  object-fit: cover; object-position: center top;
  border-bottom: 1px solid var(--border); display: block;
  border-radius: var(--r) var(--r) 0 0; cursor: zoom-in;
  background: var(--surf2);
}
/* Portrait fotky (výška > šířka jako 408x544) — zobrazit víc výšky */
.ppop-photo[height] { object-position: center 20%; }
.ppop-ph      { width: 100%; height: 50px; background: linear-gradient(135deg,var(--surf2),var(--surf3)); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 1.4rem; opacity: .35; border-radius: var(--r) var(--r) 0 0; }
.ppop-head    { padding: 10px 12px 8px; border-radius: var(--r) var(--r) 0 0; }
.ppop-badge   { display: inline-flex; align-items: center; gap: 4px; font-size: .6rem; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; padding: 2px 6px; border-radius: 3px; margin-bottom: 4px; }
.ppop-name    { font-family: 'Syne', sans-serif; font-weight: 700; font-size: .85rem; line-height: 1.3; padding-right: 12px; color: var(--text); }
.ppop-div     { height: 1px; background: var(--border); margin: 4px 0; }
.ppop-row     { display: flex; align-items: flex-start; gap: 6px; margin-bottom: 4px; font-size: .72rem; padding: 0 12px; color: var(--text); }
.ppop-i       { color: var(--muted); width: 13px; flex-shrink: 0; margin-top: 1px; text-align: center; }
.ppop-v       { word-break: break-word; color: var(--text); }
.ppop-v a     { color: var(--acc3); text-decoration: none; }
.ppop-v a:hover { text-decoration: underline; }
/* Tlačítka pod sebe — úzká popupová šířka, plná šířka tlačítek */
.ppop-foot    { padding: 6px 10px 10px; border-top: 1px solid var(--border); display: flex; flex-direction: column; gap: 5px; }
.ppop-btn     { width: 100%; padding: 7px 8px; border-radius: 7px; text-align: center; border: 1px solid var(--border); background: var(--surf2); color: var(--text); font-family: inherit; font-size: .72rem; cursor: pointer; transition: all .14s; white-space: nowrap; }
.ppop-btn:hover { background: var(--accent); border-color: var(--accent); color: #fff; }
.ppop-btn.nav  { border-color: var(--acc3); color: var(--acc3); background: rgba(14,165,233,.08); font-weight: 500; }
.ppop-btn.nav:hover { background: var(--acc3); border-color: var(--acc3); color: #fff; }

/* POI pin — base class (žádná rotace — rotateWithView:false to řeší nativně) */
.poi-pin { display: inline-block; }

/* ════════════════════════════════════════════════════════════════
   NAVIGAČNÍ WIDGET (aktivní trasa)
   ════════════════════════════════════════════════════════════════ */
#nav-widget {
  display: none;
  position: absolute; top: calc(var(--hdr) + 8px); right: 8px;
  z-index: 950;
  background: var(--surface);
  border: 1px solid rgba(14,165,233,.35);
  border-top: 2px solid var(--acc3);
  border-radius: var(--r);
  padding: 10px 12px 8px;
  min-width: 210px;
  box-shadow: var(--sh), 0 0 0 1px rgba(14,165,233,.08) inset;
  animation: slideIn .22s ease;
}
#nav-widget.on { display: block; }
/* dbadge skrytý při aktivní navigaci */
body.nav-on #dbadge { display: none !important; }

@keyframes slideIn { from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)} }

.nav-head {
  display: flex; align-items: center; gap: 6px; margin-bottom: 7px;
}
.nav-mode-ico { font-size: 1rem; flex-shrink: 0; }
.nav-dest-name { flex: 1; font-family: 'Syne', sans-serif; font-weight: 700; font-size: .82rem;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--acc3); }
.nav-close {
  width: 20px; height: 20px; border-radius: 4px;
  border: 1px solid var(--border); background: var(--surf2);
  color: var(--muted); cursor: pointer; font-size: .7rem;
  display: flex; align-items: center; justify-content: center;
  transition: all .14s; flex-shrink: 0;
}
.nav-close:hover { background: var(--orange); border-color: var(--orange); color: #fff; }

.nav-main-row {
  display: flex; align-items: baseline; gap: 8px; margin-bottom: 8px;
}
.nav-time-val {
  font-family: 'Syne', sans-serif; font-size: 1.3rem; font-weight: 800; color: var(--text);
}
.nav-dist { font-size: .7rem; color: var(--muted); }

/* Geo status — kompletně skrytý (zpřesňování tiché v pozadí) */
#nav-geo-status { display: none !important; }

.nav-actions { display: flex; gap: 5px; }
.nav-act-btn {
  flex: 1; padding: 4px 5px; border-radius: 7px;
  border: 1px solid var(--border); background: var(--surf2);
  color: var(--muted); font-family: inherit; font-size: .65rem;
  cursor: pointer; transition: all .15s; white-space: nowrap;
  display: flex; align-items: center; justify-content: center; gap: 3px;
}
.nav-act-btn:hover  { border-color: var(--acc3); color: var(--acc3); }

/* Nav widget kompas — nav-persp-btn — styly řeší JS inline */
#nav-compass-svg { transition: transform .35s ease; }

/* Recenter btn uvnitř widgetu — skrytý dokud uživatel nepohne mapou */
#nav-recenter-btn2 { display: none; }
#nav-recenter-btn2.on { display: flex; }

/* Nav-tilt: statický stav — BEZ transition (nechceme jitter každý GPS update) */
#map.nav-tilt {
  will-change: transform;
  /* transform a transform-origin nastaveny JS inline */
}

/* Tilt-entering: přechod při zapnutí / vypnutí perspektivního módu (jen 400ms) */
#map.tilt-entering {
  transition: transform .38s cubic-bezier(.4,0,.2,1) !important;
}

/* ════════════════════════════════════════════════════════════════
   RECENTER BUTTON — floating, nad mapou (při pohybu v nav)
   ════════════════════════════════════════════════════════════════ */
#nav-recenter-btn {
  display: none;
  position: absolute; z-index: 960;
  background: var(--acc3); color: #fff;
  border: none; border-radius: 20px;
  padding: 6px 15px; font-family: 'DM Sans', sans-serif;
  font-size: .76rem; font-weight: 600; cursor: pointer;
  box-shadow: 0 2px 14px rgba(14,165,233,.5);
  animation: slideIn .18s ease;
  transition: opacity .15s;
}
#nav-recenter-btn.on { display: flex; align-items: center; gap: 5px; }
#nav-recenter-btn:hover { background: var(--accent); }

/* Pozice: desktop vpravo pod widgetem, mobil nad BS */
@media (min-width: 769px) {
  #nav-recenter-btn { top: calc(var(--hdr) + 52px); right: 8px; }
}
@media (max-width: 768px) {
  #nav-recenter-btn { bottom: calc(var(--mob-peek) + 12px); left: 50%; transform: translateX(-50%); }
  #nav-widget { left: 8px; right: auto; top: calc(var(--hdr) + 8px); }
}

/* ════════════════════════════════════════════════════════════════
   NAV MODE PICKER — výběr dopravy před startem
   ════════════════════════════════════════════════════════════════ */
#nav-mode-picker {
  display: none; position: fixed; inset: 0;
  z-index: 2000; background: rgba(13,17,23,.82);
  backdrop-filter: blur(6px);
  align-items: center; justify-content: center;
  animation: fadeIn .18s ease;
}
#nav-mode-picker.on { display: flex; }
@keyframes fadeIn { from{opacity:0}to{opacity:1} }

#nmp-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 18px; padding: 22px 20px 16px;
  width: min(340px, calc(100vw - 32px));
  box-shadow: var(--sh); animation: slideIn .22s ease;
  display: flex; flex-direction: column; gap: 10px;
}
.nmp-title {
  font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1rem;
  text-align: center; color: var(--text);
}
.nmp-dest {
  font-size: .75rem; color: var(--acc3); text-align: center;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  padding: 0 8px;
}
.nmp-opts { display: flex; gap: 10px; }
.nmp-opt {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  gap: 5px; padding: 16px 10px 14px;
  border-radius: 14px; border: 2px solid var(--border);
  background: var(--surf2); cursor: pointer; transition: all .18s;
  font-family: inherit;
}
.nmp-opt:hover { border-color: var(--acc3); background: rgba(14,165,233,.08); }
.nmp-opt:active { transform: scale(.97); }
.nmp-ico  { font-size: 2rem; }
.nmp-lbl  { font-family: 'Syne', sans-serif; font-weight: 700; font-size: .85rem; color: var(--text); }
.nmp-time { font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.1rem; color: var(--acc3); min-height: 1.4em; }
.nmp-sub  { font-size: .68rem; color: var(--muted); min-height: 1em; }
/* Loading ring uvnitř karty */
.nmp-loading-row, #nmp-loading {
  display: flex; align-items: center; justify-content: center;
  gap: 8px; padding: 6px 0;
}
.nmp-spinner {
  width: 18px; height: 18px; border-radius: 50%;
  border: 2px solid var(--border); border-top-color: var(--acc3);
  animation: spin .7s linear infinite; flex-shrink: 0;
}
.nmp-loading-txt { font-size: .74rem; color: var(--muted); }
/* Disabled karta */
.nmp-opt:disabled { opacity: .4; cursor: not-allowed; pointer-events: none; }
/* Vybraná karta (hover stav) */
.nmp-opt:not(:disabled):hover { border-color: var(--acc3); background: rgba(14,165,233,.1); }
.nmp-cancel {
  background: none; border: 1px solid var(--border); color: var(--muted);
  border-radius: 8px; padding: 7px; font-family: inherit; font-size: .75rem;
  cursor: pointer; transition: all .14s; width: 100%;
}
.nmp-cancel:hover { border-color: var(--orange); color: var(--orange); }

/* ════════════════════════════════════════════════════════════════
   LIGHTBOX
   ════════════════════════════════════════════════════════════════ */
#lightbox {
  display: none; position: fixed; inset: 0; z-index: 9998;
  background: rgba(0,0,0,.93); align-items: center; justify-content: center;
}
#lightbox.on { display: flex; }
#lb-img {
  max-width: 90vw; max-height: 86vh; border-radius: 8px;
  box-shadow: 0 8px 40px rgba(0,0,0,.8);
  user-select: none; cursor: pointer;
  transition: opacity .2s;
}
#lb-close {
  position: absolute; top: 12px; right: 16px;
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,.15); border: none;
  color: #fff; font-size: 1.1rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s; z-index: 1;
}
#lb-close:hover { background: rgba(255,255,255,.3); }
#lb-prev, #lb-next {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 44px; height: 44px; border-radius: 50%;
  background: rgba(255,255,255,.15); border: none;
  color: #fff; font-size: 1.6rem; cursor: pointer;
  display: none; align-items: center; justify-content: center;
  transition: background .15s; z-index: 1;
  user-select: none;
}
#lb-prev { left: 16px; }
#lb-next { right: 16px; }
#lb-prev:hover, #lb-next:hover { background: rgba(255,255,255,.3); }
#lightbox.on.lb-multi #lb-prev,
#lightbox.on.lb-multi #lb-next { display: flex; }
#lb-counter {
  position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%);
  color: rgba(255,255,255,.6); font-size: .75rem; letter-spacing: 1px;
  display: none;
}
#lightbox.on.lb-multi #lb-counter { display: block; }

/* ════════════════════════════════════════════════════════════════
   FAB TLAČÍTKA
   ════════════════════════════════════════════════════════════════ */
#fab-col {
  position: absolute; right: 12px; bottom: 97px;
  z-index: 900; display: flex; flex-direction: column; gap: 6px; align-items: center;
}
.fab {
  width: 36px; height: 36px; border-radius: 8px;
  border: 1px solid var(--border); background: var(--surface);
  color: var(--muted); cursor: pointer; font-size: .88rem;
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--sh2); transition: all .18s; flex-shrink: 0;
  touch-action: manipulation;
}
.fab:hover      { background: var(--surf2); color: var(--text); }
.fab.on         { color: #fff; }
#fab-geo.on     { background: var(--accent); border-color: var(--accent); }
/* Geo FAB při aktivní navigaci — zešedí (navigace přebírá tracking) */
#fab-geo.nav-taking-over { opacity: .35; pointer-events: none; }
#fab-msr.on     { background: var(--acc2);   border-color: var(--acc2);   }
#fab-nav        { display: none; background: rgba(14,165,233,.15); border-color: var(--acc3); color: var(--acc3); }
#fab-nav.on     { display: flex; }
/* North-reset: normálně skrytý, zobrazí se gdy je mapa otočená */
#fab-north        { display: none; border-color: #3b82f6; color: #3b82f6; opacity: 0; }
#fab-north-svg    { transition: transform 0.3s ease; }
body.map-rotated #fab-north { display: flex; opacity: 1; transition: opacity .35s ease; }

/* ════════════════════════════════════════════════════════════════
   MĚŘICÍ PANEL
   ════════════════════════════════════════════════════════════════ */
#msr-panel {
  display: none; position: absolute; bottom: 96px;
  left: 50%; transform: translateX(-50%);
  z-index: 1100; background: var(--surface); border: 1px solid var(--acc2);
  border-radius: 10px; padding: 10px 16px 8px;
  box-shadow: var(--sh); min-width: 240px;
}
#msr-panel.on { display: block; }
.msr-cols { display: flex; gap: 0; align-items: stretch; }
.msr-col  { flex: 1; text-align: center; padding: 0 6px; white-space: nowrap; }
.msr-col + .msr-col { border-left: 1px solid var(--border); }
.msr-col-lbl { font-size: .6rem; letter-spacing: 1.2px; text-transform: uppercase; color: var(--muted); margin-bottom: 3px; white-space: nowrap; }
.msr-num     { font-family: 'Syne', sans-serif; font-size: 1.05rem; font-weight: 700; color: var(--acc2); white-space: nowrap; }
.msr-area-num { color: var(--orange); }
.msr-hint    { font-size: .63rem; color: var(--dim); text-align: center; margin-top: 6px; }
.msr-actions { display: flex; gap: 6px; margin-top: 7px; }
.msr-actions button {
  flex: 1; padding: 4px 6px; background: var(--surf2);
  border: 1px solid var(--border); border-radius: 6px;
  color: var(--muted); font-family: inherit; font-size: .68rem; cursor: pointer; transition: all .15s;
}
.msr-actions button:first-child { border-color: var(--acc2); color: var(--acc2); }
.msr-actions button:first-child:hover { background: var(--acc2); color: #fff; }
.msr-actions button:last-child:hover  { border-color: var(--orange); color: var(--orange); }

/* ════════════════════════════════════════════════════════════════
   STATS PANEL — jen pokročilý režim (skryt v základním)
   ════════════════════════════════════════════════════════════════ */
#stats-panel {
  display: none;   /* skryto v základním režimu, ukáže se v pokročilém */
  position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%);
  z-index: 900; background: var(--surface); border: 1px solid var(--border);
  border-radius: 10px; padding: 7px 14px;
  gap: 16px; font-size: .68rem; color: var(--muted);
  box-shadow: var(--sh2); pointer-events: auto; white-space: nowrap;
  transition: left .26s cubic-bezier(.4,0,.2,1), transform .26s;
}
#stats-panel.adv-show { display: flex; }
.stat-grp-lbl { font-size: .56rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
                color: var(--muted); padding: 2px 0 1px; }
.stat      { display: flex; align-items: center; gap: 5px; }
.stat-dot  { width: 7px; height: 7px; border-radius: 50%; }
.stat strong { color: var(--text); font-size: .75rem; }

/* Ostatní — hover tooltip */
.stat-ostatni-wrap {
  position: relative; cursor: default;
}
.stat-hover-table {
  position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%);
  background: var(--surface); border: 1px solid var(--border); border-radius: 10px;
  padding: 8px 12px; box-shadow: 0 8px 24px rgba(0,0,0,.35);
  white-space: nowrap; z-index: 1200; min-width: 150px;
  /* Plynulý přechod místo display:none */
  opacity: 0; pointer-events: none;
  transform: translateX(-50%) translateY(4px);
  transition: opacity .18s ease, transform .18s ease;
}
.stat-hover-table::after {
  content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  border: 6px solid transparent; border-top-color: var(--border);
}
.stat-hover-table::before {
  content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(-1px);
  border: 6px solid transparent; border-top-color: var(--surface); z-index: 1;
}
.stat-ostatni-wrap:hover .stat-hover-table,
.stat-ostatni-wrap.open .stat-hover-table {
  opacity: 1; pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.sht-row {
  display: flex; align-items: center; gap: 7px;
  font-size: .68rem; color: var(--text); padding: 3px 0;
  justify-content: space-between;
}
.sht-row + .sht-row { border-top: 1px solid var(--border); }
.sht-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.sht-row span:last-child { font-weight: 600; color: var(--text); margin-left: 8px; }

/* ════════════════════════════════════════════════════════════════
   POI PŘEHLED — základní režim
   ════════════════════════════════════════════════════════════════ */
#poi-overview {
  display: none;  /* skryto dokud JS nenaplní obsah a není desktop */
  position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%);
  z-index: 900; background: var(--surface); border: 1px solid var(--border);
  border-radius: 10px; padding: 5px 10px;
  align-items: center; gap: 6px;
  font-size: .68rem; color: var(--muted);
  box-shadow: var(--sh2); pointer-events: none;
  white-space: nowrap; flex-wrap: nowrap;
  transition: left .26s cubic-bezier(.4,0,.2,1), opacity .3s;
}
/* Desktop + defaultní režim → zobrazit */
body:not(.is-mobile) #poi-overview.poi-ov-ready { display: flex; }
#poi-overview.adv-hide { display: none !important; }
.poi-ov-total {
  font-weight: 600; color: var(--text); font-size: .72rem;
  padding-right: 6px; border-right: 1px solid var(--border); margin-right: 2px;
}
.poi-ov-cat {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: .75rem; font-weight: 500;
}
.poi-ov-cat span { font-size: .68rem; color: var(--muted); font-weight: 400; }

/* ════════════════════════════════════════════════════════════════
   STATUS BADGE
   ════════════════════════════════════════════════════════════════ */
#dbadge {
  position: absolute; top: calc(var(--hdr) + 8px); left: 50%; transform: translateX(-50%);
  z-index: 1060; background: var(--surface); border: 1px solid var(--border);
  border-radius: 20px; padding: 3px 12px; font-size: .65rem; color: var(--muted);
  pointer-events: none; opacity: .9; transition: opacity 1.2s; white-space: nowrap;
  /* Skryj pokud je prázdný */
  display: none;
}
#dbadge:not(:empty) { display: block; }
#dbadge.fade { opacity: 0; }
#dbadge.badge-ok {
  background: rgba(16,185,129,.12);
  border-color: #10b981;
  color: #10b981;
}

/* ════════════════════════════════════════════════════════════════
   LEAFLET PŘEPISY
   ════════════════════════════════════════════════════════════════ */
.leaflet-control-zoom {
  border: 1px solid var(--border) !important; border-radius: 8px !important;
  overflow: hidden; box-shadow: var(--sh2) !important;
}
.leaflet-control-zoom a {
  background: var(--surface) !important; color: var(--text) !important;
  border-color: var(--border) !important;
  width: 32px !important; height: 32px !important; line-height: 32px !important;
}
.leaflet-control-zoom a:hover { background: var(--surf2) !important; }
.leaflet-bottom.leaflet-right { padding-bottom: 10px; padding-right: 12px; }
.leaflet-control-zoom { margin: 0 !important; }
/* Rotační ovládací prvek leaflet-rotate — skrytý, plugin (setBearing/getBearing) zůstává funkční */
.leaflet-control-rotate { display: none !important; }

.leaflet-control-scale-line {
  background: var(--surface) !important; border: 1px solid var(--acc3) !important;
  border-top: none !important; color: var(--text) !important;
  font-family: 'DM Sans', sans-serif !important; font-size: 9px !important;
  padding: 2px 5px !important; border-radius: 0 0 4px 4px !important;
}
.leaflet-bottom.leaflet-left { transition: margin-left .26s cubic-bezier(.4,0,.2,1); }
.leaflet-attribution-flag { display: none !important; }

/* ════════════════════════════════════════════════════════════════
   MOBILNÍ ZOBRAZENÍ  (≤ 768px)
   ════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* Pomocné třídy */
  .mob-only  { display: flex !important; }
  .desk-only { display: none !important; }

  /* Header na mobilu */
  header { padding: 0 10px; gap: 6px; }
  .logo-sub { display: none; }
  .logo { font-size: .9rem; }

  /* Map fills full area, BS overlaps */
  #tilt-wrap { position: absolute; inset: 0; top: var(--hdr); flex: none; }
  #map        { position: absolute; inset: 0; }
  #app { height: 100vh; }

  /* ── SIDEBAR → BOTTOM SHEET — transform řídí JS ── */
  #sidebar {
    top: auto !important;
    left: 0 !important; right: 0 !important; bottom: 0 !important;
    width: 100% !important;
    border-right: none !important;
    border-top: 1px solid var(--border);
    border-radius: 18px 18px 0 0;
    max-height: 65vh;
    overflow: hidden;
    will-change: transform;
    /* JS nastavuje inline transform — žádný CSS default zde */
  }
  #sidebar.closed { transition: transform .32s cubic-bezier(.4,0,.2,1) !important; transform: translateY(110%) !important; }

  /* Mobilní drag handle */
  #mob-bs-top {
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
    padding: 0 12px 8px;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    touch-action: none; /* pro swipe gesty */
    cursor: pointer;
    min-height: var(--mob-peek);
  }
  #mob-bs-pill {
    width: 36px; height: 4px; border-radius: 2px;
    background: var(--border); margin: 8px auto 10px;
  }
  #mob-cat-icons {
    display: flex; gap: 8px; overflow-x: auto; padding-bottom: 2px;
    scrollbar-width: none;
  }
  #mob-cat-icons::-webkit-scrollbar { display: none; }

  /* Mobilní kategorie ikony */
  .mob-cat-ico {
    display: flex; flex-direction: column; align-items: center;
    gap: 3px; cursor: pointer; flex-shrink: 0; min-width: 52px;
    padding: 6px 6px; border-radius: 10px; transition: all .18s;
    border: 1.5px solid transparent;
    touch-action: manipulation;
  }
  .mob-cat-ico.active { border-color: var(--cat-color, #3b82f6); background: rgba(var(--cat-rgb, 59,130,246),.1); }
  .mob-cat-ico.dimmed { opacity: .35; }
  .mob-cat-bubble {
    width: 36px; height: 36px; border-radius: 50%;
    background: var(--cat-color, #3b82f6);
    opacity: .85; display: flex; align-items: center; justify-content: center;
    font-size: 1rem; box-shadow: 0 2px 8px rgba(0,0,0,.3);
    transition: all .18s;
  }
  .mob-cat-ico.active .mob-cat-bubble { opacity: 1; box-shadow: 0 0 12px var(--cat-color, #3b82f6); }
  .mob-cat-lbl { font-size: .58rem; color: var(--muted); text-align: center; max-width: 46px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .mob-cat-cnt { font-size: .62rem; font-weight: 600; color: var(--cat-color, #3b82f6); }

  /* Scroll obsah v BS — touch-action: pan-y = nativní scroll funguje */
  #sb-scroll { overflow-y: auto; touch-action: pan-y; overscroll-behavior: contain; }

  /* Sidebar handle — skryt na mobilu */
  #sb-handle { display: none !important; }

  /* Nav widget — přesun doleva na mobilu */
  #nav-widget { left: 8px; right: auto; top: calc(var(--hdr) + 8px); }

  /* FABs nad bottom sheet */
  #fab-col { bottom: calc(var(--mob-peek) + 12px + env(safe-area-inset-bottom, 0px)); right: 10px; }

  /* Měřicí panel — přizpůsobený portrait mobilu, bez zalomení textů */
  #msr-panel {
    bottom: calc(var(--mob-peek) + 54px);
    left: 50% !important; right: auto !important;
    transform: translateX(-50%) !important;
    min-width: 0 !important;
    width: max-content !important;
    max-width: calc(100vw - 32px) !important;
    padding: 8px 12px 7px !important;
  }
  .msr-col-lbl { font-size: .57rem !important; }
  .msr-num, .msr-area-num { font-size: .92rem !important; }
  .msr-hint { font-size: .58rem !important; margin-top: 3px !important; }
  .msr-actions { margin-top: 5px !important; }
  .msr-actions button { font-size: .62rem !important; padding: 3px 8px !important; }

  /* Stats/POI overview nad BS */
  #stats-panel, #poi-overview {
    bottom: calc(var(--mob-peek) + 10px);
  }

  /* Zoom controls — skryté na mobilu (zoom prsty) */
  .leaflet-control-zoom { display: none !important; }

  /* Scale — nad BS peekem, vlevo, jemné */
  .leaflet-bottom.leaflet-left {
    bottom: calc(var(--mob-peek) + 6px + env(safe-area-inset-bottom, 0px)) !important;
    left: 10px !important;
    margin-left: 0 !important;
  }
  .leaflet-control-scale-line {
    background: rgba(13,17,23,.72) !important;
    border-color: var(--muted) !important;
    color: var(--muted) !important;
    font-size: 8px !important;
    padding: 1px 4px !important;
    backdrop-filter: blur(4px);
  }

  /* POI overview — na mobilu skryt (countery nejsou v default módu potřeba) */
  #poi-overview { display: none !important; visibility: hidden !important; }
  /* Stats panel v advanced módu na mobilu — ultra-minimalistické countery */
  #stats-panel.adv-show {
    display: flex !important;
    padding: 4px 8px !important;
    gap: 8px !important;
    border-radius: 20px !important;
    font-size: .6rem !important;
  }
  #stats-panel.adv-show .stat-grp-lbl { display: none !important; }
  #stats-panel.adv-show .stat strong  { font-size: .68rem !important; }
  #stats-panel.adv-show .stat-dot     { width: 5px; height: 5px; }
  /* hover table: ovládáno JS třídou .open (kompatibilita mobil) */

  /* Badge — přes celou šířku, ne vlevo */
  #dbadge { font-size: .62rem; }

  /* Pokročilý režim na mobilu — skryj kategorie ikony + search */
  body.adv-on #mob-cat-icons  { display: none !important; }
  body.adv-on #mob-srch-btn   { display: none !important; }
  body.adv-on #mob-search     { display: none !important; }
  /* V pokročilém režimu: BS peek pruh smrskne na pouhý pill — bez min-height pro ikony */
  body.adv-on #mob-bs-top     { min-height: auto !important; padding-bottom: 4px !important; }

  /* Kategorie chips — skryté v mobilním BS (filtry jsou v peek ikonách) */
  #poi-cats-sec { display: none !important; }

  /* Mobile subcat pills — viditelné nad výsledky */
  #mob-subcat-wrap {
    display: flex; flex-wrap: wrap; gap: 5px;
    padding: 6px 12px 2px;
    border-top: 1px solid var(--border);
  }
  #mob-subcat-wrap:empty { display: none; }
  .mob-sub-pill {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 3px 9px; border-radius: 20px;
    font-size: .72rem; font-weight: 500; cursor: pointer;
    /* rámeček POUZE na zapnutých (active) subkategoriích */
    border: 1.5px solid transparent;
    transition: all .18s;
    opacity: .45;
  }
  /* Zapnutá (active) subkategorie — plná viditelnost + rámeček */
  .mob-sub-pill.active {
    opacity: 1;
    border-color: currentColor;
    background: rgba(255,255,255,.08);
  }
  .mob-sub-pill-ico { font-size: .75rem; }
}


/* ════════════════════════════════════════════════════════════════
   MOBILNÍ LANDSCAPE
   Telefon otočený na šířku (max-width 900px + orientation: landscape).
   Výška viewportu ~360-420px — bottom-sheet nahrazen levým sidebarem.
   Proměnná --ls-sw = šířka levého panelu (sidebar) v landscape.
   ════════════════════════════════════════════════════════════════ */
/* ── Landscape-only elementy — skryté globálně, zobrazeny jen v landscape @media ── */
#ls-logo, #sb-hbtn-ls, #ls-bottom-bar { display: none !important; }
.ls-only { display: none !important; }

@property --ml {
  syntax: '<length>';
  inherits: true;
  initial-value: 0px;
}

@media (orientation: landscape) and (max-height: 560px) {

  /* ══════════════════════════════════════════════════════════════
     CSS PROMĚNNÁ --ml (map-left): řídí levý okraj mapové plochy.
     Mění se podle stavu sidebaru (otevřený / zavřený).
     VŠECHNY map-area elementy používají var(--ml) pro left.
     Transition: left .28s → prvky se plynule posouvají s panelem.
     ══════════════════════════════════════════════════════════════ */
  :root {
    --hdr:   38px;
    --ls-sw: 220px;  /* wider for modern large phones */
    --ml:    var(--ls-sw);   /* výchozí: sidebar otevřený */
    transition: --ml .28s cubic-bezier(.4,0,.2,1);
  }
  body.ls-sb-closed {
    --ml: 0px;               /* sidebar zavřený → mapa na plnou šířku */
  }

  /* Prvky posouvající se s mapou dostávají transition left.
     POZOR: .leaflet-bottom.leaflet-left je uvnitř #tilt-wrap, NENÍ zde — ten se pohybuje sám. */
  .leaflet-bottom.leaflet-left,
  #dbadge,
  #nav-widget,
  #nav-pick-btn,
  #nav-confirm,
  #nav-recenter-btn,
  #msr-panel,
  #stats-panel {
    transition: left .28s cubic-bezier(.4,0,.2,1) !important;
  }

  /* ── Header ── */
  header     { height: 38px; padding: 0 8px; gap: 6px; }
  .logo      { font-size: .84rem; }
  .logo-sub  { display: none; }
  .logo-dot  { width: 7px; height: 7px; }
  .tbtn      { padding: 3px 7px; font-size: .61rem; height: 26px; }
  #tile-sw   { border-radius: 6px; }

  /* ── Mapa — od vrchu (header skrytý) ── */
  #tilt-wrap {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    transition: left .28s cubic-bezier(.4,0,.2,1);
  }
  body.ls-sb-closed #tilt-wrap {
    left: 0 !important;
  }

  /* ── Sidebar → levý panel ── */
  #sidebar {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: auto !important;
    bottom: 0 !important;
    width: var(--ls-sw) !important;
    max-height: none !important;
    height: 100vh !important;
    height: 100dvh !important;
    border-right: 1px solid var(--border) !important;
    border-top: none !important;
    border-radius: 0 !important;
    transform: none !important;
    transition: transform .28s cubic-bezier(.4,0,.2,1) !important;
    overflow-y: hidden !important;    /* flex handles scroll */
    overflow-x: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    /* Zajistí pokrytí gapů při animaci — žádný černý flash */
    background: var(--surface) !important;
    z-index: 500 !important;
  }
  body { background: var(--surface); }   /* gap při animaci = var(--surface), ne černá */

  /* Zavřený sidebar: sjede doleva */
  #sidebar.closed {
    transform: translateX(-100%) !important;
  }
  /* sb-scroll: flex:1 = vyplní zbývající výšku mezi scrollem a bottom barem */
  #sb-scroll {
    flex: 1 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
  }

  /* Drag pill — skrytý */
  #mob-bs-pill { display: none !important; }

  /* Kategorie + výsledky — obnovit v landscape (skryté v portrait mobile) */
  #poi-cats-sec { display: block !important; }
  #poi-res-sec  { display: block !important; }

  /* BS-top — kompaktní, bez mob-cat-icons */
  #mob-bs-top {
    display: flex !important;
    flex-direction: column !important;
    min-height: auto !important;
    padding: 6px 8px 6px !important;
    border-bottom: 1px solid var(--border);
    cursor: default !important;
    touch-action: auto !important;
  }

  /* Kategorie ikony — SKRYTÉ v landscape (není místo) */
  #mob-cat-icons { display: none !important; }

  /* Scroll obsah sidebaru */
  #sb-scroll {
    flex: 1 !important;
    overflow-y: auto !important;
    max-height: none !important;
  }

  /* Sidebar handle — skrytý */
  #sb-handle { display: none !important; }

  /* ── FAB sloupec — vpravo, fixní (nezávislý na sidebaru) ── */
  #fab-col {
    right: 8px !important;
    bottom: 36px !important;
    gap: 5px !important;
  }
  .fab {
    width: 28px !important;
    height: 28px !important;
    border-radius: 6px !important;
    font-size: .78rem !important;
  }

  /* ── Měřítko — uvnitř #tilt-wrap (relativní k mapě, ne viewportu).
     #tilt-wrap se posouvá se sidebarem → left:6px stačí, NO calc(--ml). */
  .leaflet-bottom.leaflet-left {
    bottom: clamp(2px, 1vh, 6px) !important;
    left: calc(var(--ml) + 5px) !important;
    margin-left: 0 !important;
  }
  .leaflet-control-scale-line {
    font-size: clamp(7px, 1.8vh, 9px) !important;
    padding: 1px 4px !important;
  }

  /* ── Zoom — skrytý ── */
  .leaflet-control-zoom { display: none !important; }

  /* ── Header: skrýt v landscape — nahrazeno floating logem ── */
  header { display: none !important; }

  /* ── Floating logo nad mapou — pohybuje se s --ml ── */
  #ls-logo {
    display: flex !important;
    align-items: center; gap: 5px;
    position: fixed; top: 6px;
    left: calc(var(--ml) + 5px);
    transition: left .28s cubic-bezier(.4,0,.2,1);
    z-index: 1100; pointer-events: none;
    font-family: 'Syne', sans-serif; font-weight: 800; font-size: .8rem;
    color: var(--text);
    text-shadow: 0 1px 4px rgba(0,0,0,.55), 0 0 10px rgba(0,0,0,.3);
    white-space: nowrap;
  }
  #ls-logo::before {
    content: '';
    display: inline-block; width: 18px; height: 22px;
    background: url('../css/ikonky/logo_bolatice.png') center/contain no-repeat;
    margin-right: 2px; vertical-align: middle;
    filter: drop-shadow(0 1px 3px rgba(0,0,0,.4)); flex-shrink: 0;
  }

  /* ── ☰ landscape — pravý horní roh, poloprůhledný ── */
  #sb-hbtn-ls {
    display: flex !important;
    align-items: center; justify-content: center;
    position: fixed; top: 6px; right: 6px;
    height: 30px; width: 34px; padding: 0;
    background: rgba(22,27,39,.22);
    backdrop-filter: blur(6px);
    border: none; border-radius: 8px;
    box-shadow: inset 0 0 0 1px rgba(42,51,82,.4);
    color: rgba(124,138,170,.6);
    font-size: .9rem; cursor: pointer; z-index: 1200;
    transition: color .15s, background .15s;
  }
  #sb-hbtn-ls:hover {
    background: rgba(124,58,237,.22);
    box-shadow: inset 0 0 0 1px rgba(124,58,237,.5);
    color: var(--acc2);
  }
  /* Otevřený panel: ☰ podbarven (třída .on přidána přes JS) */
  #sb-hbtn-ls.on {
    background: rgba(124,58,237,.25);
    box-shadow: inset 0 0 0 1px rgba(124,58,237,.45);
    color: var(--acc2);
  }

  /* ── sb-adv-wrap skrytý — ls-bottom-bar ho nahrazuje ── */
  #sb-adv-wrap { display: none !important; }

  /* ── ls-bottom-bar ── */
  .ls-only { display: flex !important; }
  #ls-bottom-bar {
    display: flex !important; align-items: center; gap: 6px;
    padding: 6px 8px;
    padding-bottom: max(6px, env(safe-area-inset-bottom, 6px));
    flex-shrink: 0 !important;
    flex-grow: 0 !important;
    border-top: 1px solid var(--border); background: var(--surface);
    -webkit-tap-highlight-color: transparent;
    min-height: 44px;
  }
  #ls-adv-btn {
    width: 36px; height: 36px; padding: 0; flex-shrink: 0;
    border: 1px solid var(--border); border-radius: 7px;
    background: var(--surf2); color: var(--muted); font-size: .92rem; cursor: pointer;
    transition: all .15s;
    touch-action: manipulation;
  }
  body.adv-on #ls-adv-btn { border-color: var(--acc2); color: var(--acc2); background: rgba(124,58,237,.12); }
  #ls-tile-btn {
    flex: 1; height: 36px; padding: 0 10px;
    border: 1px solid var(--border); border-radius: 7px;
    background: var(--surf2); color: var(--text); font-size: .68rem;
    cursor: pointer; white-space: nowrap; transition: all .15s; font-family: inherit;
    touch-action: manipulation;
  }
  #ls-tile-btn:hover { border-color: var(--acc2); color: var(--acc2); }

  /* ── mob-bs-top skrytý ── */
  #mob-bs-top { display: none !important; }

  /* ── Pokročilý režim tlačítko — skrytý (ls-bottom-bar nahrazuje) ── */

  /* ── Badge — uprostřed mapové plochy, posouvá se s --ml ── */
  #dbadge {
    top: calc(var(--hdr) + clamp(3px, 1vh, 8px)) !important;
    bottom: auto !important;
    left: calc(var(--ml) + (100vw - var(--ml)) / 2) !important;
    transform: translateX(-50%) !important;
    font-size: clamp(.52rem, 1.7vh, .63rem) !important;
    padding: clamp(2px, .7vh, 4px) clamp(7px, 1.8vw, 13px) !important;
    border-radius: 14px !important;
    white-space: nowrap !important;
    max-width: calc(100vw - var(--ml) - 80px) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  /* ── POI overview — vždy skryt ── */
  #poi-overview { display: none !important; visibility: hidden !important; }

  /* ── Stats panel — skrytý, v pokročilém viditelný ── */
  #stats-panel {
    display: none !important;
    visibility: hidden !important;
  }
  #stats-panel.adv-show {
    display: flex !important;
    visibility: visible !important;
    position: fixed !important;
    bottom: clamp(3px, 1.2vh, 8px) !important;
    left: calc(var(--ml) + (100vw - var(--ml)) / 2) !important;
    transform: translateX(-50%) !important;
    font-size: clamp(.55rem, 1.5vh, .65rem) !important;
    padding: clamp(3px, .9vh, 6px) clamp(8px, 1.8vw, 12px) !important;
    gap: clamp(8px, 2vw, 14px) !important;
    border-radius: 8px !important;
    z-index: 910 !important;
    pointer-events: none;
  }
  #stats-panel.adv-show .stat-dot    { width: 6px; height: 6px; }
  #stats-panel.adv-show .stat strong { font-size: clamp(.6rem, 1.6vh, .72rem); }

  /* ── Nav widget — levý horní roh mapové plochy ── */
  #nav-widget {
    top: calc(var(--hdr) + clamp(4px, 1.2vh, 8px)) !important;
    left: calc(var(--ml) + 6px) !important;
    right: auto !important;
    padding: clamp(5px, 1.4vh, 9px) clamp(8px, 2vw, 12px) clamp(4px, 1.2vh, 8px) !important;
    min-width: clamp(140px, 28vw, 200px) !important;
    max-width: clamp(160px, 32vw, 220px) !important;
    border-radius: clamp(7px, 1.8vh, 11px) !important;
  }
  .nav-dest-name { font-size: clamp(.65rem, 1.8vh, .78rem); }
  .nav-time-val  { font-size: clamp(.88rem, 2.4vh, 1.05rem); }
  .nav-dist      { font-size: clamp(.56rem, 1.5vh, .65rem); }
  .nav-main-row  { margin-bottom: clamp(3px, .8vh, 6px); gap: clamp(4px, 1vw, 8px); }
  .nav-head      { margin-bottom: clamp(3px, .8vh, 6px); gap: clamp(3px, .8vw, 6px); }
  .nav-actions   { gap: clamp(3px, .7vw, 5px); }
  .nav-act-btn   { padding: clamp(2px, .6vh, 4px) clamp(4px, 1vw, 7px); font-size: clamp(.54rem, 1.4vh, .62rem); gap: 2px; }
  .nav-close     { width: clamp(16px, 4vh, 20px); height: clamp(16px, 4vh, 20px); font-size: clamp(.58rem, 1.6vh, .72rem); }

  /* ── Vybrat cíl na mapě — levý dolní roh mapové plochy ── */
  #nav-pick-btn {
    bottom: clamp(6px, 1.8vh, 20px) !important;
    left: calc(var(--ml) + 8px) !important;
    top: auto !important;
    right: auto !important;
    font-size: clamp(.55rem, 1.6vh, .68rem) !important;
    padding: clamp(4px, 1.1vh, 7px) clamp(8px, 2vw, 13px) !important;
    border-radius: clamp(6px, 1.5vh, 10px) !important;
  }

  /* ── Nav-confirm (Navigovat / Zrušit) — horní střed mapové plochy ── */
  #nav-confirm {
    top: calc(var(--hdr) + clamp(4px, 1vh, 7px)) !important;
    left: calc(var(--ml) + (100vw - var(--ml)) / 2) !important;
    transform: translateX(-50%) !important;
    max-width: calc(100vw - var(--ml) - 20px) !important;
    padding: clamp(4px, 1vh, 7px) clamp(7px, 1.8vw, 11px) !important;
    border-radius: clamp(8px, 2vh, 11px) !important;
    gap: clamp(5px, 1.2vw, 9px) !important;
  }
  .nc-dest   { max-width: clamp(70px, 16vw, 125px); font-size: clamp(.62rem, 1.8vh, .76rem); }
  .nc-label  { font-size: clamp(.58rem, 1.7vh, .7rem); }
  .nc-btn    { padding: clamp(3px, .7vh, 5px) clamp(6px, 1.5vw, 10px); font-size: clamp(.57rem, 1.6vh, .68rem); border-radius: clamp(5px, 1.2vh, 8px); }

  /* ── Vycentrovat (nav-recenter) — dolní střed mapové plochy ── */
  #nav-recenter-btn {
    bottom: clamp(5px, 1.5vh, 10px) !important;
    left: calc(var(--ml) + (100vw - var(--ml)) / 2) !important;
    transform: translateX(-50%) !important;
    font-size: clamp(.58rem, 1.5vh, .65rem) !important;
    padding: clamp(4px, 1vh, 6px) clamp(10px, 2.5vw, 14px) !important;
    top: auto !important;
    right: auto !important;
    border-radius: clamp(6px, 1.5vh, 10px) !important;
  }
  #nav-recenter-btn2 {
    font-size: clamp(.55rem, 1.4vh, .62rem) !important;
    padding: clamp(2px, .6vh, 4px) clamp(7px, 1.8vw, 11px) !important;
  }

  /* ── Měřicí panel — střed mapové plochy ── */
  #msr-panel {
    bottom: clamp(30px, 8vh, 42px) !important;
    left: calc(var(--ml) + (100vw - var(--ml)) / 2) !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    width: auto !important;
    min-width: clamp(170px, 38vw, 220px) !important;
    font-size: clamp(.62rem, 1.7vh, .7rem) !important;
    padding: clamp(5px, 1.4vh, 8px) clamp(10px, 2.5vw, 14px) clamp(4px, 1vh, 7px) !important;
    border-radius: clamp(7px, 1.8vh, 11px) !important;
  }

  /* ── Nav mode picker — karta respektuje sidebar ── */
  #nav-mode-picker {
    padding-left: var(--ml);
    transition: padding-left .28s cubic-bezier(.4,0,.2,1);
  }
  #nmp-card {
    width: min(300px, calc(100vw - var(--ml) - 20px)) !important;
    padding: 12px 14px 10px;
    gap: 7px;
    border-radius: 12px;
    max-height: calc(100vh - 16px);
    overflow-y: auto;
  }
  .nmp-title  { font-size: .88rem; }
  .nmp-dest   { font-size: .7rem; }
  .nmp-opts   { gap: 7px; }
  .nmp-opt    { padding: 10px 7px 9px; border-radius: 10px; gap: 3px; }
  .nmp-ico    { font-size: 1.5rem; }
  .nmp-lbl    { font-size: .76rem; }
  .nmp-time   { font-size: .9rem; }
  .nmp-sub    { font-size: .6rem; }
  .nmp-cancel { padding: 6px; font-size: .7rem; }

  /* ── Příjezdový modal ── */
  #nav-arrived-card {
    padding: 16px 16px 14px;
    border-radius: 14px;
    max-height: calc(100vh - 20px);
    overflow-y: auto;
  }
  .nar-icon      { font-size: 1.8rem; margin-bottom: 2px; }
  .nar-title     { font-size: 1rem; }
  .nar-dest      { margin-bottom: 12px; }
  .nar-stats     { padding: 8px 6px; margin-bottom: 12px; }
  .nar-stat-val  { font-size: .88rem; }

  /* ── Pokročilý režim v landscape ── */
  body.adv-on #mob-bs-top { padding: 4px 8px 4px !important; }

  /* ── Kategorie POI v landscape — filter icon button ── */
  /* .sb-sec-l zobrazi nadpis s filter ikonou vpravo */
  #poi-cats-sec .sb-sec-l {
    display: flex !important;
    padding: 5px 11px;
    font-size: .7rem;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: var(--dim);
  }
  /* cats-toggle-btn — vždy viditelný v landscape */
  .cats-toggle-btn { display: flex !important; }

  /* ls-cat-body — při sbalení skrytý, při otevření flex sloupec */
  .ls-cat-body:not(.cats-collapsed) {
    display: flex !important;
    flex-direction: column;
    gap: 3px;
    padding: 2px 11px 7px;
  }
  #poi-cats-sec { padding: 0 !important; }
}

/* ════════════════════════════════════════════════════════════════
   GEO FLASH — rozsvítí GPS tlačítko při pokusu o navigaci bez polohy
   ════════════════════════════════════════════════════════════════ */
@keyframes geoFlash {
  0%   { box-shadow: 0 2px 14px rgba(59,130,246,.4); transform: scale(1); }
  40%  { box-shadow: 0 0 0 10px rgba(59,130,246,.25), 0 2px 18px rgba(59,130,246,.9);
         transform: scale(1.15); background: var(--accent); color: #fff; }
  100% { box-shadow: 0 2px 14px rgba(59,130,246,.4); transform: scale(1); }
}
#fab-geo.geo-flash {
  animation: geoFlash .55s ease 4;
  border-color: var(--accent) !important;
}

/* ════════════════════════════════════════════════════════════════
   POI IKONY — rotateWithView:false v L.marker() zajistí že se
   leaflet-rotate pluginem neotáčí. Žádná counter-rotace CSS není potřeba.
   ════════════════════════════════════════════════════════════════ */
.poi-pin {
  display: inline-block;
  /* leaflet-rotate: rotateWithView:false → žádná rotace */
}

/* Heading kužel — gradient DivIcon (~1 cm na obrazovce) */
.hdg-cone-wrap {
  display: block;
  transform-origin: 50% 100%;   /* pivot = spodek = poloha uživatele */
  transition: transform 0.3s ease;
  pointer-events: none;
}

/* Nav marker wrapper — rotujeme přes JS heading */
.nav-pos-marker {
  display: block;
  transform-origin: 50% 50%;
  pointer-events: none;
}

/* Desktop skryje mob-only prvky */
@media (min-width: 769px) {
  .mob-only  { display: none !important; }
  .desk-only { display: flex !important; }
  /* V pokročilém režimu: schovej search bar — není potřeba hledat POI */
  body.adv-on .sb-head { display: none !important; }
}

/* ════════════════════════════════════════════════════════════════
   NAV PICK — tlačítko výběru cíle + potvrzovací bar
   ════════════════════════════════════════════════════════════════ */

/* Tlačítko "Vybrat cíl" — ukáže se po aktivaci geolokace */
#nav-pick-btn {
  display: none;
  position: absolute; z-index: 950;
  background: var(--surface); border: 1.5px solid var(--acc3);
  color: var(--acc3); border-radius: 20px;
  padding: 5px 13px 5px 9px;
  font-family: 'DM Sans', sans-serif; font-size: .75rem; font-weight: 500;
  cursor: pointer; gap: 5px; align-items: center;
  box-shadow: var(--sh2); white-space: nowrap;
  transition: all .18s; animation: slideIn .2s ease;
}
#nav-pick-btn.on {
  display: flex;
}
/* Nav-pick-btn skrytý při aktivní trase */
body.nav-on #nav-pick-btn { display: none !important; }
#nav-pick-btn.pick-active {
  background: var(--acc3); color: #fff;
  border-color: var(--acc3);
  animation: pulse 1.5s ease-in-out infinite;
}
@keyframes pulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(14,165,233,.4); }
  50%      { box-shadow: 0 0 0 8px rgba(14,165,233,0); }
}
@keyframes pick-pulse {
  0%,100% { transform: scale(1);   box-shadow: 0 0 0 0   rgba(14,165,233,.6); }
  50%      { transform: scale(1.2); box-shadow: 0 0 0 10px rgba(14,165,233,0); }
}

/* Potvrzovací bar */
#nav-confirm {
  display: none;
  position: absolute; top: calc(var(--hdr) + 8px); left: 50%;
  transform: translateX(-50%);
  z-index: 1060;
  background: var(--surface);
  border: 1px solid rgba(14,165,233,.3);
  border-top: 2px solid var(--acc3);
  border-radius: 14px;
  padding: 10px 12px;
  gap: 8px; align-items: center;
  box-shadow: var(--sh), 0 0 0 1px rgba(14,165,233,.06) inset;
  white-space: nowrap;
  animation: slideIn .2s ease;
  backdrop-filter: blur(8px);
}
#nav-confirm.on { display: flex; }
.nc-label { font-size: .65rem; color: var(--muted); letter-spacing: .3px; text-transform: uppercase; }
.nc-dest  { font-family: 'Syne', sans-serif; font-size: .82rem; font-weight: 700;
            color: var(--acc3); max-width: 150px; overflow: hidden;
            text-overflow: ellipsis; }
.nc-btns  { display: flex; gap: 5px; }
.nc-btn   { padding: 5px 12px; border-radius: 8px; font-family: inherit;
            font-size: .7rem; font-weight: 600; cursor: pointer; border: 1px solid transparent;
            transition: all .14s; touch-action: manipulation; }
.nc-btn-ok  { background: var(--acc3); color: #fff; border-color: var(--acc3);
              box-shadow: 0 2px 8px rgba(14,165,233,.3); }
.nc-btn-ok:hover  { background: var(--accent); border-color: var(--accent); }
.nc-btn-no  { background: var(--surf2); color: var(--muted); border-color: var(--border); }
.nc-btn-no:hover { border-color: var(--orange); color: var(--orange); }

/* Desktop: nav-pick-btn vlevo pod widgetem */
@media (min-width: 769px) {
  #nav-pick-btn {
    top: calc(var(--hdr) + 54px); right: 8px;
  }
  #nav-confirm {
    top: calc(var(--hdr) + 8px);
  }
}
/* Mobile: nad BS peekem, vlevo */
@media (max-width: 768px) {
  #nav-pick-btn {
    bottom: calc(var(--mob-peek) + 54px); left: 10px;
  }
  #nav-confirm {
    top: calc(var(--hdr) + 8px);
    max-width: calc(100vw - 24px);
    padding: 6px 8px;
    gap: 6px;
  }
  .nc-label { display: none; }
  .nc-dest  { max-width: min(140px, 35vw); font-size: .75rem; }
  .nc-btn   { padding: 4px 8px; font-size: .67rem; }
}

/* ════════════════════════════════════════════════════════════════
   PŘÍJEZDOVÝ MODAL — statistiky po dosažení cíle
   ════════════════════════════════════════════════════════════════ */
#nav-arrived-modal {
  display: none; position: fixed; inset: 0; z-index: 9500;
  background: rgba(0,0,0,.55); backdrop-filter: blur(4px);
  align-items: center; justify-content: center;
  animation: fadeIn .25s ease;
}
#nav-arrived-modal.on { display: flex; }

#nav-arrived-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 18px; padding: 28px 24px 22px;
  max-width: 340px; width: calc(100vw - 32px);
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
  text-align: center; animation: arrivedPop .35s cubic-bezier(.34,1.56,.64,1);
}
@keyframes arrivedPop {
  from { opacity:0; transform: scale(.82) translateY(18px); }
  to   { opacity:1; transform: scale(1) translateY(0); }
}

.nar-icon  { font-size: 2.8rem; margin-bottom: 6px; }
.nar-title {
  font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.3rem;
  color: var(--text); margin-bottom: 4px;
}
.nar-dest {
  font-size: .82rem; color: var(--muted);
  margin-bottom: 22px; max-width: 260px; margin-left: auto; margin-right: auto;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.nar-stats {
  display: flex; align-items: center; justify-content: center;
  gap: 0; margin-bottom: 22px;
  background: var(--surf2); border-radius: 12px; padding: 14px 10px;
}
.nar-stat { flex: 1; text-align: center; }
.nar-stat-val {
  font-family: 'Syne', sans-serif; font-weight: 700; font-size: 1.05rem;
  color: var(--text); margin-bottom: 3px;
}
.nar-stat-lbl { font-size: .65rem; color: var(--muted); text-transform: uppercase; letter-spacing: .8px; }
.nar-sep { width: 1px; height: 36px; background: var(--border); flex-shrink: 0; }
.nar-close {
  width: 100%; padding: 12px;
  background: var(--accent); color: #fff; border: none; border-radius: 10px;
  font-family: 'DM Sans', sans-serif; font-size: .88rem; font-weight: 500;
  cursor: pointer; transition: all .18s;
}
.nar-close:hover { background: #2563eb; }

/* ── Kategorie filter toggle ──────────────────────────────────── */
.sb-sec-l {
  display: flex; align-items: center; justify-content: space-between;
}
.cats-toggle-btn {
  background: none; border: none; cursor: pointer; padding: 2px 4px;
  display: flex; align-items: center; opacity: 0.55; transition: opacity .15s;
  border-radius: 4px;
}
.cats-toggle-btn:hover { opacity: 1; background: var(--surf2); }
.cats-toggle-btn.on { opacity: 0.9; }
.cats-filter-icon {
  width: 16px; height: 16px; object-fit: contain;
  filter: invert(1) brightness(0.7);
}
.ls-cat-body {
  overflow: hidden; transition: max-height .22s ease, opacity .2s;
  max-height: 400px; opacity: 1;
}
.ls-cat-body.cats-collapsed {
  max-height: 0 !important; opacity: 0; pointer-events: none;
}

/* ── Geolokační popup — kompaktní, světlý ── */
.geo-popup .leaflet-popup-content-wrapper {
  background: var(--surface) !important;
  border: 1px solid rgba(14,165,233,.3) !important;
  border-radius: 40px !important;  /* pill shape */
  box-shadow: var(--sh), 0 0 0 1px rgba(14,165,233,.06) inset !important;
  padding: 0 !important;
  min-width: 0 !important;
  width: auto !important;
  max-width: 260px !important;
}
.geo-popup .leaflet-popup-content {
  margin: 0 !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: 150px !important;
}
.geo-popup .leaflet-popup-tip-container { display: none !important; }
.geo-popup .leaflet-popup-close-button {
  display: none !important;
}

/* ════════════════════════════════════════════════════════════════
   DESKTOP MODE NA MOBILU (pointer:coarse + wide screen)
   Prohlížeč v desktop režimu na telefonu — zachová sidebar,
   ale přizpůsobí touch targets a odstraní BS.
   ════════════════════════════════════════════════════════════════ */
@media (pointer: coarse) and (min-width: 769px) and (orientation: portrait) {
  /* Sidebar zůstane — desktop layout, ale touch-friendly */
  .hbtn, .cat-chip, .ql-row, .fab, .tbtn, .nc-btn {
    min-height: 40px;
    touch-action: manipulation;
  }
  /* Popup bude dost velký pro prst */
  .bpop-btn, .ppop-btn { min-height: 40px; font-size: .78rem; }
  /* Zoom controls větší */
  .leaflet-control-zoom a {
    width: 38px !important; height: 38px !important; line-height: 38px !important;
  }
}

/* ── Header stabilita v portrait desktop mode na mobilu ── */
@media (orientation: portrait) {
  header {
    position: fixed !important;
    top: 0 !important; left: 0 !important; right: 0 !important;
    z-index: 1100 !important;
    display: flex !important;
  }
  #tilt-wrap {
    top: var(--hdr) !important;
  }
}

/* ── POI popup — foto galerie ── */
.ppop-photo-wrap {
  position: relative; overflow: hidden;
  border-radius: var(--r) var(--r) 0 0;
  border-bottom: 1px solid var(--border);
}
.ppop-ph-prev, .ppop-ph-next {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(0,0,0,.45); border: none;
  color: #fff; font-size: 1rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  z-index: 2; transition: background .15s; opacity: .85;
  touch-action: manipulation;
}
.ppop-ph-prev { left: 6px; }
.ppop-ph-next { right: 6px; }
.ppop-ph-prev:hover, .ppop-ph-next:hover { background: rgba(0,0,0,.7); opacity: 1; }
.ppop-ph-cnt {
  position: absolute; bottom: 6px; right: 8px;
  font-size: .6rem; color: #fff; background: rgba(0,0,0,.45);
  padding: 1px 6px; border-radius: 10px; pointer-events: none;
}
.ppop-photo { transition: opacity .18s; }
.ppop-video { width: 100%; border-radius: 0; display: block; background: #000; }


/* ── POI marker pulse — klik na výsledek ── */
@keyframes poiPulse {
  0%   { transform: scale(1);    filter: none; }
  28%  { transform: scale(1.7);  filter: drop-shadow(0 0 16px var(--accent)) drop-shadow(0 0 5px #fff); }
  60%  { transform: scale(1.25); filter: drop-shadow(0 0 8px var(--accent)); }
  100% { transform: scale(1);    filter: none; }
}
.poi-pin.poi-pulse { animation: poiPulse .65s ease-out 2; transform-origin: 50% 100%; }

/* ── Subkat dimmed ── */
.sub-chip.dimmed { opacity: .28; }

/* ── POI popup action bar ── */
.ppop-action-bar {
  display: flex; gap: 5px;
  padding: 6px 10px 9px; border-top: 1px solid var(--border);
  background: var(--surf2); border-radius: 0 0 var(--r) var(--r);
}
.ppop-action-btn {
  flex: 1; display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 6px 4px 5px; border-radius: 8px; cursor: pointer;
  border: 1px solid var(--border); background: var(--surface);
  color: var(--muted); font-family: inherit; font-size: .58rem; font-weight: 500;
  transition: all .14s; white-space: nowrap;
}
.ppop-action-btn svg { width: 15px; height: 15px; }
.ppop-action-btn:hover { background: var(--surf3); color: var(--text); border-color: var(--muted); }
.ppop-action-btn.nav { border-color: var(--acc3); color: var(--acc3); background: rgba(14,165,233,.07); }
.ppop-action-btn.nav:hover { background: var(--acc3); color: #fff; border-color: var(--acc3); }

/* ── Video thumbnail — play overlay ── */
.ppop-video-thumb {
  position: relative; cursor: pointer;
  border-radius: var(--r) var(--r) 0 0; overflow: hidden;
}
.ppop-play-overlay {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,.32); transition: background .15s;
}
.ppop-video-thumb:hover .ppop-play-overlay { background: rgba(0,0,0,.18); }
.ppop-play-overlay svg {
  width: 38px; height: 38px; color: #fff;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.6));
  opacity: .9;
}

/* ════════════════════════════════════════════════════════════════
   WEATHER WIDGET
   ════════════════════════════════════════════════════════════════ */
#wx-fab {
  position: fixed; top: calc(var(--hdr) + 8px); right: 8px;
  /* Hidden in landscape mobile — wx shown in ls-bottom-bar */
  touch-action: manipulation;
  z-index: 1050;
  display: flex; align-items: center; gap: 4px;
  padding: 5px 10px; border-radius: 20px;
  background: var(--surface); border: 1px solid var(--border);
  box-shadow: 0 2px 12px rgba(0,0,0,.3);
  cursor: pointer; user-select: none;
  font-size: .82rem; font-weight: 600; color: var(--text);
  transition: box-shadow .2s, background .2s, transform .15s;
  -webkit-tap-highlight-color: transparent;
}
#wx-fab:hover { background: var(--surf2); box-shadow: 0 4px 18px rgba(0,0,0,.4); }
#wx-fab:active { transform: scale(.96); }
#wx-fab-ico { font-size: 1rem; line-height: 1; }
#wx-fab-temp { font-size: .78rem; color: var(--muted); }
#wx-fab.wx-fab-open { border-color: var(--acc3); box-shadow: 0 0 0 2px rgba(14,165,233,.2), 0 4px 18px rgba(0,0,0,.4); }

#wx-panel {
  position: fixed; top: calc(var(--hdr) + 48px); right: 8px;
  z-index: 1049; width: 300px; max-width: calc(100vw - 16px);
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 14px; box-shadow: 0 8px 32px rgba(0,0,0,.4);
  overflow: hidden;
  max-height: 0; opacity: 0; pointer-events: none;
  transition: max-height .32s cubic-bezier(.4,0,.2,1), opacity .22s ease;
  transform-origin: top right;
}
#wx-panel.wx-open {
  max-height: 520px; opacity: 1; pointer-events: auto;
  overflow-y: auto; scrollbar-width: thin; scrollbar-color: var(--border) transparent;
  overscroll-behavior: contain;
}

.wx-close {
  position: absolute; top: 8px; right: 10px;
  width: 22px; height: 22px; border-radius: 50%;
  background: rgba(255,255,255,.08); border: none;
  color: var(--muted); font-size: .7rem; cursor: pointer;
  display: none; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
#wx-panel:hover .wx-close, #wx-panel.wx-open:hover .wx-close { display: flex; }
.wx-close:hover { background: rgba(239,68,68,.2); color: #f87171; }

/* Current */
.wx-current {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 14px 10px;
  border-bottom: 1px solid var(--border);
}
.wx-ico { font-size: 2.2rem; line-height: 1; flex-shrink: 0; }
.wx-ico-storm { animation: stormPulse .8s ease-in-out infinite; }
@keyframes stormPulse { 0%,100%{filter:brightness(1)} 50%{filter:brightness(1.6) drop-shadow(0 0 8px #fbbf24)} }
.wx-vals { flex: 1; min-width: 0; }
.wx-temp {
  font-size: 3rem; font-weight: 900; line-height: 1;
  font-family: 'Syne', sans-serif;
  letter-spacing: -2px;
  display: flex; align-items: flex-start; gap: 2px;
}
.wx-deg-unit {
  display: flex; flex-direction: column; align-self: flex-start;
  padding-top: 3px; gap: 0;
}
.wx-deg { font-size: 1.5rem; font-weight: 800; line-height: 1; color: inherit; }
.wx-cel { font-size: .62rem; font-weight: 500; color: var(--muted); line-height: 1.1; letter-spacing: .5px; text-transform: uppercase; }
.wx-unit { font-size: .65rem; font-weight: 400; color: var(--muted); margin-left: 1px; }
.wx-feel, .wx-desc { font-size: .67rem; color: var(--muted); margin-top: 2px; }
.wx-side { text-align: right; font-size: .72rem; color: var(--muted); flex-shrink: 0; }
.wx-wind, .wx-hum { margin-bottom: 3px; }

/* Storm warning */
.wx-storm {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 7px 14px; font-size: .78rem; font-weight: 700; letter-spacing: .5px;
  background: linear-gradient(90deg, rgba(239,68,68,.15), rgba(251,191,36,.15), rgba(239,68,68,.15));
  color: #fbbf24; border-bottom: 1px solid rgba(251,191,36,.2);
}
.wx-storm-bolt { font-size: 1rem; animation: boltFlash 1.2s ease-in-out infinite; }
@keyframes boltFlash { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.8)} }
.wx-widget.wx-storm-active { border-color: rgba(251,191,36,.35); }

/* Section label */
.wx-section-lbl {
  padding: 8px 14px 4px;
  font-size: .6rem; letter-spacing: 1px; text-transform: uppercase;
  color: var(--dim); border-top: 1px solid var(--border);
}

/* Hours */
.wx-hours {
  display: flex; overflow-x: auto; gap: 6px;
  padding: 4px 10px 10px;
  scrollbar-width: thin; scrollbar-color: var(--border) transparent;
  /* Wheel scroll support */
  overflow-y: hidden;
}
.wx-hours::-webkit-scrollbar { height: 4px; }
.wx-hours::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }
.wx-hour {
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 8px 10px; border-radius: 8px; flex-shrink: 0;
  font-size: .72rem; background: var(--surf2); min-width: 56px;
  transition: background .15s;
}
.wx-hour:hover { background: var(--surf3); }
.wx-hour-storm { background: rgba(251,191,36,.1); border: 1px solid rgba(251,191,36,.25); }
.wx-hour-t { color: var(--muted); font-size: .6rem; }
.wx-hour-r { color: #60a5fa; font-size: .6rem; }

/* Days */
.wx-days { padding: 4px 10px 8px; display: flex; flex-direction: column; gap: 4px; }
.wx-day {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 8px; border-radius: 8px; font-size: .74rem;
  background: var(--surf2); transition: background .15s;
}
.wx-day:hover { background: var(--surf3); }
.wx-day-storm { background: rgba(251,191,36,.1); border: 1px solid rgba(251,191,36,.25); }
.wx-day-name { color: var(--muted); width: 65px; flex-shrink: 0; font-size: .68rem; }
.wx-day-ico  { font-size: 1.1rem; flex-shrink: 0; }
.wx-day-temps { flex: 1; }
.wx-day-rain, .wx-day-wind { color: var(--muted); font-size: .67rem; }

/* Footer */
.wx-footer {
  padding: 6px 14px 10px; font-size: .6rem; color: var(--dim);
  text-align: right; border-top: 1px solid var(--border);
}
.wx-loading { padding: 20px; text-align: center; color: var(--muted); font-size: .78rem; }
/* Tooltips na wx prvcích (pouze desktop) */
/* wx-tip tooltips via JS (_wxTooltip) */
#wx-tooltip {
  position: fixed; z-index: 9999; pointer-events: none;
  background: var(--surf3); border: 1px solid var(--border);
  color: var(--text); font-size: .65rem; padding: 4px 8px;
  border-radius: 6px; white-space: nowrap;
  box-shadow: 0 4px 12px rgba(0,0,0,.35);
  opacity: 0; transition: opacity .12s;
}

/* Desktop: fab pod sb-hbtn */
@media (min-width: 769px) {
  #wx-fab { top: calc(var(--hdr) + 8px); right: 8px; }
  #wx-panel { top: calc(var(--hdr) + 52px); right: 8px; }
}

/* Mobile landscape: skryt panel (místo je málo) */
@media (orientation: landscape) and (max-height: 560px) {
  #wx-panel { max-height: 260px !important; }
}


/* Tile switch fade transition */
#tile-transition-overlay {
  position: absolute; inset: 0; z-index: 500;
  pointer-events: none; opacity: 0;
  background: linear-gradient(135deg, rgba(59,130,246,.08), rgba(99,102,241,.05));
  transition: opacity .4s ease;
}
#tile-transition-overlay.flash { opacity: 1; }

/* ── Provoz schedule grid ── */
.pv-wrap { padding: 4px 12px 6px; }
.provoz-grid { display: flex; flex-direction: column; gap: 1px; font-size: .7rem; }
.pv-row { display: flex; align-items: flex-start; gap: 8px; padding: 3px 0; border-bottom: 1px solid var(--border); }
.pv-row:last-child { border-bottom: none; }
.pv-closed { opacity: .42; }
.pv-day { width: 22px; font-weight: 700; color: var(--muted); flex-shrink: 0; padding-top: 1px; }
.pv-slots { display: flex; flex-direction: column; gap: 1px; flex: 1; color: var(--text); }
.pv-slot { line-height: 1.5; }
.pv-lbl { color: var(--muted); font-size: .64rem; }
.pv-gap { height: 4px; }
.pv-zavr { color: var(--muted); font-style: italic; }

/* ── POI pulse ── */
@keyframes poiPulse {
  0%   { transform: scale(1); filter: none; }
  28%  { transform: scale(1.7); filter: drop-shadow(0 0 16px var(--accent)); }
  65%  { transform: scale(1.25); filter: drop-shadow(0 0 8px var(--accent)); }
  100% { transform: scale(1); filter: none; }
}
.poi-pin.poi-pulse { animation: poiPulse .6s ease-out 2; transform-origin: 50% 100%; }

/* ── Otevírací doba panel (vyjíždí vpravo od popupu) ─────────── */
.ppop-provoz-btn {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; padding: 6px 12px; background: none; border: none;
  color: var(--acc3); font-size: .72rem; font-family: inherit;
  cursor: pointer; text-align: left; transition: background .14s;
}
.ppop-provoz-btn:hover { background: rgba(14,165,233,.08); }
.ppop-provoz-arr { font-size: .9rem; transition: transform .2s; }
.ppop-provoz-btn.open .ppop-provoz-arr { transform: rotate(90deg); }

.ppop-schedule {
  max-height: 0; overflow: hidden;
  transition: max-height .28s cubic-bezier(.4,0,.2,1), padding .2s;
  background: var(--surf2); border-top: 1px solid var(--border);
}
.ppop-schedule.open { max-height: 300px; padding: 8px 12px 10px; }

.ppop-sched-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 4px 0; font-size: .69rem; border-bottom: 1px solid var(--border);
}
.ppop-sched-row:last-child { border-bottom: none; }
.ppop-sched-day { color: var(--muted); font-weight: 500; min-width: 60px; }
.ppop-sched-time { color: var(--text); font-weight: 600; }
.ppop-sched-note { color: var(--muted); font-size: .63rem; font-style: italic; }
.ppop-sched-period { color: var(--acc3); font-size: .63rem; font-weight: 600; }

/* ── Schedule panel: vysouvá se vpravo od popup ─────────────────── */
.ppop-sched-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 8px 28px rgba(0,0,0,.4);
  overflow: hidden;
}
.ppop-sched-inner {
  padding: 8px 10px;
}
/* provoz-grid: fullweek view */
.provoz-grid { display: flex; flex-direction: column; gap: 1px; }
.pv-row {
  display: grid; grid-template-columns: 28px 1fr;
  align-items: center; gap: 6px;
  padding: 4px 2px; border-bottom: 1px solid var(--border);
  font-size: .7rem;
}
.pv-row:last-child { border-bottom: none; }
.pv-closed .pv-zavr { color: var(--dim); font-style: italic; font-size: .65rem; }
.pv-day { color: var(--acc3); font-weight: 700; font-size: .68rem; }
.pv-slots { display: flex; flex-direction: column; gap: 1px; }
.pv-slot { color: var(--text); font-weight: 500; }
.pv-lbl  { color: var(--muted); font-size: .63rem; font-style: italic; margin-left: 3px; }
.pv-gap  { height: 2px; }

/* provoz btn in popup row */
.ppop-provoz-btn {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; padding: 5px 12px; background: none; border: none;
  color: var(--acc3); font-size: .72rem; font-family: inherit;
  cursor: pointer; text-align: left; transition: background .14s;
  border-top: 1px solid var(--border);
}
.ppop-provoz-btn:hover { background: rgba(14,165,233,.08); }
.ppop-provoz-arr { font-size: .9rem; transition: transform .2s; }
.ppop-provoz-btn.open .ppop-provoz-arr { transform: rotate(90deg); }

/* Leaflet popup: allow overflow for schedule panel */
.leaflet-popup { overflow: visible !important; }
.leaflet-popup-content-wrapper { overflow: visible !important; }


/* ── wx-fab: hide in landscape mobile, show ls-wx-btn instead ── */
@media (orientation: landscape) and (max-height: 560px) {
  #wx-fab { display: none !important; }
  #ls-wx-btn {
    height: 36px; padding: 0 10px;
    border: 1px solid var(--border); border-radius: 7px;
    background: var(--surf2); color: var(--text); font-size: .68rem;
    cursor: pointer; white-space: nowrap; transition: all .15s; font-family: inherit;
    touch-action: manipulation; display: flex; align-items: center; gap: 4px;
    flex-shrink: 0;
  }
  #ls-wx-btn:hover { border-color: var(--acc3); color: var(--acc3); }
}

/* ── Celsius superscript: ČÍSLO°c — ° and c positioned top-right ── */
.wx-deg-unit {
  display: inline-flex; flex-direction: column; align-items: flex-start;
  font-size: .45em; line-height: 1; margin-left: 1px;
  vertical-align: super; margin-top: -0.3em;
}
.wx-deg { font-size: 1.1em; line-height: 1; color: inherit; opacity: .85; }
.wx-cel { font-size: .9em; line-height: 1; color: inherit; font-weight: 700; letter-spacing: -.5px; }

/* ════════════════════════════════════════════════════════════════
   POPUP STATUS INDIKÁTOR — otevírací doba
   ════════════════════════════════════════════════════════════════ */
.ppop-status {
  display: flex; align-items: center; gap: 7px;
  margin-top: 5px; padding: 4px 8px 5px;
  border-radius: 6px; font-size: .7rem;
  border: 1px solid transparent;
  transition: all .18s;
}
/* Otevřeno */
.ppop-status-open {
  background: linear-gradient(120deg, rgba(34,197,94,.12), rgba(16,185,129,.06));
  border-color: rgba(34,197,94,.25);
}
.ppop-status-open .ppop-status-lbl { color: #4ade80; font-weight: 700; }

/* Brzy zavírá */
.ppop-status-closing {
  background: linear-gradient(120deg, rgba(245,158,11,.14), rgba(234,179,8,.06));
  border-color: rgba(245,158,11,.3);
}
.ppop-status-closing .ppop-status-lbl { color: #fbbf24; font-weight: 700; }
.ppop-status-closing .ppop-status-dot {
  animation: dotBlink .8s ease-in-out infinite alternate;
}

/* Zavřeno */
.ppop-status-closed {
  background: rgba(239,68,68,.06);
  border-color: rgba(239,68,68,.18);
}
.ppop-status-closed .ppop-status-lbl { color: #f87171; font-weight: 600; }

/* Dot */
.ppop-status-dot {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
  box-shadow: 0 0 6px currentColor;
}
.ppop-status-open .ppop-status-dot    { box-shadow: 0 0 8px #22c55e; }
.ppop-status-closing .ppop-status-dot { box-shadow: 0 0 8px #f59e0b; }
.ppop-status-closed .ppop-status-dot  { box-shadow: none; opacity: .7; }

@keyframes dotBlink {
  from { opacity: 1; transform: scale(1); }
  to   { opacity: .4; transform: scale(.75); }
}

/* Rozvrh toggle button inside status bar */
.ppop-status-toggle {
  margin-left: auto; padding: 2px 7px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 4px; background: rgba(255,255,255,.06);
  color: var(--muted); font-family: inherit; font-size: .62rem;
  cursor: pointer; white-space: nowrap;
  transition: all .15s;
}
.ppop-status-toggle:hover { background: rgba(255,255,255,.14); color: var(--text); }
.ppop-status-toggle.open  { border-color: var(--acc3); color: var(--acc3); }
