:root{
--bg:#0A1628;
--surface:#0D1F3C;
--card:#112547;
--border:rgba(255,255,255,.1);
--border2:rgba(255,255,255,.18);
--text:#FFFFFF;
--text2:#B8D0F0;
--muted:#6B8DB5;
--accent:#1A6FFF;
--accent-dk:#0051CC;
--accbg:rgba(26,111,255,0.11);
--topbg:rgba(10,22,40,.96);
--red:#FF453A;
--green:#30D158;
--orange:#FF9F0A;
--purple:#BF5AF2;
--teal:#5AC8FA;
}
body.dark{
--bg:#050D1A;
--surface:#0A1628;
--card:#0D1F3C;
--border:rgba(255,255,255,.08);
--border2:rgba(255,255,255,.15);
--text:#FFFFFF;
--text2:#B8D0F0;
--muted:#5A7A9E;
--topbg:rgba(5,13,26,.97);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;width:100%;overflow:hidden;background:var(--bg);font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--text);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;transition:background .2s,color .2s}
#topbar{
position:fixed;top:0;left:0;right:0;z-index:1000;
background:#081827;
border-bottom:1px solid var(--border);
transition:background .2s;
box-shadow:0 2px 16px rgba(0,0,0,.3);
}
.trow{
display:flex;align-items:center;gap:6px;
padding:max(env(safe-area-inset-top),8px) 10px 6px;
box-sizing:border-box;
}
.logo{
font-family:'Inter',sans-serif;font-size:18px;font-weight:800;
color:var(--text);line-height:1;flex-shrink:0;letter-spacing:-.7px;
margin-right:4px;
}
.logo em{color:var(--accent);font-style:normal}
#cnt{
font-size:11px;color:var(--text2);font-weight:600;
background:var(--accbg);border-radius:20px;padding:3px 10px;
margin-right:auto;white-space:nowrap;
border:1px solid rgba(26,111,255,0.15);
}
.tbtn{
background:none;
border:none;
border-radius:0;
width:42px;height:42px;
padding:0;
cursor:pointer;
display:flex;align-items:center;justify-content:center;
transition:transform .12s,filter .12s;
flex-shrink:0;
}
.tbtn:hover{ filter:brightness(1.2); transform:scale(1.08); }
.tbtn:active{ transform:scale(.9); }
.tbtn.on{ filter:brightness(1.3) drop-shadow(0 0 6px rgba(26,111,255,0.6)); }
.tbtn img{
width:42px;height:42px;
border-radius:13px;
display:block;
object-fit:cover;
}
.tbtn-add{
background:var(--accent)!important;
border-radius:14px!important;
width:42px!important;height:42px!important;
font-size:26px!important;color:#fff!important;
box-shadow:0 2px 10px rgba(26,111,255,0.38)!important;
}
.tbtn-add img{
width:42px!important;height:42px!important;
border-radius:13px!important;
}
.tbtn-add:hover{filter:brightness(1.15)!important;}
#catBar{
display:flex;align-items:stretch;
border-bottom:1px solid var(--border);
padding:8px 0 10px;
background:var(--surface);
overflow:hidden;
gap:0;
}
#catScrollArea{
display:flex;overflow-x:auto;
scrollbar-width:none;gap:2px;flex:1;padding:0 4px;
}
#catScrollArea::-webkit-scrollbar{display:none}
#catActions{
display:flex;gap:2px;flex-shrink:0;
padding:0 4px;
border-left:none;
}
.cat{
flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:4px;
padding:5px 7px 7px;cursor:pointer;
font-size:10px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;
color:rgba(255,255,255,.5);transition:all .18s;
white-space:nowrap;border-radius:12px;
user-select:none;border:none;background:none;
font-family:'Inter',sans-serif;
position:relative;z-index:1;
}
.cat:hover{ color:rgba(255,255,255,.85); }
.cat.on{ color:#fff;text-shadow:0 0 12px rgba(100,160,255,.8); }
.cat-icon{
width:72px;height:72px;
display:flex;align-items:center;justify-content:center;
border-radius:18px;
background:none;border:none;
transition:box-shadow .18s ease;
overflow:hidden;position:relative;
box-shadow:none;
}
.cat-icon img{
width:72px;height:72px;
object-fit:cover;border-radius:18px;
transition:filter .18s;
display:block;
transform:none!important;
}
.cat:hover .cat-icon{
box-shadow:0 0 14px 4px rgba(26,111,255,0.41), 0 0 24px 8px rgba(26,111,255,0.19);
}
.cat:hover .cat-icon img{
filter:brightness(1.15);
transform:none;
}
.cat.on .cat-icon{
box-shadow:0 0 16px 6px rgba(26,111,255,0.49), 0 0 30px 10px rgba(26,111,255,0.22);
}
.cat.on .cat-icon img{
filter:brightness(1.1);
transform:none;
}
.cat.on::after{
content:'';display:block;
width:80%;height:4px;
background:radial-gradient(ellipse at center,#5ab4ff 0%,rgba(26,111,255,0.45) 45%,transparent 75%);
border-radius:4px;margin:0 auto;
box-shadow:0 0 12px 4px rgba(26,111,255,0.56),0 0 22px 6px rgba(26,111,255,0.26);
position:relative;top:-1px;
}
.action-cat::after{display:none!important;}
.action-cat{ opacity:.9; }
.action-cat:hover{ opacity:1; }
.action-cat .cat-icon img{
display:block!important;opacity:1!important;visibility:visible!important;
}
.action-cat:hover .cat-icon{
box-shadow:0 0 14px 4px rgba(26,111,255,0.41), 0 0 24px 8px rgba(26,111,255,0.19)!important;
}
.action-cat:hover .cat-icon img{
filter:brightness(1.15)!important;
transform:none!important;
}
.action-add .cat-icon{
background:var(--accent)!important;
border-radius:18px!important;
box-shadow:0 3px 10px rgba(26,111,255,0.38)!important;
}
.cat-separator{
width:2px;
background:rgba(80,160,255,0.41);
margin:8px 4px;
align-self:stretch;
flex-shrink:0;
border-radius:2px;
box-shadow:0 0 4px rgba(80,160,255,0.3);
}
.cat.cat-group .cat-icon{background:none;}
.cat.cat-group.ws-open .cat-icon{background:none;}
:root{ --panel-w:300px; --panel-h:45vh; }
#sidePanel{
position:fixed;top:0;left:0;bottom:0;z-index:1400;
width:var(--panel-w);
background:#044378 url("images/icon_0.webp") center/cover no-repeat;
background-blend-mode:multiply;
border-right:1px solid var(--border);
display:flex;flex-direction:column;
transform:translateX(-100%);
transition:transform .38s cubic-bezier(.32,1,.4,1),opacity .25s,box-shadow .38s;
box-shadow:none;
padding-top:0;
}
#sidePanel.open{ transform:translateX(0); }
#sidePanel.pos-right{
left:auto;right:0;
border-right:none;border-left:1px solid var(--border);
transform:translateX(100%);
box-shadow:-4px 0 24px rgba(0,0,0,.12);
}
#sidePanel.pos-right.open{ transform:translateX(0); }
#sidePanel.pos-bottom{
top:auto;left:0;right:0;width:100%;
height:var(--panel-h);
border-right:none;border-top:2px solid var(--border);
transform:translateY(100%);
box-shadow:0 -4px 24px rgba(0,0,0,.12);
flex-direction:column;
padding-top:0;
}
#sidePanel.pos-bottom.open{ transform:translateY(0); }
#sidePanel.pos-bottom #sideList{ flex-direction:row; }
#sideList{overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;}
#sidePanel.pos-bottom #sideList{overflow-x:auto;overflow-y:hidden;display:flex;gap:0;}
#sidePanel.pos-bottom .side-card{min-width:200px;flex-direction:column;align-items:flex-start;border-bottom:none;border-right:1px solid var(--border);}
#sidePanel.pos-bottom .side-thumb{width:100%;height:90px;border-radius:6px 6px 0 0;margin-bottom:6px;}
#sideHead{
padding:0;
flex-shrink:0;
background:transparent;
}
#sidePanel.pos-bottom #sideHead{
padding:8px 12px;flex-direction:row;
border-bottom:1px solid var(--border);
}
#sideCnt{font-size:11px;color:var(--muted);font-weight:500;margin-left:auto;white-space:nowrap;}
.side-card{
display:flex;gap:10px;align-items:center;
padding:10px 12px;margin:4px 8px;border-radius:12px;
border:1px solid var(--border);
cursor:pointer;transition:all .15s;
background:var(--card);
}
.side-card:hover{background:var(--accbg);border-color:var(--accent);}
.side-thumb{
width:50px;height:50px;border-radius:10px;flex-shrink:0;
background:var(--bg);border:1px solid var(--border);
display:flex;align-items:center;justify-content:center;
font-size:20px;overflow:hidden;
}
.side-thumb img{width:100%;height:100%;object-fit:cover;}
.side-info{flex:1;min-width:0;}
.side-title{font-size:13px;font-weight:700;color:var(--text);line-height:1.3;margin-bottom:2px;
overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.side-loc{font-size:11px;color:var(--muted);}
.side-dist{font-size:11px;color:var(--teal);font-weight:600;margin-top:1px;}
.side-cat{font-size:10px;color:var(--accent);font-weight:600;margin-top:2px;text-transform:uppercase;letter-spacing:.3px;}
#panelToggle{
position:fixed;
left:0;
top:50%;
transform:translateY(-50%);
z-index:1500;
background:none;border:none;padding:0;
cursor:pointer;
transition:left .3s cubic-bezier(.32,1,.4,1);
}
#panelToggle.open{
left:var(--panel-w);
}
#panelToggle:hover{ filter:brightness(1.15); }
#panelToggle .pt-arrow{ font-size:18px;font-weight:700;line-height:1; }
#panelToggle .pt-text{
font-size:8px;font-weight:700;letter-spacing:1.5px;
text-transform:uppercase;writing-mode:vertical-rl;
transform:rotate(180deg);opacity:.85;
}
#panelToggle.open{ left:var(--panel-w); }
#panelToggle.pos-right{
left:auto;right:0;
border-radius:14px 0 0 14px;
box-shadow:-2px 0 10px rgba(0,122,255,0.3);
transform:translateY(-50%);
}
#panelToggle.pos-right:hover{ width:36px; }
#panelToggle.pos-right.open{ right:var(--panel-w); left:auto; }
#panelToggle.pos-bottom{
left:50%;top:auto;bottom:56px;
transform:translateX(-50%);
width:80px;height:28px;
border-radius:12px 12px 0 0;
flex-direction:row;gap:5px;
box-shadow:0 -2px 10px rgba(0,122,255,0.26);
}
#panelToggle.pos-bottom .pt-text{ writing-mode:horizontal-tb;transform:none; }
#panelToggle.pos-bottom.open{ bottom:calc(var(--panel-h) + 56px); }
.panel-controls{display:flex;gap:3px;margin-left:4px;}
.pc-btn{
background:none;border:1px solid var(--border);
border-radius:5px;padding:3px 7px;
font-size:11px;color:var(--muted);cursor:pointer;
transition:all .12s;line-height:1.4;
}
.pc-btn:hover,.pc-btn.on{background:var(--accbg);color:var(--accent);border-color:var(--accent);}
.ws-rb{background:var(--bg);border:1.5px solid var(--border);border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;transition:all .12s;font-family:'Inter',sans-serif;}
.ws-rb.on{background:var(--accent);color:#fff;border-color:var(--accent);}
.ws-rb:hover:not(.on){background:var(--accbg);border-color:var(--accent);color:var(--accent);}
#dzikoPanel{
position:fixed;
z-index:1100;
background:var(--surface);
border:1px solid var(--border);
border-radius:0 0 16px 16px;
box-shadow:0 8px 32px rgba(0,0,0,.14);
padding:12px 14px 14px;
display:none;
flex-direction:column;
gap:10px;
min-width:320px;
max-width:min(96vw, 520px);
}
#dzikoPanel.open{ display:flex; }
.dziko-section-title{
font-size:10px;font-weight:700;color:var(--muted);
text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;
}
.dziko-row{ display:flex;flex-wrap:wrap;gap:5px; }
.dziko-pill{
background:var(--bg);border:1.5px solid var(--border);
border-radius:20px;padding:5px 12px;font-size:12px;font-weight:600;
color:var(--text2);cursor:pointer;transition:all .12s;
font-family:'Inter',sans-serif;white-space:nowrap;
line-height:1.2;
}
.dziko-pill.on{background:var(--accent);color:#fff;border-color:var(--accent);}
.dziko-pill:hover:not(.on){background:var(--accbg);border-color:var(--accent);color:var(--accent);}
.dziko-pill.voiv{ font-size:11px;padding:4px 10px; }
.dziko-pill.scale{ font-size:13px;font-weight:700;padding:6px 16px; }
.dziko-stats{
font-size:11px;color:var(--muted);
padding:6px 10px;background:var(--bg);
border-radius:8px;border:1px solid var(--border);
text-align:center;
}
.dziko-divider{ height:1px;background:var(--border);margin:2px 0; }
@media(min-width:600px){
#map.panel-left{ left:var(--panel-w); }
#map.panel-right{ right:var(--panel-w); }
#sheet.panel-left{ right:16px; }
}
#map{position:fixed;inset:0;z-index:1;transition:left .3s,right .3s;}
.leaflet-tile-pane{transition:filter .3s}
.leaflet-control-zoom{margin-right:12px!important;margin-bottom:20px!important}
.leaflet-control-zoom a{
background:var(--surface)!important;color:var(--text)!important;
border-color:var(--border)!important;font-size:18px!important;font-weight:400!important;
width:36px!important;height:36px!important;line-height:36px!important;
}
.pin-popup-wrap .leaflet-popup-content-wrapper{
padding:0!important;border-radius:14px!important;
background:transparent!important;border:none!important;
box-shadow:none!important;
}
.pin-popup-wrap .leaflet-popup-content{margin:0!important;padding:0!important;}
.pin-popup-wrap .leaflet-popup-tip-container{display:none!important;}
.leaflet-popup-content-wrapper{
background:var(--surface)!important;color:var(--text)!important;
border:1px solid var(--border)!important;border-radius:12px!important;
box-shadow:0 4px 20px rgba(0,0,0,.15)!important;
}
.leaflet-popup-tip{background:var(--surface)!important}
.leaflet-popup-content{margin:12px 16px!important;font-family:'Inter',sans-serif;font-size:14px}
#bnav{ display:none!important; }
.ntab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;color:var(--muted);transition:color .15s;padding:2px 0}
.ntab.on{color:var(--accent)}
.ntab svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.ntab span{font-size:10px;font-weight:500;margin-top:1px}
#lp{position:fixed;inset:0;z-index:1800;background:var(--bg);overflow-y:auto;-webkit-overflow-scrolling:touch;display:none;padding-bottom:16px}
#lp.show{display:block}
.lcard{display:flex;gap:12px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;background:var(--surface);transition:background .1s}
.lcard:active{background:var(--bg)}
.lthumb{width:56px;height:56px;border-radius:10px;flex-shrink:0;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:26px;overflow:hidden;object-fit:cover}
.ltitle{font-size:16px;font-weight:600;color:var(--text);margin-bottom:2px;line-height:1.3}
.lloc{font-size:13px;color:var(--muted);margin-bottom:5px}
.ltags{display:flex;gap:4px;flex-wrap:wrap}
.ltag{font-size:11px;padding:2px 8px;border-radius:6px;background:var(--accbg);color:var(--accent);font-weight:500}
.lsrc{font-size:11px;padding:2px 8px;border-radius:6px;background:rgba(52,199,89,.1);color:#34C759;font-weight:500}
.luser{background:rgba(255,149,0,.12);color:var(--orange)}
#sheet{
position:fixed;
bottom:16px; right:16px;
width:340px; max-width:calc(100vw - 32px);
max-height:calc(100vh - 140px);
z-index:2000;
background:var(--surface);
border-radius:16px;
border:1px solid var(--border);
transform:translateY(24px);
opacity:0;
pointer-events:none;
transition:transform .3s cubic-bezier(.32,1,.4,1), opacity .25s;
display:flex;flex-direction:column;
box-shadow:0 8px 40px rgba(0,0,0,.18);
overflow:hidden;
}
#sheet.open{
transform:translateY(0);
opacity:1;
pointer-events:auto;
}
@media(max-width:600px){
#sheet{
bottom:0; right:0; left:0;
width:100%; max-width:100%;
border-radius:20px 20px 0 0;
max-height:82vh;
transform:translateY(100%);
opacity:1;
}
#sheet.open{ transform:translateY(0); }
}
.drag{padding:10px 0 4px;text-align:center;cursor:pointer;flex-shrink:0}
.drag div{width:36px;height:4px;border-radius:4px;background:var(--border2);display:inline-block}
@media(min-width:601px){ .drag{ display:none; } }
#sScroll{overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;}
#sheetClose{
position:absolute;top:10px;right:10px;z-index:10;
width:28px;height:28px;border-radius:50%;
background:rgba(0,0,0,.45);border:none;color:#fff;
font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;
backdrop-filter:blur(4px);
}
@media(max-width:600px){ #sheetClose{ display:flex !important; } }
#heroWrap{
position:relative;
width:100%;
height:200px;
flex-shrink:0;
overflow:hidden;
background:var(--bg);
}
#heroImg{
width:100%;height:100%;
object-fit:cover;
display:block;
transition:opacity .4s;
}
#heroImg.loading{opacity:0}
#heroSkeleton{
position:absolute;inset:0;
background:linear-gradient(90deg,var(--bg) 25%,var(--border) 50%,var(--bg) 75%);
background-size:200% 100%;
animation:shimmer 1.4s infinite;
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
#heroCredit{
position:absolute;bottom:8px;right:10px;
font-size:10px;color:rgba(255,255,255,.75);
text-shadow:0 1px 3px rgba(0,0,0,.6);
font-family:'Inter',sans-serif;pointer-events:none;
}
#heroUserPhotos{
display:flex;gap:5px;padding:8px 12px;
overflow-x:auto;flex-shrink:0;background:var(--surface);
border-bottom:1px solid var(--border);
scrollbar-width:none;
}
#heroUserPhotos:empty{ display:none; padding:0; }
.hero-thumb{
width:56px;height:56px;border-radius:8px;flex-shrink:0;
object-fit:cover;border:1.5px solid var(--border);
cursor:pointer;transition:transform .15s, border-color .15s;
}
.hero-thumb:hover{ border-color:var(--accent); transform:scale(1.05); }
.hero-thumb.active{ border-color:var(--accent); border-width:2px; }
#sContent{padding:14px 14px 8px}
.sphoto{width:100%;height:220px;object-fit:cover;display:block}
.sphoto-ph{width:100%;height:80px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:36px}
.st{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.stg{font-size:11px;padding:4px 10px;border-radius:6px;background:var(--accbg);color:var(--accent);font-weight:600;text-transform:none;letter-spacing:0}
.stg.w{background:rgba(52,199,89,.1);color:var(--green)}
.stg.u{background:rgba(255,149,0,.1);color:var(--orange)}
.stg.edited{background:rgba(52,199,89,.12);color:#1a7431;font-size:10px}
.sname{font-size:22px;font-weight:700;color:var(--text);line-height:1.2;margin-bottom:4px;letter-spacing:-.3px}
.sloc{font-size:14px;color:var(--muted);margin-bottom:14px;font-weight:400}
.sdesc{font-size:15px;color:var(--text2);line-height:1.65;margin-bottom:16px}
.sfacts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.sfact{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.sfl{font-size:12px;color:var(--muted);margin-bottom:3px;font-weight:500}
.sfv{font-size:15px;color:var(--text);font-weight:600}
.user-actions{
display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px;margin-bottom:8px;
}
.edit-btn{
display:flex;align-items:center;justify-content:center;gap:6px;
background:var(--accbg);border:1.5px solid var(--accent);color:var(--accent);
border-radius:12px;padding:12px;font-size:14px;font-weight:600;
cursor:pointer;font-family:'Inter',sans-serif;transition:all .15s;
}
.edit-btn:active{background:var(--accent);color:#fff;}
.del-btn{
display:flex;align-items:center;justify-content:center;gap:6px;
background:rgba(255,59,48,.08);border:1.5px solid rgba(255,59,48,.35);color:var(--red);
border-radius:12px;padding:12px;font-size:14px;font-weight:600;
cursor:pointer;font-family:'Inter',sans-serif;transition:all .15s;
}
.del-btn:active{background:var(--red);color:#fff;}
#delConfirm{
position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.5);
display:none;align-items:flex-end;justify-content:center;
padding-bottom:max(env(safe-area-inset-bottom),16px);
}
#delConfirm.show{display:flex;animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
#delConfirmBox{
background:var(--surface);border-radius:16px 16px 0 0;
padding:24px 20px max(env(safe-area-inset-bottom),24px);
width:100%;max-width:480px;text-align:center;
}
#delConfirmBox h3{font-size:17px;font-weight:700;margin-bottom:8px;color:var(--text)}
#delConfirmBox p{font-size:14px;color:var(--muted);margin-bottom:20px}
.del-confirm-btns{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.del-confirm-btns button{
padding:14px;border-radius:12px;font-size:16px;font-weight:600;
cursor:pointer;font-family:'Inter',sans-serif;border:none;
}
#inlineEdit{
background:var(--bg);
border:1.5px solid var(--accent);
border-radius:14px;
padding:14px;
margin-bottom:12px;
display:none;
}
#inlineEdit.open{ display:block; }
.ie-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;margin-top:10px}
.ie-label:first-child{margin-top:0}
.ie-inp{
width:100%;padding:9px 12px;
border:1.5px solid var(--border);border-radius:10px;
background:var(--surface);color:var(--text);
font-size:14px;font-family:'Inter',sans-serif;
box-sizing:border-box;transition:border-color .15s;
}
.ie-inp:focus{outline:none;border-color:var(--accent);}
.ie-textarea{min-height:80px;resize:vertical;line-height:1.5;}
.ie-photos{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px;}
.ie-photo-slot{
width:72px;height:72px;border-radius:10px;
border:2px dashed var(--border);
display:flex;align-items:center;justify-content:center;
cursor:pointer;overflow:hidden;position:relative;
background:var(--surface);transition:border-color .15s;flex-shrink:0;
}
.ie-photo-slot:hover{border-color:var(--accent);}
.ie-photo-slot img{width:100%;height:100%;object-fit:cover;border-radius:8px;}
.ie-photo-slot .ie-rm{
position:absolute;top:2px;right:2px;
background:rgba(0,0,0,.6);color:#fff;border:none;
border-radius:50%;width:18px;height:18px;font-size:10px;
cursor:pointer;display:none;align-items:center;justify-content:center;
}
.ie-photo-slot:hover .ie-rm{display:flex;}
.ie-save-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px;}
.ie-save{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:12px;font-size:14px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;}
.ie-cancel{background:var(--bg);color:var(--text2);border:1.5px solid var(--border);border-radius:10px;padding:12px;font-size:14px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;}
.ie-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;}
.ie-tag{padding:5px 12px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface);color:var(--text2);font-size:12px;font-weight:500;cursor:pointer;transition:all .12s;}
.ie-tag.on{background:var(--accent);color:#fff;border-color:var(--accent);}
.routebtn{
display:flex;align-items:center;justify-content:center;gap:8px;width:100%;
background:var(--accbg);border:1.5px solid var(--accent);color:var(--accent);
border-radius:12px;padding:14px;font-size:16px;font-weight:600;
cursor:pointer;font-family:'Inter',sans-serif;transition:background .15s;margin-bottom:10px;
}
.routebtn:active{background:rgba(0,122,255,0.15)}
.navbtn{
display:flex;align-items:center;justify-content:center;gap:8px;
background:var(--accent);color:#fff;border-radius:12px;
padding:14px;text-decoration:none;font-size:16px;font-weight:600;
}
#routeInfo{display:none;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:10px}
#goBtn.active{
background:var(--orange)!important;
box-shadow:0 3px 12px rgba(255,159,10,.4)!important;
animation:goPulse 1.5s infinite;
}
@keyframes goPulse{
0%,100%{box-shadow:0 3px 12px rgba(255,159,10,.4);}
50%{box-shadow:0 3px 20px rgba(255,159,10,.7);}
}
#routeBar{
display:none;
position:fixed;
bottom:16px;left:50%;transform:translateX(-50%);
z-index:800;
background:var(--surface);
border:1.5px solid var(--accent);
border-radius:16px;
padding:12px 16px;
min-width:280px;max-width:min(90vw,420px);
box-shadow:0 3px 18px rgba(0,122,255,0.14);
font-family:'Inter',sans-serif;
}
#routeBar.show{ display:block; }
#addModal{
position:fixed;inset:0;z-index:5000;
background:rgba(0,0,0,.52);
-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
display:none;align-items:center;justify-content:center;
padding:16px;
}
#addModal.open{display:flex}
#addPanel{
width:100%;max-width:480px;
max-height:88vh;
overflow-y:auto;-webkit-overflow-scrolling:touch;
background:var(--surface);
border-radius:20px;
box-shadow:0 20px 60px rgba(0,0,0,.3);
animation:modalIn .22s cubic-bezier(.34,1.56,.64,1);
}
@keyframes modalIn{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}
.ap-head{
display:flex;align-items:center;justify-content:space-between;
padding:16px 18px 14px;border-bottom:1px solid var(--border);
position:sticky;top:0;background:var(--surface);z-index:1;border-radius:20px 20px 0 0;
}
.ap-title{font-size:17px;font-weight:700;color:var(--text)}
.ap-close{
background:var(--bg);border:none;border-radius:50%;
width:30px;height:30px;cursor:pointer;font-size:15px;
display:flex;align-items:center;justify-content:center;
color:var(--muted);font-weight:700;
}
.ap-body{padding:14px 18px 18px}
.frow{margin-bottom:12px}
.flabel{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:5px;display:block;text-transform:uppercase;letter-spacing:.3px}
.finp{
width:100%;background:var(--bg);border:1px solid var(--border);
color:var(--text);border-radius:10px;padding:12px 14px;
font-size:16px;font-family:'Inter',sans-serif;outline:none;
transition:border-color .15s;resize:none;
}
.finp:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(0,122,255,0.11)}
.finp::placeholder{color:var(--muted)}
.fgps{display:grid;grid-template-columns:1fr 1fr;gap:8px}
#photoGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:6px}
.photo-slot{aspect-ratio:1;border-radius:10px;border:1.5px dashed var(--border2);background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s;overflow:hidden;position:relative}
.photo-slot:active{border-color:var(--accent)}
.photo-slot img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.photo-slot .rm{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.55);border:none;border-radius:50%;width:22px;height:22px;color:#fff;font-size:11px;cursor:pointer;display:none;align-items:center;justify-content:center;font-weight:700}
.photo-slot.filled .rm{display:flex}
.photo-add-icon{font-size:24px}
.photo-add-text{font-size:11px;color:var(--muted);margin-top:4px;font-weight:500}
#tagSelect{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.tsel{padding:7px 14px;border-radius:20px;background:var(--bg);border:1px solid var(--border);color:var(--text2);font-size:13px;cursor:pointer;transition:all .15s;font-weight:400}
.tsel.on{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:500}
.fcat{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.fcbtn{padding:8px 16px;border-radius:20px;background:var(--bg);border:1px solid var(--border);color:var(--text2);font-size:14px;cursor:pointer;transition:all .15s;font-weight:400}
.fcbtn.on{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:500}
.fsubmit{width:100%;background:var(--accent);color:#fff;border:none;border-radius:12px;padding:15px;font-size:17px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;margin-top:8px;letter-spacing:0}
.fsubmit:active{opacity:.85}
.flocate{display:flex;align-items:center;gap:8px;background:var(--accbg);border:1px solid rgba(0,122,255,0.19);border-radius:10px;padding:10px 14px;color:var(--accent);font-size:14px;cursor:pointer;margin-bottom:10px;font-weight:500}
.veh-wrap{
position:relative;display:inline-flex;flex-direction:column;
align-items:center;cursor:pointer;user-select:none;
}
.veh-canvas{
width:56px;height:48px;
filter:drop-shadow(0 4px 8px rgba(0,0,0,.35));
transition:transform .2s;
object-fit:contain;
}
.veh-canvas:active{transform:scale(.93);}
@keyframes camperBob{
0%,100%{transform:translateY(0) rotate(-1deg);}
25%{transform:translateY(-2px) rotate(0deg);}
75%{transform:translateY(1px) rotate(-2deg);}
}
#topVehImg{
width:52px;height:44px;
object-fit:contain;
filter:drop-shadow(0 3px 10px rgba(0,0,0,.6)) brightness(1.05);
animation:camperBob 3s ease-in-out infinite;
cursor:pointer;
transition:filter .2s;
}
#topVehImg:active{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));transform:scale(.93);}
.veh-shadow{
width:44px;height:8px;
background:radial-gradient(ellipse,rgba(0,0,0,.25) 0%,transparent 70%);
margin-top:-4px;
border-radius:50%;
}
.veh-label{
font-size:9px;font-weight:700;color:var(--muted);
letter-spacing:.5px;text-transform:uppercase;margin-top:1px;
}
#vehPanel{
position:fixed;bottom:80px;left:50%;transform:translateX(-50%);
z-index:5000;background:var(--surface);border:1px solid var(--border);
border-radius:20px;padding:16px;box-shadow:0 8px 32px rgba(0,0,0,.18);
display:none;min-width:280px;
}
#vehPanel.show{display:block;animation:fadeUp .2s ease}
@keyframes pulse{0%,100%{box-shadow:0 0 0 3px rgba(0,122,255,0.19)}50%{box-shadow:0 0 0 6px rgba(0,122,255,0.04)}}
@keyframes fadeUp{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.veh-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:12px}
.veh-opt{
display:flex;flex-direction:column;align-items:center;gap:4px;
cursor:pointer;padding:10px 6px;border-radius:12px;
border:2px solid transparent;transition:all .15s;
}
.veh-opt:hover{background:var(--bg)}
.veh-opt.on{border-color:var(--accent);background:var(--accbg)}
.veh-opt svg{width:52px;height:36px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}
.veh-opt-label{font-size:11px;font-weight:600;color:var(--text2)}
.km-pin{
width:28px;height:28px;
background:#34C759;
border-radius:50% 50% 50% 0;
transform:rotate(-45deg);
border:2.5px solid #fff;
cursor:pointer;
box-shadow:0 2px 8px rgba(0,0,0,.28);
transition:transform .15s,box-shadow .15s;
}
.km-pin:hover{
transform:rotate(-45deg) scale(1.15);
background:#248A3D;
box-shadow:0 4px 14px rgba(52,199,89,.45);
}
.km-pin.nurkowanie{ background:#0066CC }
.km-pin.kajaki{ background:#00B4D8 }
.km-pin.offroad{ background:#8B4513 }
.km-pin.marina{ background:#0077B6 }
.km-pin.dziko{ background:#2d6a4f }
.km-pin.warsztat{ background:#FF6B00 }
.km-pin.user{ background:#FF3B30 }
.km-pin.sel{
transform:rotate(-45deg) scale(2) !important;
background:#1A7431;
box-shadow:0 6px 20px rgba(52,199,89,.6);
border-width:3px;
z-index:999;
}
.pin-popup{
background:var(--surface);
border-radius:14px;
box-shadow:0 4px 20px rgba(0,0,0,.18);
border:1px solid var(--border);
overflow:hidden;
width:220px;
pointer-events:auto;
font-family:'Inter',sans-serif;
animation:popupIn .18s ease;
}
@keyframes popupIn{from{opacity:0;transform:scale(.92) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}
.pin-popup-photo{
width:100%;height:110px;
object-fit:cover;display:block;
background:var(--bg);
}
.pin-popup-photo-ph{
width:100%;height:110px;
background:linear-gradient(135deg,var(--bg),var(--border));
display:flex;align-items:center;justify-content:center;font-size:36px;
}
.pin-popup-body{padding:8px 10px 10px}
.pin-popup-name{font-size:14px;font-weight:700;color:var(--text);line-height:1.3;margin-bottom:2px}
.pin-popup-loc{font-size:11px;color:var(--muted)}
.pin-popup-dist{font-size:11px;color:var(--accent);font-weight:600;margin-top:2px}
.pin-popup-fuel{font-size:11px;color:var(--orange);font-weight:600;margin-top:3px;padding-top:3px;border-top:1px solid var(--border)}
.ks-tooltip{
background:#fff!important;
border:1px solid #E5E5EA!important;
border-radius:10px!important;
box-shadow:0 4px 16px rgba(0,0,0,.12)!important;
padding:7px 11px!important;
font-family:'Inter',sans-serif!important;
font-size:13px!important;
font-weight:600!important;
color:#000!important;
white-space:nowrap;
}
.ks-tooltip::before{display:none!important}
.leaflet-tooltip-top.ks-tooltip::before{display:none!important}
#mapCtxMenu{
position:fixed;z-index:3000;
background:var(--surface);
border:1px solid var(--border);
border-radius:18px;
box-shadow:0 12px 40px rgba(0,0,0,.22);
overflow:hidden;
min-width:220px;
max-width:280px;
display:none;
animation:popupIn .15s cubic-bezier(.34,1.56,.64,1);
}
#mapCtxMenu.show{ display:block; }
.ctx-head{
font-size:11px;font-weight:700;color:var(--muted);
letter-spacing:.5px;text-transform:uppercase;
}
.ctx-item{
display:flex;align-items:center;gap:10px;
padding:12px 14px;cursor:pointer;
font-size:14px;font-weight:500;color:var(--text);
transition:background .1s;
border:none;background:none;width:100%;text-align:left;
font-family:'Inter',sans-serif;
}
.ctx-item:hover{ background:var(--bg); }
.ctx-item:active{ background:var(--accbg); }
.ctx-item .ctx-ico{ font-size:18px;width:24px;text-align:center;flex-shrink:0; }
.ctx-item .ctx-sub{ font-size:11px;color:var(--muted);margin-top:1px; }
.ctx-sep{ height:1px;background:var(--border);margin:2px 0; }
#toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);z-index:9000;background:rgba(0,0,0,.78);color:#fff;padding:9px 20px;border-radius:20px;font-size:13px;font-weight:500;font-family:'Inter',sans-serif;opacity:0;transition:opacity .25s,transform .25s;pointer-events:none;white-space:nowrap;backdrop-filter:blur(8px)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#detailBadge{
position:fixed;bottom:20px;left:50%;transform:translateX(-50%);
z-index:3500;background:rgba(0,0,0,.72);color:#fff;
padding:7px 18px;border-radius:20px;font-size:13px;font-weight:500;
pointer-events:none;opacity:0;transition:opacity .3s;
white-space:nowrap;backdrop-filter:blur(8px);
font-family:'Inter',sans-serif;
}
#detailBadge.show{opacity:1}
.empty{text-align:center;padding:60px 20px;color:var(--muted);font-size:16px}
#sw{
position:relative;
display:flex;align-items:center;
margin:0 8px 6px;
background:var(--bg);
border:1.5px solid var(--border);
border-radius:14px;
padding:0 10px;
gap:6px;
transition:border-color .15s;
}
#sw:focus-within{border-color:var(--accent);}
.si{font-size:15px;color:var(--muted);flex-shrink:0;pointer-events:none;}
#sq{
flex:1;background:transparent;border:none;outline:none;
font-size:14px;font-weight:500;color:var(--text);
padding:9px 0;
font-family:'Inter',sans-serif;
}
#sq::placeholder{color:var(--muted);}
.sx{
font-size:14px;color:var(--muted);cursor:pointer;
flex-shrink:0;padding:4px;
display:none;
transition:color .12s;
}
.sx:hover{color:var(--text);}
#sugg{
display:none;
position:absolute;
top:calc(100% + 4px);
left:0;right:0;
background:var(--surface);
border:1px solid var(--border);
border-radius:12px;
box-shadow:0 8px 24px rgba(0,0,0,.18);
z-index:4000;
overflow:hidden;
}
.si-row{
display:flex;align-items:center;gap:8px;
padding:10px 14px;
cursor:pointer;
font-size:13px;font-weight:500;color:var(--text);
transition:background .1s;
}
.si-row:hover{background:var(--accbg);}
.si-row span:first-child{font-size:16px;flex-shrink:0;}
.si-row span:nth-child(2){flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

#kajakiPanel{
position:fixed;
z-index:1100;
background:var(--surface);
border:1px solid var(--border);
border-radius:0 0 16px 16px;
box-shadow:0 8px 32px rgba(0,0,0,.14);
padding:12px 14px 14px;
display:none;
flex-direction:column;
gap:10px;
min-width:320px;
max-width:min(96vw, 520px);
}
#kajakiPanel.open{ display:flex; }

/* ═══════════════════════════════════════════════
   RESPONSYWNOŚĆ — SMARTFON
   ═══════════════════════════════════════════════ */

/* Dotyk — większe cele kliknięcia */
@media (max-width: 768px) {

  /* --- TOPBAR / KATEGORIE --- */
  .cat {
    min-width: 66px;
    padding: 4px 7px 5px;
    font-size: 10px;
  }
  .cat-icon {
    width: 46px;
    height: 46px;
  }
  #catBar {
    padding: 7px 0 9px;
  }

  /* --- PANEL BOCZNY → DOLNY DRAWER na mobile --- */
  #sidePanel {
    top: auto !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 60px !important;
    width: 100% !important;
    height: 55vh !important;
    border-right: none !important;
    border-top: 1.5px solid var(--border) !important;
    border-radius: 18px 18px 0 0 !important;
    transform: translateY(100%) !important;
    box-shadow: 0 -6px 32px rgba(0,0,0,.22) !important;
  }
  #sidePanel.open {
    transform: translateY(0) !important;
  }
  /* Uchwyt drag */
  #sidePanel::before {
    content: '';
    display: block;
    width: 36px;
    height: 4px;
    border-radius: 4px;
    background: var(--border2);
    margin: 10px auto 4px;
    flex-shrink: 0;
  }
  #sideHead {
    padding: 4px 14px 6px !important;
  }
  #sideHead img {
    display: none !important;
  }
  #sideCnt {
    padding: 2px 0 4px !important;
    font-size: 12px !important;
  }
  /* Karty w panelu bocznym — poziomo */
  #sideList {
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .side-card {
    padding: 10px 14px;
    gap: 10px;
  }
  .side-thumb {
    width: 52px;
    height: 52px;
  }

  /* --- PASEK TRASY --- */
  #routeBar {
    bottom: 62px;
    left: 8px;
    right: 8px;
    transform: none;
    min-width: unset;
    max-width: 100%;
    border-radius: 14px;
    padding: 10px 12px;
  }

  /* --- PANEL PALIWA — stack pionowo --- */
  #routeFuelBar > div:last-child {
    flex-wrap: wrap;
    gap: 6px;
  }
  #routeBurnInput, #routePriceInput {
    width: 70px !important;
  }

  /* --- SHEET (karta miejsca) --- */
  #sheet {
    bottom: 0;
    right: 0;
    left: 0;
    width: 100%;
    max-width: 100%;
    border-radius: 20px 20px 0 0;
    max-height: 85vh;
    transform: translateY(100%);
    opacity: 1;
  }
  #sheet.open {
    transform: translateY(0);
  }
  .drag { display: block !important; }
  #sheetClose { display: flex !important; }

  /* --- MODAL DODAWANIA --- */
  #addPanel {
    max-height: 95vh;
    border-radius: 20px 20px 0 0;
  }
  #addModal {
    align-items: flex-end;
    padding: 0;
  }

  /* --- PANEL DZIKO / KAJAKI --- */
  #dzikoPanel, #kajakiPanel {
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 0 0 16px 16px;
    min-width: unset;
  }
  .dziko-row {
    flex-wrap: wrap;
    gap: 5px;
  }

  /* --- PANEL WARSZTATY PROMIEŃ --- */
  #wsRadiusPanel {
    flex-wrap: wrap;
    gap: 5px;
    padding: 6px 10px 8px;
  }

  /* --- ZOOM LEAFLET — przesuń wyżej nad bnav --- */
  .leaflet-control-zoom {
    margin-bottom: 80px !important;
    margin-right: 8px !important;
  }

  /* --- PRZYCISKI DOTYKOWE — większe --- */
  .ntab {
    padding: 4px 0;
  }
  .ntab svg {
    width: 26px;
    height: 26px;
  }
  .ntab span {
    font-size: 9px;
  }

  /* --- PANEL POJAZDU --- */
  #vehPanel {
    bottom: 62px;
    left: 8px;
    right: 8px;
    max-width: unset;
  }

  /* --- FUELCALC MODAL --- */
  #fuelCalc {
    padding: 8px 0;
  }

  /* --- LISTA MIEJSC --- */
  #lp {
    padding-bottom: 16px;
  }

  /* --- INLINE EDIT PANEL --- */
  #inlineEdit {
    bottom: 62px;
    left: 8px;
    right: 8px;
    max-width: unset !important;
  }

  /* --- WYSZUKIWARKA --- */
  #searchBar {
    left: 8px;
    right: 8px;
  }
}

