*{box-sizing:border-box}body{margin:0;font-family:Arial,sans-serif;background:#0f172a;color:#e2e8f0}.app{max-width:1100px;margin:0 auto;padding:16px}.card{background:#111827;border:1px solid #1f2937;border-radius:12px;padding:14px;margin-bottom:12px}h1,h2{margin:0 0 10px}.muted{color:#94a3b8}.tabs{display:flex;flex-wrap:wrap;gap:8px}.tab{border:1px solid #334155;background:#0b1220;color:#e2e8f0;border-radius:8px;padding:10px 12px;cursor:pointer}.tab.active{background:#2563eb;border-color:#2563eb}.row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:8px}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}label{display:block;font-size:13px;color:#cbd5e1}input,select,button{width:100%;margin-top:4px;border:1px solid #334155;border-radius:8px;padding:10px;background:#0b1220;color:#e2e8f0}button{cursor:pointer;background:#2563eb;border:none}button.secondary{background:#334155}button.danger{background:#b91c1c}.checks{display:flex;gap:16px}.checks label{display:flex;align-items:center;gap:8px}.checks input{width:auto;margin-top:0}.map{margin-top:10px;width:100%;min-height:280px;border:1px solid #334155;border-radius:8px}.out{white-space:pre-wrap;border:1px solid #334155;border-radius:8px;background:#0b1220;padding:8px;min-height:44px;margin-top:8px;font-size:12px}.links a{color:#60a5fa}.hint{margin-top:8px;font-size:12px;color:#94a3b8}.footer{display:flex;justify-content:space-between;color:#94a3b8;margin:8px 2px 20px}.thermocline-banner{display:flex;flex-direction:column;gap:6px;padding:8px;border:1px solid #1e3a8a;border-radius:8px;background:#0ea5e90f;margin:6px 0}.tc-svg{width:100%;height:70px}.tc-advice{color:#cbd5e1;font-size:12px}.field-error{color:#fca5a5;font-size:11px;margin-top:4px}.input-bad input,.input-bad select{border-color:#dc2626}.warnings-panel{display:flex;flex-direction:column;gap:6px;margin:10px 0}.warning{padding:8px 10px;border-radius:8px;border:1px solid #475569;background:#0b1220;display:grid;gap:4px}.warning-head{display:flex;align-items:center;gap:8px}.warning-icon{font-size:16px;flex:0 0 auto}.warning-title{flex:1;font-size:14px}.warning-dismiss{width:auto;padding:0 8px;background:transparent;color:#94a3b8;border:1px solid #334155;border-radius:6px;font-size:16px;line-height:1}.warning-body{color:#cbd5e1;font-size:13px}.warning-when{color:#94a3b8;font-size:11px}.warning-danger{border-color:#dc2626;background:linear-gradient(90deg,#dc26262e,#dc26260a);color:#fecaca}.warning-warn{border-color:#b45309;background:linear-gradient(90deg,#f59e0b2e,#f59e0b0a);color:#fde68a}.warning-info{border-color:#1e3a8a;background:linear-gradient(90deg,#2563eb2e,#2563eb0a);color:#bfdbfe}.offline-banner{background:linear-gradient(90deg,#f59e0b2e,#f59e0b0a);border:1px solid #b45309;color:#fde68a;padding:8px 10px;border-radius:8px;font-size:13px;margin:6px 0}.day-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-top:10px}.day-card{background:#0b1220;border:1px solid #1f2937;border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:8px}.day-card.hot{border-color:#16a34a;box-shadow:0 0 0 1px #16a34a66}.day-card.cold{border-color:#b91c1c;opacity:.9}.day-card.gated{border-style:dashed}.day-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.day-date{font-weight:600}.day-score{font-size:22px;font-weight:700}.day-conf{font-size:11px;color:#94a3b8}.score-bar{display:flex;height:6px;border-radius:3px;background:#1f2937;overflow:hidden}.score-bar>span{background:linear-gradient(90deg,#ef4444,#facc15,#16a34a);display:block}.day-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 10px;font-size:12px;color:#cbd5e1}.day-meta dt{color:#94a3b8}.day-meta dd{margin:0;text-align:right}.factors{display:flex;flex-direction:column;gap:3px;font-size:12px}.factor{display:flex;justify-content:space-between;gap:6px;padding:2px 6px;border-radius:4px;background:#ffffff08}.factor .name{color:#94a3b8;font-weight:500}.factor .value{font-variant-numeric:tabular-nums;font-weight:600}.factor .value.pos{color:#4ade80}.factor .value.neg{color:#f87171}.factor.gate{background:#dc262626;border-left:3px solid #dc2626;padding-left:8px}.factor.gate .name:before{content:"⚡ "}.factor .detail{color:#64748b;font-size:11px;flex-basis:100%}.water-banner{display:flex;flex-wrap:wrap;gap:12px;padding:10px 12px;background:linear-gradient(90deg,#2563eb2e,#2563eb00);border:1px solid #1e3a8a;border-radius:10px;margin:10px 0}.water-banner .stat{display:flex;flex-direction:column}.water-banner .stat .k{color:#94a3b8;font-size:11px}.water-banner .stat .v{font-size:18px;font-weight:600}.water-banner .stat .v.up{color:#4ade80}.water-banner .stat .v.down{color:#f87171}.chart-block{margin-top:14px}.chart-block h3{margin:0 0 6px;font-size:13px;color:#cbd5e1;font-weight:600}.chart{width:100%;height:110px;background:#0b1220;border:1px solid #1f2937;border-radius:8px}.chart .axis{stroke:#334155;stroke-width:1}.chart .grid{stroke:#1f2937;stroke-width:1;stroke-dasharray:2 3}.chart .line{fill:none;stroke-width:2}.chart .area{opacity:.2}.chart .dot{stroke-width:1;stroke:#0b1220}.chart .label{fill:#64748b;font-size:10px;font-family:Arial,sans-serif}.chart-legend{display:flex;gap:12px;flex-wrap:wrap;font-size:11px;color:#94a3b8;margin-top:4px}.chart-legend .swatch{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:4px;vertical-align:middle}.history-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;margin-bottom:8px}.history-summary .stat{background:#0b1220;border:1px solid #1f2937;border-radius:8px;padding:8px 10px}.history-summary .k{font-size:11px;color:#94a3b8}.history-summary .v{font-size:16px;font-weight:600}.catch-list{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-direction:column;gap:6px}.catch-list li{background:#0b1220;border:1px solid #1f2937;border-radius:8px;padding:8px 10px;font-size:13px;display:flex;justify-content:space-between;gap:10px}.catch-list .meta{color:#94a3b8;font-size:11px}@media (max-width: 880px){.row,.grid{grid-template-columns:1fr}.checks{flex-direction:column;gap:6px}}
