*{margin:0;padding:0;box-sizing:border-box}
:root{--sb:env(safe-area-inset-bottom,34px);--st:env(safe-area-inset-top,50px)}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;overflow:hidden;height:100dvh}
#map{width:100%;height:100dvh;z-index:1;background:#eae6dc}
#ov{position:fixed;top:0;left:0;width:100%;height:100%;z-index:399;pointer-events:none}
.leaflet-top.leaflet-left{top:calc(50px + var(--st))}
.leaflet-control-zoom a{width:34px!important;height:34px!important;line-height:34px!important;font-size:17px!important}
#hdr{position:fixed;top:0;left:0;right:0;z-index:1000;padding:calc(6px + var(--st)) 10px 6px;display:flex;align-items:center;justify-content:space-between;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.06)}
.logo{display:flex;align-items:center;gap:6px}
.li{width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:18px;line-height:1}
.lt{font-size:16px;font-weight:700;color:#1a1a2e;letter-spacing:-.3px}
.hright{display:flex;align-items:center;gap:8px}
.stats{display:flex;gap:8px;font-size:11px;font-weight:600;color:#666}
.st{display:flex;align-items:center;gap:3px}
.dd{width:6px;height:6px;border-radius:50%}.dd-s{background:#16a34a}.dd-h{background:#7c3aed}
.lbtn{background:none;border:1px solid #ddd;border-radius:6px;padding:3px 6px;font-size:10px;font-weight:600;color:#666;cursor:pointer;-webkit-tap-highlight-color:transparent}
.lbtn:hover,.lbtn.active{border-color:#F59E0B;color:#F59E0B}
.mbtn{position:fixed;z-index:1000;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.95);border:1px solid rgba(0,0,0,.08);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.1);-webkit-tap-highlight-color:transparent}
.mbtn:active{transform:scale(.92)}
#locbtn{right:12px;font-size:18px;position:absolute;bottom:calc(100% + 60px)}
#listbtn{right:12px;font-size:17px;position:absolute;bottom:calc(100% + 12px)}
#sunlist{position:fixed;bottom:0;left:0;right:0;z-index:1100;max-height:70dvh;background:rgba(255,255,255,.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid rgba(0,0,0,.08);border-radius:16px 16px 0 0;box-shadow:0 -4px 24px rgba(0,0,0,.12);transform:translateY(100%);transition:transform .3s ease;overflow:hidden;display:flex;flex-direction:column}
#sunlist.open{transform:translateY(0)}
.sl-hdr{padding:14px 16px 10px;border-bottom:1px solid rgba(0,0,0,.06);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.sl-title{font-size:15px;font-weight:700;color:#1a1a2e}
.sl-close{background:none;border:none;font-size:20px;color:#999;cursor:pointer;padding:4px 8px}
.sl-body{overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;padding:0 0 calc(8px + var(--sb))}
.sl-empty{padding:24px 16px;text-align:center;color:#999;font-size:13px}
@keyframes spin{to{transform:rotate(360deg)}}
.sl-item{padding:12px 16px;border-bottom:1px solid rgba(0,0,0,.04);display:flex;align-items:center;gap:12px;cursor:pointer}
.sl-item:active{background:rgba(0,0,0,.03)}
.sl-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.sl-icon.sun-now{background:rgba(22,163,74,.1)}.sl-icon.sun-soon{background:rgba(245,158,11,.1)}.sl-icon.shade{background:rgba(124,58,237,.08)}
.sl-info{flex:1;min-width:0}
.sl-name{font-size:13px;font-weight:600;color:#1a1a2e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sl-type{font-size:10px;color:#999;text-transform:uppercase;letter-spacing:.3px}
.sl-dist{font-size:11px;color:#999;flex-shrink:0;text-align:right}
.sl-badge{display:inline-block;font-size:9px;font-weight:600;padding:2px 6px;border-radius:4px;margin-top:2px}
.sl-badge.now{background:rgba(22,163,74,.12);color:#16a34a}.sl-badge.soon{background:rgba(245,158,11,.12);color:#b45309}.sl-badge.no{background:rgba(124,58,237,.08);color:#7c3aed}
#ctl{position:fixed;bottom:0;left:0;right:0;z-index:1000;padding:6px 12px calc(8px + var(--sb));background:#fffce7;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(0,0,0,.06)}
.td{text-align:center;margin-bottom:2px}
.dr{display:flex;align-items:center;justify-content:center;gap:6px}
.dl{font-size:10px;color:#999;min-height:13px}
.tb{font-size:36px;font-weight:700;letter-spacing:-1.5px;line-height:1;color:#1a1a2e;font-variant-numeric:tabular-nums}
.sa{font-size:9px;color:#aaa;margin-top:0}
input[type=range]{-webkit-appearance:none;width:100%;height:32px;background:transparent;outline:none;margin:0;touch-action:none}
input[type=range]::-webkit-slider-runnable-track{height:4px;border-radius:2px;background:#e0e0e0}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:28px;height:28px;border-radius:50%;background:#F59E0B;cursor:pointer;border:2.5px solid #fff;box-shadow:0 1px 6px rgba(0,0,0,.2);margin-top:-12px}
input[type=range]::-moz-range-track{height:4px;border-radius:2px;background:#e0e0e0}
input[type=range]::-moz-range-thumb{width:28px;height:28px;border-radius:50%;background:#F59E0B;cursor:pointer;border:2.5px solid #fff}
.sl2{display:flex;justify-content:space-between;font-size:8px;color:#ccc;min-height:11px}
.cr{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:4px}
.bn{padding:7px 12px;border-radius:16px;border:1px solid #ddd;background:#fff;color:#333;font-size:11px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.bp{background:#F59E0B;color:#fff;border-color:#F59E0B}
#vpop{position:fixed;z-index:1000;background:#fff;border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.18);padding:12px 14px;max-width:280px;min-width:180px;display:none;pointer-events:auto}
#vpop .vp-close{position:absolute;top:6px;right:10px;background:none;border:none;font-size:18px;color:#999;cursor:pointer;padding:2px 6px}
.pn{font-weight:700;font-size:14px;color:#1a1a2e;padding-right:20px}.pt{font-size:9px;color:#999;text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}.ps{font-weight:600;margin-bottom:2px}.pf{font-size:10px;color:#999}.pa{font-size:11px;color:#666;margin-top:3px}.ph{font-size:10px;color:#888;margin-top:3px;line-height:1.4}.pr{font-size:11px;color:#f59e0b;margin-top:2px}
.loc-person{width:28px;height:28px;filter:drop-shadow(0 1px 3px rgba(0,0,0,.3))}
#search-wrap{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1200;background:rgba(0,0,0,.3);display:none}
#search-wrap.open{display:flex;flex-direction:column}
#search-box{background:#fff;padding:calc(6px + var(--st)) 12px 0;box-shadow:0 4px 24px rgba(0,0,0,.12)}
#search-hdr{display:flex;align-items:center;gap:8px;padding-bottom:10px}
#search-input{flex:1;padding:9px 12px;border:1px solid #ddd;border-radius:10px;font-size:16px;outline:none;background:#f8f8f8;font-family:inherit}
#search-input:focus{border-color:#F59E0B;background:#fff}
#search-close{background:none;border:none;font-size:20px;color:#999;cursor:pointer;padding:4px 8px}
#search-results{background:#fff;overflow-y:auto;-webkit-overflow-scrolling:touch;max-height:50dvh}
.sr-item{padding:10px 12px;border-bottom:1px solid rgba(0,0,0,.04);cursor:pointer}
.sr-item:active{background:rgba(0,0,0,.03)}
.sr-name{font-size:14px;font-weight:600;color:#1a1a2e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-addr{font-size:11px;color:#999;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.sr-tag{font-size:9px;color:#aaa;text-transform:uppercase;letter-spacing:.3px}
