*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,system-ui,sans-serif;height:100vh;overflow:hidden;background:#f0f2f5}#app{display:flex;flex-direction:column;height:100vh}@font-face{font-family:BricolageGrotesqueMedium;src:url(/fonts/BricolageGrotesque-Medium.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}#header{background:#fff;padding:10px 20px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px #0000001a;z-index:1000;flex-shrink:0}#header h1{font-size:1.3rem;font-weight:700;color:#1a1a2e;letter-spacing:-.5px;font-family:BricolageGrotesqueMedium}#header h1 .meri{color:#f97316}#header h1 .way{color:#4682df}#header-right{margin-left:auto;display:flex;align-items:center;justify-content:end;gap:12px}#sun-info{font-size:.82rem;font-weight:600;display:none}#search-panel{background:#fff;padding:10px 16px;display:flex;gap:8px;align-items:center;flex-wrap:wrap;border-bottom:1px solid #e5e7eb;z-index:999;flex-shrink:0}#search-panel input[type=text]{flex:1;min-width:160px;padding:8px 12px;border:1.5px solid #e5e7eb;border-radius:8px;font-size:.88rem;outline:none;transition:border-color .2s}#search-panel input[type=text]:focus{border-color:#f97316}.dt-group{display:flex;gap:6px}#search-panel input[type=date],#search-panel input[type=time]{padding:8px 10px;border:1.5px solid #e5e7eb;border-radius:8px;font-size:.82rem;outline:none;color:#374151}#search-btn{padding:8px 20px;background:#f97316;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s,opacity .2s;white-space:nowrap}#search-btn:hover{background:#ea6b0a}#search-btn:disabled{opacity:.5;cursor:not-allowed}#map{flex:1;z-index:1}#status{position:fixed;top:130px;left:50%;transform:translate(-50%);background:#0f172ae0;color:#fff;padding:8px 18px;border-radius:20px;font-size:.84rem;z-index:3000;display:none;backdrop-filter:blur(4px);white-space:nowrap}#status.on{display:block}#compass-wrap{position:fixed;top:130px;right:16px;z-index:2000;display:none;flex-direction:column;align-items:center;gap:4px}#compass-wrap.on{display:flex}#compass-box{width:72px;height:72px;background:#fff;border-radius:50%;box-shadow:0 2px 10px #0000002e;display:flex;align-items:center;justify-content:center}#compass-label{font-size:.68rem;color:#6b7280;background:#fff;padding:2px 8px;border-radius:4px;box-shadow:0 1px 4px #0000001a}.ac-dropdown{position:absolute;list-style:none;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;box-shadow:0 6px 20px #0000001f;z-index:9999;max-height:220px;overflow-y:auto;padding:4px 0}.ac-item{padding:9px 14px;font-size:.84rem;color:#374151;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ac-item:hover{background:#f9fafb}#results{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -4px 24px #00000024;z-index:2000;display:none}#results.on{display:block}#tabs{display:flex;border-bottom:1.5px solid #f3f4f6;padding:0 16px}.tab-btn{flex:1;padding:10px 0;border:none;background:none;font-size:.88rem;font-weight:600;color:#9ca3af;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-1.5px;transition:all .2s}.tab-btn.active{color:#f97316;border-bottom-color:#f97316}.tab-btn.shady.active{color:#1a3a6b;border-bottom-color:#1a3a6b}.tab-pane{display:none;padding:14px 16px;gap:16px;align-items:center}.tab-pane.active{display:flex}.stat{display:flex;flex-direction:column;align-items:center;min-width:64px}.stat .val{font-size:1.2rem;font-weight:700;color:#111827}.stat .lbl{font-size:.68rem;color:#9ca3af;margin-top:2px}.bar-wrap{flex:1}.bar-labels{display:flex;justify-content:space-between;font-size:.72rem;color:#9ca3af;margin-bottom:4px}.bar-track{height:11px;background:#f3f4f6;border-radius:6px;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,#1d4ed8,#fbbf24,#f97316);border-radius:6px;transition:width .6s ease}.pct{font-size:1.05rem;font-weight:700;margin-top:6px}.pct.sunny{color:#f97316}.pct.shady{color:#1a3a6b}#summary{font-size:.72rem;color:#9ca3af;text-align:center;padding:8px 16px 12px;border-top:1px solid #f3f4f6}#about-btn{margin-left:8px;width:28px;height:28px;border-radius:50%;border:1.5px solid #e5e7eb;background:#fff;color:#9ca3af;font-size:.85rem;font-style:italic;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,color .2s;flex-shrink:0}#about-btn:hover{border-color:#f97316;color:#f97316}#about-overlay{display:none;position:fixed;inset:0;background:#0000004d;z-index:3999;backdrop-filter:blur(2px)}#about-overlay.on{display:block}#about-drawer{position:fixed;top:0;right:0;width:340px;max-width:100vw;height:100%;background:#fff;z-index:4000;box-shadow:-4px 0 32px #00000029;display:flex;flex-direction:column;transform:translate(100%);transition:transform .28s cubic-bezier(.4,0,.2,1)}#about-drawer.open{transform:translate(0)}#about-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid #f3f4f6}#about-lang{display:flex;gap:4px}.lang-btn{padding:4px 10px;border:1.5px solid #e5e7eb;border-radius:6px;background:#fff;font-size:.78rem;font-weight:600;color:#6b7280;cursor:pointer;transition:all .15s}.lang-btn:hover{border-color:#f97316;color:#f97316}.lang-btn.active{background:#f97316;border-color:#f97316;color:#fff}#about-close{width:30px;height:30px;border:none;background:none;font-size:1.3rem;color:#9ca3af;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}#about-close:hover{background:#f3f4f6;color:#374151}#about-body{flex:1;overflow-y:auto;padding:24px 20px}.about-pane{display:none}.about-pane.active{display:block}.about-pane h2{font-size:1.4rem;font-weight:700;letter-spacing:-.5px;margin-bottom:6px}.about-pane h2 .meri{color:#f97316}.about-pane h2 .way{color:#4682df}.about-tagline{font-size:.9rem;font-weight:600;color:#374151;margin-bottom:18px}.about-pane p{font-size:.88rem;color:#4b5563;line-height:1.65;margin-bottom:14px}.about-opensource{margin-top:20px;padding:12px 14px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;font-size:.83rem;color:#4b5563;line-height:1.6}p.opensource-badge{background:#4682df;color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:4px;margin-bottom:6px;letter-spacing:.3px;width:fit-content}#about-links{padding:16px 20px;border-top:1px solid #f3f4f6;display:flex;gap:10px}.about-link{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 12px;border-radius:8px;font-size:.85rem;font-weight:600;text-decoration:none;transition:opacity .2s}.about-link:hover{opacity:.8}.github-link{background:#1a1a2e;color:#fff}.kofi-link{background:#ff5e5b;color:#fff}@media(max-width:600px){#search-panel input[type=text]{flex:0 0 100%;min-width:0}#about-drawer{width:100vw}}
