/* ── TOKENS ── */
:root {
  --g0:#0a1a10; --g1:#112218; --g2:#1a3828; --g3:#24573a;
  --leaf:#3daa70; --mint:#7dcca0; --mist:#b8e8cc;
  --sky:#1a8fa0;  --skylt:#4dc4d8;
  --fog:#edf8f2;
  --panel:rgba(11,26,16,0.95);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden;font-family:'DM Sans',system-ui,sans-serif;background:var(--g0);color:var(--fog)}

/* ── HEADER ── */
header{
  height:44px;display:flex;align-items:center;gap:8px;padding:0 12px;
  background:var(--g1);border-bottom:1px solid rgba(61,170,112,.2);
  position:relative;z-index:1000;flex-shrink:0;
}
.logo-orb{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--leaf),var(--sky));display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.logo-txt{font-family:'DM Serif Display',Georgia,serif;font-size:.95rem;color:var(--mint);white-space:nowrap}
.logo-txt em{color:var(--skylt);font-style:italic}
.h-sp{flex:1}
.h-tag{font-size:.6rem;color:var(--leaf);opacity:.6;letter-spacing:.05em}
.home-link{
  color:var(--mist);
  text-decoration:none;
  font-size:.58rem;
  text-transform:uppercase;
  letter-spacing:.16em;
  padding:5px 8px;
  border:1px solid rgba(125,204,160,.28);
  border-radius:999px;
  transition:border-color .15s,color .15s,background .15s;
}
.home-link:hover{
  color:var(--fog);
  border-color:var(--mint);
  background:rgba(61,170,112,.12);
}
@media(max-width:480px){.h-tag{display:none}}
.pdot{width:7px;height:7px;border-radius:50%;background:var(--leaf);box-shadow:0 0 6px var(--leaf);animation:blink 2s infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

/* ── APP BODY ── */
.app{display:flex;height:calc(100vh - 44px);position:relative;overflow:hidden}

/* ── MAP ── */
#map{flex:1;min-width:0;min-height:0;z-index:1}

/* ── PANEL: sidebar on desktop, bottom drawer on mobile ── */
#panel{
  width:256px;flex-shrink:0;order:-1;
  background:var(--panel);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-right:1px solid rgba(61,170,112,.15);
  display:flex;flex-direction:column;
  overflow-y:auto;overflow-x:hidden;
  z-index:900;
  scrollbar-width:thin;scrollbar-color:var(--g3) transparent;
}
@media(max-width:639px){
  #panel{
    position:absolute;left:0;right:0;bottom:0;
    width:100%;order:0;
    max-height:60vh;
    border-right:none;border-top:1px solid rgba(61,170,112,.22);
    border-radius:14px 14px 0 0;
    box-shadow:0 -6px 28px rgba(0,0,0,.45);
  }
}

@media(max-width:639px){
  #legend{bottom:auto;top:8px;right:8px}
}

/* drag handle — mobile only */
.dragh{justify-content:center;padding:8px 0 3px;cursor:grab;flex-shrink:0;display:none}
@media(max-width:639px){.dragh{display:flex}}
.draghb{width:34px;height:4px;border-radius:2px;background:rgba(61,170,112,.3)}

/* ── SECTION ── */
.sec{padding:9px 11px;border-bottom:1px solid rgba(61,170,112,.07)}
.sec:last-child{border-bottom:none}
.stl{
  font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--leaf);margin-bottom:6px;
  display:flex;align-items:center;gap:4px;
}
.stl::before{content:'';width:2px;height:9px;background:var(--leaf);border-radius:1px;display:inline-block;flex-shrink:0}