/* Bardzo małe ekrany (iPhone SE, 320px) */
@media (max-width: 375px) {
  .cat {
    min-width: 52px;
    font-size: 9px;
  }
  .cat-icon {
    width: 32px;
    height: 32px;
  }
  #routeBar {
    padding: 8px 10px;
  }
  #routeBarDist {
    font-size: 16px !important;
  }
}

/* ═══════════════════════════════════════════════
   PRZYCISK KATEGORII + MODAL (mobile)
   ═══════════════════════════════════════════════ */

/* Przycisk kółko — widoczny tylko na mobile */
#catToggleBtn {
  display: none;
  position: fixed;
  top: 10px;
  right: 10px;
  z-index: 1200;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--accent);
  border: none;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 10px rgba(26,111,255,0.38);
  transition: transform .15s, box-shadow .15s;
  flex-direction: column;
  gap: 3px;
  padding: 0;
}
#catToggleBtn:active { transform: scale(.92); }
#catToggleBtn .dot {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: rgba(255,255,255,.25);
  display: flex; align-items: center; justify-content: center;
}
#catToggleBtn .dot img {
  width: 14px; height: 14px;
  object-fit: contain; border-radius: 3px;
  display: block;
}
/* Badge aktywnych kategorii */
#catBadge {
  position: absolute;
  top: -3px; right: -3px;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: #FF453A;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  display: none;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--bg);
}
#catBadge.show { display: flex; }

