:root{color-scheme:light;--bg: #eef5f3;--paper: #ffffff;--ink: #172524;--muted: #637270;--line: rgba(22, 55, 54, .12);--brand: #087a91;--brand-soft: rgba(8, 122, 145, .12);--good: #0d8b5d;--warn: #bd6b14;--bad: #bc3323;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;background:linear-gradient(180deg,rgba(8,122,145,.12),transparent 320px),var(--bg);color:var(--ink)}button{font:inherit}.shell{width:min(1120px,100%);margin:0 auto;padding:22px 16px 42px}.gateShell{min-height:100svh;display:grid;place-items:center;padding:20px}.gateCard{width:min(420px,100%);padding:24px;border:1px solid var(--line);border-radius:8px;background:#ffffffe6;box-shadow:0 16px 40px #183a3a14}.gateCard h1{font-size:42px;line-height:1;margin-bottom:22px}.gateCard label{display:block;margin-bottom:8px;color:var(--muted);font-size:13px;font-weight:680}.gateRow{display:grid;grid-template-columns:1fr auto;gap:8px}.gateRow input,.gateRow button{min-height:44px;border-radius:8px;border:1px solid var(--line)}.gateRow input{min-width:0;padding:0 12px;color:var(--ink);background:var(--paper)}.gateRow button{padding:0 16px;color:#fff;background:var(--brand);cursor:pointer}.gateError{color:var(--bad);font-size:14px}.hero{min-height:148px;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:12px 4px 20px}.eyebrow{margin:0 0 8px;color:var(--brand);font-weight:760;letter-spacing:0;text-transform:uppercase;font-size:13px}h1{margin:0;max-width:760px;font-size:clamp(36px,7vw,72px);line-height:.98;letter-spacing:0}.iconButton{width:46px;height:46px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--brand);background:#ffffffc7;cursor:pointer}.tabBar{display:flex;gap:8px;margin:0 0 14px;padding:6px;overflow-x:auto;border:1px solid var(--line);border-radius:8px;background:#ffffffb8}.tab{min-height:40px;padding:0 13px;border:0;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;gap:7px;color:var(--muted);background:transparent;cursor:pointer;white-space:nowrap}.tab.active{color:var(--brand);background:var(--brand-soft);font-weight:720}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.detailGrid{display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);gap:14px}.card{background:#ffffffe0;border:1px solid var(--line);border-radius:8px;padding:18px;min-height:214px;box-shadow:0 16px 40px #183a3a14}.ferryCard{grid-row:span 2}.wideCard{grid-column:span 2}.cardHeader,.routeLine,.secondaryRow,.beachList>div,.dataRow{display:flex;align-items:center;justify-content:space-between;gap:10px}.cardHeader{margin-bottom:18px;color:var(--muted);font-size:13px;font-weight:680}.headerTitle{display:inline-flex;align-items:center;gap:8px;color:var(--brand);text-transform:uppercase}.routeLine{color:var(--muted);font-size:14px;margin-bottom:8px}.bigMetric{display:flex;align-items:baseline;gap:12px;margin:8px 0 18px;color:var(--brand)}.bigMetric strong{font-size:clamp(54px,9vw,86px);line-height:.9;font-weight:260}.bigMetric span{color:var(--muted);font-size:18px}.bigMetric.bad{color:var(--bad)}.secondaryRow{background:var(--brand-soft);color:var(--brand);padding:10px 12px;border-radius:8px;font-size:14px}.condition{display:flex;gap:12px;color:var(--brand);align-items:flex-start;margin-bottom:16px}.condition.warn{color:var(--bad)}.condition strong{display:block;font-size:22px;line-height:1.15;margin-bottom:4px}.condition span,.muted{color:var(--muted);font-size:14px;line-height:1.45}.splitMetrics{display:flex;gap:10px;margin-top:14px}.metric{flex:1;min-width:0;padding:11px 8px;border-radius:8px;background:#6372701a;text-align:center}.metric strong{display:block;font-size:21px;color:var(--brand);line-height:1.1;white-space:nowrap}.metric span{display:block;margin-top:4px;color:var(--muted);font-size:12px}.metric.good strong{color:var(--good)}.metric.warn strong{color:var(--warn)}.metric.bad strong{color:var(--bad)}.bars{height:62px;display:flex;align-items:flex-end;gap:3px;margin-top:22px;border-top:1px solid var(--line);padding-top:10px}.bars span{flex:1;min-width:3px;background:var(--brand);opacity:.82;border-radius:3px 3px 1px 1px}.largeBars{height:112px}.windChart{position:relative;display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;min-height:190px;margin-top:8px;padding:12px 0 34px;border-top:1px solid var(--line)}.waitForecastChart{position:relative;display:grid;grid-template-columns:48px minmax(0,1fr);gap:10px;min-height:178px;margin-top:8px;padding:12px 0 34px;border-top:1px solid var(--line)}.waitScale{height:120px;display:flex;flex-direction:column;justify-content:space-between;padding-top:1px;color:var(--muted);font-size:11px;text-align:right;white-space:nowrap}.waitPlot{position:relative;display:grid;grid-template-columns:repeat(48,minmax(8px,1fr));gap:3px;min-width:0}.waitGridLines{position:absolute;inset:0 0 auto;height:120px;display:flex;flex-direction:column;justify-content:space-between;pointer-events:none}.waitGridLines span{display:block;border-top:1px solid var(--line)}.waitHourLines{position:absolute;inset:0 0 auto;height:120px;display:grid;grid-template-columns:repeat(48,minmax(8px,1fr));gap:3px;pointer-events:none}.waitHourLines span{border-left:1px solid rgba(22,55,54,.07)}.waitHourLines span:last-child{border-right:1px solid rgba(22,55,54,.07)}.nowMarker{position:absolute;top:0;bottom:28px;left:50%;width:1px;background:var(--line);z-index:1}.nowMarker:after{content:"agora";position:absolute;top:-12px;left:5px;color:var(--muted);font-size:11px}.waitColumn{position:relative;z-index:2;min-width:0;display:grid;grid-template-rows:120px auto;justify-items:center;gap:4px;color:var(--muted);font-size:11px}.waitBars{position:relative;width:100%;height:120px;display:flex;align-items:flex-end;justify-content:center}.actualWaitBar,.forecastWaitBar,.missingWaitBar{display:block;width:min(12px,80%);border-radius:4px 4px 1px 1px}.actualWaitBar{background:var(--brand)}.forecastWaitBar{background:#0d8b5d8c}.missingWaitBar{height:3px;background:var(--line)}.windScale{height:120px;display:flex;flex-direction:column;justify-content:space-between;padding-top:1px;color:var(--muted);font-size:11px;text-align:right}.windPlot{position:relative;display:grid;grid-template-columns:repeat(24,minmax(18px,1fr));grid-template-rows:120px 22px;gap:6px;min-width:0}.windGridLines{position:absolute;inset:0 0 auto;height:120px;display:flex;flex-direction:column;justify-content:space-between;pointer-events:none}.windGridLines span{display:block;border-top:1px solid var(--line)}.windColumn{position:relative;min-width:0;grid-row:1;height:120px}.windBars{position:relative;width:24px;height:120px;display:flex;align-items:flex-end;justify-content:center;margin:0 auto}.gustBar,.speedBar{display:block;border-radius:4px 4px 1px 1px}.gustBar{width:16px;background:#bd6b1447}.speedBar{position:absolute;bottom:0;width:7px;background:var(--brand)}.windXAxis{grid-column:1 / -1;grid-row:2;display:grid;grid-template-columns:repeat(24,minmax(18px,1fr));gap:6px;align-items:start;color:var(--muted);font-size:12px}.windXAxis span{min-width:0;text-align:center;white-space:nowrap}.chartLegend{position:absolute;right:0;bottom:0;display:flex;gap:12px;color:var(--muted);font-size:12px}.scaleUnit{font-weight:720;color:var(--ink)}.chartLegend span{display:inline-flex;align-items:center;gap:5px}.chartLegend i{width:10px;height:10px;border-radius:2px}.legendSpeed{background:var(--brand)}.legendGust{background:#bd6b1447}.legendActual{background:var(--brand)}.legendForecast{background:#0d8b5d8c}.beachList{display:grid;gap:10px;margin-top:14px}.beachList>div{color:var(--ink);font-size:14px}.beachList strong{color:var(--bad);font-size:12px}.dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto}.badDot{background:var(--bad)}.goodDot{background:var(--good)}.neutralDot{background:var(--muted)}.rows{display:grid;gap:10px}.compactRows{gap:8px}.dataRow{min-height:52px;padding:10px 0;border-bottom:1px solid var(--line)}.dataRow:last-child{border-bottom:0}.dataRow strong,.historyRow strong{display:block;color:var(--ink);font-size:15px}.dataRow span{color:var(--muted);font-size:13px}.inlineMetrics{display:flex;gap:10px;align-items:center;justify-content:flex-end;color:var(--muted);font-size:13px;white-space:nowrap}.badge{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 10px;border-radius:999px;background:#6372701f;color:var(--muted);font-size:12px;font-weight:720;white-space:nowrap}.badge.good{background:#0d8b5d1f;color:var(--good)}.badge.warn{background:#bd6b141f;color:var(--warn)}.badge.bad{background:#bc33231f;color:var(--bad)}.historyRow{display:grid;grid-template-columns:minmax(130px,1fr) minmax(150px,2fr);align-items:center;gap:14px;min-height:38px}.historyDots{display:flex;justify-content:flex-end;gap:6px}.qualityDot{width:12px;height:12px;border-radius:50%;flex:0 0 auto}.notice{display:flex;align-items:flex-start;gap:10px;margin:0 0 14px;padding:13px 14px;border-radius:8px;border:1px solid var(--line);background:var(--paper);font-weight:640}.notice.warn{color:var(--warn)}.notice.bad{color:var(--bad)}.skeleton{position:relative;overflow:hidden}.skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,transparent,rgba(255,255,255,.75),transparent);animation:shimmer 1.2s infinite}.spin{animation:spin .8s linear infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:780px){.shell{padding-inline:12px}.hero{min-height:128px}.grid,.detailGrid{grid-template-columns:1fr}.ferryCard{grid-row:auto}.wideCard{grid-column:auto}.card{padding:16px}.bigMetric strong{font-size:58px}.tab{flex:0 0 auto}.historyRow{grid-template-columns:1fr;align-items:flex-start}.historyDots{justify-content:flex-start}.windChart,.waitForecastChart{overflow-x:auto}.waitPlot{min-width:860px}.windPlot{min-width:620px}.chartLegend{left:0;right:auto}}
