/* ═══════════════════════════════════════════════════════
   LOKALSI — Components
   Wymaga: tokens.css załadowanego przed tym plikiem
   ═══════════════════════════════════════════════════════ */

/* ── Accessibility ── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── Reset ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html,body{width:100%;height:100%;overflow:hidden}
body{font-family:var(--ff);color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased}
button{font-family:var(--ff);cursor:pointer}

/* ── Icon helper ── */
.i{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.i svg{width:100%;height:100%}
.i-14{width:14px;height:14px}.i-16{width:16px;height:16px}
.i-18{width:18px;height:18px}.i-20{width:20px;height:20px}

/* ── Map canvas ── */
#map{position:absolute;inset:0;z-index:0}

/* ════════════════════════════════════
   TASKBAR
   ════════════════════════════════════ */
.tb{
    position:absolute;top:0;left:0;right:0;z-index:200;
    height:var(--tb-h);
    display:flex;align-items:center;
    padding:0 10px;gap:4px;
    background:var(--bg-glass);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    border-bottom:1px solid var(--brd);
}
.no-blur .tb{background:var(--bg-2)}

.tb-brand{
    display:flex;align-items:center;gap:8px;
    text-decoration:none;color:var(--fg);
    padding:5px 8px;border-radius:var(--rs);
    transition:background var(--ease);flex-shrink:0;
}
.tb-brand:hover{background:var(--accent-mut)}
.tb-brand-mark{
    width:28px;height:28px;border-radius:var(--rx);
    display:flex;align-items:center;justify-content:center;
    background:var(--accent);flex-shrink:0;
}
.tb-brand-mark svg{width:15px;height:15px;color:var(--accent-fg)}
.tb-brand-name{font-weight:700;font-size:.84rem;letter-spacing:.12em;text-transform:uppercase}
.tb-brand-sep{width:1px;height:16px;background:var(--brd);flex-shrink:0}
.tb-brand-city{font-size:.77rem;color:var(--fg-2);font-weight:400}

.tb-space{flex:1}

.tb-btn{
    width:40px;height:40px;
    border:none;border-radius:var(--rs);
    background:transparent;color:var(--fg-2);
    display:flex;align-items:center;justify-content:center;
    transition:background var(--ease),color var(--ease);
}
.tb-btn:hover{background:var(--accent-mut);color:var(--accent)}
.tb-btn.on{background:var(--accent);color:var(--accent-fg)}
.tb-btn svg{width:18px;height:18px}

.tb-shortcuts{display:none;align-items:center;gap:2px}
[data-taskbar="c"] .tb-shortcuts{display:flex}
.tb-menu{display:flex}
[data-taskbar="c"] .tb-menu{display:none}
[data-taskbar="a"] .tb-settings{display:none}

.tb-live{display:none;align-items:center;gap:5px;font-size:.67rem;color:var(--fg-3);font-family:var(--fm)}
[data-taskbar="c"] .tb-live{display:flex}
.tb-live-dot{width:6px;height:6px;border-radius:50%;background:var(--ok);animation:pulse 2s ease infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ════════════════════════════════════
   PANELS
   ════════════════════════════════════ */
.panel{
    position:absolute;
    top:var(--tb-h);bottom:44px;
    left:10px;
    width:var(--pw);
    z-index:150;
    display:flex;flex-direction:column;gap:6px;
    transform:translateX(calc(-1 * var(--pw) - 24px));
    opacity:0;pointer-events:none;
    transition:transform var(--ease),opacity var(--ease);
}
.panel.open{transform:translateX(0);opacity:1;pointer-events:auto}

.panel-card{
    background:var(--bg-glass);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    border:1px solid var(--brd);
    border-radius:var(--r);
    box-shadow:var(--s2);
    overflow:hidden;
}
.no-blur .panel-card{background:var(--bg)}

.panel-settings{
    left:auto;right:10px;width:280px;
    transform:translateX(calc(280px + 24px));
}
.panel-settings.open{transform:translateX(0)}

/* ── Search ── */
.srch{padding:10px}
.srch-w{position:relative}
.srch-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--fg-3);pointer-events:none}
.srch-i{
    width:100%;height:40px;
    border:1px solid var(--brd);border-radius:var(--rs);
    padding:0 36px 0 36px;
    font-family:var(--ff);font-size:.84rem;
    background:var(--bg-2);color:var(--fg);
    outline:none;transition:var(--ease);
}
.srch-i:focus{border-color:var(--accent);background:var(--bg);box-shadow:0 0 0 3px var(--accent-mut)}
.srch-i::placeholder{color:var(--fg-3)}
.srch-clear{
    position:absolute;right:8px;top:50%;transform:translateY(-50%);
    width:24px;height:24px;border:none;border-radius:50%;
    background:var(--brd);display:none;
    align-items:center;justify-content:center;transition:var(--ease);
}
.srch-clear:hover{background:var(--brd-h)}
.srch-clear svg{width:12px;height:12px;color:var(--fg-2)}
.srch-i:not(:placeholder-shown)~.srch-clear{display:flex}