/* Overlay modal */
#catModal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 3500;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  align-items: center;
  justify-content: center;
  padding: 20px;
}
#catModal.open { display: flex; }

/* Ramka modala */
#catModalBox {
  background: var(--surface);
  border-radius: 20px;
  border: 1px solid var(--border);
  padding: 18px 16px 16px;
  width: 100%;
  max-width: 360px;
  box-shadow: 0 20px 60px rgba(0,0,0,.35);
  animation: modalIn .2s cubic-bezier(.34,1.56,.64,1);
}
#catModalTitle {
  font-size: 15px;
  font-weight: 700;
  color: var(--text2);
  text-align: center;
  margin-bottom: 14px;
  letter-spacing: .2px;
}
/* Siatka ikon kategorii */
#catModalGrid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 12px;
}
#catModalSep {
  height: 1px;
  background: var(--border);
  margin: 10px 0;
}
/* Siatka akcji */
#catModalActions {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 14px;
}
/* Kafelek w modalu */
.cm-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 10px 4px;
  border-radius: 12px;
  border: 1.5px solid transparent;
  background: var(--bg);
  cursor: pointer;
  transition: border-color .15s, background .15s;
  -webkit-tap-highlight-color: transparent;
}
.cm-tile:active { background: var(--accbg); }
.cm-tile.on {
  border-color: var(--accent);
  background: var(--accbg);
}
.cm-tile img {
  width: 38px; height: 38px;
  border-radius: 10px;
  object-fit: cover;
  display: block;
}
.cm-tile span {
  font-size: 9px;
  font-weight: 600;
  color: var(--text2);
  text-align: center;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 100%;
}
.cm-tile.on span { color: var(--accent); }