/* ── SEARCH ── */
.swrap{position:relative}
#addr{
  width:100%;background:rgba(255,255,255,.05);
  border:1.5px solid rgba(61,170,112,.22);border-radius:8px;
  padding:7px 34px 7px 9px;color:var(--fog);
  font-family:inherit;font-size:.8rem;outline:none;
  transition:border-color .2s,background .2s;
  -webkit-appearance:none;
}
#addr::placeholder{color:rgba(125,204,160,.35)}
#addr:focus{border-color:var(--leaf);background:rgba(255,255,255,.07)}
#sbtn{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  background:none;border:none;cursor:pointer;color:var(--leaf);font-size:15px;padding:3px;
}
#sugs{
  position:absolute;top:calc(100% + 3px);left:0;right:0;
  background:#0d2016;border:1px solid rgba(61,170,112,.2);border-radius:8px;
  overflow:hidden;z-index:9999;display:none;
  box-shadow:0 8px 24px rgba(0,0,0,.6);max-height:160px;overflow-y:auto;
}
.sitem{padding:7px 10px;font-size:.76rem;cursor:pointer;color:var(--fog);border-bottom:1px solid rgba(61,170,112,.05);transition:background .1s}
.sitem:last-child{border-bottom:none}
.sitem:hover,.sitem:active{background:rgba(61,170,112,.12)}

/* ── MAP STYLE TOGGLE ── */
.lyrs{display:flex;gap:4px}
.lbtn{
  flex:1;padding:5px 2px;background:rgba(255,255,255,.04);
  border:1.5px solid rgba(61,170,112,.16);border-radius:7px;cursor:pointer;
  font-size:.65rem;font-weight:500;color:rgba(125,204,160,.6);text-align:center;transition:all .15s;
}
.lbtn:hover{background:rgba(61,170,112,.1);border-color:var(--leaf)}
.lbtn.on{background:rgba(61,170,112,.2);border-color:var(--leaf);color:var(--mint)}

/* ── TRANSPORT ── */
.tgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px}
.tbtn{
  background:rgba(255,255,255,.04);border:1.5px solid rgba(61,170,112,.15);
  border-radius:7px;padding:5px 2px 4px;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:2px;transition:all .15s;
}
.tbtn .ti{font-size:14px;line-height:1}
.tbtn .tl{font-size:.52rem;font-weight:500;color:rgba(125,204,160,.55)}
.tbtn:hover,.tbtn:active{background:rgba(61,170,112,.1);border-color:var(--leaf)}
.tbtn.on{background:rgba(61,170,112,.2);border-color:var(--leaf)}
.tbtn.on .tl{color:var(--mint)}

/* ── TIME ── */
.tmgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
.tmbtn{
  background:rgba(255,255,255,.04);border:1.5px solid rgba(61,170,112,.15);
  border-radius:7px;padding:5px 2px;cursor:pointer;
  font-size:.7rem;font-weight:500;color:var(--mint);text-align:center;transition:all .15s;
}
.tmbtn:hover,.tmbtn:active{background:rgba(61,170,112,.1);border-color:var(--leaf)}
.tmbtn.on{background:rgba(26,143,160,.2);border-color:var(--sky);color:var(--skylt)}

/* ── ANALYZE BTN ── */
#abtn{
  width:100%;padding:9px;
  background:linear-gradient(135deg,var(--g3),var(--sky));
  border:none;border-radius:8px;color:#fff;
  font-family:inherit;font-size:.82rem;font-weight:600;
  cursor:pointer;transition:opacity .2s,transform .15s;
  box-shadow:0 3px 14px rgba(26,143,160,.28);
  -webkit-appearance:none;
}
#abtn:hover{opacity:.88;transform:translateY(-1px)}
#abtn:active{transform:none;opacity:.95}
#abtn:disabled{opacity:.35;cursor:not-allowed;transform:none}

/* ── GO ROW ── */
.go-row{display:flex;gap:5px;margin-top:2px}
.go-row #abtn{flex:1}
#clearbtn{
  padding:9px 12px;
  background:rgba(255,255,255,.04);
  border:1.5px solid rgba(61,170,112,.16);
  border-radius:8px;color:rgba(125,204,160,.5);
  font-size:.85rem;line-height:1;
  cursor:pointer;transition:all .15s;flex-shrink:0;
  -webkit-appearance:none;
}
#clearbtn:hover{background:rgba(230,57,70,.12);border-color:rgba(230,57,70,.3);color:#e07070}
#clearbtn:active{transform:scale(.94)}
#clearbtn:disabled{opacity:.2;cursor:not-allowed}

