*{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:460px;max-width:50vw;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 label{font-size:12px;display:flex;align-items:center;gap:6px}
.grid label input[type="number"], textarea, select{flex:1}
.grid input, select{padding:8px 10px;border:1px solid var(--line);border-radius:10px}
textarea{width:100%;height:180px;border:1px solid var(--line);border-radius:10px;padding:8px;font-family:ui-monospace,Menlo,Monaco,monospace;font-size:12px}
.trip{grid-template-columns:repeat(3,1fr)}
.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)}
