*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #F5E6D3;--navy: #1B2631;--coral: #E74C3C;--coral-light: #F39C12;--white: #FFFFFF;--text-muted: #7A7974;--border: #D4C5B0;--card-bg: #F7F4F0;--font: "Satoshi", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--col-w: 52px;--col-count: 15;--total-w: calc(var(--col-w) * var(--col-count))}html{font-size:16px}body{font-family:var(--font);background:var(--bg);color:var(--navy);min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden}.header{background:linear-gradient(180deg,var(--navy) 0%,#243342 100%);color:var(--white);padding:16px 20px 14px}.header-top{display:flex;align-items:center;gap:10px;margin-bottom:14px}.header-tabs-row{display:flex;align-items:center;gap:0;margin-top:14px;margin-bottom:4px}.updated-time{padding-left:8px;display:flex;align-items:center;gap:4px;flex-shrink:0;color:#fff6;white-space:nowrap;cursor:default}.updated-icon{width:14px;height:14px;flex-shrink:0;opacity:.45;transition:opacity .2s}.updated-icon.spinning{animation:iconSpin 1s linear infinite;opacity:.75}@keyframes iconSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.updated-ts{font-size:.62rem;font-weight:600;color:#ffffff80}@media (max-width: 480px){.updated-icon{opacity:.5}}.header-logo svg{width:34px;height:34px}.header-title{font-size:1.3rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1px}.header-tagline{font-size:.68rem;font-weight:400;color:#ffffff73;letter-spacing:.01em}.header-title-wrap{min-width:0;flex:1}.day-tabs{display:flex;gap:6px;flex-wrap:nowrap;overflow-x:auto;flex:1;min-width:0;scrollbar-width:none;padding-right:4px}.day-tabs::-webkit-scrollbar{display:none}.day-tab{padding:7px 12px;border-radius:20px;border:1.5px solid rgba(255,255,255,.2);background:transparent;color:#ffffffa6;font-family:var(--font);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.day-tab:hover{border-color:#ffffff73;color:var(--white)}.day-tab.active{background:var(--white);color:var(--navy);border-color:var(--white);font-weight:700}.now-label{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff6;margin-bottom:4px;margin-top:14px}.current-conditions{display:flex;align-items:center;gap:14px;font-size:.85rem;color:#ffffffbf;flex-wrap:wrap}.condition-item{display:flex;align-items:center;gap:5px}.condition-value{font-weight:700;color:var(--white)}.non-coastal-notice{display:flex;align-items:flex-start;gap:12px;background:#eaf4fb;border-left:4px solid #2980B9;color:#1a3a4a;padding:14px 18px;font-size:.88rem;line-height:1.5;margin:0}.non-coastal-notice[hidden]{display:none}.non-coastal-notice strong{display:block;font-weight:700;margin-bottom:3px;font-size:.9rem}.non-coastal-notice p{margin:0;opacity:.85}.non-coastal-icon{font-size:1.4rem;flex-shrink:0;line-height:1;margin-top:1px}.info-banner{color:var(--white);text-align:center;font-weight:700;display:none}.info-banner.visible{display:flex;align-items:center;justify-content:center;gap:8px}.info-banner .label{font-weight:500;opacity:.92}.info-banner .time-range{font-weight:800;letter-spacing:.01em}.best-time-banner{background:linear-gradient(135deg,#f39c12,#e67e22,#e74c3c);padding:11px 20px;font-size:.9rem;text-shadow:0 1px 2px rgba(0,0,0,.12)}.sea-frett-banner{background:linear-gradient(135deg,#4a7a94,#3d6678,#2f5163);padding:10px 20px;font-size:.85rem;text-shadow:0 1px 2px rgba(0,0,0,.2)}.best-time-info-btn{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;border:1.5px solid rgba(255,255,255,.6);background:transparent;color:#ffffffd9;font-size:.65rem;font-weight:700;font-family:var(--font);cursor:pointer;flex-shrink:0;line-height:1;transition:background .15s}.best-time-info-btn:hover{background:#fff3}.best-time-popover{position:fixed;bottom:0;left:0;right:0;background:#1a2535;border-radius:16px 16px 0 0;padding:20px 24px 28px;z-index:200;box-shadow:0 -4px 24px #0006;transform:translateY(100%);transition:transform .25s ease;max-width:540px;margin:0 auto}.best-time-popover.open{transform:translateY(0)}.best-time-popover h3{font-size:.95rem;font-weight:700;color:var(--white);margin:0 0 10px}.best-time-popover p{font-size:.8rem;color:#ffffffa6;line-height:1.5;margin:0 0 12px}.best-time-factors{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.best-time-factors li{display:flex;align-items:center;gap:10px;font-size:.8rem;color:#fffc}.factor-bar-wrap{flex:1;height:4px;background:#ffffff1f;border-radius:2px}.factor-bar{height:4px;border-radius:2px;background:#3498db}.factor-pct{font-size:.7rem;color:#ffffff73;width:30px;text-align:right}.best-time-popover-close{position:absolute;top:14px;right:18px;background:none;border:none;color:#ffffff80;font-size:1.3rem;cursor:pointer;line-height:1}.scroll-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border) transparent;overscroll-behavior-x:contain}.scroll-wrapper::-webkit-scrollbar{height:4px}.scroll-wrapper::-webkit-scrollbar-track{background:transparent}.scroll-wrapper::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.scroll-inner{width:var(--total-w);min-width:100%}@media (min-width: 780px){:root{--col-w: calc(100vw / var(--col-count, 15));--total-w: 100vw}}.weather-strip-container{background:var(--card-bg);border-bottom:1px solid var(--border)}.weather-strip{display:grid;grid-template-columns:repeat(var(--col-count, 15),var(--col-w));width:var(--total-w)}.weather-col{display:grid;grid-template-rows:18px 16px 14px 14px 26px 14px 18px;align-items:center;justify-items:center;padding:8px 0 6px;position:relative;background:var(--card-bg);border-right:1px solid rgba(0,0,0,.06)}.weather-col:last-child{border-right:none}.weather-col.best-hour{background:#f39c1226}.weather-col.best-hour:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#f39c12,#e74c3c);border-radius:3px 3px 0 0}.weather-col.current-hour{border-top:3px solid #3498db}.weather-temp{font-size:.78rem;font-weight:700;color:var(--navy);font-variant-numeric:tabular-nums;line-height:1}.weather-wind{font-size:.62rem;color:var(--text-muted);font-weight:500;font-variant-numeric:tabular-nums;line-height:1}.weather-wind small{font-size:.5rem;opacity:.7}.weather-gust{font-size:.58rem;color:#c0392b;font-weight:700;font-variant-numeric:tabular-nums;line-height:1}.weather-frett{font-size:.55rem;color:#5d8a9e;font-weight:700;line-height:1;letter-spacing:.01em}.weather-icon{font-size:1.2rem;line-height:1}.weather-precip{font-size:.58rem;color:#2980b9;font-weight:600;line-height:1}.weather-hour{font-size:.62rem;color:var(--text-muted);font-weight:600;line-height:1}.beach-outer{position:relative}.beach-container{position:relative;width:var(--total-w)}#beachCanvas{display:block;width:var(--total-w);height:auto}.tide-axis{position:absolute;top:0;left:0;pointer-events:none}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;transition:opacity .5s ease}.loading-overlay.hidden{opacity:0;pointer-events:none}.loading-wave{width:64px;height:64px;margin-bottom:18px}.loading-text{font-size:.9rem;color:var(--text-muted);font-weight:500}.error-state{text-align:center;padding:60px 20px;display:none}.error-state.visible{display:block}.error-state h2{font-size:1.15rem;margin-bottom:8px;font-weight:700}.error-state p{color:var(--text-muted);font-size:.88rem;max-width:340px;margin:0 auto;line-height:1.5}.error-state a{color:#2980b9;font-weight:600;text-decoration:underline}.error-state button{margin-top:20px;padding:10px 28px;border-radius:24px;border:none;background:var(--navy);color:var(--white);font-family:var(--font);font-weight:600;font-size:.85rem;cursor:pointer;transition:transform .15s,box-shadow .15s}.error-state button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.location-btn{display:flex;align-items:center;gap:6px;background:#ffffff26;border:1.5px solid rgba(255,255,255,.35);border-radius:20px;color:var(--white);font-family:var(--font);font-size:.8rem;font-weight:700;padding:6px 10px;cursor:pointer;transition:background .2s,border-color .2s;white-space:nowrap;max-width:180px;margin-left:auto;flex-shrink:0}.location-btn:hover{background:#ffffff40;border-color:#fff9}.location-btn .loc-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.location-btn .loc-chevron{opacity:.6;flex-shrink:0}.location-btn svg.loc-pin{flex-shrink:0;opacity:.8}.loc-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a14288c;z-index:900;display:none;align-items:flex-end;justify-content:center}.loc-overlay.open{display:flex}.loc-sheet{background:var(--white);border-radius:20px;width:100%;max-width:560px;max-height:92vh;display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom,0);animation:sheetUp .25s ease}@media (min-width: 641px){.loc-sheet{border-radius:20px 20px 0 0}.loc-overlay{align-items:flex-end}}@media (max-width: 640px){.loc-overlay{align-items:flex-start;padding-top:60px}.loc-sheet{height:calc(92vh - 60px)}}@keyframes sheetUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.loc-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 12px;border-bottom:1px solid var(--border)}.loc-sheet-header h2{font-size:1rem;font-weight:700;color:var(--navy)}.loc-close{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:1.4rem;line-height:1;padding:2px 4px}.loc-search-wrap{padding:12px 16px;border-bottom:1px solid var(--border)}.loc-search{width:100%;padding:9px 14px;border-radius:10px;border:1.5px solid var(--border);font-family:var(--font);font-size:1rem;background:var(--bg);color:var(--navy);outline:none;transition:border-color .2s}.loc-search:focus{border-color:#3498db}.loc-list{overflow-y:auto;flex:1;padding:6px 0 12px}.loc-item{display:flex;align-items:center;gap:10px;padding:11px 20px;cursor:pointer;transition:background .15s;border-bottom:1px solid rgba(0,0,0,.04)}.loc-item:hover{background:var(--bg)}.loc-item.active{background:#3498db14}.loc-item-name{font-size:.88rem;font-weight:600;color:var(--navy)}.loc-item-type{font-size:.72rem;color:var(--text-muted);margin-top:1px}.loc-item-tick{margin-left:auto;color:#3498db;font-size:1rem;display:none}.loc-item.active .loc-item-tick{display:block}.loc-loading,.loc-empty{padding:24px;text-align:center;color:var(--text-muted);font-size:.85rem}.feedback-section{display:flex;flex-direction:column;align-items:center;gap:8px;padding:28px 20px 20px;background:var(--bg)}.feedback-btn{display:inline-flex;align-items:center;gap:8px;background:var(--navy);color:var(--white);border:2px solid rgba(255,255,255,.15);border-radius:24px;font-family:var(--font);font-size:.9rem;font-weight:700;padding:12px 24px;cursor:pointer;transition:background .2s,transform .15s;letter-spacing:.01em}.feedback-btn:hover{background:#1a2d4a;transform:translateY(-1px)}.feedback-btn:active{transform:translateY(0)}.feedback-hint{font-size:.72rem;color:var(--text-muted);font-weight:500}.footer{text-align:center;padding:16px 20px 24px;font-size:.75rem;color:var(--text-muted);line-height:1.6}.footer a{color:#2980b9;text-decoration:none;font-weight:500}.footer a:hover{text-decoration:underline}.footer .location{font-weight:700;color:var(--navy);display:block;margin-bottom:4px;font-size:.8rem}.build-time{display:block;margin-top:6px;font-size:.65rem;color:var(--border)}.sst-badge{position:absolute;left:50vw;transform:translate(-50%);z-index:10;pointer-events:none;display:flex;align-items:center;gap:10px;background:#082046a6;border:1px solid rgba(100,170,255,.3);border-radius:20px;padding:8px 14px 8px 12px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);white-space:nowrap}.sst-text{display:flex;flex-direction:column;gap:3px}.sst-temp{font-size:15px;font-weight:700;color:#fffffff5;line-height:1;font-variant-numeric:tabular-nums}.sst-label{font-size:9.5px;font-weight:500;color:#96d2ffcc;letter-spacing:.04em;line-height:1}.skeleton-strip{display:grid;grid-template-columns:repeat(var(--col-count, 15),var(--col-w));width:var(--total-w);padding:10px 0}.skeleton-col{display:flex;flex-direction:column;align-items:center;gap:6px;padding:0 4px}.skeleton-block{background:linear-gradient(90deg,#e0d5c8 25%,#ede3d6,#e0d5c8 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}