/* Przycisk zamknij */
#catModalClose {
  width: 100%;
  padding: 12px;
  border-radius: 12px;
  border: none;
  background: var(--bg);
  color: var(--text2);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  transition: background .15s;
}
#catModalClose:active { background: var(--border); }

/* MOBILE — ukryj pasek, pokaż kółko */
@media (max-width: 768px) {
  #catBar { display: none !important; }
  #catToggleBtn { display: flex !important; }
  /* Schowaj też search bar w topbar, zostaw tylko mapę */
  #sw { margin-top: 0 !important; }
  #topbar { padding-bottom: 0; }
}

/* ═══════════════════════════════════════════════
   SEARCHBAR NA MOBILE — górny pasek z kółkiem
   ═══════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* Schowaj searchbar w topbar */
  #topbar #sw { display: none !important; }

  /* Górny pasek mobile — fixed nad mapą */
  #mobileTopBar {
    display: flex;
    position: fixed;
    top: max(env(safe-area-inset-top), 10px);
    left: 10px;
    right: 10px;
    z-index: 1200;
    align-items: center;
    gap: 8px;
    pointer-events: none;
  }
  #mobileTopBar > * { pointer-events: auto; }

  /* Kółko kategorii — wewnątrz mobilnego topbar */
  #catToggleBtn {
    position: static !important;
    top: auto !important;
    right: auto !important;
    flex-shrink: 0;
  }

  /* Searchbar mobile */
  #mobileSearch {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 0 10px 0 12px;
    height: 44px;
    box-shadow: 0 2px 12px rgba(0,0,0,.22);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
  #mobileSearch .si {
    font-size: 15px;
    flex-shrink: 0;
    margin-right: 6px;
    opacity: .6;
  }
  #mobileSearch input {
    flex: 1;
    background: none;
    border: none;
    outline: none;
    color: var(--text);
    font-size: 15px;
    font-family: 'Inter', sans-serif;
    min-width: 0;
  }
  #mobileSearch input::placeholder { color: var(--muted); }
  #mobileSearch .sx {
    font-size: 14px;
    color: var(--muted);
    cursor: pointer;
    padding: 4px;
    display: none;
  }
  #mobileSugg {
    position: absolute;
    top: calc(100% + 6px);
    left: 0; right: 0;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(0,0,0,.25);
    z-index: 1300;
    display: none;
  }
  #mobileSugg .si-row {
    padding: 12px 14px;
    border-bottom: 1px solid var(--border);
    display: flex; align-items: center; gap: 10px;
    cursor: pointer; font-size: 14px; color: var(--text);
  }
  #mobileSugg .si-row:last-child { border-bottom: none; }
  #mobileSugg .si-row:active { background: var(--accbg); }
  #mobileSugg .si-sub {
    font-size: 11px; color: var(--muted);
    display: block; margin-top: 1px;
  }
  #mobileSugg .si-row span:nth-child(2) {
    flex: 1; min-width: 0;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  }
}

