:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--bg: #f5f6f8;--surface: #ffffff;--border: #e2e4e9;--text: #1a1d27;--text-muted: #6b7280;--accent: #2563eb;--danger: #dc2626;--danger-bg: rgba(220, 38, 38, .08)}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6}.app{min-height:100vh;max-width:1000px;margin:0 auto;padding:0 16px}.hero{text-align:center;padding:40px 16px 28px;border-bottom:1px solid var(--border);margin-bottom:24px}.hero h1{font-size:2rem;font-weight:700;margin-bottom:4px}.subtitle{color:var(--text-muted);font-size:1rem}.city-picker{padding:20px 24px}.city-picker-header{margin-bottom:12px}.city-picker-header h2{font-size:1rem;font-weight:600;color:var(--text-muted)}.city-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.city-tag{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border:2px solid;border-radius:999px;font-size:.85rem;font-weight:600;background:var(--surface)}.city-tag-remove{background:none;border:none;color:inherit;font-size:1.1rem;cursor:pointer;padding:0;line-height:1;opacity:.5;transition:opacity .15s}.city-tag-remove:hover{opacity:1}.city-autocomplete{position:relative}.city-input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:.9rem;background:var(--bg);color:var(--text);outline:none;transition:border-color .2s}.city-input:focus{border-color:var(--accent)}.city-input::placeholder{color:var(--text-muted)}.autocomplete-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #0000001a;z-index:100;overflow:hidden}.autocomplete-option{display:block;width:100%;padding:10px 14px;text-align:right;border:none;background:none;color:var(--text);font-size:.9rem;cursor:pointer;transition:background .1s}.autocomplete-option:hover,.autocomplete-option--active{background:var(--bg)}.autocomplete-option+.autocomplete-option{border-top:1px solid var(--border)}.summary-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-top:10px}.summary-card{background:var(--surface);border:1px solid var(--border);border-top:3px solid;border-radius:10px;padding:10px 14px 8px;display:flex;flex-direction:column;align-items:center;gap:6px}.summary-city{font-size:.85rem;font-weight:700}.summary-columns{display:flex;width:100%;align-items:stretch}.summary-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.summary-col-label{font-size:.65rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.02em}.summary-col-divider{width:1px;background:var(--border);margin:0 6px}.summary-count{font-size:1.5rem;font-weight:700;line-height:1.1}.summary-split{display:flex;align-items:center;gap:6px;margin-top:2px;justify-content:center}.summary-split-item{font-size:.8rem;color:var(--text-muted);font-weight:600}.summary-split-divider{width:1px;height:10px;background:var(--border)}.content{display:flex;flex-direction:column;gap:3px;padding-bottom:32px}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;margin-top:20px}.card.city-picker{margin-top:0}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.card-header h2{font-size:1.15rem;font-weight:600}.alert-count{background:#2563eb14;color:var(--accent);padding:4px 12px;border-radius:999px;font-size:.9rem;font-weight:600}.refresh-btn{background:var(--accent);color:#fff;border:none;padding:6px 16px;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:opacity .2s}.refresh-btn:hover{opacity:.85}.night-config{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;background:var(--surface);border:1px solid var(--border);border-radius:10px;font-size:.85rem}.night-config-label{color:var(--text);font-weight:600}.night-config-sep{color:var(--text-muted);font-weight:500}.night-select{padding:6px 10px;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--text);font-size:.85rem;font-weight:500;outline:none;cursor:pointer;transition:border-color .2s,box-shadow .2s}.night-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px #2563eb26}.chart-legend-custom{display:flex;flex-direction:column;align-items:center;gap:6px;margin:8px 0;font-size:.8rem;color:var(--text-muted)}.legend-row{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}.legend-item{display:flex;align-items:center;gap:6px}.legend-swatch{display:inline-block;width:14px;height:14px;border-radius:3px}.legend-night{background:#1e1b4b33;border:1px solid #818cf8}.legend-day{background:#fff;border:1px solid #d1d5db}.chart-scroll-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -8px;direction:ltr}.chart-inner{width:100%}.loading{text-align:center;color:var(--text-muted);padding:32px}.error{color:var(--danger);padding:12px;background:var(--danger-bg);border-radius:8px}.no-history{color:var(--text-muted);text-align:center;padding:32px}.empty-state{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 24px}.empty-state svg{opacity:.4}.alerts-table-wrapper{max-height:500px;overflow-y:auto}.alerts-table{width:100%;border-collapse:collapse;table-layout:fixed}.alerts-table thead{position:sticky;top:0;z-index:1}.alerts-table th{background:var(--surface);text-align:center;padding:10px 16px;font-size:.85rem;font-weight:600;color:var(--text-muted);border-bottom:2px solid var(--border)}.alerts-table td{padding:9px 16px;font-size:.9rem;color:var(--text);border-bottom:1px solid var(--border);text-align:center}.alerts-table tbody tr:hover{background:var(--bg)}.city-badge{padding:2px 10px;border-radius:4px;font-size:.8rem;font-weight:600;border:1px solid;white-space:nowrap}.history-category{background:#0000000d;color:var(--text-muted);padding:2px 8px;border-radius:4px;font-size:.8rem;font-weight:600;font-family:monospace}.history-type{background:#2563eb14;color:var(--accent);padding:2px 10px;border-radius:4px;font-size:.85rem;font-weight:500}.footer{text-align:center;padding:24px 0;border-top:1px solid var(--border);color:var(--text-muted);font-size:.85rem}.footer a{color:var(--accent);text-decoration:none}.footer a:hover{text-decoration:underline}.recharts-tooltip-item{direction:rtl}.recharts-legend-item svg{margin-left:6px}@media(max-width:768px){.app{padding:0 10px}.hero{padding:28px 10px 20px;margin-bottom:16px}.hero h1{font-size:1.45rem}.card{padding:16px;margin-top:14px;border-radius:10px}.city-picker{padding:14px 16px}.card-header{margin-bottom:12px;padding-bottom:10px}.card-header h2{font-size:1.05rem}.city-input{font-size:16px}.summary-row{grid-template-columns:1fr;gap:8px}.summary-card{flex-direction:row;align-items:center;padding:10px 14px;gap:12px}.summary-city{min-width:80px;text-align:right}.summary-columns{flex:1}.night-config{flex-wrap:wrap;justify-content:center;gap:8px;padding:10px 14px;font-size:.82rem}.alerts-table th,.alerts-table td{padding:8px 10px;font-size:.82rem}.city-badge{font-size:.75rem;padding:2px 8px}.chart-scroll-wrapper{margin:0 -12px;padding-bottom:6px}}@media(max-width:480px){.app{padding:0 6px}.hero{padding:20px 6px 14px;margin-bottom:10px}.hero h1{font-size:1.2rem}.card{padding:12px;margin-top:10px;border-radius:8px}.city-picker{padding:12px}.card-header h2{font-size:.95rem}.city-tag{padding:4px 10px;font-size:.78rem}.city-input{padding:9px 12px;font-size:16px}.summary-card{padding:8px 10px;gap:8px;border-radius:8px}.summary-city{font-size:.78rem;min-width:65px}.summary-count{font-size:1.3rem}.summary-col-label{font-size:.6rem}.summary-split-item{font-size:.72rem}.night-config{padding:8px 10px;font-size:.78rem;gap:6px}.night-select{padding:5px 8px;font-size:.78rem}.refresh-btn{padding:5px 12px;font-size:.8rem}.alert-count{padding:3px 10px;font-size:.82rem}.alerts-table-wrapper{max-height:400px;margin:0 -8px}.alerts-table th,.alerts-table td{padding:7px 6px;font-size:.78rem}.city-badge{font-size:.7rem;padding:1px 6px}.chart-legend-custom{gap:10px;font-size:.72rem}.legend-swatch{width:12px;height:12px}.error{font-size:.85rem;padding:10px}.footer{padding:16px 0;font-size:.78rem}}
