:root{
  --bg:#04060a; --bg-2:#070a10;
  --panel:rgba(10,16,22,.74); --panel-solid:#0a0f15; --panel-2:rgba(14,22,30,.72); --panel-3:#121b24;
  --line:rgba(0,229,208,.13); --line-2:rgba(0,229,208,.32);
  --txt:#e9fbff; --muted:#7d93a1; --muted-2:#46545f;
  --accent:#00e5d0; --accent-2:#4df5e6;
  --grad:linear-gradient(120deg,#00e5d0,#10b3d6);
  --grad-c:linear-gradient(120deg,#00e5d0,#22d3ee 36%,#ff2d95);
  --yt:#ff0033; --ig:#e1306c; --tt:#25f4ee; --ok:#39ff14; --biz:#22d3ee;
  --r:16px; --shadow:0 18px 50px rgba(0,0,0,.62); --glow:0 0 0 1px var(--line),0 0 32px rgba(0,229,208,.18);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--txt);overflow-x:hidden}
h1,h2,.logo-txt,.intro-title{font-family:'Chakra Petch',sans-serif}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:10px}::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:10px;border:3px solid transparent;background-clip:content-box}

/* ============ ANIMATED AURORA BACKGROUND ============ */
.aurora{position:fixed;inset:0;z-index:0;overflow:hidden;background:var(--bg)}
.blob{position:absolute;border-radius:50%;filter:blur(120px);opacity:.5;mix-blend-mode:screen;will-change:transform}
.b1{width:560px;height:560px;background:radial-gradient(circle,#1b1f27,transparent 66%);top:-160px;left:-120px;animation:float1 22s ease-in-out infinite}
.b2{width:620px;height:620px;background:radial-gradient(circle,#14171d,transparent 66%);bottom:-220px;right:-140px;animation:float2 26s ease-in-out infinite}
.b3{width:480px;height:480px;background:radial-gradient(circle,#202530,transparent 66%);top:40%;left:45%;animation:float3 30s ease-in-out infinite}
@keyframes float1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(120px,80px) scale(1.15)}}
@keyframes float2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-100px,-60px) scale(1.1)}}
@keyframes float3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-80px,60px) scale(1.2)}}
.grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:48px 48px;mask:radial-gradient(circle at 50% 40%,#000,transparent 80%)}

/* ============ INTRO SPLASH ============ */
.intro{position:fixed;inset:0;z-index:5000;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(900px 600px at 50% 30%,rgba(0,229,208,.14),transparent 60%),rgba(7,8,16,.55);backdrop-filter:blur(8px);
  transition:opacity .6s,visibility .6s}
.intro.hide{opacity:0;visibility:hidden}
.intro-inner{text-align:center;animation:introUp .9s cubic-bezier(.2,.8,.2,1)}
@keyframes introUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
.intro-mark{position:relative;width:110px;height:110px;margin:0 auto 26px}
.intro-mark .ring{position:absolute;inset:0;border-radius:50%;border:2px solid transparent;
  background:conic-gradient(from 0deg,#ff4d1c,#ff2d6f,#a855f7,#1d6dff,#ff4d1c) border-box;
  -webkit-mask:linear-gradient(#000 0 0) padding-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;
  animation:spin 4s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.logo-mark.big{position:absolute;inset:26px;width:auto;height:auto;border-radius:18px}
.intro-title{font-size:54px;font-weight:800;letter-spacing:-1.5px}
.intro-title b{background:var(--grad-c);-webkit-background-clip:text;background-clip:text;color:transparent}
.intro-title i{font-style:normal;font-size:22px;color:var(--muted-2);font-weight:700;vertical-align:super}
.intro-tag{color:var(--muted);font-size:17px;line-height:1.6;margin:18px 0 28px}
.intro-tag .hl{color:var(--accent-2);font-weight:600}
.intro-stats{display:flex;gap:30px;justify-content:center;margin-bottom:34px}
.intro-stats .is b{font-family:'Chakra Petch';font-size:30px;display:block;background:var(--grad-c);-webkit-background-clip:text;background-clip:text;color:transparent}
.intro-stats .is small{color:var(--muted);font-size:12.5px;letter-spacing:.4px}
.intro-cta{font-size:16px;padding:14px 30px}

/* ============ HEADER ============ */
header{height:66px;display:flex;align-items:center;gap:18px;padding:0 22px;position:sticky;top:0;z-index:1200;
  background:rgba(10,11,17,.82);backdrop-filter:blur(18px) saturate(140%);border-bottom:1px solid var(--line)}
.logo{display:flex;align-items:center;gap:11px}
.logo-img{width:34px;height:34px;display:block;filter:drop-shadow(0 4px 12px rgba(255,45,149,.45))}
.intro-logo{width:88px;height:88px;position:absolute;inset:11px;animation:logoPop .9s cubic-bezier(.2,.8,.2,1)}
@keyframes logoPop{from{transform:scale(.6);opacity:0}to{transform:none;opacity:1}}
.intro-sub{margin-top:18px;font-size:13px;color:var(--muted-2)}
.intro-sub b{color:var(--accent-2)}
.side-foot{padding:13px 18px;border-top:1px solid var(--line);font-size:11.5px;color:var(--muted-2);display:flex;flex-direction:column;gap:6px}
.ff-links{display:flex;flex-wrap:wrap;gap:7px;align-items:center}
.ff-links a{color:var(--muted)}
.ff-links a:hover{color:var(--accent-2)}
.ff-links span{color:var(--muted-2)}
.legal a{color:var(--accent-2);text-decoration:underline}
.logo-mark{width:32px;height:32px;border-radius:10px;background:var(--grad);position:relative;box-shadow:0 4px 18px rgba(0,229,208,.55)}
.logo-mark::after{content:"";position:absolute;width:7px;height:7px;border-radius:50%;background:#fff;top:7px;right:7px}
.logo-txt{font-size:21px;font-weight:800;letter-spacing:-.4px}
.logo-txt b{background:var(--grad-c);-webkit-background-clip:text;background-clip:text;color:transparent}
.logo-txt i{font-style:normal;font-size:12px;color:var(--muted-2);font-weight:700}

.tabs{display:flex;gap:4px;background:rgba(255,255,255,.04);padding:5px;border-radius:13px;border:1px solid var(--line)}
.tab{display:flex;align-items:center;gap:7px;border:none;background:transparent;color:var(--muted);padding:9px 16px;border-radius:9px;font-size:14px;font-weight:600;transition:.2s}
.tab:hover{color:var(--txt)}
.tab.active{background:rgba(255,255,255,.08);color:var(--txt);box-shadow:0 2px 12px rgba(0,0,0,.35)}
.demo-pill{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--accent-2);border:1px solid rgba(77,245,230,.35);background:rgba(77,245,230,.08);padding:4px 10px;border-radius:20px}
.spacer{flex:1}
.btn-ghost{background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--txt);padding:9px 14px;border-radius:11px;font-size:14px;font-weight:600;transition:.2s}
.btn-ghost:hover{border-color:var(--line-2);background:rgba(255,255,255,.09)}
.btn-primary{position:relative;background:var(--grad);border:none;color:#022;padding:11px 20px;border-radius:11px;font-size:14px;font-weight:800;box-shadow:0 0 22px rgba(0,229,208,.5),0 6px 18px rgba(0,0,0,.4);transition:.2s;overflow:hidden;text-shadow:0 1px 0 rgba(255,255,255,.2)}
.btn-primary::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-20deg);transition:left .6s}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(0,229,208,.5)}
.btn-primary:hover::after{left:130%}
.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.me{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.05);border:1px solid var(--line);padding:5px 14px 5px 5px;border-radius:30px;font-size:13px;font-weight:600;cursor:pointer;transition:.2s}
.me:hover{border-color:var(--line-2)}
.me .av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff}