/* ── Categories ── */
.cat-h{padding:10px 14px 6px;font-size:.62rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--fg-3)}
.cat-g{display:grid;grid-template-columns:1fr 1fr;gap:2px;padding:0 6px 6px}
.cat-b{
    display:flex;align-items:center;gap:8px;
    padding:8px 10px;min-height:44px;
    border:none;border-radius:var(--rs);
    background:transparent;cursor:pointer;
    font-size:.76rem;font-weight:500;color:var(--fg);
    transition:var(--ease);text-align:left;line-height:1.2;
}
.cat-b:hover{background:var(--bg-3)}
.cat-b.on{background:var(--accent);color:var(--accent-fg)}
.cat-ic{width:26px;height:26px;border-radius:var(--rx);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cat-ic svg{width:14px;height:14px}
.cat-b.on .cat-ic{background:rgba(255,255,255,.18)!important}
.cat-b.on .cat-ic svg{color:var(--accent-fg)!important}
/* "Wszystko" — pełna szerokość gridu */
.cat-b:first-child{grid-column:1/-1}

/* ── POI list ── */
.poi-card{flex:1 1 0;min-height:0;display:flex;flex-direction:column}
.poi-h{padding:10px 14px 6px;font-size:.62rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--fg-3);display:flex;justify-content:space-between;align-items:center}
.poi-cnt{background:var(--bg-3);padding:2px 8px;border-radius:20px;font-size:.62rem;font-weight:600;color:var(--fg-2)}
.poi-sc{flex:1;overflow-y:auto;padding:0 6px 6px}
.poi-sc::-webkit-scrollbar{width:3px}
.poi-sc::-webkit-scrollbar-thumb{background:var(--brd-h);border-radius:3px}
.poi-r{display:flex;align-items:center;gap:10px;padding:10px;min-height:44px;border-radius:var(--rs);cursor:pointer;transition:var(--ease)}
.poi-r:hover{background:var(--bg-3)}
.poi-d{width:32px;height:32px;border-radius:var(--rs);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.poi-d svg{width:15px;height:15px}
.poi-bd{flex:1;min-width:0}
.poi-n{font-weight:600;font-size:.82rem;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.poi-a{font-size:.72rem;color:var(--fg-2);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.poi-arr{color:var(--fg-3);opacity:0;transition:var(--ease)}
.poi-r:hover .poi-arr{opacity:1}
.poi-0{padding:28px 16px;text-align:center;color:var(--fg-3);font-size:.8rem}

/* ── Settings panel ── */
.set-section{padding:16px 18px;border-bottom:1px solid var(--brd)}
.set-section:last-child{border-bottom:none}
.set-label{font-size:.62rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--fg-3);margin-bottom:12px}
.set-themes{display:flex;gap:6px}
.set-theme-b{
    flex:1;height:40px;min-height:40px;border:2px solid transparent;
    border-radius:var(--rs);cursor:pointer;
    transition:var(--ease);overflow:hidden;
}
.set-theme-b:hover{transform:scale(1.04)}
.set-theme-b.on{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-mut)}
.set-theme-b.tn{background:linear-gradient(135deg,#d4edda,#b8d4e3 50%,#f5f5f5)}
.set-theme-b.ts{background:linear-gradient(135deg,#EAE6DA,#D6CFC2 60%,#B5541A)}
.set-theme-b.tb{background:linear-gradient(135deg,#0A1628,#0F2240 55%,#4A90D9)}

.set-taskbar{display:flex;gap:4px}
.set-tb-b{
    flex:1;padding:8px 4px;min-height:44px;
    border:1px solid var(--brd);border-radius:var(--rs);
    background:var(--bg-2);color:var(--fg-2);
    font-size:.72rem;font-weight:600;cursor:pointer;
    transition:var(--ease);text-align:center;
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
}
.set-tb-b:hover{border-color:var(--accent);color:var(--accent)}
.set-tb-b.on{background:var(--accent);border-color:var(--accent);color:var(--accent-fg)}
.set-tb-b small{font-size:.6rem;opacity:.7;font-weight:400}

/* ── Toast ── */
.toast{
    position:fixed;top:calc(var(--tb-h) + 8px);left:50%;
    transform:translateX(-50%) translateY(-20px);
    z-index:9999;background:var(--fg);color:var(--bg);
    font-size:.78rem;font-weight:500;
    padding:8px 18px;border-radius:40px;
    box-shadow:var(--s3);transition:transform var(--ease),opacity var(--ease);
    pointer-events:none;white-space:nowrap;opacity:0;
}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast.ok{background:var(--ok);color:#fff}
.toast.warn{background:var(--warn);color:#fff}
.toast.err{background:var(--err);color:#fff}

/* ── Loading screen ── */
#ld{
    position:fixed;inset:0;z-index:9999;
    background:var(--bg);
    display:flex;flex-direction:column;
    align-items:center;justify-content:center;
    transition:opacity .5s ease,visibility .5s ease;
}
#ld.done{opacity:0;visibility:hidden;pointer-events:none}
.ld-b{font-size:2rem;font-weight:700;color:var(--fg);letter-spacing:.2em;text-transform:uppercase}
.ld-c{font-size:.7rem;color:var(--fg-2);letter-spacing:.4em;text-transform:uppercase;margin:4px 0 32px}
.ld-bar{width:80px;height:2px;background:var(--brd);border-radius:2px;overflow:hidden}
.ld-bar::after{content:'';display:block;width:36%;height:100%;background:var(--accent);border-radius:2px;animation:ld 1s ease-in-out infinite}
@keyframes ld{0%{transform:translateX(-100%)}100%{transform:translateX(380%)}}

/* ── Info bar ── */
.ib{
    position:absolute;bottom:10px;left:50%;transform:translateX(-50%);
    z-index:100;
    background:var(--bg-glass);backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    border:1px solid var(--brd);border-radius:40px;
    padding:6px 16px;box-shadow:var(--s1);
    display:flex;align-items:center;gap:10px;
    font-size:.67rem;font-weight:500;color:var(--fg-2);
    user-select:none;white-space:nowrap;pointer-events:none;
}
.no-blur .ib{background:var(--bg-2)}
.ib .dot{width:5px;height:5px;border-radius:50%;background:var(--ok);animation:pulse 2s ease infinite}
.ib .sep{width:1px;height:12px;background:var(--brd)}
.ib .mono{font-family:var(--fm);font-size:.64rem}
.ib-osm{display:inline-flex;align-items:center;gap:4px}
.ib-globe{width:10px;height:10px;flex-shrink:0;animation:globe-rotate 16s linear infinite}
@keyframes globe-rotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* ── MapLibre overrides ── */
.maplibregl-popup-content{
    border-radius:var(--r)!important;padding:0!important;
    box-shadow:var(--s3)!important;font-family:var(--ff)!important;
    border:1px solid var(--pop-brd)!important;
    max-width:260px!important;overflow:hidden;
    background:var(--pop-bg)!important;
}
.maplibregl-popup-close-button{font-size:18px!important;padding:2px 8px!important;color:var(--pop-fg2)!important;right:2px!important;top:2px!important}
.maplibregl-popup-close-button:hover{background:transparent!important;color:var(--pop-fg)!important}
.maplibregl-popup-anchor-bottom .maplibregl-popup-tip{border-top-color:var(--pop-bg)!important}
.maplibregl-popup-anchor-top .maplibregl-popup-tip{border-bottom-color:var(--pop-bg)!important}
.maplibregl-ctrl-group{border-radius:var(--rs)!important;border:1px solid var(--brd)!important;box-shadow:var(--s2)!important;overflow:hidden;background:var(--bg-glass)!important;backdrop-filter:blur(8px)}
.maplibregl-ctrl-group button{width:36px!important;height:36px!important}
.maplibregl-ctrl-attrib{font-size:10px!important;background:var(--bg-glass)!important;backdrop-filter:blur(4px)}

/* ── Popup content ── */
.pop-hd{padding:14px 16px 12px}
.pop-chip{
    display:inline-flex;align-items:center;gap:5px;
    padding:3px 10px 3px 7px;border-radius:100px;
    font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
    margin-bottom:8px;
}
.pop-chip-ic{width:13px;height:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pop-chip-ic svg{width:100%;height:100%}
.pop-name{font-size:.94rem;font-weight:700;line-height:1.3;color:var(--pop-fg)}
.pop-body{padding:10px 16px 12px;border-top:1px solid var(--pop-brd)}
.pop-row{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.pop-row svg{width:13px;height:13px;color:var(--pop-fg2);flex-shrink:0}
.pop-row span{font-size:.78rem;color:var(--pop-fg2)}
.pop-row a{font-size:.78rem;color:var(--accent);font-weight:500;text-decoration:none}
.pop-row a:hover{text-decoration:underline}
.pop-fly{
    display:flex;align-items:center;justify-content:center;gap:5px;
    width:100%;height:34px;margin-top:8px;
    background:var(--accent-mut);color:var(--accent);
    border:1px solid var(--brd-h);border-radius:var(--rs);
    font-size:.76rem;font-weight:600;cursor:pointer;
    transition:var(--ease);
}
.pop-fly:hover{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}

/* ── WCAG Stage 1 — focus rings (zawsze aktywne) ── */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.tb-btn:focus-visible,.cat-b:focus-visible,.set-tb-b:focus-visible{outline-offset:-2px}

/* ── Animacje ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.a-in{animation:fadeUp .35s ease forwards;opacity:0}
/* .a-fade — dla elementów z własnym transform (np. .ib z translateX(-50%)) */
.a-fade{animation:fadeIn .35s ease forwards;opacity:0}

/* ── Responsive ── */
@media(max-width:768px){
    :root{--tb-h:46px}
    .panel{
        top:auto;left:0;right:0;bottom:0;
        width:100%;height:72vh;max-height:72vh;
        border-radius:var(--r) var(--r) 0 0;
        transform:translateY(100%);gap:0;
        overflow:hidden;background:var(--bg);
    }
    .panel.open{transform:translateY(0)}
    /* Drag handle */
    .panel::before{
        content:'';display:block;
        width:36px;height:4px;
        background:var(--brd-h);border-radius:2px;
        margin:10px auto 4px;flex-shrink:0;
    }
    .panel-card{border-radius:0;border-left:none;border-right:none;border-top:none}
    .panel-card:first-child{border-top:1px solid var(--brd)}
    .panel-settings{left:0;right:0;width:100%;height:auto;transform:translateY(100%)}
    .panel-settings.open{transform:translateY(0)}
    .tb-brand-sep,.tb-brand-city{display:none}
    .ib{bottom:8px;padding:5px 12px;font-size:.63rem;gap:8px}
}

/* ── Perf: reduced motion ── */
@media(prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
