@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=DM+Serif+Display&display=swap";:root{--bg-deep: #070b14;--bg-card: rgba(15, 23, 42, .6);--bg-card-border: rgba(255, 255, 255, .06);--text-primary: #e2e8f0;--text-secondary: rgba(226, 232, 240, .6);--text-muted: rgba(226, 232, 240, .35);--blue: #3b82f6;--blue-glow: rgba(59, 130, 246, .15);--red: #ef4444;--red-glow: rgba(239, 68, 68, .12);--amber: #f59e0b;--amber-glow: rgba(245, 158, 11, .12);--green: #22c55e;--green-glow: rgba(34, 197, 94, .12);--font-body: "DM Sans", sans-serif;--font-display: "DM Serif Display", serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg-deep);color:var(--text-primary);min-height:100vh;line-height:1.6}.app{position:relative;min-height:100vh;overflow:hidden}.bg-wash{position:fixed;inset:0;background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(30,58,138,.3),transparent),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(15,23,42,.8),transparent);pointer-events:none;z-index:0}header{position:relative;z-index:1;text-align:center;padding:3rem 1.5rem 1rem}header h1{font-family:var(--font-display);font-size:clamp(2.2rem,6vw,3.5rem);font-weight:400;line-height:1.15;letter-spacing:-.01em;color:var(--text-primary)}.subtitle{margin-top:.5rem;font-size:.875rem;color:var(--text-secondary);font-weight:400;letter-spacing:.04em;text-transform:uppercase}main{position:relative;z-index:1;max-width:640px;margin:0 auto;padding:0 1.25rem 3rem}.card-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1rem}.card-grid .warnings-card{margin-bottom:0}.status-hero{text-align:center;padding:2.5rem 1.5rem;margin-bottom:1.5rem;border-radius:16px;background:var(--bg-card);border:1px solid var(--bg-card-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:background .5s,border-color .5s}.status-hero[data-status=FLOODED]{background:linear-gradient(135deg,rgba(239,68,68,.1),var(--bg-card));border-color:#ef444433}.status-hero[data-status=NEAR_FLOOD]{background:linear-gradient(135deg,rgba(245,158,11,.1),var(--bg-card));border-color:#f59e0b33}.status-hero[data-status=RECEDING]{background:linear-gradient(135deg,rgba(59,130,246,.08),var(--bg-card));border-color:#3b82f626}.status-hero[data-status=CLEAR]{background:linear-gradient(135deg,rgba(34,197,94,.06),var(--bg-card));border-color:#22c55e1f}.status-answer{font-family:var(--font-display);font-size:clamp(3rem,10vw,5rem);line-height:1.1;margin-bottom:.75rem}[data-status=FLOODED] .status-answer{color:var(--red)}[data-status=NEAR_FLOOD] .status-answer{color:var(--amber)}[data-status=RECEDING] .status-answer{color:var(--blue)}[data-status=CLEAR] .status-answer{color:var(--green)}.status-detail{font-size:.95rem;color:var(--text-secondary);max-width:400px;margin:0 auto;line-height:1.5}.loading-pulse{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--text-secondary)}.loading-dot{width:12px;height:12px;border-radius:50%;background:var(--blue);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.error-msg{display:flex;align-items:center;justify-content:center;gap:.5rem;color:var(--amber)}.error-icon{font-size:1.25rem}.card{background:var(--bg-card);border:1px solid var(--bg-card-border);border-radius:14px;padding:1.5rem;margin-bottom:1rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.card h2{font-family:var(--font-body);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:1rem}.card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.card-header h2{margin-bottom:0}.trend-badge{font-size:.75rem;font-weight:500;padding:.25rem .65rem;border-radius:100px;letter-spacing:.02em}.trend-rising{background:var(--red-glow);color:var(--red)}.trend-falling{background:var(--green-glow);color:var(--green)}.trend-steady{background:var(--blue-glow);color:var(--blue)}.trend-unknown{background:#ffffff0d;color:var(--text-muted)}.level-display{display:flex;align-items:baseline;gap:.5rem;margin-bottom:1.25rem}.level-value{font-family:var(--font-display);font-size:3rem;line-height:1;color:var(--text-primary)}.level-unit{font-size:.9rem;color:var(--text-muted)}.thresholds{display:flex;flex-direction:column;gap:.5rem}.threshold{display:flex;align-items:center;gap:.6rem;font-size:.825rem;color:var(--text-muted);transition:color .3s}.threshold.exceeded{color:var(--text-secondary)}.threshold-marker{width:10px;height:10px;border-radius:3px;flex-shrink:0}.threshold-marker.road-flood{background:var(--red)}.threshold-marker.warning{background:var(--amber)}.threshold-marker.normal{background:#fff3}.threshold.exceeded .threshold-marker.road-flood{box-shadow:0 0 8px var(--red)}.threshold.exceeded .threshold-marker.warning{box-shadow:0 0 8px var(--amber)}.threshold-label{flex:1}.threshold-value{font-variant-numeric:tabular-nums}.warnings-card{border-color:#f59e0b40;background:linear-gradient(135deg,rgba(245,158,11,.06),var(--bg-card))}.warnings-card h2{color:var(--amber)}.warning-icon{margin-right:.25rem}.warning-link{display:block;text-decoration:none;color:inherit;border-radius:8px;padding:.75rem;margin:0 -.75rem;transition:background .2s}.warning-link:hover{background:#f59e0b14}.warning-link:first-of-type{border-top:none;padding-top:.75rem}.warning-item{padding:.75rem 0;border-top:1px solid rgba(255,255,255,.05)}.warning-item:first-of-type{border-top:none;padding-top:0}.warning-severity{font-weight:600;font-size:.85rem;color:var(--amber);margin-bottom:.15rem}.warning-area{font-size:.85rem;color:var(--text-secondary);margin-bottom:.4rem}.warning-message{font-size:.825rem;color:var(--text-secondary);line-height:1.5;margin-bottom:.4rem}.warning-time{font-size:.75rem;color:var(--text-muted)}.road-status-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.road-indicator{font-family:var(--font-display);font-size:1.75rem;line-height:1}.road-indicator.open{color:var(--green)}.road-indicator.closed{color:var(--red)}.road-indicator.unknown{color:var(--amber)}.confidence{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;padding:.2rem .5rem;border-radius:100px}.conf-high{background:#ffffff14;color:var(--text-secondary)}.conf-medium{background:#f59e0b1a;color:var(--amber)}.conf-low{background:#ef44441a;color:var(--red)}.road-reason{font-size:.875rem;color:var(--text-secondary);line-height:1.5;margin-bottom:1rem}.transit-info{display:flex;gap:1.5rem;padding:.75rem 1rem;background:#ffffff08;border-radius:10px;margin-bottom:.75rem}.transit-item{display:flex;flex-direction:column;gap:.15rem}.transit-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.transit-value{font-size:1.1rem;font-weight:600;font-variant-numeric:tabular-nums}.transit-item.delay .transit-value{color:var(--amber)}.congestion-low{color:var(--green)}.congestion-medium{color:var(--amber)}.congestion-high{color:var(--red)}.traffic-meta{font-size:.8rem}.traffic-live{color:var(--green)}.traffic-no-data{color:var(--text-muted)}.chart-card{padding-bottom:1rem}.chart-range{display:flex;gap:.25rem}.range-btn{background:#ffffff0d;border:1px solid transparent;color:var(--text-muted);padding:.3rem .6rem;border-radius:6px;font-size:.75rem;font-family:var(--font-body);cursor:pointer;transition:all .2s}.range-btn:hover{background:#ffffff14;color:var(--text-secondary)}.range-btn.active{background:var(--blue-glow);color:var(--blue);border-color:#3b82f64d}.river-chart{margin:0 -.75rem}.chart-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted);font-size:.875rem}footer{margin-top:2rem;text-align:center}.last-updated{font-size:.8rem;color:var(--text-muted);margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:.75rem}.refresh-btn{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);padding:.3rem .75rem;border-radius:6px;font-size:.75rem;font-family:var(--font-body);cursor:pointer;transition:all .2s}.refresh-btn:hover:not(:disabled){background:#ffffff1a;color:var(--text-primary)}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.attribution{font-size:.7rem;color:var(--text-muted);line-height:1.6}.card-grid .card{margin-bottom:0}@media(min-width:900px){main{max-width:960px}.card-grid{grid-template-columns:1fr 1fr}.card-grid .warnings-card{grid-column:1 / -1}}@media(max-width:480px){header{padding:2rem 1rem .75rem}main{padding:0 .75rem 2rem}.card{padding:1.15rem}.status-hero{padding:2rem 1.15rem}.level-value{font-size:2.5rem}.transit-info{gap:1rem}}.recharts-tooltip-wrapper{outline:none!important}