/* ── AMENITIES ── */
.amgrid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.amtog{
  display:flex;align-items:center;gap:5px;
  background:rgba(255,255,255,.03);border:1.5px solid rgba(61,170,112,.1);
  border-radius:7px;padding:5px 7px;cursor:pointer;transition:all .15s;user-select:none;
  -webkit-tap-highlight-color:transparent;
}
.amtog:hover,.amtog:active{background:rgba(61,170,112,.07);border-color:rgba(61,170,112,.22)}
.amtog.on{border-color:rgba(61,170,112,.4);background:rgba(61,170,112,.1)}
.amtog .ai{font-size:12px;flex-shrink:0;line-height:1}
.amtog .an{font-size:.63rem;font-weight:500;color:rgba(125,204,160,.75);line-height:1.2}
.amtog.on .an{color:var(--mint)}

#loadbtn{
  width:100%;margin-top:6px;padding:7px;
  background:rgba(61,170,112,.08);border:1.5px solid rgba(61,170,112,.25);
  border-radius:7px;color:var(--mint);
  font-family:inherit;font-size:.75rem;font-weight:500;
  cursor:pointer;transition:all .15s;-webkit-appearance:none;
}
#loadbtn:hover{background:rgba(61,170,112,.16)}
#loadbtn:disabled{opacity:.3;cursor:not-allowed}

/* ── RESULTS ── */
#rsec{display:none}
.rrow{display:flex;justify-content:space-between;align-items:center;padding:3px 0;font-size:.7rem;border-bottom:1px solid rgba(61,170,112,.05)}
.rrow:last-child{border-bottom:none}
.rlbl{color:rgba(125,204,160,.6);display:flex;align-items:center;gap:3px}
.rct{font-weight:600;color:var(--mint);background:rgba(61,170,112,.12);padding:1px 7px;border-radius:20px;font-size:.67rem}

/* ── STATUS ── */
#sts{
  padding:6px 11px;font-size:.69rem;color:var(--skylt);
  background:rgba(26,143,160,.05);border-top:1px solid rgba(26,143,160,.1);
  min-height:30px;display:flex;align-items:center;gap:5px;flex-shrink:0;
}
.spin{width:11px;height:11px;border:2px solid rgba(26,143,160,.25);border-top-color:var(--sky);border-radius:50%;animation:spin .7s linear infinite;display:none;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── LEGEND ── */
#legend{
  position:absolute;bottom:24px;right:10px;z-index:700;
  background:rgba(8,18,12,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(61,170,112,.18);border-radius:9px;
  padding:8px 11px;min-width:118px;display:none;
  pointer-events:none;
}
.ltl{font-size:.57rem;letter-spacing:.1em;text-transform:uppercase;color:var(--leaf);margin-bottom:5px;font-weight:600}
.li{display:flex;align-items:center;gap:5px;font-size:.66rem;color:rgba(125,204,160,.82);margin-bottom:2px}
.lsw{width:11px;height:11px;border-radius:3px;flex-shrink:0}

/* ── LEAFLET OVERRIDES ── */
.leaflet-popup-content-wrapper{
  background:#0a1c10!important;border:1px solid rgba(61,170,112,.3)!important;
  border-radius:9px!important;color:var(--fog)!important;
  box-shadow:0 5px 20px rgba(0,0,0,.6)!important;
}
.leaflet-popup-tip{background:#0a1c10!important}
.leaflet-popup-content{margin:8px 11px!important;font-family:inherit!important}
.pname{font-weight:600;font-size:.82rem;color:var(--mint);margin-bottom:2px}
.ptype{font-size:.68rem;color:rgba(125,204,160,.55)}
.paddr{font-size:.65rem;color:rgba(125,204,160,.4);margin-top:2px}
.leaflet-control-zoom a{background:#0d1e13!important;color:var(--mint)!important;border-color:rgba(61,170,112,.25)!important;font-size:16px!important;line-height:26px!important}
.leaflet-control-zoom a:hover{background:var(--g3)!important}
.leaflet-bar{border:1px solid rgba(61,170,112,.25)!important;box-shadow:none!important}
.leaflet-control-attribution{background:rgba(0,0,0,.5)!important;color:rgba(255,255,255,.4)!important;font-size:9px!important}
.leaflet-control-attribution a{color:rgba(61,170,112,.7)!important}
