*{box-sizing:border-box;margin:0;padding:0}body{font-family:DM Sans,sans-serif;background:#f5f6f8;color:#1a2332;min-height:100vh}.topbar{background:#1a2332;color:#fff;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;flex-wrap:wrap;gap:8px;box-shadow:0 2px 12px #00000038}.topbar-left{display:flex;align-items:center;gap:10px}.topbar-logo{font-family:Space Mono,monospace;font-size:20px;font-weight:700;letter-spacing:-.5px}.topbar-divider{width:1px;height:18px;background:#ffffff26}.topbar-loc{font-size:13px;color:#ffffffeb;font-weight:500}.skill-row{display:flex;gap:3px;background:#ffffff14;border-radius:8px;padding:3px}.skill-btn{padding:5px 12px;border:none;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif;color:#ffffff80;background:transparent;transition:all .15s;text-transform:uppercase;letter-spacing:.5px}.skill-btn.active{background:#ffffff26;color:#fff}.skill-btn:hover{color:#fff}.container{max-width:1040px;margin:0 auto;padding:20px 16px 50px}.zone-bar{display:flex;gap:6px;margin-bottom:20px;overflow-x:auto;padding-bottom:4px}.zone-btn{padding:7px 16px;border:1px solid #dde0e6;border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;background:#fff;color:#5a6577;white-space:nowrap;font-family:DM Sans,sans-serif;transition:all .15s}.zone-btn.active{background:#1a2332;color:#fff;border-color:#1a2332}.zone-btn:hover{border-color:#1a2332}.current{background:#fff;border-radius:12px;border:1px solid #e8eaee;margin-bottom:20px;overflow:hidden}.current-header{padding:18px 22px 0;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:8px}.current-title{font-size:13px;color:#1a2332;text-transform:uppercase;letter-spacing:.6px;font-weight:700}.current-time{font-size:12px;color:#a0a8b8}.rating-row{display:flex;align-items:center;gap:14px;padding:10px 22px 6px}.rating-label{font-size:28px;font-weight:800;letter-spacing:-.5px}.rating-dots{display:flex;gap:4px}.rating-dot{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:20px;opacity:.3}.rating-dot.filled{opacity:1}.rating-desc{font-size:13px;color:#5a6577;padding:0 22px 16px;line-height:1.5}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1px;background:#e8eaee;border-top:1px solid #e8eaee}.card{background:#fff;padding:16px 20px}.card-label{font-size:10px;color:#7a8599;text-transform:uppercase;letter-spacing:.8px;font-weight:600;margin-bottom:8px}.card-main{font-size:24px;font-weight:700;line-height:1.2}.card-main span{font-size:14px;font-weight:500;color:#7a8599}.card-sub{font-size:12px;color:#7a8599;margin-top:4px}.compass{width:64px;height:64px;border-radius:50%;border:1.5px solid #dde0e6;position:relative;margin:4px 0;flex-shrink:0;aspect-ratio:1}.compass-label{position:absolute;font-size:8px;color:#a0a8b8;font-weight:600}.compass-arrow{position:absolute;top:50%;left:50%;width:2px;height:24px;background:#1a2332;border-radius:1px;transform-origin:bottom center}.forecast-strip{background:#fff;border-radius:12px;border:1px solid #e8eaee;margin-bottom:20px;overflow:hidden}.day-tabs{display:flex;overflow-x:auto;border-bottom:1px solid #e8eaee;padding:0 12px}.day-tab{padding:12px 14px;font-size:12px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;color:#7a8599;white-space:nowrap;transition:all .15s;font-family:DM Sans,sans-serif;background:none;border-top:none;border-left:none;border-right:none}.day-tab.active{color:#1a2332;border-bottom-color:#1a2332}.day-tab:hover{color:#1a2332}.day-tab-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-left:6px;vertical-align:middle}.timeline-section{padding:16px 22px}.tl-label-row{display:flex;justify-content:space-between;margin-bottom:6px;flex-wrap:wrap;gap:4px}.tl-label{font-size:10px;color:#7a8599;text-transform:uppercase;letter-spacing:.6px;font-weight:600}.tl-bar,.tl-seg{display:none}.tl-seg:hover{opacity:.8}.tl-hours{display:flex;justify-content:space-between}.tl-hour{font-size:10px;color:#a0a8b8;font-weight:500}.tl-tip{display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#1a2332;color:#fff;padding:8px 12px;border-radius:8px;font-size:11px;white-space:nowrap;z-index:10;pointer-events:none;min-width:160px;line-height:1.5}.tl-tip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#1a2332}.tl-seg:hover .tl-tip{display:block}.tl-summary{font-size:13px;color:#5a6577;padding:8px 0 0;line-height:1.5}.section-title{font-size:12px;font-weight:700;color:#1a2332;text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px;padding-top:8px}table{width:100%;min-width:600px;border-collapse:collapse;font-size:12px}th{padding:8px 6px;font-size:9px;color:#7a8599;text-transform:uppercase;letter-spacing:.6px;font-weight:600;text-align:left;border-bottom:1px solid #e8eaee}td{padding:8px 6px;border-bottom:1px solid #f0f1f3}tr:last-child td{border-bottom:none}.mini{padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;font-family:Space Mono,monospace}.wbar{display:inline-block;width:32px;height:4px;background:#e8eaee;border-radius:2px;overflow:hidden;vertical-align:middle;margin-right:5px}.wbar-in{height:100%;border-radius:2px}.dim{color:#7a8599}.warn{color:#e74c3c}.legend{background:#fff;border-radius:12px;border:1px solid #e8eaee;padding:18px 22px;margin-bottom:16px}.legend-title{font-size:12px;font-weight:700;color:#1a2332;text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}.legend-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.legend-card{text-align:center;padding:10px 6px;border-radius:8px;background:#fafbfc;border:1px solid #eef0f3}.legend-card-label{font-size:13px;font-weight:700;margin-bottom:4px}.legend-card-score{font-size:10px;color:#7a8599;font-family:Space Mono,monospace;margin-bottom:6px}.legend-card-dots{display:flex;gap:3px;justify-content:center;margin-bottom:6px}.legend-card-dot{width:14px;height:6px;border-radius:2px}.legend-card-desc{font-size:10px;color:#7a8599;line-height:1.4}.disclaimer{background:#fff;border-radius:12px;border:1px solid #e8eaee;padding:16px 20px;font-size:11px;color:#7a8599;line-height:1.6}.disclaimer strong{color:#5a6577}.src{margin-top:4px;font-size:10px;color:#a0a8b8}@media(max-width:700px){.cards,.legend-grid{grid-template-columns:repeat(2,1fr)}.legend-grid .legend-card:last-child{grid-column:span 2}.stat-strip{grid-template-columns:repeat(2,1fr)}.stat-strip-cell:nth-child(2){border-right:none}.stat-strip-cell:nth-child(1),.stat-strip-cell:nth-child(2){border-bottom:1px solid #e8eaee}.forecast-layout{flex-direction:column;gap:0}.zone-sidebar{order:-1;position:static;width:100%;flex-direction:row;gap:0;margin-bottom:16px}.zone-sidebar .zone-bar{flex-direction:row;overflow-x:auto;padding-bottom:4px;gap:6px}.zone-sidebar .zone-btn{white-space:nowrap;line-height:1;padding:7px 16px;border-radius:20px;width:auto}.zone-sidebar .map-toggle{flex-shrink:0;width:auto;margin-top:0;border-radius:20px;align-self:flex-start}}.tl-unified-wrap{display:flex;gap:2px;align-items:flex-end;margin-bottom:6px}.tl-unified:hover .tl-ubar{opacity:1!important;transform:scaleY(1.12) scaleX(1.08);z-index:3}.tl-unified:hover .tl-kt{color:#1a2332!important;font-weight:700!important;font-size:9px!important}.tl-unified:hover .tl-tip{display:block}.tl-ubar{border-radius:4px 4px 2px 2px;position:relative;transition:all .15s ease;transform-origin:bottom center;min-height:8px;width:100%}.tl-kt{position:absolute;top:-15px;left:50%;transform:translate(-50%);font-size:8px;color:#a0a8b8;font-weight:400;font-family:Space Mono,monospace;white-space:nowrap;transition:all .12s}.tl-kt-sel{color:#1a2332!important;font-weight:700!important;font-size:9px!important}.tl-unified:hover .tl-kt{color:#1a2332;font-weight:700;font-size:9px}.tl-bar-icons{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);line-height:1;opacity:.55;pointer-events:none;white-space:nowrap;color:#1a2332;display:flex;gap:1px;align-items:center}.tl-unified:hover .tl-bar-icons{opacity:.85}.map-toggle{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border:1px solid #dde0e6;border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;background:#fff;color:#5a6577;font-family:DM Sans,sans-serif;transition:all .15s;margin-left:6px}.map-toggle.active{background:#1a2332;color:#fff;border-color:#1a2332}.map-toggle:hover{border-color:#1a2332}.map-wrap{display:none;background:#fff;border-radius:12px;border:1px solid #e8eaee;margin-bottom:20px;overflow:hidden}.map-wrap.open{display:block}.map-container{height:340px;width:100%;position:relative}.map-info{padding:12px 18px;font-size:12px;color:#5a6577;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;border-top:1px solid #e8eaee}.map-coords{font-family:Space Mono,monospace;font-size:11px;color:#7a8599}.map-loc-name{font-weight:600;color:#1a2332;font-size:13px}.map-hint{font-size:11px;color:#a0a8b8;font-style:italic}.custom-marker{background:#7c3aed;border:2px solid #fff;border-radius:50%;width:14px;height:14px;box-shadow:0 2px 8px #0000004d}.marina-marker{background:#1db954;border:2px solid #fff;border-radius:50%;width:10px;height:10px;box-shadow:0 1px 4px #0003}.tl-graph-wrap{display:flex;gap:0;align-items:stretch;margin-bottom:6px}.tl-yaxis{width:30px;position:relative;flex-shrink:0;height:180px;margin-top:15px}.tl-ytick{position:absolute;right:6px;font-size:8px;color:#a0a8b8;font-family:Space Mono,monospace;transform:translateY(50%);line-height:1}.tl-ylabel{position:absolute;top:-14px;right:6px;font-size:7px;color:#a0a8b8;text-transform:uppercase;letter-spacing:.5px;font-family:Space Mono,monospace}.tl-graph-area{flex:1;position:relative;min-width:0}.tl-gridlines{position:absolute;inset:15px 0 0;pointer-events:none;z-index:0}.tl-gridline{position:absolute;left:0;right:0;height:1px;background:#0000000f}.tl-unified-wrap{display:flex;gap:2px;align-items:flex-end;position:relative;z-index:1}.tl-ideal-band{position:absolute;left:0;right:0;background:#1db9540f;border-top:1px dashed rgba(29,185,84,.25);border-bottom:1px dashed rgba(29,185,84,.25);pointer-events:none;z-index:0}.map-weather-section{margin-bottom:16px}.wx-map-wrap{border-radius:8px;overflow:hidden;border:1px solid #e8eaee;position:relative}.wx-map{height:420px;width:100%;background:#e8edf2}.wx-map-legend{position:absolute;bottom:12px;left:12px;background:#ffffffeb;border-radius:8px;padding:8px 12px;font-size:10px;z-index:1000;box-shadow:0 2px 8px #0000001a;backdrop-filter:blur(4px)}.wx-map-legend-title{font-weight:700;color:#1a2332;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px;font-size:9px}.wx-map-legend-bar{display:flex;height:8px;border-radius:2px;overflow:hidden;margin-bottom:3px;width:140px}.wx-map-legend-labels{display:flex;justify-content:space-between;font-size:8px;color:#7a8599;font-family:Space Mono,monospace;width:140px}.map-info-bar{padding:8px 14px;font-size:10px;color:#a0a8b8;background:#fafbfc;border:1px solid #e8eaee;border-top:none;border-radius:0 0 8px 8px}.map-info-bar a:hover{text-decoration:underline}.map-info-bar a{color:#1db954;text-decoration:none;font-weight:500}.map-layer-btns{display:flex;gap:3px}.map-layer-btn{padding:4px 10px;border:1px solid #dde0e6;border-radius:6px;font-size:10px;font-weight:600;cursor:pointer;background:#fff;color:#7a8599;font-family:DM Sans,sans-serif;transition:all .12s;text-transform:uppercase;letter-spacing:.3px}.map-layer-btn.active{background:#1a2332;color:#fff;border-color:#1a2332}.map-layer-btn:hover{border-color:#1a2332}.best-window-banner{display:flex;align-items:center;gap:10px;border-radius:8px;padding:10px 14px;margin-top:10px;border-width:1px;border-style:solid}.forecast-layout{display:flex;gap:20px;align-items:flex-start}.zone-sidebar{width:180px;flex-shrink:0;display:flex;flex-direction:column;gap:6px;position:sticky;top:68px}.forecast-main{flex:1;min-width:0}.zone-sidebar .zone-bar{flex-direction:column;margin-bottom:0;overflow-x:visible;padding-bottom:0;gap:4px}.zone-sidebar .zone-btn{width:100%;text-align:left;border-radius:8px;white-space:normal;line-height:1.35;padding:8px 12px}.zone-sidebar .map-toggle{width:100%;text-align:center;border-radius:8px;margin-top:4px}.stale-data-banner{padding:12px 16px;background:#fff3cd;color:#8a6d1f;border-bottom:1px solid #f0d58a;font-size:13px;font-weight:600;line-height:1.4}.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid #e8eaee}.stat-strip-cell{padding:14px 16px;border-right:1px solid #e8eaee}.stat-strip-cell:last-child{border-right:none}.stat-strip-label{font-size:9px;color:#a0a8b8;text-transform:uppercase;letter-spacing:.6px;font-weight:600;margin-bottom:6px}.stat-strip-value{font-size:20px;font-weight:700;color:#1a2332;line-height:1}.stat-strip-value span{font-size:13px;font-weight:500;color:#7a8599}.stat-strip-sub{font-size:11px;color:#7a8599;margin-top:3px}@keyframes pulse-fade{0%,to{opacity:1}50%{opacity:.5}}.data-badge-pulse{animation:pulse-fade 1.5s ease infinite}.week-ahead-card{background:#fff;border-radius:12px;border:1px solid #e8eaee;margin-bottom:20px;padding:18px 22px}.week-ahead-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.week-ahead-title{font-size:13px;color:#1a2332;text-transform:uppercase;letter-spacing:.6px;font-weight:700}.week-ahead-badge{font-size:10px;padding:3px 10px;border-radius:10px;background:#7c3aed14;color:#7c3aed;font-weight:600;letter-spacing:.3px}.week-ahead-body{font-size:15px;color:#2c3a4a;line-height:1.75;font-weight:400}.week-ahead-loading{color:#a0a8b8;font-size:13px;font-style:italic}.settings-btn{padding:6px 10px;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:transparent;color:#ffffffa6;cursor:pointer;font-size:16px;transition:all .15s;line-height:1;font-family:DM Sans,sans-serif}.settings-btn:hover{background:#ffffff1a;color:#fff;border-color:#fff3}.boat-type-btn{padding:5px 10px;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:#ffffff0f;color:#fffc;cursor:pointer;font-size:11px;font-weight:500;font-family:DM Sans,sans-serif;transition:all .15s;display:flex;align-items:center;gap:4px;white-space:nowrap}.boat-type-btn:hover{background:#ffffff1f;color:#fff;border-color:#fff3}.boat-type-chevron{font-size:9px;opacity:.5}.settings-overlay{position:fixed;inset:0;background:#1a233280;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(2px)}.settings-modal{background:#fff;border-radius:16px;box-shadow:0 8px 40px #0003;width:100%;max-width:420px;padding:28px 28px 24px;max-height:90vh;overflow-y:auto}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.settings-title{font-size:15px;font-weight:700;color:#1a2332;letter-spacing:-.2px}.settings-close{border:none;background:none;cursor:pointer;color:#a0a8b8;font-size:24px;line-height:1;padding:0 4px;border-radius:4px;transition:color .12s}.settings-close:hover{color:#1a2332}.settings-field{margin-bottom:18px}.settings-label{font-size:10px;font-weight:700;color:#1a2332;text-transform:uppercase;letter-spacing:.6px;display:block;margin-bottom:7px}.settings-select{width:100%;padding:9px 36px 9px 12px;border:1px solid #dde0e6;border-radius:8px;font-size:13px;color:#1a2332;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23a0a8b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 12px center;font-family:DM Sans,sans-serif;appearance:none;cursor:pointer;transition:border-color .15s}.settings-select:focus{outline:none;border-color:#1a2332}.settings-toggle-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;padding:12px 14px;background:#fafbfc;border-radius:8px;border:1px solid #eef0f3}.settings-toggle-label{font-size:13px;font-weight:600;color:#1a2332}.settings-toggle-desc{font-size:11px;color:#7a8599;margin-top:2px}.settings-toggle{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.settings-toggle input{opacity:0;width:0;height:0;position:absolute}.settings-toggle-slider{position:absolute;inset:0;background:#dde0e6;border-radius:12px;cursor:pointer;transition:.2s}.settings-toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px #0003}.settings-toggle input:checked+.settings-toggle-slider{background:#1db954}.settings-toggle input:checked+.settings-toggle-slider:before{transform:translate(20px)}.settings-actions{display:flex;gap:8px;margin-top:22px;padding-top:18px;border-top:1px solid #f0f1f3}.settings-save{flex:1;padding:10px;background:#1a2332;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif;transition:opacity .15s}.settings-save:hover{opacity:.85}.settings-reset{padding:10px 16px;background:#fff;color:#7a8599;border:1px solid #dde0e6;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;font-family:DM Sans,sans-serif;transition:all .15s}.settings-reset:hover{border-color:#1a2332;color:#1a2332}.conf-banner{border-radius:8px;padding:10px 14px;margin:8px 0 10px;display:block;box-sizing:border-box;width:100%}.conf-banner-label{font-size:13px;font-weight:700;color:#1a2332;text-align:center}.conf-banner-desc{font-size:12px;color:#5a6577;line-height:1.4;margin-top:3px;text-align:center}.conf-banner-source{font-size:10px;color:#a0a8b8;margin-top:4px;text-align:center}.depart-ctrl{position:absolute;top:12px;right:12px;z-index:1000;background:#ffffffeb;border-radius:8px;padding:8px 12px;font-size:10px;box-shadow:0 2px 8px #0000001a;backdrop-filter:blur(4px);display:flex;align-items:center;gap:6px;font-family:DM Sans,sans-serif}.depart-ctrl label{font-weight:700;color:#1a2332;text-transform:uppercase;letter-spacing:.5px;font-size:9px;white-space:nowrap;cursor:default}.depart-ctrl select{border:1px solid #dde0e6;border-radius:6px;padding:3px 8px;font-size:11px;font-family:DM Sans,sans-serif;color:#1a2332;background:#fff;cursor:pointer;outline:none}.route-hint{font-size:11px;color:#7a8599;margin:6px 0 2px;min-height:16px}.route-panel{background:#fff;border-radius:12px;border:1px solid #e8eaee;margin-top:12px;overflow:hidden}.route-panel-hdr{padding:12px 18px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e8eaee;flex-wrap:wrap;gap:6px}.route-panel-title{font-size:12px;font-weight:700;color:#1a2332;text-transform:uppercase;letter-spacing:.6px}.route-tbl-wrap{overflow-x:hidden}.route-tbl{width:100%;min-width:580px;border-collapse:collapse;font-size:12px;font-family:DM Sans,sans-serif}.route-tbl th{padding:8px 10px;font-size:9px;color:#7a8599;text-transform:uppercase;letter-spacing:.6px;font-weight:600;text-align:left;border-bottom:1px solid #e8eaee;white-space:nowrap}.route-tbl td{padding:9px 10px;border-bottom:1px solid #f0f1f3;vertical-align:middle}.route-tbl tbody tr:last-child td{border-bottom:none}.route-tbl tr.rleg-warn td{background:#fff8e1}.route-tbl tr.rleg-warn td:first-child{border-left:3px solid #f5a623;padding-left:8px}.route-tbl tr.rleg-bad td{background:#fee8e8}.route-tbl tr.rleg-bad td:first-child{border-left:3px solid #e74c3c;padding-left:8px}.route-tbl tr.rleg-total td{font-weight:700;border-top:2px solid #e8eaee;background:#fafbfc}.conf-info-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#00000014;font-size:11px;cursor:pointer;margin-left:6px;vertical-align:middle;user-select:none;font-style:normal}.conf-tooltip{position:fixed;z-index:2000;max-width:300px;background:#1a2332;color:#fff;font-size:12px;line-height:1.6;border-radius:10px;padding:14px 16px;box-shadow:0 4px 20px #0000004d;display:none;pointer-events:none;font-family:DM Sans,sans-serif}.conf-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1a2332}.conf-tooltip.pos-below:after{top:auto;bottom:100%;border-top-color:transparent;border-bottom-color:#1a2332}.route-story-panel{background:#fff;border-radius:12px;border:1px solid #e8eaee;margin-top:12px;overflow:hidden}.rps-section{padding:16px 18px;border-top:1px solid #e8eaee}.rps-section:first-child{border-top:none}.rps-title{font-size:10px;font-weight:700;color:#1a2332;text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}.rbcard-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.rbcard-title{font-size:13px;color:#1a2332;text-transform:uppercase;letter-spacing:.6px;font-weight:700}.rbcard-regen{padding:4px 10px;border:1px solid #dde0e6;border-radius:6px;font-size:11px;font-weight:500;cursor:pointer;background:#fff;color:#7a8599;font-family:DM Sans,sans-serif;transition:all .12s}.rbcard-regen:hover{border-color:#1a2332;color:#1a2332}.rbcard-body{font-size:15px;color:#2c3a4a;line-height:1.75;font-weight:400}.rbcard-loading{color:#a0a8b8;font-size:13px;font-style:italic}.route-bubble{position:absolute;z-index:2000;background:#1a2332;color:#fff;border-radius:12px;padding:14px 16px;min-width:240px;max-width:300px;box-shadow:0 8px 32px #00000040;font-family:DM Sans,sans-serif;pointer-events:none;display:none}.route-bubble.arrow-left:after{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);border:8px solid transparent;border-right-color:#1a2332}.route-bubble.arrow-right:after{content:"";position:absolute;right:-8px;top:50%;transform:translateY(-50%);border:8px solid transparent;border-left-color:#1a2332}.mode-switcher{display:flex;background:#ffffff14;border-radius:10px;padding:3px;gap:2px;position:absolute;left:50%;transform:translate(-50%)}.mode-btn{padding:6px 20px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif;color:#ffffff80;background:transparent;transition:all .15s;letter-spacing:.1px;white-space:nowrap}.mode-btn.active{background:#ffffff26;color:#fff}.mode-btn:hover{color:#fff}.route-map-section{background:#fff;border-radius:12px;border:1px solid #e8eaee;margin-bottom:12px;overflow:hidden;padding:16px 18px}@media(max-width:600px){.mode-switcher{position:relative;left:auto;transform:none}}#route-mode{position:fixed;inset:56px 0 0;width:100vw;z-index:10;overflow:hidden}.route-split{display:flex;position:fixed;inset:56px 0 0;width:100vw;height:calc(100vh - 56px);overflow:hidden;z-index:10}.route-split-left{flex:0 0 260px;width:260px;min-width:260px;max-width:260px;background:#1a2332;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;z-index:2}.route-split-map{flex:1 1 auto;width:0;min-width:0;position:relative;overflow:hidden;z-index:1}.route-split-map #wx-map{position:absolute!important;inset:0!important;width:100%!important;height:100%!important}.route-split-right{flex:0 0 280px;width:280px;min-width:280px;max-width:280px;background:#f5f6f8;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;border-left:1px solid #e8eaee;padding:16px;gap:12px;z-index:2}.left-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 14px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.left-sidebar-title{font-size:11px;font-weight:700;color:#ffffffe6;text-transform:uppercase;letter-spacing:.6px}.left-sidebar-badge{font-size:10px;padding:2px 8px;border-radius:8px;background:#7c3aed4d;color:#c4b5fd;font-weight:600}#left-sidebar-empty{padding:40px 20px;text-align:center;flex:1}#left-sidebar-loading{padding:24px 20px}#left-sidebar-briefing{padding:18px 18px 0;flex:1}.left-regen-btn{margin-top:16px;padding:6px 14px;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:transparent;color:#ffffff80;font-size:11px;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif;transition:all .15s;display:block}.left-regen-btn:hover{background:#ffffff14;color:#fffc;border-color:#fff3}.left-sidebar-divider{height:1px;background:#ffffff12;margin:16px 0;flex-shrink:0}.left-stat-row{display:flex;justify-content:space-between;align-items:center;padding:7px 18px}.left-stat-label{font-size:11px;color:#fff6;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.left-stat-value{font-size:13px;color:#ffffffd9;font-weight:600;font-family:Space Mono,monospace}#left-sidebar-stats{padding-bottom:20px}.route-map-controls{position:absolute;bottom:24px;right:12px;z-index:1000;display:flex;flex-direction:column;gap:4px}.route-layer-btn{width:36px;height:36px;border:1px solid #dde0e6;border-radius:8px;background:#fffffff2;backdrop-filter:blur(4px);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px #0000001f;transition:all .15s}.route-layer-btn:hover{background:#fff;box-shadow:0 2px 8px #00000026}.route-layer-btn.active{background:#1a2332;border-color:#1a2332;filter:invert(1)}.route-map-divider{height:1px;background:#dde0e6;margin:4px 0}.route-draw-btn.drawing{background:#7c3aed;border-color:#7c3aed;filter:invert(1)}.route-toast{position:absolute;bottom:80px;left:50%;transform:translate(-50%);background:#1a2332;color:#fff;padding:8px 16px;border-radius:20px;font-size:12px;font-weight:600;font-family:DM Sans,sans-serif;z-index:1001;animation:toastFade 2.5s ease forwards;white-space:nowrap;pointer-events:none}@keyframes toastFade{0%{opacity:0;transform:translate(-50%) translateY(8px)}15%{opacity:1;transform:translate(-50%) translateY(0)}75%{opacity:1}to{opacity:0}}.sidebar-depart-card{background:#fff;border-radius:12px;border:1px solid #e8eaee;padding:16px}.sidebar-section-label{font-size:10px;font-weight:700;color:#1a2332;text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px}.sidebar-depart-row{display:flex;gap:8px}.sidebar-select{flex:1;padding:8px 10px;border:1px solid #dde0e6;border-radius:8px;font-size:13px;font-family:DM Sans,sans-serif;color:#1a2332;background:#fff;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23a0a8b8' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;cursor:pointer;min-width:0}.sidebar-select:focus{outline:none;border-color:#1a2332}.sidebar-empty{background:#fff;border-radius:12px;border:1px solid #e8eaee;padding:28px 20px;text-align:center}.sidebar-marina-list{display:flex;flex-direction:column;gap:6px;text-align:left}.sidebar-marina-btn{padding:8px 12px;border:1px solid #e8eaee;border-radius:8px;background:#fafbfc;font-size:12px;font-weight:500;color:#1a2332;cursor:pointer;font-family:DM Sans,sans-serif;text-align:left;transition:all .15s;display:flex;align-items:center;gap:8px;width:100%}.sidebar-marina-btn:hover{background:#1a2332;color:#fff;border-color:#1a2332}.sidebar-drawing-status{background:#7c3aed18;border:1px solid #7c3aed40;border-radius:10px;padding:12px 16px;font-size:13px;color:#7c3aed;font-weight:600;text-align:center}#wx-map{height:100%!important;min-height:unset!important}#route-analysis-section .route-tbl{min-width:unset;width:100%;font-size:11px}#route-analysis-section .route-tbl th,#route-analysis-section .route-tbl td{padding:6px}#route-analysis-section .route-panel{border-radius:0;border:none;margin-top:0}@media(max-width:768px){.route-split{flex-direction:column;height:auto}.route-split-left{flex:0 0 auto;min-width:unset;max-width:unset;width:100%;min-height:180px}.route-split-map{flex:0 0 400px;width:100%}.route-split-right{flex:0 0 auto;min-width:unset;max-width:unset;width:100%}}.best-windows-card{background:#fff;border-radius:12px;border:1px solid #e8eaee;margin-bottom:20px;overflow:hidden}.bw-hero{padding:0;border-bottom:none;cursor:default}.bw-hero:hover{background:transparent}.bw-also{padding:0}.bw-also-label{font-size:10px;color:#a0a8b8;text-transform:uppercase;letter-spacing:.5px;font-weight:600;padding:0 20px 8px}.bw-cta{padding:14px 22px;background:#fafbfc;border-top:1px solid #e8eaee;display:flex;align-items:center;justify-content:space-between;gap:12px}.bw-cta-text{font-size:13px;color:#7a8599}.bw-cta-btn{font-size:12px;font-weight:600;padding:6px 14px;border-radius:8px;background:#fff;border:1px solid #dde0e6;color:#1a2332;cursor:pointer;font-family:DM Sans,sans-serif;transition:all .12s;white-space:nowrap}.bw-cta-btn:hover{border-color:#1a2332}.bw-cta-done{font-size:13px;color:#1db954;font-weight:600}.bw-freq-opts{display:flex;gap:8px}.bw-freq-btn{font-size:12px;font-weight:600;padding:6px 14px;border-radius:8px;background:#fff;border:1px solid #dde0e6;color:#1a2332;cursor:pointer;font-family:DM Sans,sans-serif;transition:all .12s;white-space:nowrap}.bw-freq-btn:hover{border-color:#1a2332;background:#f4f5f7}.app-layout{display:flex;align-items:flex-start}.app-layout>.container{flex:1;min-width:0;margin-left:0;margin-right:0}.pref-sidebar{position:fixed;top:0;right:0;bottom:0;width:320px;max-width:90vw;height:100%;overflow-y:auto;padding:20px 16px 32px;background:#fff;z-index:200;box-shadow:-4px 0 24px #00000026;transform:translate(100%);transition:transform .3s ease;border-right:none}.pref-sidebar.open{transform:translate(0)}.pref-backdrop{display:none;position:fixed;inset:0;background:#1a233266;z-index:199;backdrop-filter:blur(2px)}.pref-backdrop.open{display:block}.pref-sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-shrink:0}.pref-sidebar-title{font-size:11px;font-weight:700;color:#1a2332;text-transform:uppercase;letter-spacing:.6px}.pref-close{display:block;background:none;border:none;font-size:20px;line-height:1;color:#7a8599;cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .15s;font-family:DM Sans,sans-serif}.pref-close:hover{color:#1a2332}.pref-location-section{display:none}.pref-divider{display:none;border:none;border-top:1px solid #e8eaee;margin:4px -16px 16px}.mobile-zone-bar{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.mobile-zone-bar .zone-btn{border-radius:8px;white-space:normal;line-height:1.35;padding:8px 12px;width:auto;font-size:12px}.pref-field{margin-bottom:14px}.pref-label{font-size:10px;font-weight:700;color:#1a2332;text-transform:uppercase;letter-spacing:.6px;display:block;margin-bottom:6px}.pref-label-note{font-weight:400;color:#a0a8b8;text-transform:none;letter-spacing:0;font-size:9px}.pref-select{width:100%;padding:8px 28px 8px 10px;border:1px solid #dde0e6;border-radius:8px;font-size:12px;color:#1a2332;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23a0a8b8' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") no-repeat right 10px center;font-family:DM Sans,sans-serif;appearance:none;cursor:pointer;transition:border-color .15s}.pref-select:focus{outline:none;border-color:#1a2332}.pref-dual-slider{position:relative;height:20px;margin-bottom:4px}.pref-slider-track{position:absolute;top:50%;left:0;right:0;height:4px;background:#e8eaee;border-radius:2px;transform:translateY(-50%)}.pref-slider-fill{position:absolute;top:0;height:100%;background:var(--accent,#1D9E75);border-radius:2px;pointer-events:none}.pref-range{position:absolute;top:50%;width:100%;height:4px;background:transparent;pointer-events:none;appearance:none;outline:none;transform:translateY(-50%);margin:0}.pref-range::-webkit-slider-thumb{pointer-events:auto;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent,#1D9E75);border:2px solid #fff;box-shadow:0 1px 4px #00000040;cursor:pointer;transition:transform .1s}.pref-range::-moz-range-thumb{pointer-events:auto;width:12px;height:12px;border-radius:50%;background:var(--accent,#1D9E75);border:2px solid #fff;box-shadow:0 1px 4px #00000040;cursor:pointer;border:none}.pref-range:hover::-webkit-slider-thumb,.pref-range:focus::-webkit-slider-thumb{transform:scale(1.2)}.pref-single-slider{margin-bottom:4px}.pref-range-single{width:100%;height:4px;appearance:none;border-radius:2px;outline:none;cursor:pointer;display:block}.pref-range-single::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent,#378ADD);border:2px solid #fff;box-shadow:0 1px 4px #00000040;cursor:pointer;transition:transform .1s}.pref-range-single::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--accent,#378ADD);border:2px solid #fff;box-shadow:0 1px 4px #00000040;cursor:pointer;border:none}.pref-range-single:hover::-webkit-slider-thumb{transform:scale(1.2)}.pref-slider-vals{font-size:11px;color:#5a6577;font-family:Space Mono,monospace;text-align:center;margin-top:2px}.pref-hours-ww-note{display:none;font-size:10px;color:#7f77dd;font-style:italic;text-align:center;margin-top:3px}.pref-segs{display:flex;gap:3px}.pref-seg{flex:1;padding:6px 2px;border:1px solid #dde0e6;border-radius:6px;font-size:11px;font-weight:500;cursor:pointer;background:#fff;color:#5a6577;font-family:DM Sans,sans-serif;transition:all .12s;text-align:center;line-height:1.2}.pref-seg.active{background:#1a2332;color:#fff;border-color:#1a2332}.pref-seg:hover:not(.active){border-color:#1a2332;color:#1a2332}.pref-ww-wrap{margin:14px 0 16px;padding:11px 13px;background:#fafbfc;border-radius:10px;border:1px solid #eef0f3;cursor:pointer;transition:all .15s;user-select:none}.pref-ww-wrap.active{background:#7f77dd1a;border-color:#7f77dd}.pref-ww-inner{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.pref-ww-label{font-size:13px;font-weight:600;color:#1a2332}.pref-ww-badge{font-size:9px;font-weight:700;padding:2px 7px;border-radius:10px;background:#e8eaee;color:#7a8599;letter-spacing:.5px;transition:all .15s}.pref-ww-wrap.active .pref-ww-badge{background:#7f77dd;color:#fff}.pref-ww-desc{font-size:10px;color:#7a8599;line-height:1.4}.pref-apply{width:100%;padding:10px;background:#1a2332;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif;margin-bottom:7px;transition:opacity .15s;display:block}.pref-apply:hover{opacity:.85}.pref-reset{width:100%;padding:9px;background:#fff;color:#7a8599;border:1px solid #dde0e6;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;font-family:DM Sans,sans-serif;transition:all .15s;display:block}.pref-reset:hover{border-color:#1a2332;color:#1a2332}@media(max-width:768px){html,body{overflow-x:hidden;max-width:100%}.topbar{position:sticky!important;top:0;flex-wrap:nowrap;gap:6px;padding:10px 14px;padding-top:max(10px,env(safe-area-inset-top));padding-left:max(14px,env(safe-area-inset-left));padding-right:max(14px,env(safe-area-inset-right))}.topbar-divider{display:none}.topbar-loc{font-size:11px;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.skill-row,.boat-type-btn{display:none}.app-layout{display:block}.app-layout>.container{margin-left:0;margin-right:0}.container{overflow-x:hidden;padding-left:14px;padding-right:14px;padding-bottom:max(50px,env(safe-area-inset-bottom))}.forecast-layout{align-items:stretch}.forecast-main{width:100%;min-width:0}.pref-sidebar{position:fixed;inset:0;width:100%;height:100%;max-height:none;border-radius:0;transform:translateY(100%);transition:transform .3s ease;z-index:200;border-right:none;border-top:none;padding-top:max(16px,env(safe-area-inset-top));padding-bottom:max(20px,env(safe-area-inset-bottom))}.pref-sidebar.open{transform:translateY(0)}.zone-sidebar{display:none}.pref-location-section,.pref-divider{display:block}.bw-cta{flex-wrap:wrap}.bw-also-grid{grid-template-columns:1fr!important}.pref-seg{min-height:44px;display:flex;align-items:center;justify-content:center}}