@media (min-width: 769px) {
  #mobileTopBar { display: none !important; }
}

/* ═══════════════════════════════════════════════
   MOBILE — ukryj boczny panel z lokalizacjami
   ═══════════════════════════════════════════════ */
@media (max-width: 768px) {
  #panelToggle { display: none !important; }
  #sidePanel { display: none !important; }
  #map { left: 0 !important; right: 0 !important; }
}

/* ═══════════════════════════════════════════════
   ROUTEBAR — zwijanie punktów trasy
   ═══════════════════════════════════════════════ */
#routeBarCollapsible {
  overflow: hidden;
  transition: max-height .35s cubic-bezier(.4,0,.2,1), opacity .25s;
  max-height: 600px;
  opacity: 1;
}
#routeBarCollapsible.collapsed {
  max-height: 0 !important;
  opacity: 0;
}
#routeBar.collapsed #routeBarCollapseHint {
  display: inline !important;
}
/* Na mobile — auto-zwiń po przekroczeniu 2 punktów */
@media (max-width: 768px) {
  #routeBar {
    max-height: 75vh;
    overflow-y: auto;
  }
}

/* ═══════════════════════════════════════════════
   OPTYMALIZACJA WYDAJNOŚCI — mobile i desktop
   ═══════════════════════════════════════════════ */
