*{box-sizing:border-box}
:root{--bg:#ffffff;--ink:#0b0b12;--mut:#666;--line:#e6e6ec;--brand:#111;--iso:#2563eb}
html,body,#app{height:100%}
body{margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink)}
#app{display:flex}
.panel{width:520px;max-width:52vw;height:100%;border-right:1px solid var(--line);padding:16px;overflow:auto}
.panel h1{font-size:20px;margin:0 0 6px;font-weight:600}
.sub{font-size:13px;color:var(--mut);margin:0 0 14px}
section{border:1px solid var(--line);border-radius:14px;padding:12px;margin:12px 0}
h2{font-size:14px;margin:0 0 8px}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.grid.models{grid-template-columns:1fr 1fr}
.grid label{font-size:12px;display:flex;align-items:center;gap:6px}
.grid label input[type="number"], textarea, select, input[type="datetime-local"]{flex:1}
.grid input, select, input[type="datetime-local"]{padding:8px 10px;border:1px solid var(--line);border-radius:10px}
textarea{width:100%;height:160px;border:1px solid var(--line);border-radius:10px;padding:8px;font-family:ui-monospace,Menlo,Monaco,monospace;font-size:12px}
.rules{grid-template-columns:repeat(2,1fr)}
.actions{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}
button{padding:8px 12px;border-radius:10px;border:1px solid var(--line);background:var(--brand);color:#fff;cursor:pointer}
button#gpx, button#csv{background:#fff;color:var(--ink)}
#map-wrap{position:relative;flex:1}
#map{position:absolute;inset:0}
.loading{position:absolute;inset:0;display:grid;place-items:center;background:radial-gradient(circle at 50% 50%, #f6f7fb, transparent 60%)}
.hidden{display:none}
.hint{font-size:11px;color:var(--mut);margin:6px 0 0}

.stats{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.stats div{display:flex;justify-content:space-between;border:1px solid var(--line);border-radius:10px;padding:6px 8px;font-size:12px}
.stats div span{color:var(--mut)}

.sliderRow{display:flex;align-items:center;gap:8px}
#play{width:36px;height:36px;border-radius:50%}
#timeSlider{flex:1}
.timeReadout{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:8px}
.timeReadout div{display:flex;justify-content:space-between;border:1px solid var(--line);border-radius:10px;padding:6px 8px;font-size:12px}
.timeReadout span{color:var(--mut)}

.boat{font-size:18px;transform: translate(-50%,-50%) rotate(0deg);}
.leaflet-iso{color:var(--iso)}

details#polarBox summary{cursor:pointer;padding:6px 8px;border:1px solid var(--line);border-radius:10px;background:#f8f9fb}
details#polarBox textarea{margin-top:8px}

.legend{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:8px}
.legend-row{display:flex;align-items:center;gap:6px;font-size:12px;border:1px solid var(--line);border-radius:10px;padding:6px 8px}
.swatch{display:inline-block;width:14px;height:14px;border-radius:3px;border:1px solid #0001}
.swatch.spd0{background:#3b82f6}
.swatch.spd1{background:#22c55e}
.swatch.spd2{background:#eab308}
.swatch.spd3{background:#f97316}
.swatch.spd4{background:#ef4444}
.swatch.m-ecmwf{background:#7c3aed} /* purple */
.swatch.m-gfs{background:#16a34a} /* green */
.swatch.m-icon{background:#f59e0b} /* amber */
.swatch.m-gem{background:#06b6d4} /* cyan */

.modelInfo{font-size:12px;display:grid;gap:6px}
.modelInfo .row{display:grid;grid-template-columns:1fr;gap:4px;border:1px solid var(--line);border-radius:10px;padding:6px 8px}
.modelInfo .row .hdr{display:flex;justify-content:space-between;align-items:center}
.modelInfo .row .meta{display:grid;grid-template-columns:1fr 1fr;gap:4px}


details#modelPanel{border:1px solid var(--line);border-radius:14px;padding:8px 10px;margin:12px 0}
details#modelPanel>summary{cursor:pointer;font-weight:600;margin:0 0 6px}