/* ============ CONTEXT BANNER ============ */
.ctx-banner{display:none;align-items:center;gap:10px;padding:11px 24px;font-size:13.5px;position:relative;z-index:1100;border-bottom:1px solid var(--line);backdrop-filter:blur(12px)}
.ctx-banner.show{display:flex;animation:dropIn .35s}
@keyframes dropIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.ctx-banner.biz{background:linear-gradient(90deg,rgba(79,140,255,.16),transparent);color:#cfe0ff}
.ctx-banner.creator{background:linear-gradient(90deg,rgba(0,229,208,.14),transparent);color:#ffd8c6}

/* ============ LAYOUT ============ */
.layout{display:flex;height:78vh;min-height:560px;position:relative;z-index:1;max-width:1320px;margin:0 auto;
  border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}
.ctx-banner.show ~ .layout{height:78vh}
.sidebar{width:404px;background:rgba(10,12,20,.55);backdrop-filter:blur(16px);border-right:1px solid var(--line);display:flex;flex-direction:column;flex-shrink:0}
.map-area{flex:1;position:relative}
#map{position:absolute;inset:0;background:#0a0c14}
.map-vignette{position:absolute;inset:0;pointer-events:none;z-index:450;box-shadow:inset 0 0 160px 30px rgba(7,8,16,.85)}

/* Mapa jako podgląd na stronie: nie przechwytuje gestów scrolla.
   Pełna interakcja (zoom/pan) w modalu pod przyciskiem „Zobacz na mapie". */
.map-area.preview #map{pointer-events:none}
.map-area.preview .leaflet-control-container{display:none}
.map-open{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:600;
  display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border:none;border-radius:999px;
  background:var(--grad);color:#04211f;font-family:'Chakra Petch';font-weight:700;font-size:14px;
  cursor:pointer;box-shadow:0 10px 30px rgba(0,0,0,.5)}
.map-open:hover{filter:brightness(1.08)}
/* Przycisk „Zobacz na mapie" tylko na mobile — na desktopie mapa działa inline. */
@media (min-width:769px){ .map-open{display:none} }
.map-modal{position:fixed;inset:0;z-index:2000;display:none;flex-direction:column;background:var(--bg)}
.map-modal.show{display:flex}
.map-modal-bar{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;border-bottom:1px solid var(--line);background:var(--panel-solid)}
.map-modal-bar .mm-title{font-family:'Chakra Petch';font-weight:700;font-size:16px}
.mm-close{padding:9px 16px;border:1px solid var(--line-2);border-radius:10px;
  background:rgba(255,255,255,.05);color:var(--txt);cursor:pointer;font-size:14px}
.mm-close:hover{border-color:var(--accent)}
.map-modal-body{flex:1;position:relative}

.search-wrap{padding:18px 16px 10px;position:relative}
.search-wrap::before{content:"🔎";position:absolute;left:30px;top:50%;transform:translateY(-30%);opacity:.5;font-size:14px;pointer-events:none}
#search{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--txt);padding:13px 16px 13px 40px;border-radius:13px;font-size:14px;transition:.2s}
#search:focus{outline:none;border-color:var(--accent);background:rgba(0,229,208,.06);box-shadow:0 0 0 3px rgba(0,229,208,.15)}
.filter-block{padding:0 16px 14px;display:flex;flex-direction:column;gap:9px;border-bottom:1px solid var(--line)}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--muted);font-size:13px;font-weight:600;padding:8px 14px;border-radius:30px;transition:.18s}
.chip:hover{color:var(--txt);border-color:var(--line-2);transform:translateY(-1px)}
.chip.on{background:var(--grad);color:#022;font-weight:800;border-color:transparent;box-shadow:0 0 16px rgba(0,229,208,.4)}
.chips.small .chip{font-size:12px;padding:6px 12px}
.chips.small .chip.on{background:rgba(255,255,255,.1);color:var(--txt);box-shadow:none;border-color:var(--line-2)}

.list-head{display:flex;justify-content:space-between;align-items:center;padding:13px 18px 6px;font-size:12px;color:var(--muted)}
.list-head .sort{color:var(--muted-2);cursor:pointer}
.list{flex:1;overflow-y:auto;padding:6px 12px 16px;display:flex;flex-direction:column;gap:11px}

/* ============ CREATOR CARD ============ */
.card{flex-shrink:0;background:var(--panel);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:18px;padding:15px;display:flex;gap:13px;cursor:pointer;transition:.22s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden;opacity:0;animation:cardIn .5s forwards}
@keyframes cardIn{to{opacity:1}}
.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--g,var(--grad));opacity:0;transition:.22s}
.card::after{content:"";position:absolute;inset:0;border-radius:18px;background:radial-gradient(400px circle at var(--mx,50%) var(--my,0),rgba(255,255,255,.06),transparent 40%);opacity:0;transition:.3s;pointer-events:none}
.card:hover{border-color:var(--line-2);transform:translateY(-3px);box-shadow:var(--shadow)}
.card:hover::before{opacity:1}.card:hover::after{opacity:1}
.card.dim{opacity:.3;filter:grayscale(.5)}
.av{width:58px;height:58px;border-radius:17px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:'Chakra Petch';font-weight:800;font-size:19px;color:#fff;letter-spacing:-.5px;box-shadow:0 6px 18px rgba(0,0,0,.35)}
.card .info{flex:1;min-width:0}
.card .nm{display:flex;align-items:center;gap:6px;font-family:'Chakra Petch';font-weight:700;font-size:16px}
.vrf{color:var(--biz);font-size:13px}
.card .loc{font-size:12.5px;color:var(--muted);margin-top:3px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.bike-badge{font-size:11px;color:var(--accent-2);background:rgba(77,245,230,.1);border:1px solid rgba(77,245,230,.22);padding:1px 8px;border-radius:6px;white-space:nowrap}
.card .bio{font-size:12.5px;color:#b9c0cf;margin-top:8px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.socs{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.soc{font-size:11px;font-weight:700;padding:4px 9px;border-radius:8px;display:flex;align-items:center;gap:5px}
.soc.yt{background:rgba(255,0,51,.14);color:#ff5e7a}
.soc.ig{background:rgba(225,48,108,.14);color:#ff7fb0}
.soc.tt{background:rgba(37,244,238,.12);color:#62e8e4}

/* ============ MAP PIN ============ */
.pin{width:40px;height:40px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:2.5px solid rgba(255,255,255,.92);box-shadow:0 6px 16px rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;transition:.2s}
.pin:hover{transform:rotate(-45deg) scale(1.12)}
.pin span{transform:rotate(45deg);font-size:17px}
.pin{box-shadow:0 6px 16px rgba(0,0,0,.55),0 0 14px rgba(0,229,208,.35)}
.pin.moto{background:linear-gradient(135deg,#00e5d0,#22d3ee)}
.pin.auto{background:linear-gradient(135deg,#22d3ee,#6366f1)}
.pin.both{background:linear-gradient(135deg,#ff2d95,#a855f7)}
.pin.druk_3d{background:linear-gradient(135deg,#f59e0b,#ef4444)}
.pin.drony{background:linear-gradient(135deg,#38bdf8,#6366f1)}
.pin.pulse{animation:pulse 1.7s infinite}
@keyframes pulse{0%{box-shadow:0 6px 16px rgba(0,0,0,.55),0 0 0 0 rgba(0,229,208,.55)}70%{box-shadow:0 6px 16px rgba(0,0,0,.55),0 0 0 18px rgba(0,229,208,0)}100%{box-shadow:0 6px 16px rgba(0,0,0,.55),0 0 0 0 rgba(0,229,208,0)}}

.map-hint{position:absolute;top:18px;left:50%;transform:translateX(-50%);z-index:600;background:var(--grad);color:#fff;padding:11px 20px;border-radius:30px;font-size:13.5px;font-weight:600;box-shadow:0 10px 30px rgba(0,229,208,.45)}

/* ===== floating community stat bar ===== */
.stat-bar{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:500;display:flex;gap:2px;
  background:rgba(12,14,22,.7);backdrop-filter:blur(16px) saturate(140%);border:1px solid var(--line-2);border-radius:18px;padding:6px;box-shadow:var(--shadow)}
.stat-bar .sb{padding:9px 20px;text-align:center;border-radius:13px;transition:.2s}
.stat-bar .sb:hover{background:rgba(255,255,255,.05)}
.stat-bar .sb b{font-family:'Chakra Petch';font-size:19px;display:block;line-height:1}
.stat-bar .sb small{color:var(--muted);font-size:11px;letter-spacing:.3px}
.stat-bar .sep{width:1px;background:var(--line);margin:6px 0}

/* ===== leaflet popup ===== */
.leaflet-popup-content-wrapper{background:var(--panel-solid);color:var(--txt);border:1px solid var(--line-2);border-radius:16px;box-shadow:var(--shadow)}
.leaflet-popup-content{margin:15px 17px}
.leaflet-popup-tip{background:var(--panel-solid)}
.leaflet-container a.leaflet-popup-close-button{color:var(--muted);padding:8px 8px 0 0}
.pp{min-width:210px}
.pp .pn{font-family:'Chakra Petch';font-weight:700;font-size:15px;display:flex;align-items:center;gap:6px}
.pp .pm{color:var(--muted);font-size:12px;margin:5px 0 12px}
.pp button{width:100%;background:var(--grad);border:none;color:#fff;padding:10px;border-radius:10px;font-weight:700;font-size:13px}

/* ============ OVERLAY / DRAWER ============ */
.overlay{position:fixed;inset:0;background:rgba(4,5,10,.66);backdrop-filter:blur(6px);z-index:2000;display:none;align-items:center;justify-content:flex-end}
.overlay.show{display:flex;animation:fade .25s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.drawer{width:540px;max-width:100%;height:100%;background:rgba(12,14,22,.92);backdrop-filter:blur(20px);border-left:1px solid var(--line-2);overflow-y:auto;animation:slide .35s cubic-bezier(.2,.8,.2,1)}
@keyframes slide{from{transform:translateX(60px);opacity:.3}to{transform:none;opacity:1}}

.cover{height:160px;position:relative;overflow:hidden}
.cover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(12,14,22,.9))}
.cover .x{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.45);border:none;color:#fff;font-size:16px;backdrop-filter:blur(4px);z-index:2}
.p-head{padding:0 28px;margin-top:-46px;position:relative;z-index:1}
.p-av{width:96px;height:96px;border-radius:26px;border:4px solid rgba(12,14,22,.92);display:flex;align-items:center;justify-content:center;font-family:'Chakra Petch';font-weight:800;font-size:32px;color:#fff;box-shadow:0 10px 30px rgba(0,0,0,.4)}
.p-name{font-family:'Chakra Petch';font-size:25px;font-weight:800;margin-top:14px;display:flex;align-items:center;gap:8px}
.p-loc{color:var(--muted);font-size:14px;margin-top:5px;display:flex;align-items:center;gap:8px}
.cat-pill{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 10px;border-radius:7px;background:rgba(255,255,255,.07);color:var(--accent-2)}
.p-body{padding:22px 28px 44px;display:flex;flex-direction:column;gap:20px}
.p-bio{font-size:14.5px;line-height:1.6;color:#cdd3df}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.spec{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:14px;padding:13px 15px;transition:.2s}
.spec:hover{border-color:var(--line-2);transform:translateY(-2px)}
.spec small{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.spec b{display:block;font-size:15px;margin-top:4px;font-family:'Chakra Petch'}
.stats{display:flex;gap:11px}
.stat{flex:1;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:16px;padding:15px;text-align:center;position:relative;transition:.2s}
.stat:hover{transform:translateY(-2px)}
.stat b{font-family:'Chakra Petch';font-size:23px;display:block}
.stat small{color:var(--muted);font-size:11px;display:flex;gap:4px;align-items:center;justify-content:center;margin-top:4px}
.stat .auto-tag{position:absolute;top:9px;right:9px}
.auto-tag{font-size:9px;font-weight:700;color:var(--ok);background:rgba(52,211,153,.12);border:1px solid rgba(52,211,153,.3);padding:1px 6px;border-radius:5px;letter-spacing:.3px}
.section-t{font-size:12px;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);font-weight:700}
.lastvid{border-radius:16px;overflow:hidden;border:1px solid var(--line);cursor:pointer;transition:.22s}
.lastvid:hover{border-color:var(--line-2);transform:translateY(-2px);box-shadow:var(--shadow)}
.lv-thumb{height:158px;position:relative;display:flex;align-items:center;justify-content:center}
.lv-thumb .play{width:56px;height:56px;border-radius:50%;background:rgba(0,0,0,.45);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff;border:2px solid rgba(255,255,255,.8);transition:.2s}
.lastvid:hover .play{transform:scale(1.1)}
.lv-yt{position:absolute;top:11px;left:11px;background:var(--yt);color:#fff;font-size:10px;font-weight:800;padding:3px 8px;border-radius:5px;letter-spacing:.5px}
.lv-info{padding:12px 15px;background:rgba(255,255,255,.03)}
.lv-info .t{font-weight:600;font-size:14px;line-height:1.4}
.lv-info .m{color:var(--muted);font-size:12px;margin-top:4px}
.link-list{display:flex;flex-direction:column;gap:8px}
.link-btn{display:flex;align-items:center;gap:12px;padding:13px 16px;border-radius:13px;background:rgba(255,255,255,.04);border:1px solid var(--line);font-weight:600;font-size:14px;transition:.18s}
.link-btn:hover{border-color:var(--accent);transform:translateX(4px)}
.link-btn .dot{width:9px;height:9px;border-radius:50%}
.link-btn .arr{margin-left:auto;color:var(--muted)}
.contact-btn{width:100%;padding:15px;border-radius:14px;border:none;background:var(--grad);color:#022;font-weight:800;font-size:15px;box-shadow:0 0 24px rgba(0,229,208,.45);position:relative;overflow:hidden}
.contact-btn::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-20deg);transition:left .6s}
.contact-btn:hover::after{left:130%}

/* ============ WIZARD ============ */
.wizard{width:580px;max-width:100%;height:100%;background:rgba(12,14,22,.94);backdrop-filter:blur(20px);border-left:1px solid var(--line-2);overflow-y:auto;padding:28px 32px 44px;position:relative;animation:slide .35s cubic-bezier(.2,.8,.2,1)}
.wizard .x{position:absolute;top:22px;right:24px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--muted);font-size:15px}
.wiz-steps{display:flex;gap:8px;margin:6px 0 28px}
.wiz-steps .dot{height:5px;flex:1;border-radius:5px;background:var(--line-2);transition:.3s}
.wiz-steps .dot.active{background:var(--grad)}
.step{display:none}
.step.active{display:block;animation:stepIn .35s}
@keyframes stepIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
.step h2{font-size:24px;font-weight:800}
.step .sub{color:var(--muted);font-size:14px;line-height:1.55;margin:9px 0 24px}
.f{margin-bottom:16px}
.f label{font-size:13px;font-weight:600;color:var(--muted);margin-bottom:7px;display:flex;align-items:center;gap:8px}
.f input,.f select,.f textarea{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--txt);padding:13px 15px;border-radius:12px;font-size:14px;font-family:inherit;transition:.18s}
.f input:focus,.f select:focus,.f textarea:focus{outline:none;border-color:var(--accent);background:rgba(0,229,208,.05);box-shadow:0 0 0 3px rgba(0,229,208,.15)}
.f textarea{resize:vertical}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.socf.yt input{border-left:3px solid var(--yt)}
.socf.ig input{border-left:3px solid var(--ig)}
.socf.tt input{border-left:3px solid var(--tt)}
.wide{width:100%;margin-top:6px}
.nav2{display:flex;gap:12px;margin-top:14px}
.nav2 .btn-ghost{flex:1}.nav2 .btn-primary{flex:2}
.legal{font-size:11.5px;color:var(--muted-2);text-align:center;margin-top:15px}
.pick-map{height:310px;border-radius:16px;overflow:hidden;border:1px solid var(--line-2)}
/* mapa wyboru punktu żyje w pełnoekranowym modalu — wypełnia jego ciało */
#pickModal{z-index:2100}
#pickModal .map-modal-body{position:relative}
#pickMap{position:absolute;inset:0;background:#0a0c14}
.pick-bar-actions{display:flex;gap:10px;align-items:center}
.coord{margin:13px 0;font-size:13px;color:var(--muted);background:rgba(255,255,255,.04);border:1px solid var(--line);padding:11px 15px;border-radius:11px;text-align:center}
.coord.set{color:var(--ok);border-color:rgba(52,211,153,.3);background:rgba(52,211,153,.06)}

/* ============ CENTERED MODAL (login / contact) ============ */
.overlay.center{align-items:center;justify-content:center;padding:20px}
.modal{position:relative;width:420px;max-width:100%;background:rgba(15,17,25,.96);backdrop-filter:blur(20px);border:1px solid var(--line-2);border-radius:22px;padding:34px 32px 28px;box-shadow:var(--shadow);animation:modalPop .3s cubic-bezier(.2,.8,.2,1)}
@keyframes modalPop{from{transform:scale(.94);opacity:0}to{transform:none;opacity:1}}
.modal .x{position:absolute;top:18px;right:18px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--muted);font-size:15px}
.modal-logo{width:54px;height:54px;margin:0 auto 14px}
.modal-logo img{width:100%;height:100%}
.modal h2{font-size:23px;font-weight:800;text-align:center}
.modal .sub{color:var(--muted);font-size:14px;text-align:center;line-height:1.5;margin:8px 0 24px}
.modal .f{margin-bottom:15px}
.modal-foot{text-align:center;font-size:13px;color:var(--muted);margin-top:18px}
.modal-foot a{color:var(--accent-2);font-weight:600}

/* ============ TOAST ============ */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(90px);z-index:6000;background:rgba(34,38,52,.95);backdrop-filter:blur(12px);border:1px solid var(--line-2);color:var(--txt);padding:15px 24px;border-radius:15px;font-size:14px;font-weight:600;box-shadow:var(--shadow);opacity:0;transition:.35s cubic-bezier(.2,.8,.2,1);display:flex;align-items:center;gap:11px}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast .ic{width:27px;height:27px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:14px}

/* Header actions wrapper (desktop: bez różnicy; mobile: kolapsuje do menu) */
.header-actions{display:flex;align-items:center;gap:10px}
.hamburger{display:none}

@media(max-width:820px){
  .tab .l{display:none}
  .btn-ghost#locBtn{display:none}.drawer,.wizard{width:100%}.demo-pill{display:none}
  .intro-title{font-size:40px}.intro-stats{gap:18px}.stat-bar .sb{padding:8px 13px}

  /* LAYOUT: stack pionowo (sidebar nad mapą) — wcześniej sidebar miał position:absolute
     i przykrywał całą mapę, przez co na mobilce mapy nie było widać. */
  .layout{flex-direction:column;height:auto;min-height:0;margin:0 12px;border-radius:18px;overflow:visible}
  .sidebar{flex:0 0 auto;width:100%;height:auto;max-height:42vh;border-right:none;border-bottom:1px solid var(--line)}
  .map-area{flex:0 0 auto;width:100%;height:62vh;min-height:380px}
  /* Lista twórców skroluje wewnątrz sidebara, żeby mapa pozostała widoczna */
  .sidebar .list{overflow-y:auto;-webkit-overflow-scrolling:touch}
}

/* Hamburger menu — header-actions chowa się na mobile, hamburger toggluje */
@media(max-width:640px){
  .hamburger{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;
    width:44px;height:44px;background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:10px;
    cursor:pointer;padding:0;transition:.2s}
  .hamburger:hover{border-color:var(--accent)}
  .hamburger span{display:block;width:18px;height:2px;background:var(--txt);border-radius:2px;transition:.2s}
  .hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
  .hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

  /* Schowane domyślnie — joinBtn wyjdzie z menu i zostanie obok hamburgera (patrz niżej) */
  .header-actions{display:none;position:absolute;top:calc(100% + 6px);right:12px;
    background:rgba(15,17,25,.98);backdrop-filter:blur(16px);border:1px solid var(--line-2);
    border-radius:14px;padding:10px;flex-direction:column;gap:6px;min-width:220px;
    box-shadow:var(--shadow);z-index:1300}
  .header-actions.open{display:flex}
  .header-actions .btn-ghost,
  .header-actions .btn-primary{width:100%;justify-content:flex-start;text-align:left}
  /* Ujawniamy wewnątrz menu wcześniej chowane przyciski */
  .header-actions #locBtn{display:flex}
  .header-actions #ideasBtn{display:flex}
  .header-actions #loginBtn{font-size:14px;padding:11px 14px}
  .header-actions #loginBtn::before{display:none}
}
@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important}}

/* ============================================================
   LANDING (intro) — hero + CTA z orbitą + stopka
   ============================================================ */
.intro{display:block;align-items:initial;justify-content:initial;overflow-y:auto;padding:0;
  background:radial-gradient(1000px 600px at 50% -5%,rgba(124,58,237,.18),transparent 55%),radial-gradient(900px 600px at 90% 30%,rgba(0,229,208,.10),transparent 55%),rgba(7,8,16,.96);backdrop-filter:none}
.landing{min-height:100%;max-width:1180px;margin:0 auto;padding:0 24px 0;animation:introUp .8s cubic-bezier(.2,.8,.2,1)}
.btn-primary.lg,.btn-ghost.lg{padding:14px 26px;font-size:15px}

.land-top{display:flex;align-items:center;justify-content:space-between;padding:22px 4px}
.land-top .logo{display:flex;align-items:center;gap:11px}
.land-top .logo-img{width:34px;height:34px}
.land-top .logo-txt{font-family:'Chakra Petch';font-size:21px;font-weight:800}
.land-top .logo-txt b{background:var(--grad-c);-webkit-background-clip:text;background-clip:text;color:transparent}

.hero{text-align:center;padding:48px 0 56px}
.hero-badge{display:inline-block;font-size:13px;font-weight:600;color:var(--accent-2);background:rgba(77,245,230,.08);border:1px solid rgba(77,245,230,.28);padding:7px 16px;border-radius:30px;margin-bottom:26px}
.vert-teaser{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 22px}
.vt-pill{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;padding:8px 15px;border-radius:30px;border:1px solid var(--line-2);color:var(--txt);background:rgba(255,255,255,.04)}
.vt-pill.on{background:rgba(0,229,208,.1);border-color:rgba(0,229,208,.35);color:var(--accent-2)}
.hero-title{font-size:60px;line-height:1.05;font-weight:800;letter-spacing:-2px}
.grad-txt{background:var(--grad-c);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-tag{color:var(--muted);font-size:17px;line-height:1.6;margin:22px auto 32px;max-width:620px}
.hero-tag b{color:var(--accent-2)}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:36px}
.hero .intro-stats{justify-content:center}

/* CTA card */
.cta-card{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center;
  background:linear-gradient(135deg,rgba(26,29,40,.9),rgba(16,18,26,.9));border:1px solid var(--line-2);
  border-radius:28px;padding:48px 50px;margin:10px 0 70px;position:relative;overflow:hidden}
.cta-card::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 80% 50%,rgba(124,58,237,.16),transparent 60%);pointer-events:none}
.cta-left{position:relative;z-index:1}
.cta-left h2{font-size:38px;line-height:1.12;font-weight:800;letter-spacing:-1px}
.cta-left p{color:var(--muted);font-size:15.5px;line-height:1.6;margin:18px 0 26px;max-width:440px}
.cta-btns{display:flex;gap:13px;flex-wrap:wrap;margin-bottom:10px}
.hero-discover{display:inline-block;color:var(--muted);font-size:13px;text-decoration:none;border-bottom:1px dashed rgba(255,255,255,.18);padding-bottom:1px;margin-bottom:18px;transition:.2s}
.hero-discover:hover{color:var(--accent);border-bottom-color:var(--accent)}
.btn-outline{background:transparent;border:1px solid var(--line-2);color:var(--txt);padding:11px 20px;border-radius:11px;font-size:14px;font-weight:700;transition:.2s;display:inline-flex;align-items:center;gap:8px}
.btn-outline:hover{border-color:var(--accent);background:rgba(0,229,208,.08)}
.cta-feat{font-size:13px;color:var(--muted-2);font-weight:600}

/* ORBIT */
.cta-right{display:flex;justify-content:center;align-items:center;position:relative;z-index:1}
.orbit{position:relative;width:360px;height:360px}
.oring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.07);top:50%;left:50%;transform:translate(-50%,-50%)}
.oring.r1{width:360px;height:360px}
.oring.r2{width:250px;height:250px;animation:ringPulse 6s ease-in-out infinite}
.oring.r3{width:140px;height:140px;border-color:rgba(255,255,255,.1)}
@keyframes ringPulse{0%,100%{box-shadow:0 0 0 0 rgba(0,229,208,0)}50%{box-shadow:0 0 30px 0 rgba(0,229,208,.12)}}
.orb-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:84px;height:84px;border-radius:50%;
  background:radial-gradient(circle,rgba(30,34,46,.95),rgba(12,14,22,.95));border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;box-shadow:0 0 40px rgba(255,45,149,.3)}
.orb-center img{width:48px;height:48px}
.orb{position:absolute;width:58px;height:58px;border-radius:16px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(0,0,0,.45);animation:orbFloat 5s ease-in-out infinite}
.orb svg{width:30px;height:30px}
.orb.yt{background:#ff0033;box-shadow:0 8px 26px rgba(255,0,51,.5);animation-delay:0s}
.orb.ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);box-shadow:0 8px 26px rgba(220,39,67,.5);animation-delay:.6s}
.orb.tt{background:#0b0b0f;box-shadow:0 8px 26px rgba(37,244,238,.4);animation-delay:1.1s}
.orb.fb{background:#1877f2;box-shadow:0 8px 26px rgba(24,119,242,.5);animation-delay:1.6s}
.orb.xt{background:#0b0b0f;box-shadow:0 8px 26px rgba(255,255,255,.18);animation-delay:2.1s}
.orb.li{background:#0a66c2;box-shadow:0 8px 26px rgba(10,102,194,.5);animation-delay:2.6s}
@keyframes orbFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* FOOTER */
.land-foot{position:relative;border-top:1px solid var(--line);padding:54px 0 0;margin-top:10px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:36px;position:relative;z-index:2}
.foot-brand .logo{display:flex;align-items:center;gap:11px;margin-bottom:14px}
.foot-brand .logo-img{width:32px;height:32px}
.foot-brand .logo-txt{font-family:'Chakra Petch';font-size:19px;font-weight:800}
.foot-brand .logo-txt b{background:var(--grad-c);-webkit-background-clip:text;background-clip:text;color:transparent}
.foot-brand p{color:var(--muted);font-size:13.5px;line-height:1.6;max-width:300px}
.foot-col h4{font-size:14px;font-weight:700;margin-bottom:14px;font-family:'Chakra Petch'}
.foot-col a{display:block;color:var(--muted);font-size:14px;margin-bottom:10px;transition:.15s;text-decoration:none}
.foot-col a:hover{color:var(--accent-2)}
.subscribe{display:flex;background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:30px;padding:5px;margin-bottom:18px}
.subscribe input{flex:1;background:transparent;border:none;color:var(--txt);padding:8px 14px;font-size:13.5px;outline:none}
.subscribe button{background:#fff;color:#0b0c14;border:none;padding:8px 18px;border-radius:24px;font-weight:700;font-size:13.5px;cursor:pointer;transition:.2s}
.subscribe button:hover{background:var(--accent-2)}
.foot-socials{display:flex;gap:10px}
.foot-socials a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.05);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:.2s}
.foot-socials a svg{width:18px;height:18px}
.foot-socials a:hover{color:#fff;border-color:var(--line-2);transform:translateY(-2px)}
.watermark{font-family:'Chakra Petch';font-weight:800;font-size:clamp(70px,15vw,180px);line-height:.8;text-align:center;letter-spacing:-4px;
  background:linear-gradient(180deg,rgba(255,255,255,.05),transparent);-webkit-background-clip:text;background-clip:text;color:transparent;
  margin:30px 0 -10px;pointer-events:none;user-select:none;overflow:hidden}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
  border-top:1px solid var(--line);padding:22px 0 30px;font-size:13px;color:var(--muted)}
.foot-bottom a{color:var(--muted);text-decoration:none}
.foot-bottom a:hover{color:var(--accent-2)}

@media(max-width:900px){
  .cta-card{grid-template-columns:1fr;padding:36px 28px}
  .cta-right{margin-top:10px}.orbit{transform:scale(.82)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:28px}
  .hero-title{font-size:42px}.cta-left h2{font-size:30px}
}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr}.hero-title{font-size:34px}}

/* ===== górny baner CTA (klimatyczny nagłówek) ===== */
.top-cta{max-width:1320px;margin:0 auto;padding:30px 24px 16px;position:relative;z-index:1}
.top-cta .cta-card{margin:0}
.cta-left .intro-stats{justify-content:flex-start;gap:26px;margin:16px 0 0}
.land-foot{max-width:1320px;margin:46px auto 0;padding:54px 24px 0;position:relative;z-index:1}
.app-pad{height:18px}

/* ===== POD MAPĄ: karuzela + najnowsi ===== */
.below-map{max-width:1320px;margin:30px auto 0;padding:0 24px;position:relative;z-index:1;display:flex;flex-direction:column;gap:34px}
.bm-block{}
.bm-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.bm-head h3{font-family:'Chakra Petch',sans-serif;font-size:20px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.bm-actions{display:flex;gap:8px}
.car-nav{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--txt);font-size:20px;line-height:1;transition:.18s}
.car-nav:hover{border-color:var(--accent);color:var(--accent)}
.carousel{display:flex;gap:16px;overflow-x:auto;scroll-behavior:smooth;padding-bottom:8px;scrollbar-width:none;-ms-overflow-style:none}
.carousel::-webkit-scrollbar{display:none}
.vid-card{flex:0 0 280px;background:var(--panel);border:1px solid var(--line);border-radius:16px;overflow:hidden;cursor:pointer;transition:.2s}
.vid-card:hover{border-color:var(--line-2);transform:translateY(-3px);box-shadow:var(--shadow)}
.vid-thumb{height:158px;position:relative;display:flex;align-items:center;justify-content:center}
.vid-thumb .play{width:50px;height:50px;border-radius:50%;background:rgba(0,0,0,.45);border:2px solid rgba(255,255,255,.8);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;backdrop-filter:blur(3px)}
.vid-thumb .yt{position:absolute;top:10px;left:10px;background:var(--yt);color:#fff;font-size:10px;font-weight:800;padding:3px 7px;border-radius:5px;letter-spacing:.5px}
.vid-meta{padding:12px 14px}
.vid-meta .t{font-weight:600;font-size:13.5px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.vid-meta .c{display:flex;align-items:center;gap:7px;margin-top:9px;font-size:12px;color:var(--muted)}
.vid-meta .c .mini{width:22px;height:22px;border-radius:7px;font-size:9px;font-weight:800;color:#fff;display:flex;align-items:center;justify-content:center}
.newest-row{display:flex;gap:13px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none;-ms-overflow-style:none}
.newest-row::-webkit-scrollbar{display:none}
.new-card{flex:0 0 200px;display:flex;align-items:center;gap:11px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:12px;cursor:pointer;transition:.2s;position:relative}
.new-card:hover{border-color:var(--line-2);transform:translateY(-2px)}
.new-card .av{width:44px;height:44px;border-radius:13px;font-size:15px}
.new-card .nn{font-family:'Chakra Petch',sans-serif;font-weight:600;font-size:14px}
.new-card .nc{font-size:11.5px;color:var(--muted);margin-top:2px}
.new-badge{position:absolute;top:8px;right:8px;font-size:9px;font-weight:800;color:var(--ok);background:rgba(57,255,20,.12);border:1px solid rgba(57,255,20,.3);padding:1px 6px;border-radius:5px;letter-spacing:.4px}

/* ===== wide modal / ideas / inbox ===== */
.wide-modal{max-width:600px;max-height:88vh;display:flex;flex-direction:column}
.idea-form{display:flex;flex-direction:column;gap:9px;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:16px}
.idea-form input,.idea-form textarea{background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--txt);padding:10px 13px;border-radius:10px;font-size:14px;font-family:inherit}
.idea-form input:focus,.idea-form textarea:focus{outline:none;border-color:var(--accent)}
.idea-form .btn-primary{align-self:flex-start}
.ideas-list{overflow-y:auto;display:flex;flex-direction:column;gap:11px;padding-right:4px}
.idea{display:flex;gap:14px;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:14px;padding:14px}
.idea-vote{display:flex;flex-direction:column;align-items:center;gap:3px;min-width:54px}
.idea-vote button{width:42px;height:38px;border-radius:10px;background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--txt);font-size:15px;transition:.18s}
.idea-vote button:hover{border-color:var(--accent);color:var(--accent)}
.idea-vote button.voted{background:var(--grad);color:#022;border-color:transparent;box-shadow:0 0 14px rgba(0,229,208,.4)}
.idea-vote b{font-family:'Orbitron',sans-serif;font-size:16px}
.idea-vote small{font-size:10px;color:var(--muted)}
.idea-body .it{font-family:'Chakra Petch',sans-serif;font-weight:600;font-size:15px}
.idea-body .id{font-size:13px;color:#b9c0cf;margin-top:4px;line-height:1.45}
.idea-body .ia{font-size:11px;color:var(--muted-2);margin-top:7px}
.inbox-list{overflow-y:auto;display:flex;flex-direction:column;gap:11px;padding-right:4px;min-height:120px}
.msg{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:14px;padding:14px}
.msg.spam{opacity:.5}
.msg-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:7px}
.msg-from{font-weight:700;font-size:14px}
.msg-from .tag{font-size:10px;font-weight:700;padding:1px 7px;border-radius:5px;margin-left:7px;background:rgba(34,211,238,.14);color:#7fe7f5}
.msg-from .tag.cr{background:rgba(0,229,208,.14);color:var(--accent)}
.msg-date{font-size:11px;color:var(--muted-2)}
.msg-subj{font-size:13.5px;font-weight:600;color:var(--accent-2)}
.msg-body{font-size:13.5px;color:#c4cbd8;line-height:1.5;margin:5px 0 10px}
.msg-actions{display:flex;gap:8px}
.btn-mini{font-size:12px;padding:6px 12px;border-radius:8px;background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--muted);font-weight:600;transition:.15s}
.btn-mini:hover{border-color:#ff4d6d;color:#ff6b85}
.empty-state{text-align:center;color:var(--muted);font-size:14px;padding:30px 10px}
.inbox-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--accent);color:#022;font-size:11px;font-weight:800;margin-left:6px}

@media(max-width:680px){.vid-card{flex-basis:230px}.below-map{padding:0 16px}}

/* ===== akcenty neon / cyberpunk ===== */
body::after{content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,0) 0,rgba(0,0,0,0) 2px,rgba(255,255,255,.018) 3px,rgba(0,0,0,0) 4px);
  mix-blend-mode:overlay;opacity:.6}
/* futurystyczny font dla logo / znaku wodnego / liczb (Orbitron) */
.logo-txt,.watermark{font-family:'Orbitron',sans-serif;letter-spacing:0}
.stat-bar .sb b,.intro-stats .is b,.stat b{font-family:'Orbitron',sans-serif}
.hero-title,.cta-left h2{font-family:'Chakra Petch',sans-serif;letter-spacing:.5px;text-transform:uppercase}
.grad-txt,.logo-txt b{filter:drop-shadow(0 0 14px rgba(0,229,208,.35))}
.hero-title,.cta-left h2{text-shadow:0 0 32px rgba(0,229,208,.16)}
.stat-bar .sb b,.intro-stats .is b{filter:drop-shadow(0 0 10px rgba(0,229,208,.4))}
.av{box-shadow:0 0 0 1px rgba(0,229,208,.22),0 6px 18px rgba(0,0,0,.55)}
.tab.active{box-shadow:0 0 16px rgba(0,229,208,.16),inset 0 0 0 1px rgba(0,229,208,.22)}
.vrf{color:var(--accent-2)}
.search-wrap::before{opacity:.7}
/* mapa: ciut więcej kontrastu pod neon */
.leaflet-tile{filter:brightness(.92) contrast(1.08) saturate(1.1)}

/* ===== panel właściciela profilu ===== */
.owner-panel{background:rgba(77,245,230,.07);border:1px solid rgba(77,245,230,.28);border-radius:16px;padding:16px}
.owner-tag{font-size:13px;font-weight:700;color:var(--accent-2);margin-bottom:13px}
.owner-btns{display:flex;flex-direction:column;gap:10px}
.owner-btns .btn-outline.wide{width:100%;justify-content:center;padding:13px}

/* ===== baner cookies ===== */
.cookie-bar{position:fixed;left:50%;bottom:22px;transform:translateX(-50%) translateY(20px);z-index:5500;
  display:flex;align-items:center;gap:16px;max-width:760px;width:calc(100% - 36px);
  background:rgba(18,21,30,.92);backdrop-filter:blur(18px) saturate(140%);border:1px solid var(--line-2);
  border-radius:18px;padding:16px 20px;box-shadow:var(--shadow);opacity:0;transition:.4s cubic-bezier(.2,.8,.2,1)}
.cookie-bar.show{opacity:1;transform:translateX(-50%) translateY(0)}
.cookie-ic{font-size:26px;flex-shrink:0}
.cookie-txt{font-size:13px;line-height:1.5;color:var(--muted)}
.cookie-txt b{color:var(--txt)}
.cookie-txt a{color:var(--accent-2)}
.cookie-btns{display:flex;gap:10px;flex-shrink:0}
.cookie-btns .btn-ghost{padding:9px 14px;white-space:nowrap}
.cookie-btns .btn-primary{padding:10px 18px;white-space:nowrap}
@media(max-width:680px){.cookie-bar{flex-direction:column;align-items:flex-start;bottom:12px}.cookie-btns{width:100%}.cookie-btns button{flex:1}}

/* ============================================================
   MOBILE — kompleksowe optymalizacje (tablety + telefony)
   ============================================================ */

/* iOS: bez zoom-na-fokusie wymaga font-size ≥ 16px na inputach */
@media (max-width:820px){
  .f input,.f select,.f textarea,#search,.subscribe input{font-size:16px}
}

/* Touch targets — WCAG/iOS minimum 44×44 */
@media (max-width:820px){
  .tab,.btn-ghost,.btn-primary,.btn-outline,
  .chip,.cookie-btns button,.car-nav,
  .foot-socials a,.subscribe button{min-height:44px}
}

/* Telefony — header kompakt, ukrycie mniej krytycznych akcji */
@media (max-width:640px){
  header{padding:0 12px;gap:8px}
  .tabs{gap:2px}
  .tab{padding:9px 10px;min-width:44px;justify-content:center}
  /* "Pomysły" to delight, nie rdzeń (PRODUCT.md): chowamy na małych ekranach */
  #ideasBtn{display:none}
  /* "Zaloguj" kompaktowo — sama ikona */
  #loginBtn{font-size:0;padding:11px 12px}
  #loginBtn::before{content:"🔑";font-size:16px}
  /* joinBtn duplikuje wielki cyan CTA z hero — chowamy go z mobile, mniej tłoku w headerze */
  #joinBtn{display:none}
  .hamburger{flex-shrink:0;margin-left:auto}
  /* logo trochę mniejsze, żeby zostało miejsce na taby i hamburgera */
  .land-top .logo-img,header .logo-img{width:28px;height:28px}
  header .logo-txt,.land-top .logo-txt{font-size:18px}
  /* gdy user zalogowany — meChip ma być widoczny zamiast joinBtn */
  .me{margin-left:auto}
  .me + .hamburger{margin-left:0}
  .ctx-banner{font-size:12.5px;padding:9px 12px}
  .top-cta{padding:18px 12px 8px}
  .land-foot{padding:34px 12px 0;margin-top:24px}
  .landing{padding:0 12px}
  .land-top{padding:14px 4px}
  .land-top .logo-txt{font-size:18px}
  /* Modal padding kompaktowo */
  .modal{padding:26px 22px 22px}
  .drawer,.wizard{padding:18px 18px 28px}
  /* Karuzela: węższe karty, więcej oddechu */
  .vid-card{flex-basis:220px}
  .new-card{flex:0 0 180px}
  .below-map{padding:0 12px}
}

/* Bardzo wąskie ekrany (≤520px) — chowamy dekorację orbit, kompresujemy hero */
@media (max-width:520px){
  .cta-right{display:none}
  .cta-card{grid-template-columns:1fr;padding:26px 18px;border-radius:22px;margin-bottom:40px}
  .cta-left h2{font-size:24px;line-height:1.15}
  .cta-left p{font-size:14px;margin:14px 0 20px}
  /* Statystyki na 3 sąsiadujące kolumny pełnej szerokości */
  .intro-stats{gap:10px;justify-content:space-between;width:100%}
  .cta-left .intro-stats{gap:10px;justify-content:space-between;margin:14px 0 0}
  .intro-stats .is{flex:1;min-width:0;text-align:center}
  .intro-stats .is b{font-size:22px}
  .intro-stats .is small{font-size:11px;letter-spacing:.2px}
  .hero-discover{font-size:12px}
  /* Większy primary CTA = łatwiej trafić kciukiem */
  .btn-primary.lg,.btn-ghost.lg,.btn-outline.lg{width:100%;justify-content:center}
  .cta-btns{flex-direction:column;gap:10px}
  /* Watermark stopki — mniej dramatyczny na małych */
  .watermark{font-size:clamp(50px,18vw,90px);margin:18px 0 -4px}
}

/* Lock scrolla body kiedy modal/drawer otwarty (CSS :has — Chrome 105+/Safari 15.4+/Firefox 121+) */
@supports selector(:has(*)){
  body:has(.overlay.show){overflow:hidden}
}

/* ============================================================
   FIX: mapa rozjeżdżała się na mobile (Leaflet zachowywał
   inline width/height z init time, nie z aktualnego kontenera)
   ============================================================ */
html{overflow-x:hidden}                /* twardy guard, gdyby cokolwiek przeciekło */
body{max-width:100vw}
.map-area{overflow:hidden}             /* Leaflet nie wyjdzie poza kontener */
/* Lekka korekta — bez !important na położeniu (psuło renderowanie tile'ów Leafleta) */
.leaflet-container{width:100%;height:100%}