.leaflet-tile-pane {
  will-change: transform;
}
.leaflet-zoom-animated {
  will-change: transform;
}
/* Wyłącz transition na markerach podczas zoom */
.leaflet-marker-pane * {
  transition: none !important;
}
.leaflet-zoom-anim .leaflet-zoom-animated {
  transition: transform 0.2s cubic-bezier(0,0,0.25,1) !important;
}
/* Popraw touch performance */
.leaflet-container {
  touch-action: pan-x pan-y;
  -webkit-tap-highlight-color: transparent;
}

/* ═══════════════════════════════════════════════
   SUWAK PINEZEK
   ═══════════════════════════════════════════════ */
#pinSliderPanel {
  position: fixed;
  z-index: 1100;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px 18px 16px;
  box-shadow: 0 8px 32px rgba(0,0,0,.25);
  min-width: 260px;
  max-width: 320px;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-8px);
  transition: opacity .2s ease, transform .2s ease;
}
#pinSliderPanel.open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
#pinSliderTitle {
  font-size: 13px;
  font-weight: 700;
  color: var(--text2);
  margin-bottom: 12px;
  text-align: center;
}
#pinSliderRow {
  display: flex;
  align-items: center;
  gap: 8px;
}
#pinSliderRow span {
  font-size: 11px;
  color: var(--muted);
  white-space: nowrap;
  flex-shrink: 0;
}
#pinSlider {
  flex: 1;
  -webkit-appearance: none;
  appearance: none;
  height: 6px;
  border-radius: 3px;
  background: var(--border);
  outline: none;
  cursor: pointer;
}
#pinSlider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--accent);
  cursor: pointer;
  box-shadow: 0 2px 4px rgba(0,122,255,0.3);
}
#pinSlider::-moz-range-thumb {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--accent);
  cursor: pointer;
  border: none;
}
#pinSliderVal {
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  color: var(--accent);
  margin-top: 8px;
}
/* Pozycja — desktop pod przyciskiem, mobile na środku */
@media (min-width: 769px) {
  #pinSliderPanel {
    top: auto;
    right: 12px;
  }
}
@media (max-width: 768px) {
  #pinSliderPanel {
    left: 50%;
    transform: translateX(-50%);
    bottom: 80px;
    min-width: 280px;
  }
}

/* ═══════════════════════════════════════════════
   ROTACJA MAPY — heading-up podczas GO!
   ═══════════════════════════════════════════════ */
#map {
  transition: transform 0.8s ease-out;
}
/* Gdy GO! aktywne — szybsza aktualizacja */
#map.go-active {
  transition: transform 0.4s ease-out;
}
/* Kompas */
#compassBtn {
  transition: opacity 0.3s;
}
