﻿:root{--color-bg-primary: #0a1628;--color-bg-secondary: #122a4a;--color-bg-card: #1a3a5c;--color-bg-card-hover: #224a70;--color-accent-primary: #00d4aa;--color-accent-secondary: #4fc3f7;--color-accent-warning: #ffb74d;--color-accent-danger: #ef5350;--color-text-primary: #e8f4f8;--color-text-secondary: #b0d0e0;--color-text-muted: #8aaaba;--color-tide-rising: #4fc3f7;--color-tide-falling: #ff8a65;--color-tide-high: #00d4aa;--color-tide-low: #ffb74d;--color-chart-line: #00d4aa;--color-chart-fill: rgba(0, 212, 170, 0.15);--color-chart-now: #ef5350;--color-chart-grid: rgba(148, 184, 200, 0.1);--color-rating-good: #00d4aa;--color-rating-fair: #ffb74d;--color-rating-poor: #ff8a65;--color-rating-hazard: #ef5350;--gradient-good: linear-gradient(135deg, #0a3d2e 0%, #1a5c4a 100%);--gradient-fair: linear-gradient(135deg, #3d3a0a 0%, #5c5a1a 100%);--gradient-poor: linear-gradient(135deg, #3d1a0a 0%, #5c2a1a 100%);--gradient-hazardous: linear-gradient(135deg, #3d0a0a 0%, #5c1a1a 100%);--color-icon-sunrise: #ffb74d;--color-icon-sunset: #ff8a65;--space-xs: 0.25rem;--space-sm: 0.5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-card: 0 4px 20px rgba(0, 0, 0, 0.3);--shadow-glow: 0 0 20px rgba(0, 212, 170, 0.3);--font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;--font-mono: 'SF Mono', Monaco, 'Cascadia Code', 'Courier New', monospace}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background:linear-gradient(135deg, var(--color-bg-primary) 0%, var(--color-bg-secondary) 100%);background-attachment:fixed;color:var(--color-text-primary);min-height:100vh;line-height:1.6}a{color:var(--color-accent-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-accent-secondary);text-decoration:underline}header{position:sticky;top:0;z-index:1000;height:48px;background:rgba(22,22,24,.85);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid hsla(0,0%,100%,.06)}.header-nav{display:flex;align-items:center;max-width:1200px;margin:0 auto;padding:0 16px;height:100%;gap:16px}.header-brand{display:flex;align-items:center;gap:6px;text-decoration:none;color:var(--color-text-primary);transition:opacity .2s ease}.header-brand:hover{opacity:.7;text-decoration:none;color:var(--color-text-primary)}.header-brand .brand-icon{font-size:18px;line-height:1}.header-brand .brand-text{font-size:14px;font-weight:600;letter-spacing:-0.01em}@media(max-width: 400px){.header-brand .brand-text{display:none}}.location-button{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;background:rgba(0,0,0,0);border:none;border-radius:4px;font-family:var(--font-family);color:var(--color-text-primary);cursor:pointer;transition:opacity .15s ease;margin-left:auto}.location-button:hover{opacity:.7}.location-button:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.location-button[aria-expanded=true] .chevron-icon{transform:rotate(180deg)}.location-button .location-name{font-size:17px;font-weight:600;letter-spacing:-0.02em}.location-button .chevron-icon{opacity:.4;transition:transform .2s ease;margin-top:1px}@media(max-width: 480px){.location-button .location-name{font-size:15px;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.theme-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:hsla(0,0%,100%,.08);border:none;border-radius:8px;font-size:15px;color:var(--color-text-primary);cursor:pointer;transition:background-color .15s ease,transform .15s ease;flex-shrink:0}.theme-toggle:hover{background:hsla(0,0%,100%,.15);transform:scale(1.05)}.theme-toggle:active{transform:scale(0.95)}.theme-toggle:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.theme-toggle #theme-icon{line-height:1}.location-panel{position:fixed;inset:0;z-index:2000}.location-panel[hidden]{display:none}.panel-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.panel-content{position:absolute;top:60px;left:50%;transform:translateX(-50%);width:90%;max-width:400px;max-height:calc(100vh - 100px);overflow-y:auto;background:var(--color-bg-card);border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.3);animation:panel-slide-down .2s ease-out}@media(max-width: 480px){.panel-content{top:auto;bottom:0;left:0;right:0;transform:none;width:100%;max-width:none;max-height:70vh;border-radius:16px 16px 0 0;animation:panel-slide-up .25s ease-out}}@keyframes panel-slide-down{from{opacity:0;transform:translateX(-50%) translateY(-10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}@keyframes panel-slide-up{from{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid hsla(0,0%,100%,.08)}.panel-header .panel-title{font-size:17px;font-weight:600;letter-spacing:-0.02em;color:var(--color-text-primary)}.panel-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:hsla(0,0%,100%,.08);border:none;border-radius:50%;font-size:14px;color:var(--color-text-secondary);cursor:pointer;transition:background-color .2s ease}.panel-close:hover{background:hsla(0,0%,100%,.15)}.panel-body{padding:16px 20px 24px}.location-group{margin-bottom:28px}.location-group:last-child{margin-bottom:0}.location-group.single-option{opacity:.8}.location-group.single-option .location-group-label::after{content:" (only option)";font-weight:400;text-transform:none;letter-spacing:normal;opacity:.7}.location-group-label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:12px}.location-options{display:flex;flex-wrap:wrap;gap:10px}.location-option{padding:12px 20px;background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.12);border-radius:24px;font-family:var(--font-family);font-size:14px;font-weight:500;color:var(--color-text-primary);cursor:pointer;transition:all .15s ease}.location-option:hover:not(:disabled){background:hsla(0,0%,100%,.15);border-color:hsla(0,0%,100%,.2);transform:translateY(-1px)}.location-option:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.location-option.selected{background:var(--color-accent-primary);border-color:var(--color-accent-primary);color:#fff;font-weight:600;box-shadow:0 2px 8px rgba(0,212,170,.3)}.location-option.only-option{cursor:default;background:hsla(0,0%,100%,.05);border-color:hsla(0,0%,100%,.1)}.location-option.only-option.selected{background:rgba(0,212,170,.2);border-color:rgba(0,212,170,.4);color:var(--color-text-primary);box-shadow:none}.location-option.only-option:hover:not(:disabled){transform:none}footer{text-align:center;padding:var(--space-lg) var(--space-md);color:var(--color-text-muted);font-size:.8rem;border-top:1px solid hsla(0,0%,100%,.05);margin-top:var(--space-lg)}footer p{margin-bottom:var(--space-sm)}#last-update{font-family:var(--font-mono);font-size:.75rem}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:var(--space-lg);padding:var(--space-lg);max-width:1400px;margin:0 auto}@media(min-width: 768px){.dashboard-grid{grid-template-columns:repeat(2, 1fr)}}@media(min-width: 1200px){.dashboard-grid{grid-template-columns:repeat(3, 1fr)}}.card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-card);border:1px solid hsla(0,0%,100%,.05);transition:transform .2s ease,box-shadow .2s ease}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card),var(--shadow-glow)}.card h2{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-secondary);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid hsla(0,0%,100%,.1)}.card.loading{opacity:.7;position:relative}.card.loading::after{content:"Loading...";position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);background:rgba(0,0,0,.8);color:var(--color-accent-primary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.85rem;animation:pulse 1.5s ease-in-out infinite}@media(min-width: 768px){.card-wide{grid-column:span 2}}@media(min-width: 1200px){.card-wide{grid-column:span 3}}.card-header+* h2,.card-header h2{margin-bottom:0;padding-bottom:0;border-bottom:none}@keyframes pulse{0%,100%{opacity:.6}50%{opacity:1}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width: 480px){.dashboard-grid{padding:var(--space-md);gap:var(--space-md)}.card{padding:var(--space-md)}}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid hsla(0,0%,100%,.1)}.card-header h2{margin-bottom:0;padding-bottom:0;border-bottom:none}.data-freshness{font-size:.75rem;font-weight:500;padding:2px 8px;border-radius:10px;background:rgba(0,0,0,.3);white-space:nowrap}.data-freshness.fresh{color:var(--color-rating-good)}.data-freshness.stale{color:var(--color-accent-warning)}.data-freshness.old{color:var(--color-accent-danger)}.data-freshness.cached::before{content:"📦 "}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-lg);text-align:center;color:var(--color-text-muted)}.error-state .error-icon{font-size:2rem;margin-bottom:var(--space-sm)}.error-state .error-message{font-size:.85rem;margin-bottom:var(--space-md)}.retry-btn{background:var(--color-bg-card-hover);color:var(--color-accent-primary);border:1px solid var(--color-accent-primary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;font-size:.8rem;font-weight:600;transition:all .2s ease}.retry-btn:hover{background:var(--color-accent-primary);color:var(--color-bg-primary)}.retry-btn:disabled{opacity:.5;cursor:not-allowed}.status-indicator{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);min-height:100px}.status-indicator .arrow{font-size:3rem;line-height:1;transition:all .2s ease}.status-indicator .label{font-size:1.2rem;font-weight:700;letter-spacing:.15em}.status-indicator.rising .arrow,.status-indicator.rising .label{color:var(--color-tide-rising)}.status-indicator.falling .arrow,.status-indicator.falling .label{color:var(--color-tide-falling)}.status-indicator.unavailable .arrow,.status-indicator.unavailable .label{color:var(--color-text-muted)}.value-display{text-align:center;min-height:80px;display:flex;flex-direction:column;align-items:center;justify-content:center}.value-display .value{font-family:var(--font-mono);font-size:2.8rem;font-weight:700;color:var(--color-text-primary);color:var(--color-accent-primary);line-height:1.1}.value-display .unit{font-size:.85rem;color:var(--color-text-secondary);margin-top:var(--space-xs)}.timestamp{text-align:center;font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-sm)}.unavailable{color:var(--color-accent-warning) !important}.error-message{color:var(--color-accent-danger);font-size:.85rem;text-align:center;padding:var(--space-md)}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--color-text-muted);border-top-color:var(--color-accent-primary);border-radius:50%;animation:spin 1s linear infinite}.swell-quality--epic{color:var(--color-rating-epic) !important}.swell-quality--good{color:var(--color-rating-good) !important}.swell-quality--fair{color:var(--color-rating-fair) !important}.swell-quality--poor{color:var(--color-rating-poor) !important}.swell-quality--muted{color:var(--color-text-muted) !important}.card-hero{grid-column:1/-1;background:var(--gradient-good);border:2px solid var(--color-rating-good);padding:var(--space-lg) var(--space-xl);transition:background .5s ease,border-color .5s ease}.card-hero:hover{transform:none}@media(max-width: 480px){.card-hero{padding:var(--space-md) var(--space-lg)}}.ocean-status{text-align:center}.status-badge{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:50px;background:rgba(0,0,0,.3);margin-bottom:var(--space-sm)}.status-badge .rating-icon{font-size:1.8rem}.status-badge .rating-text{font-size:1.8rem;font-weight:800;letter-spacing:.1em;color:var(--color-rating-good);transition:color .3s ease}.status-badge.good .rating-text{color:var(--color-rating-good)}.status-badge.fair .rating-text{color:var(--color-rating-fair)}.status-badge.poor .rating-text{color:var(--color-rating-poor)}.status-badge.hazardous .rating-text{color:var(--color-rating-hazard)}@media(max-width: 480px){.status-badge{padding:var(--space-xs) var(--space-md)}.status-badge .rating-icon,.status-badge .rating-text{font-size:1.4rem}}.status-message{font-size:1rem;color:var(--color-text-primary);margin-bottom:var(--space-md);font-weight:400}@media(max-width: 480px){.status-message{font-size:.9rem}}.status-details{display:grid;grid-template-columns:repeat(4, 1fr);gap:var(--space-sm);margin-bottom:var(--space-md);max-width:600px;margin-left:auto;margin-right:auto}@media(max-width: 600px){.status-details{grid-template-columns:repeat(2, 1fr)}}.detail-item{background:rgba(0,0,0,.2);padding:var(--space-sm);border-radius:var(--radius-sm);text-align:center}.detail-item .detail-label{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:2px}.detail-item .detail-value{display:block;font-size:.85rem;font-weight:600;color:var(--color-text-primary)}.detail-item .detail-value.good{color:var(--color-rating-good)}.detail-item .detail-value.fair{color:var(--color-rating-fair)}.detail-item .detail-value.poor{color:var(--color-rating-poor)}.detail-item .detail-value.hazardous{color:var(--color-rating-hazard)}.skill-recommendation{font-size:.8rem;color:var(--color-text-secondary);font-style:italic;margin-bottom:0}.hazard-alerts{margin-top:var(--space-lg);display:none}.hazard-alert{display:inline-flex;align-items:center;gap:var(--space-sm);background:rgba(239,83,80,.2);border:1px solid var(--color-accent-danger);color:var(--color-accent-danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);margin:var(--space-xs);font-weight:600;font-size:.85rem}.tide-hero-section{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--space-md);align-items:center;margin:var(--space-md) 0 0;padding:var(--space-md);background:rgba(0,0,0,.25);border-radius:var(--radius-md)}@media(max-width: 700px){.tide-hero-section{grid-template-columns:1fr;gap:var(--space-sm);text-align:center;padding:var(--space-sm)}}.tide-direction-hero{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs)}.tide-direction-hero .tide-arrow-large{font-size:2.5rem;line-height:1;animation:bounce 1.5s ease-in-out infinite}.tide-direction-hero .tide-state-text{font-size:1.2rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.tide-direction-hero .current-level-hero{font-size:.85rem;color:var(--color-text-secondary);font-family:var(--font-mono)}.tide-direction-hero.rising .tide-arrow-large,.tide-direction-hero.rising .tide-state-text{color:var(--color-tide-rising)}.tide-direction-hero.falling .tide-arrow-large,.tide-direction-hero.falling .tide-state-text{color:var(--color-tide-falling)}.tide-countdown{text-align:center;padding:var(--space-sm) var(--space-md)}.tide-countdown .countdown-label{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:var(--space-xs)}.tide-countdown .countdown-time{display:block;font-family:var(--font-mono);font-size:1.6rem;font-weight:700;color:var(--color-text-primary);line-height:1.2;margin-bottom:var(--space-xs)}.tide-countdown .countdown-detail{display:block;font-size:.75rem;color:var(--color-text-secondary)}.tide-countdown.high .countdown-label{color:var(--color-tide-high)}.tide-countdown.low .countdown-label{color:var(--color-tide-low)}.beach-window{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:rgba(0,0,0,.2);border-radius:var(--radius-sm)}.beach-window .beach-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.beach-window .beach-status{font-size:1.1rem;font-weight:700}.beach-window .beach-detail{font-size:.7rem;color:var(--color-text-secondary);text-align:center}.beach-window.active .beach-status{color:var(--color-rating-good)}.beach-window.upcoming .beach-status{color:var(--color-rating-fair)}.beach-window.inactive .beach-status{color:var(--color-text-muted)}.rating-breakdown-container{margin-top:var(--space-md);max-width:600px;margin-left:auto;margin-right:auto}.rating-breakdown-toggle{display:inline-flex;align-items:center;gap:var(--space-sm);background:rgba(0,0,0,0);border:1px solid hsla(0,0%,100%,.2);color:var(--color-text-secondary);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);font-size:.8rem;cursor:pointer;transition:all .2s ease}.rating-breakdown-toggle:hover{background:hsla(0,0%,100%,.08);color:var(--color-text-primary);border-color:hsla(0,0%,100%,.3)}.rating-breakdown-toggle .toggle-icon{font-size:.6rem;transition:all .2s ease}.rating-breakdown-toggle[aria-expanded=true] .toggle-icon{transform:rotate(180deg)}.rating-breakdown-content{margin-top:var(--space-sm);background:rgba(0,0,0,.3);border-radius:var(--radius-md);padding:var(--space-md);text-align:left}.rating-breakdown-content[hidden]{display:none}.breakdown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid hsla(0,0%,100%,.1)}.breakdown-score{font-size:.85rem;color:var(--color-text-secondary)}.breakdown-score strong{color:var(--color-accent-primary);font-size:1.1rem;font-family:var(--font-mono)}.breakdown-link{font-size:.75rem;color:var(--color-accent-primary);text-decoration:none}.breakdown-link:hover{text-decoration:underline}.breakdown-factors{display:flex;flex-direction:column;gap:var(--space-xs)}.breakdown-factor{display:grid;grid-template-columns:100px 1fr auto;gap:var(--space-sm);align-items:center;padding:var(--space-xs) 0;font-size:.8rem}@media(max-width: 480px){.breakdown-factor{grid-template-columns:80px 1fr auto;font-size:.75rem}}.factor-name{color:var(--color-text-muted);font-weight:500;text-transform:uppercase;font-size:.7rem;letter-spacing:.03em}.factor-detail{color:var(--color-text-secondary)}.factor-impact{font-family:var(--font-mono);font-weight:600;text-align:right;min-width:40px}.factor-impact.positive{color:var(--color-rating-good)}.factor-impact.negative{color:var(--color-rating-poor)}.factor-impact.neutral{color:var(--color-text-muted)}.breakdown-empty{color:var(--color-text-muted);font-size:.8rem;font-style:italic;text-align:center;margin:0}:root.light-mode .rating-breakdown-toggle{border-color:rgba(0,0,0,.15)}:root.light-mode .rating-breakdown-toggle:hover{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.25)}:root.light-mode .rating-breakdown-content{background:rgba(0,0,0,.04)}:root.light-mode .breakdown-header{border-bottom-color:rgba(0,0,0,.1)}.sun-times-content{display:flex;justify-content:space-around;align-items:center;gap:var(--space-md);padding:var(--space-md) 0}.sun-item{text-align:center;flex:1}.sun-item .sun-icon{font-size:2rem;margin-bottom:var(--space-xs)}.sun-item .sun-label{display:block;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:var(--space-xs)}.sun-item .sun-time{font-family:var(--font-mono);font-size:1.4rem;font-weight:600;color:var(--color-text-primary)}.sun-item.sunrise .sun-icon{color:var(--color-icon-sunrise)}.sun-item.sunset .sun-icon{color:var(--color-icon-sunset)}.day-length{text-align:center;font-size:.85rem;color:var(--color-text-secondary);padding-top:var(--space-sm);border-top:1px solid hsla(0,0%,100%,.1);margin-top:var(--space-md)}.swell-content{display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-lg);align-items:center}@media(max-width: 500px){.swell-content{grid-template-columns:1fr;text-align:center}}.swell-primary{text-align:center}.swell-primary .swell-height{font-family:var(--font-mono);font-size:3rem;font-weight:700;color:var(--color-accent-primary);line-height:1}@media(max-width: 480px){.swell-primary .swell-height{font-size:2.2rem}}.swell-primary .swell-unit{font-size:1rem;color:var(--color-text-secondary)}.swell-primary .swell-quality{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-top:var(--space-xs)}.swell-details{display:flex;flex-direction:column;gap:var(--space-sm)}.swell-detail{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm);background:rgba(0,0,0,.2);border-radius:var(--radius-sm)}.swell-detail .label{font-size:.8rem;color:var(--color-text-muted)}.swell-detail .value{font-family:var(--font-mono);font-size:.9rem;color:var(--color-text-primary);font-weight:600;white-space:nowrap}.swell-compass{width:80px;height:80px;position:relative}@media(max-width: 480px){.swell-compass{display:none}}.compass-ring{width:100%;height:100%;border:2px solid var(--color-text-muted);border-radius:50%;position:relative}.compass-arrow{position:absolute;top:50%;left:50%;width:4px;height:35px;background:var(--color-accent-primary);transform-origin:bottom center;transform:translate(-50%, -100%) rotate(0deg);border-radius:2px;transition:transform .5s ease}.compass-arrow::after{content:"";position:absolute;top:-6px;left:-4px;border-left:6px solid rgba(0,0,0,0);border-right:6px solid rgba(0,0,0,0);border-bottom:10px solid var(--color-accent-primary)}.compass-labels{position:absolute;top:0;left:0;width:100%;height:100%;font-size:.6rem;color:var(--color-text-muted)}.compass-labels span{position:absolute}.compass-labels .n{top:2px;left:50%;transform:translateX(-50%)}.compass-labels .s{bottom:2px;left:50%;transform:translateX(-50%)}.compass-labels .e{right:4px;top:50%;transform:translateY(-50%)}.compass-labels .w{left:4px;top:50%;transform:translateY(-50%)}.tide-pair{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.next-high,.next-low{text-align:center;padding:var(--space-md);border-radius:var(--radius-md);background:rgba(0,0,0,.2)}.next-high .type,.next-low .type{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--color-text-muted);font-weight:700;margin-bottom:var(--space-sm)}.next-high .value,.next-low .value{display:block;font-family:var(--font-mono);font-size:1.3rem;font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-xs)}.next-high .time,.next-low .time{display:block;font-size:.8rem;color:var(--color-text-secondary)}.next-high .type{color:var(--color-tide-high)}.next-low .type{color:var(--color-tide-low)}.chart-container{position:relative;height:250px;width:100%}@media(max-width: 480px){.chart-container{height:200px}}#tide-chart{width:100% !important;height:100% !important}.weather-content{text-align:center}.wind-info{display:flex;align-items:center;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-md);padding:var(--space-md);background:rgba(0,0,0,.2);border-radius:var(--radius-md)}.wind-arrow{font-size:2rem;color:var(--color-accent-secondary);transition:transform .5s ease;display:inline-block}.wind-speed{font-family:var(--font-mono);font-size:1.1rem;color:var(--color-accent-secondary);font-weight:600}.wind-direction-text{font-size:.8rem;color:var(--color-text-secondary);display:block}.forecast{color:var(--color-text-secondary);font-size:.9rem;line-height:1.5}.temperature{font-size:1rem;color:var(--color-text-primary);margin-bottom:var(--space-sm)}#signup-card{padding:var(--space-md) var(--space-lg)}.signup-header{text-align:center;margin-bottom:var(--space-sm)}.signup-header h2{margin-bottom:4px;font-size:1.1rem}.signup-header .signup-subtitle{color:var(--color-text-secondary);font-size:.8rem}.signup-form{max-width:500px;margin:0 auto}.signup-row{margin-bottom:var(--space-sm)}.signup-row:last-of-type{margin-bottom:0}.signup-location-row{display:grid;grid-template-columns:repeat(3, 1fr);gap:var(--space-sm)}@media(max-width: 480px){.signup-location-row{grid-template-columns:1fr;gap:var(--space-xs)}}.turnstile-row{display:flex;justify-content:center}.form-group>label:not(.radio-option){display:block;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:3px}.form-group input[type=email],.form-group input[type=text],.form-group select{width:100%;padding:8px 12px;background:var(--color-bg-secondary);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:.9rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.form-group input[type=email]:focus,.form-group input[type=text]:focus,.form-group select:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 2px rgba(0,212,170,.2)}.form-group input[type=email]::placeholder,.form-group input[type=text]::placeholder,.form-group select::placeholder{color:var(--color-text-muted)}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394b8c8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}.form-group-email{max-width:400px;margin:0 auto}.radio-group{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}@media(max-width: 480px){.radio-group{grid-template-columns:1fr}}.radio-option{display:grid;grid-template-columns:18px 1fr;grid-template-rows:auto auto;column-gap:10px;row-gap:2px;padding:12px 14px;background:var(--color-bg-secondary);border:2px solid hsla(0,0%,100%,.12);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;text-transform:none;letter-spacing:normal;font-size:inherit;color:inherit;margin-bottom:0}.radio-option:hover{border-color:hsla(0,0%,100%,.25);background:var(--color-bg-card-hover)}.radio-option:has(input:checked){border-color:var(--color-accent-primary);background:rgba(0,212,170,.08);box-shadow:0 0 0 1px var(--color-accent-primary)}.radio-option input[type=radio]{appearance:none;width:18px;height:18px;border:2px solid hsla(0,0%,100%,.3);border-radius:50%;margin:0;grid-column:1;grid-row:1;align-self:center;position:relative;cursor:pointer;transition:border-color .2s,background-color .2s}.radio-option input[type=radio]:checked{border-color:var(--color-accent-primary);background:var(--color-accent-primary)}.radio-option input[type=radio]:checked::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);width:6px;height:6px;background:#fff;border-radius:50%}.radio-option .radio-label{grid-column:2;grid-row:1;font-size:.95rem;font-weight:600;color:var(--color-text-primary);align-self:center}.radio-option .radio-desc{grid-column:2;grid-row:2;font-size:.7rem;font-weight:400;color:var(--color-text-muted);line-height:1.4;margin-top:2px}.conditional-section[style*="display: none"]{display:none !important}.slider-container{padding:var(--space-xs) 0}input[type=range]{width:100%;height:8px;border-radius:4px;background:var(--color-bg-secondary);appearance:none;cursor:pointer;touch-action:none}input[type=range]::-webkit-slider-thumb{appearance:none;width:28px;height:28px;border-radius:50%;background:var(--color-accent-primary);cursor:pointer;transition:transform .2s}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1)}input[type=range]::-moz-range-thumb{width:28px;height:28px;border:none;border-radius:50%;background:var(--color-accent-primary);cursor:pointer}.slider-labels{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-xs);font-size:.75rem;color:var(--color-text-muted)}.slider-labels .slider-value{font-size:1.2rem;font-weight:700;color:var(--color-accent-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 24px;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .2s,transform .2s}.btn:hover{opacity:.9}.btn:active{transform:scale(0.98)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{width:100%;max-width:240px;margin:0 auto;display:flex;background:var(--color-accent-primary);color:var(--color-bg-primary)}.signup-disclaimer{text-align:center;font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-sm);line-height:1.4}@media(max-width: 480px){.signup-disclaimer{font-size:.85rem}}.conditions-disclaimer{text-align:center;font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-md);line-height:1.4}@media(max-width: 480px){.conditions-disclaimer{font-size:.85rem}}.conditions-disclaimer a{color:var(--color-text-secondary);text-decoration:underline}.conditions-disclaimer a:hover,.conditions-disclaimer a:focus{color:var(--color-accent-primary)}.signup-message{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-lg);border-radius:var(--radius-md);font-weight:500;text-align:center}.signup-message .message-icon{font-size:1.5rem}.signup-success{background:rgba(0,212,170,.15);color:var(--color-accent-primary)}.signup-error{background:rgba(239,83,80,.15);color:var(--color-accent-danger)}.score-tooltip-trigger{position:relative;display:inline-flex;align-items:center;margin-left:6px;cursor:help}.score-tooltip-trigger .score-tooltip-icon{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;font-size:.6rem;font-weight:700;color:var(--color-text-muted);border:1px solid var(--color-text-muted);border-radius:50%;transition:color .2s,border-color .2s}.score-tooltip-trigger:hover .score-tooltip-icon,.score-tooltip-trigger:focus .score-tooltip-icon{color:var(--color-accent-primary);border-color:var(--color-accent-primary)}.score-tooltip-trigger .score-tooltip{position:absolute;bottom:100%;left:50%;transform:translateX(-50%);width:max-content;max-width:200px;padding:10px 12px;margin-bottom:8px;background:var(--color-bg-card);border:1px solid hsla(0,0%,100%,.15);border-radius:var(--radius-sm);box-shadow:0 4px 12px rgba(0,0,0,.3);font-size:.7rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);text-transform:none;letter-spacing:normal;text-align:left;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;z-index:100}.score-tooltip-trigger .score-tooltip::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid rgba(0,0,0,0);border-top-color:var(--color-bg-card)}.score-tooltip-trigger .score-tooltip strong{display:block;margin-bottom:4px;color:var(--color-text-primary);font-size:.75rem}.score-tooltip-trigger .score-tooltip a{display:inline-block;margin-top:6px;color:var(--color-accent-primary);text-decoration:none}.score-tooltip-trigger .score-tooltip a:hover{text-decoration:underline}.score-tooltip-trigger:hover .score-tooltip,.score-tooltip-trigger:focus .score-tooltip,.score-tooltip-trigger:focus-within .score-tooltip{opacity:1;visibility:visible}#map{position:relative;z-index:1;height:300px;border-radius:var(--radius-md);overflow:hidden;border:1px solid hsla(0,0%,100%,.1)}@media(max-width: 480px){#map{height:250px}}.leaflet-container{background:var(--color-bg-secondary);font-family:var(--font-family)}.station-marker{background:rgba(0,0,0,0);border:none}.marker-pin{width:18px;height:18px;border-radius:50%;background:var(--color-accent-primary);border:3px solid hsla(0,0%,100%,.9);box-shadow:0 0 0 2px var(--color-accent-primary),0 0 12px rgba(0,212,170,.7),0 2px 6px rgba(0,0,0,.4);transition:all .2s ease;cursor:pointer}.marker-pin:hover{background:var(--color-chart-now);transform:scale(1.1);box-shadow:0 0 0 3px var(--color-chart-now),0 0 16px rgba(239,83,80,.7),0 2px 8px rgba(0,0,0,.4)}.station-marker.selected .marker-pin{width:22px;height:22px;background:var(--color-chart-now);border:3px solid #fff;box-shadow:0 0 0 3px var(--color-chart-now),0 0 20px rgba(239,83,80,.8),0 2px 8px rgba(0,0,0,.5);animation:marker-pulse 2s ease-in-out infinite}@keyframes marker-pulse{0%,100%{box-shadow:0 0 0 3px var(--color-chart-now),0 0 20px rgba(239,83,80,.8),0 2px 8px rgba(0,0,0,.5)}50%{box-shadow:0 0 0 5px var(--color-chart-now),0 0 30px #ef5350,0 2px 8px rgba(0,0,0,.5)}}.leaflet-popup-content-wrapper{background:var(--color-bg-card);color:var(--color-text-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-card)}.leaflet-popup-tip{background:var(--color-bg-card)}.leaflet-popup-content{margin:8px 12px;font-size:.8rem;line-height:1.4}.leaflet-popup-content strong{color:var(--color-accent-primary);font-size:.85rem}.popup-btn{display:block;width:100%;background:var(--color-accent-primary);color:var(--color-bg-primary);border:none;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;margin-top:var(--space-sm);font-weight:600;font-size:.75rem;transition:background .2s ease}.popup-btn:hover{background:var(--color-accent-secondary)}.leaflet-control-attribution{background:rgba(10,22,40,.8) !important;color:var(--color-text-muted) !important;font-size:.7rem}.leaflet-control-attribution a{color:var(--color-accent-primary) !important}.share-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-accent-primary);border:none;border-radius:var(--radius-md);color:var(--color-bg-primary);font-size:.85rem;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all .2s ease;margin-top:var(--space-md)}.share-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.share-btn:active{transform:scale(0.98)}.share-btn .share-icon{width:18px;height:18px;flex-shrink:0}.share-btn .share-btn-text{white-space:nowrap}.share-panel{position:fixed;inset:0;z-index:2000}.share-panel[hidden]{display:none}.share-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.share-content{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);width:90%;max-width:400px;background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:0 10px 40px rgba(0,0,0,.3);animation:share-fade-in .2s ease-out;overflow:hidden}@media(max-width: 480px){.share-content{position:absolute;top:auto;bottom:0;left:0;right:0;transform:none;width:100%;max-width:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0;animation:share-slide-up .25s ease-out}}@keyframes share-fade-in{from{opacity:0;transform:translate(-50%, -50%) scale(0.95)}to{opacity:1;transform:translate(-50%, -50%) scale(1)}}@keyframes share-slide-up{from{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.share-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid hsla(0,0%,100%,.08)}.share-title{font-size:1rem;font-weight:600;color:var(--color-text-primary)}.share-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:hsla(0,0%,100%,.08);border:none;border-radius:50%;color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease}.share-close:hover{background:hsla(0,0%,100%,.15)}.share-preview-card{margin:var(--space-md);padding:var(--space-md);background:linear-gradient(135deg, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0.15) 100%);border-radius:var(--radius-lg);border:1px solid hsla(0,0%,100%,.08)}.share-preview-header{margin-bottom:var(--space-md)}.share-location{display:flex;align-items:center;gap:var(--space-xs)}.share-location .location-icon{opacity:.6;color:var(--color-text-secondary)}.share-location-name{font-size:.9rem;font-weight:600;color:var(--color-text-primary)}.share-rating-display{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);margin-bottom:var(--space-md);padding:var(--space-sm) 0}.share-rating-badge{display:flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-lg);border-radius:50px;background:rgba(0,0,0,.4);min-width:100px}.share-rating-badge .share-rating-text{font-size:1.1rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;transition:all .2s ease}.share-rating-badge.good .share-rating-text{color:var(--color-rating-good)}.share-rating-badge.fair .share-rating-text{color:var(--color-rating-fair)}.share-rating-badge.poor .share-rating-text{color:var(--color-rating-poor)}.share-rating-badge.hazardous .share-rating-text{color:var(--color-rating-hazard)}.share-score{display:flex;align-items:baseline;gap:2px}.share-score .share-score-value{font-size:2rem;font-weight:700;font-family:var(--font-mono);color:var(--color-accent-primary);line-height:1}.share-score .share-score-label{font-size:.9rem;color:var(--color-text-muted)}.share-conditions-grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:var(--space-xs)}@media(max-width: 480px){.share-conditions-grid{grid-template-columns:repeat(2, 1fr)}}.share-condition{text-align:center;padding:var(--space-sm) var(--space-xs);background:rgba(0,0,0,.2);border-radius:var(--radius-sm)}.share-condition .share-condition-label{display:block;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:2px}.share-condition .share-condition-value{display:block;font-size:.75rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.share-url-preview{padding:var(--space-sm) var(--space-md);margin:0 var(--space-md) var(--space-sm);background:rgba(0,0,0,.15);border-radius:var(--radius-sm)}.share-url-preview .share-preview-url{font-size:.7rem;color:var(--color-accent-primary);font-family:var(--font-mono);word-break:break-all;margin:0;text-align:center}.share-preview-text[hidden]{display:none}.share-preview{padding:var(--space-md);background:rgba(0,0,0,.2);margin:var(--space-sm) var(--space-md);border-radius:var(--radius-md)}.share-preview-text:not([hidden]){font-size:.85rem;color:var(--color-text-primary);line-height:1.5;white-space:pre-line;margin-bottom:var(--space-sm)}.share-targets{display:grid;grid-template-columns:repeat(4, 1fr);gap:var(--space-xs);padding:var(--space-md) var(--space-lg)}@media(max-width: 480px){.share-targets{grid-template-columns:repeat(4, 1fr)}}.share-target{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm);background:hsla(0,0%,100%,.06);border:1px solid rgba(0,0,0,0);border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer;transition:all .2s ease;opacity:0;transform:translateY(10px);animation-delay:calc(var(--stagger-index, 0)*.04s)}.share-target.animate-in{animation:share-target-appear .25s ease-out forwards}.share-target:hover{background:hsla(0,0%,100%,.12);border-color:hsla(0,0%,100%,.1)}.share-target:hover .share-target-icon svg{transform:scale(1.1)}.share-target:active{transform:scale(0.95)}@keyframes share-target-appear{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.share-target-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-bg-secondary);border-radius:50%;font-size:1.1rem;font-weight:700}.share-target-icon svg{transition:all .2s ease}@media(max-width: 480px){.share-target-icon{width:36px;height:36px;font-size:1rem}.share-target-icon svg{width:16px;height:16px}}.share-target-name{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-muted)}.share-target[data-share-target=twitter] .share-target-icon{background:#000;color:#fff}.share-target[data-share-target=facebook] .share-target-icon{background:#1877f2;color:#fff}.share-target[data-share-target=whatsapp] .share-target-icon{background:#25d366;color:#fff}.share-target[data-share-target=email] .share-target-icon{background:var(--color-accent-primary);color:var(--color-bg-primary)}.share-target[data-share-target=sms] .share-target-icon{background:#34c759;color:#fff}.share-target[data-share-target=linkedin] .share-target-icon{background:#0a66c2;color:#fff}.share-target[data-share-target=reddit] .share-target-icon{background:#ff4500;color:#fff}.share-target[data-share-target=telegram] .share-target-icon{background:#08c;color:#fff}.share-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm);padding:0 var(--space-lg) var(--space-lg)}.share-copy-btn,.share-copy-url-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-bg-secondary);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:.85rem;font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all .2s ease}.share-copy-btn:hover,.share-copy-url-btn:hover{background:var(--color-bg-card-hover);border-color:hsla(0,0%,100%,.2)}.share-copy-btn svg,.share-copy-url-btn svg{opacity:.7}.copy-toast{position:fixed;bottom:100px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--color-bg-card);color:var(--color-text-primary);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);box-shadow:0 4px 20px rgba(0,0,0,.3);font-size:.85rem;font-weight:500;opacity:0;pointer-events:none;transition:all .2s ease;z-index:3000}.copy-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.copy-toast.error{background:var(--color-accent-danger);color:#fff}:root.light-mode .share-backdrop{background:rgba(0,0,0,.3)}:root.light-mode .share-header{border-bottom-color:rgba(0,0,0,.08)}:root.light-mode .share-close{background:rgba(0,0,0,.06)}:root.light-mode .share-close:hover{background:rgba(0,0,0,.1)}:root.light-mode .share-preview-card{background:linear-gradient(135deg, rgba(0, 0, 0, 0.04) 0%, rgba(0, 0, 0, 0.02) 100%);border-color:rgba(0,0,0,.08)}:root.light-mode .share-rating-badge{background:rgba(0,0,0,.06)}:root.light-mode .share-condition{background:rgba(0,0,0,.03)}:root.light-mode .share-url-preview{background:rgba(0,0,0,.03)}:root.light-mode .share-preview{background:rgba(0,0,0,.04)}:root.light-mode .share-target{background:rgba(0,0,0,.04)}:root.light-mode .share-target:hover{background:rgba(0,0,0,.08)}:root.light-mode .share-target-icon{background:var(--color-bg-secondary)}:root.light-mode .share-copy-btn,:root.light-mode .share-copy-url-btn{background:var(--color-bg-secondary);border-color:rgba(0,0,0,.1)}:root.light-mode .share-copy-btn:hover,:root.light-mode .share-copy-url-btn:hover{background:var(--color-bg-card-hover);border-color:rgba(0,0,0,.15)}:root.light-mode .copy-toast{background:var(--color-bg-card);box-shadow:0 4px 20px rgba(0,0,0,.15)}.methodology-page{max-width:900px;margin:0 auto;padding:var(--space-xl)}.methodology-header{text-align:center;margin-bottom:var(--space-xl);padding-bottom:var(--space-xl);border-bottom:1px solid hsla(0,0%,100%,.1)}.methodology-header h1{font-size:2.5rem;color:var(--color-accent-primary);margin-bottom:var(--space-md)}.methodology-header .subtitle{font-size:1.2rem;color:var(--color-text-secondary);max-width:600px;margin:0 auto}.back-link{display:inline-flex;align-items:center;gap:var(--space-sm);color:var(--color-accent-primary);text-decoration:none;margin-bottom:var(--space-lg);font-size:.9rem}.back-link:hover{text-decoration:underline}.methodology-section{margin-bottom:var(--space-xl)}.methodology-section h2{font-size:1.5rem;color:var(--color-text-primary);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:2px solid var(--color-accent-primary)}.methodology-section h3{font-size:1.1rem;color:var(--color-accent-secondary);margin:var(--space-lg) 0 var(--space-md)}.methodology-section p{color:var(--color-text-secondary);line-height:1.8;margin-bottom:var(--space-md)}.data-source-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));gap:var(--space-lg);margin:var(--space-lg) 0}.data-source-card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);border:1px solid hsla(0,0%,100%,.05)}.data-source-card h4{color:var(--color-accent-primary);margin-bottom:var(--space-sm);font-size:1rem}.data-source-card p{font-size:.9rem;margin-bottom:var(--space-sm)}.data-source-card ul{list-style:none;padding:0;margin:0}.data-source-card li{color:var(--color-text-muted);font-size:.85rem;padding:var(--space-xs) 0;padding-left:var(--space-md);position:relative}.data-source-card li::before{content:"•";position:absolute;left:0;color:var(--color-accent-primary)}.scoring-table{width:100%;border-collapse:collapse;margin:var(--space-lg) 0;background:var(--color-bg-card);border-radius:var(--radius-lg);overflow:hidden}.scoring-table th,.scoring-table td{padding:var(--space-md);text-align:left;border-bottom:1px solid hsla(0,0%,100%,.05)}.scoring-table th{background:rgba(0,0,0,.2);color:var(--color-text-primary);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.scoring-table td{color:var(--color-text-secondary);font-size:.9rem}.scoring-table tr:last-child td{border-bottom:none}.scoring-table .score-good{color:var(--color-rating-good);font-weight:600}.scoring-table .score-fair{color:var(--color-rating-fair);font-weight:600}.scoring-table .score-poor{color:var(--color-rating-poor);font-weight:600}.scoring-table .score-hazard{color:var(--color-rating-hazard);font-weight:600}.rating-badge-example{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:50px;font-weight:700;font-size:.9rem}.rating-badge-example.good{background:rgba(0,212,170,.2);color:var(--color-rating-good)}.rating-badge-example.fair{background:rgba(255,183,77,.2);color:var(--color-rating-fair)}.rating-badge-example.poor{background:rgba(255,138,101,.2);color:var(--color-rating-poor)}.rating-badge-example.hazardous{background:rgba(239,83,80,.2);color:var(--color-rating-hazard)}.rating-thresholds{display:grid;grid-template-columns:repeat(auto-fit, minmax(150px, 1fr));gap:var(--space-md);margin:var(--space-lg) 0}.threshold-card{text-align:center;padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--color-bg-card)}.threshold-card.good{border:2px solid var(--color-rating-good)}.threshold-card.good .rating-name{color:var(--color-rating-good)}.threshold-card.fair{border:2px solid var(--color-rating-fair)}.threshold-card.fair .rating-name{color:var(--color-rating-fair)}.threshold-card.poor{border:2px solid var(--color-rating-poor)}.threshold-card.poor .rating-name{color:var(--color-rating-poor)}.threshold-card.hazardous{border:2px solid var(--color-rating-hazard)}.threshold-card.hazardous .rating-name{color:var(--color-rating-hazard)}.threshold-card .rating-name{font-size:1.2rem;font-weight:700;margin-bottom:var(--space-xs)}.threshold-card .rating-score{font-size:.9rem;color:var(--color-text-muted)}.formula-box{background:rgba(0,0,0,.3);border-radius:var(--radius-lg);padding:var(--space-lg);margin:var(--space-lg) 0;font-family:var(--font-mono);font-size:.9rem;color:var(--color-text-secondary);border-left:4px solid var(--color-accent-primary)}.formula-box code{color:var(--color-accent-primary)}.note-box{background:rgba(79,195,247,.1);border-radius:var(--radius-lg);padding:var(--space-lg);margin:var(--space-lg) 0;border-left:4px solid var(--color-accent-secondary)}.note-box p{margin:0;color:var(--color-text-primary)}.update-info{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);margin:var(--space-lg) 0}.update-info h4{color:var(--color-text-primary);margin-bottom:var(--space-md)}.update-info ul{list-style:none;padding:0;margin:0}.update-info li{display:flex;justify-content:space-between;padding:var(--space-sm) 0;border-bottom:1px solid hsla(0,0%,100%,.05);color:var(--color-text-secondary);font-size:.9rem}.update-info li:last-child{border-bottom:none}.update-info li span:last-child{color:var(--color-accent-primary);font-family:var(--font-mono)}:root.light-mode .methodology-header{border-bottom-color:rgba(0,0,0,.1)}:root.light-mode .methodology-section h2{border-bottom-color:var(--color-accent-primary)}:root.light-mode .data-source-card{border-color:rgba(0,0,0,.08)}:root.light-mode .scoring-table th{background:rgba(0,0,0,.04)}:root.light-mode .scoring-table td{border-bottom-color:rgba(0,0,0,.08)}:root.light-mode .formula-box{background:rgba(0,0,0,.04)}:root.light-mode .note-box{background:rgba(0,113,227,.08)}@media(max-width: 600px){.methodology-page{padding:var(--space-lg)}.methodology-header h1{font-size:1.8rem}.scoring-table{font-size:.85rem}.scoring-table th,.scoring-table td{padding:var(--space-sm)}}.legal-container{max-width:800px;margin:0 auto;padding:var(--space-lg)}.legal-header{text-align:center;margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid hsla(0,0%,100%,.1)}.legal-header h1{font-size:2rem;color:var(--color-text-primary);margin-bottom:var(--space-sm)}.legal-header .last-updated{color:var(--color-text-muted);font-size:.9rem}.back-link{display:inline-flex;align-items:center;gap:var(--space-xs);color:var(--color-accent-primary);text-decoration:none;font-size:.9rem;margin-bottom:var(--space-lg)}.back-link:hover{text-decoration:underline}.legal-section{margin-bottom:var(--space-xl)}.legal-section h2{font-size:1.25rem;color:var(--color-accent-primary);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid rgba(0,212,170,.2)}.legal-section h3{font-size:1rem;color:var(--color-text-primary);margin:var(--space-lg) 0 var(--space-sm) 0}.legal-section p,.legal-section li{color:var(--color-text-secondary);line-height:1.7;margin-bottom:var(--space-md)}.legal-section ul,.legal-section ol{padding-left:var(--space-lg);margin-bottom:var(--space-md)}.legal-section li{margin-bottom:var(--space-sm)}.legal-section a{color:var(--color-accent-primary)}.data-table{width:100%;border-collapse:collapse;margin:var(--space-md) 0}.data-table th,.data-table td{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid hsla(0,0%,100%,.1)}.data-table th{color:var(--color-text-primary);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.data-table td{color:var(--color-text-secondary);font-size:.9rem}.info-box{background:rgba(0,212,170,.1);border:1px solid rgba(0,212,170,.3);border-radius:var(--radius-md);padding:var(--space-md);margin:var(--space-md) 0}.info-box p{margin:0;color:var(--color-text-secondary)}.warning-box{background:rgba(239,83,80,.1);border:1px solid var(--color-accent-danger);border-radius:var(--radius-md);padding:var(--space-lg);margin:var(--space-lg) 0}.warning-box h3{color:var(--color-accent-danger);font-size:1rem;margin-bottom:var(--space-sm)}.warning-box p,.warning-box li{color:var(--color-text-secondary)}.legal-footer{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid hsla(0,0%,100%,.1);text-align:center}.legal-footer p{color:var(--color-text-muted);font-size:.85rem;margin-bottom:var(--space-sm)}.legal-footer p:last-child{font-size:.8rem;margin-bottom:0}.legal-footer a{color:var(--color-accent-primary)}.legal-footer a.secondary{color:var(--color-text-secondary)}:root.light-mode .legal-header{border-bottom-color:rgba(0,0,0,.1)}:root.light-mode .legal-section h2{border-bottom-color:rgba(0,113,227,.2)}:root.light-mode .data-table th,:root.light-mode .data-table td{border-bottom-color:rgba(0,0,0,.1)}:root.light-mode .info-box{background:rgba(0,113,227,.05);border-color:rgba(0,113,227,.2)}:root.light-mode .warning-box{background:rgba(215,0,21,.05)}:root.light-mode .legal-footer{border-top-color:rgba(0,0,0,.1)}:root.light-mode{--color-bg-primary: #ffffff;--color-bg-secondary: #f5f5f7;--color-bg-card: #ffffff;--color-bg-card-hover: #fafafa;--color-text-primary: #1d1d1f;--color-text-secondary: #424245;--color-text-muted: #86868b;--color-accent-primary: #0071e3;--color-accent-secondary: #06c;--color-accent-warning: #bf5600;--color-accent-danger: #d70015;--color-tide-rising: #0066cc;--color-tide-falling: #cc4400;--color-tide-high: #00875a;--color-tide-low: #bf5600;--color-chart-line: #0071e3;--color-chart-fill: rgba(0, 113, 227, 0.08);--color-chart-now: #d70015;--color-chart-grid: rgba(0, 0, 0, 0.06);--color-rating-good: #00875a;--color-rating-fair: #bf5600;--color-rating-poor: #cc4400;--color-rating-hazard: #d70015;--gradient-good: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);--gradient-fair: linear-gradient(135deg, #fffbeb 0%, #fef3c7 100%);--gradient-poor: linear-gradient(135deg, #fff7ed 0%, #fed7aa 100%);--gradient-hazardous: linear-gradient(135deg, #fef2f2 0%, #fecaca 100%);--color-icon-sunrise: #f59e0b;--color-icon-sunset: #ea580c;--shadow-card: 0 1px 3px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.04);--shadow-card-hover: 0 4px 12px rgba(0, 0, 0, 0.1);--shadow-glow: none}:root.light-mode body{background:var(--color-bg-secondary)}:root.light-mode header{background:hsla(0,0%,100%,.72);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid rgba(0,0,0,.08)}:root.light-mode .location-button:hover{background:rgba(0,0,0,.06)}:root.light-mode .location-button:active{background:rgba(0,0,0,.08)}:root.light-mode .location-button[aria-expanded=true]{background:rgba(0,0,0,.06)}:root.light-mode .theme-toggle{background:rgba(0,0,0,.05)}:root.light-mode .theme-toggle:hover{background:rgba(0,0,0,.1)}:root.light-mode .panel-backdrop{background:rgba(0,0,0,.3)}:root.light-mode .panel-content{box-shadow:0 10px 40px rgba(0,0,0,.15);border:1px solid rgba(0,0,0,.08)}:root.light-mode .panel-header{background:rgba(0,0,0,.02);border-bottom:1px solid rgba(0,0,0,.1)}:root.light-mode .panel-close{background:rgba(0,0,0,.06)}:root.light-mode .panel-close:hover{background:rgba(0,0,0,.1)}:root.light-mode .location-group-label{color:#6e6e73}:root.light-mode .location-option{background:#f0f0f5;border:1px solid rgba(0,0,0,.12);color:var(--color-text-primary)}:root.light-mode .location-option:hover:not(:disabled){background:#e5e5ea;border-color:rgba(0,0,0,.18);transform:translateY(-1px)}:root.light-mode .location-option.selected{background:var(--color-accent-primary);border-color:var(--color-accent-primary);color:#fff;font-weight:600;box-shadow:0 2px 8px rgba(0,113,227,.3)}:root.light-mode .location-option.only-option{background:#f5f5f7;border-color:rgba(0,0,0,.1);opacity:.8}:root.light-mode .location-option.only-option.selected{background:rgba(0,113,227,.15);border-color:rgba(0,113,227,.4);color:var(--color-accent-primary);font-weight:600;box-shadow:none}:root.light-mode .location-option.only-option:hover:not(:disabled){transform:none}:root.light-mode .card{background:var(--color-bg-card);border:1px solid rgba(0,0,0,.04);box-shadow:var(--shadow-card)}:root.light-mode .card:hover{box-shadow:var(--shadow-card-hover)}:root.light-mode .card h2{color:var(--color-text-primary);border-bottom-color:rgba(0,0,0,.06)}:root.light-mode .card-header{border-bottom-color:rgba(0,0,0,.06);background:rgba(0,0,0,0)}:root.light-mode .card-hero{border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-card)}:root.light-mode .detail-item,:root.light-mode .swell-detail,:root.light-mode .wind-info,:root.light-mode .next-high,:root.light-mode .next-low{background:var(--color-bg-secondary);border-radius:8px}:root.light-mode .tide-hero-section{background:var(--color-bg-secondary)}:root.light-mode .beach-window{background:var(--color-bg-secondary)}:root.light-mode .status-badge{background:hsla(0,0%,100%,.95);box-shadow:0 1px 4px rgba(0,0,0,.1)}:root.light-mode .day-length{border-top-color:rgba(0,0,0,.06)}:root.light-mode .compass-ring{border-color:var(--color-text-muted)}:root.light-mode footer{border-top:1px solid rgba(0,0,0,.06);background:var(--color-bg-card)}:root.light-mode .leaflet-control-attribution{background:hsla(0,0%,100%,.95) !important;color:var(--color-text-muted) !important}:root.light-mode #map{border:1px solid rgba(0,0,0,.08);border-radius:8px}:root.light-mode .marker-pin{border-color:#fff}:root.light-mode #region-select,:root.light-mode #area-select,:root.light-mode #station-select{background-color:var(--color-bg-card);border:1px solid rgba(0,0,0,.12);color:var(--color-text-primary);box-shadow:0 1px 2px rgba(0,0,0,.04);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23424245' d='M6 8L2 4h8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}:root.light-mode #region-select:focus,:root.light-mode #area-select:focus,:root.light-mode #station-select:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px rgba(0,113,227,.15)}:root.light-mode #region-select option,:root.light-mode #area-select option,:root.light-mode #station-select option{background:var(--color-bg-card);color:var(--color-text-primary)}:root.light-mode .form-group input[type=email],:root.light-mode .form-group input[type=text],:root.light-mode .form-group select{border:1px solid rgba(0,0,0,.12);background-color:var(--color-bg-card)}:root.light-mode .form-group input[type=email]:focus,:root.light-mode .form-group input[type=text]:focus,:root.light-mode .form-group select:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px rgba(0,113,227,.15)}:root.light-mode .form-group select{background-color:var(--color-bg-card);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23424245' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}:root.light-mode .radio-option{background:var(--color-bg-card);border:2px solid rgba(0,0,0,.1)}:root.light-mode .radio-option:hover{border-color:rgba(0,0,0,.2);background:var(--color-bg-secondary)}:root.light-mode .radio-option:has(input:checked){background:rgba(0,113,227,.06);border-color:var(--color-accent-primary);box-shadow:0 0 0 1px var(--color-accent-primary)}:root.light-mode .radio-option input[type=radio]{border-color:rgba(0,0,0,.25)}:root.light-mode .radio-option input[type=radio]:checked{border-color:var(--color-accent-primary);background:var(--color-accent-primary)}:root.light-mode input[type=range]{background:rgba(0,0,0,.08)}:root.light-mode .data-freshness{background:var(--color-bg-secondary);color:var(--color-text-muted)}:root.light-mode .data-freshness.fresh{color:var(--color-rating-good)}:root.light-mode .data-freshness.stale{color:var(--color-accent-warning)}.hidden{display:none !important}.visible{display:block !important}.flex-visible{display:flex !important}.no-scroll{overflow:hidden !important}.error-fullscreen{padding:var(--space-xl);text-align:center;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md)}.error-fullscreen h1{color:var(--color-accent-danger);font-size:1.5rem}.error-fullscreen p{color:var(--color-text-secondary)}.error-fullscreen button{padding:var(--space-sm) var(--space-lg);background:var(--color-accent-primary);color:var(--color-bg-primary);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.error-fullscreen button:hover{opacity:.9}.card-hero.rating-good{background:var(--gradient-good);border-color:var(--color-rating-good)}.card-hero.rating-fair{background:var(--gradient-fair);border-color:var(--color-rating-fair)}.card-hero.rating-poor{background:var(--gradient-poor);border-color:var(--color-rating-poor)}.card-hero.rating-hazardous{background:var(--gradient-hazardous);border-color:var(--color-rating-hazard)}/*# sourceMappingURL=styles.css.map */
