*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e;color:#eee;min-height:100vh;padding:20px}.container{max-width:800px;margin:0 auto}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}h1{color:#4fc3f7;margin:0}.refresh-btn{background:#2196f3;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center}.refresh-btn:hover{background:#1976d2}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.refresh-btn .spinning{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.data-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.card{background:#16213e;border-radius:12px;padding:20px 20px 12px;border:1px solid #0f3460;display:flex;flex-direction:column}.card h2{font-size:14px;color:#5a9ac0;text-transform:uppercase;margin-bottom:8px}.card .value{font-size:32px;font-weight:700;color:#4fc3f7}.card .unit{font-size:16px;color:#5a9ac0;margin-left:4px}.wind-arrow{display:inline-block;font-size:28px;color:#4fc3f7;margin-left:8px;font-weight:700}.card .value.skeleton{color:#2a4a6b}.card .cached{color:#ff9800;font-size:10px;margin-left:4px}.source-bar{margin-top:auto;padding-top:8px;font-size:9px;color:#3a7595}.card .station{font-size:12px;color:#4a87a8;margin-top:8px}.card .timestamp{font-size:12px;color:#3a7595;margin-top:4px}.tides-list{background:#16213e;border-radius:12px;padding:20px;border:1px solid #0f3460}.tides-list h2{font-size:14px;color:#5a9ac0;text-transform:uppercase;margin-bottom:16px}.tide-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #0f3460}.tide-row:last-child{border-bottom:none}.tide-time{color:#6aabcc}.tide-height{color:#4fc3f7;font-weight:700}.loading{color:#5a9ac0}.error{color:#f44336}.tide-gauge-card{margin-bottom:24px}.tide-gauge-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.tide-current-value{font-size:28px;font-weight:700;color:#4fc3f7}.tide-gauge{margin-bottom:12px;margin-top:22px}.tide-gauge-bar{position:relative;height:12px;background:linear-gradient(to right,#1a3a5c,#2d5a87);border-radius:6px;overflow:visible}.tide-gauge-fill{height:100%;background:linear-gradient(to right,#0d47a1,#4fc3f7);border-radius:12px 0 0 12px;transition:width .5s ease}.tide-gauge-marker{position:absolute;top:-4px;width:3px;height:20px;background:#fff;border-radius:2px;transform:translate(-50%);box-shadow:0 0 8px #4fc3f7cc;z-index:2}.tide-mean-line{position:absolute;top:0;width:2px;height:12px;transform:translate(-50%);z-index:1}.tide-mean-line.mlw{background:repeating-linear-gradient(to bottom,#ff9800 0px,#ff9800 3px,transparent 3px,transparent 6px)}.tide-mean-line.mhw{background:repeating-linear-gradient(to bottom,#4caf50 0px,#4caf50 3px,transparent 3px,transparent 6px)}.mean-label{position:absolute;top:-18px;left:50%;transform:translate(-50%);font-size:10px;font-weight:700;white-space:nowrap}.tide-mean-line.mlw .mean-label{color:#ff9800}.tide-mean-line.mhw .mean-label{color:#4caf50}.tide-gauge-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:12px}.tide-low{color:#5a9ac0}.tide-high{color:#5a9ac0;text-align:right}.tide-low small,.tide-high small{color:#3a7595}.tide-next{font-size:14px;color:#6aabcc;margin-top:8px}.tide-status-badges{display:flex;gap:12px;margin-top:12px}.tide-badge{font-size:12px;padding:4px 10px;border-radius:12px;background:#ff980033;color:#ff9800;border:1px solid rgba(255,152,0,.3)}.tide-badge.above{background:#4caf5033;color:#4caf50;border:1px solid rgba(76,175,80,.3)}.salinity-bar-container{margin-top:10px}.salinity-bar{position:relative;display:flex;height:10px;border-radius:5px;overflow:visible}.salinity-segment{height:100%}.salinity-segment.low{background:linear-gradient(to right,#0d47a1,#4fc3f7);border-radius:5px 0 0 5px}.salinity-segment.prime{background:#4fc3f7;border-left:1px solid rgba(0,0,0,.3);border-right:1px solid rgba(0,0,0,.3)}.salinity-segment.high{background:linear-gradient(to right,#4fc3f7,#0d47a1);border-radius:0 5px 5px 0}.salinity-marker{position:absolute;top:-3px;width:3px;height:16px;background:#fff;border-radius:2px;transform:translate(-50%);box-shadow:0 0 6px #fff9;z-index:1}.salinity-labels{display:flex;justify-content:space-between;margin-top:4px;font-size:10px;color:#5a9ac0}.salinity-labels span{flex:1;text-align:center}.salinity-labels span:first-child{text-align:left}.salinity-labels span:last-child{text-align:right}.jellyfish-risk-label{font-size:12px;font-weight:600;margin-top:6px}.tides-forecast{background:#16213e;border-radius:12px;padding:20px;border:1px solid #0f3460}.tides-forecast h2{font-size:14px;color:#5a9ac0;text-transform:uppercase;margin-bottom:16px}.days-container{display:flex}.day-box{flex:1;min-width:0}.day-box:not(:last-child) .day-timeline:after{content:"";position:absolute;right:0;top:0;height:100%;width:1px;background:#ffffff1a}@media (max-width: 360px){.days-container{flex-direction:column}}.day-label{font-size:14px;font-weight:700;color:#6aabcc;margin-bottom:8px}.day-timeline{position:relative;height:60px;overflow:visible;margin-bottom:20px}.time-block{position:absolute;top:0;height:100%}.time-block.night{background:linear-gradient(to bottom,#0a1628,#152238)}.time-block.day{background:linear-gradient(to bottom,#1e3a5f,#2d5a87)}.hour-marker{position:absolute;top:0;height:100%;width:1px;background:#ffffff1a}.hour-marker span{position:absolute;bottom:-18px;left:50%;transform:translate(-50%);font-size:10px;color:#3a7595}.now-marker{position:absolute;top:0;width:3px;height:100%;background:#4fc3f7;transform:translate(-50%);z-index:1;box-shadow:0 0 6px #4fc3f780}.tide-arrow{position:absolute;display:flex;flex-direction:column;align-items:center;transform:translate(-50%);z-index:2}.tide-arrow.high{top:2px}.tide-arrow.low{bottom:2px;flex-direction:column-reverse}.tide-arrow .arrow{font-size:14px;line-height:1}.tide-arrow.high .arrow{color:#4caf50}.tide-arrow.low .arrow{color:#ff9800}.tide-arrow .tide-info{display:flex;flex-direction:column;align-items:center;margin-top:2px;white-space:nowrap}.tide-arrow.low .tide-info{position:absolute;bottom:100%;margin-top:0;margin-bottom:2px}.tide-arrow .tide-value{font-size:11px;font-weight:700;color:#fff;white-space:nowrap}.tide-arrow .tide-time-label{font-size:8px;color:#fff;white-space:nowrap;font-weight:700;line-height:12px}@media (max-width: 768px){body{padding:10px}h1{margin:0;font-size:24px}.data-grid{gap:8px;margin-bottom:12px}.card{padding:12px;border-radius:8px}.card h2{margin-bottom:4px;font-size:12px}.card .value{font-size:24px}.card .station,.card .timestamp{margin-top:4px}.tide-gauge{margin-top:20px;margin-bottom:8px}.tide-gauge-labels{margin-top:4px;font-size:10px}.tides-forecast{padding:12px;border-radius:8px}.tides-forecast h2{margin-bottom:8px}.day-label{font-size:12px;margin-bottom:4px}.day-timeline{height:50px;margin-bottom:10px}}
