:root{--bg-main:#1d242b;--bg-card:#222831;--bg-header:#1a2f3d;--bg-sidebar:#0f1b22;--border-subtle:#7aada02e;--text-bright:#e8eef5;--text-muted:#a8b8c8;--text-dim:#8a9fb5;--teal:#7aada0;--teal-on:#0d1816;--orange:#e8762e;--orange-on:#1a0d05;--swell-primary:#4a7a8a;--swell-primary-text:#7ab5c8;--swell-secondary:#8a7a50;--swell-secondary-text:#c4a86a;--tide-rising:#c890b5;--tide-falling:#9c8cb5;--rating-good:#7ab87a;--rating-fair-to-good:#a8b85a;--rating-fair:#d07838;--rating-poor-to-fair:#c05828;--rating-poor:#a04030;--font-display:"Pirata One", serif;--font-ui:"Inter Tight", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-numeric:"Inter Tight", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{color:#fff;font-family:var(--font-ui);-webkit-font-smoothing:antialiased;background:#1c1c1c}.app{min-height:100vh}.app.loading{color:#888;justify-content:center;align-items:center;min-height:100vh;display:flex}.main-content{min-width:0;margin-left:64px;padding:0}.spot-page{flex-direction:column;height:100vh;display:flex;position:relative;overflow:hidden}.page-header{justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.75rem 0 1.25rem;display:flex}.page-header-titles{flex-direction:column;gap:10px;display:flex}.page-header-region{color:#555;letter-spacing:1.5px;font-size:9px;font-weight:600}.page-header-title{font-family:var(--font-display);color:#e8eef5;letter-spacing:-.5px;margin:0;font-size:32px;font-weight:400;line-height:1.1}.page-header-toggle{z-index:10;border:1px solid #3a3a3a;border-radius:0;align-items:stretch;display:flex;position:absolute;top:1.75rem;right:2rem;overflow:hidden}.page-toggle{color:#8a8a8a;font-family:var(--font-ui);letter-spacing:1px;text-transform:uppercase;cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border:none;padding:6px 14px;font-size:10px;font-weight:600;transition:color .15s,background .15s}.page-toggle:hover:not(.active){color:#c4c4c4}.page-toggle.active{color:var(--text-bright);background:#3a3a3a}.spot-layout{flex:1;grid-template-columns:minmax(0,1fr) 540px;gap:20px;min-height:0;padding:1rem 2rem 1.5rem;transition:grid-template-columns .25s,gap .25s;display:grid}.spot-layout.maximized{grid-template-columns:minmax(0,1fr) 0;gap:0}.forecast-col{transition:opacity .2s,visibility .2s}.spot-layout.maximized .forecast-col{opacity:0;visibility:hidden;overflow:hidden}.viewer-col,.forecast-col{min-width:0;min-height:0}.forecast-col{flex-direction:column;display:flex;overflow:hidden}.chart-view{background:var(--bg-main);height:100%;display:flex;overflow:visible}.chart-view-empty{color:#5a7080;text-align:center;padding:2rem}.chart-values{background:var(--bg-sidebar);border-right:1px solid #ffffff14;flex-direction:column;flex-shrink:0;gap:6px;width:120px;padding:18px 0 8px 12px;display:flex}.chart-value-row{border-left:3px solid var(--teal);flex-direction:column;justify-content:center;gap:2px;padding-left:6px;display:flex}.chart-values-spacer{flex-shrink:0;height:18px}.chart-value-label{font-family:var(--font-display);color:#c8dde8;letter-spacing:.5px;font-size:16px;font-weight:400}.chart-value-line{font-family:var(--font-numeric);font-size:11px;font-weight:600}.chart-value-line-weather{align-items:center;gap:5px;display:inline-flex}.chart-value-sub{font-family:var(--font-ui);opacity:.85;font-size:9px;font-weight:500}.chart-stack{flex-direction:column;flex:1;gap:6px;min-width:0;padding:18px 8px 8px;display:flex;position:relative}.chart-row{background:#ffffff05;border:1px solid #ffffff0f;border-radius:6px;flex-shrink:0;position:relative;overflow:hidden}.chart-row svg{display:block}.chart-cursor{background:var(--orange);z-index:6;pointer-events:none;width:2px;position:absolute;top:18px;bottom:8px;transform:translate(-50%)}.tide-extreme-marker{cursor:pointer;z-index:2;background:0 0;border:0;border-radius:50%;width:12px;height:12px;transition:background .12s,transform .12s;position:absolute;transform:translate(-50%,-50%)}.tide-extreme-marker:hover{background:var(--orange);transform:translate(-50%,-50%)scale(1)}.chart-cursor-label{color:var(--orange);font-family:var(--font-numeric);letter-spacing:.3px;white-space:nowrap;font-size:11px;font-weight:700;position:absolute;top:-16px;left:50%;transform:translate(-50%)}.chart-tooltip{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap;pointer-events:none;z-index:8;text-align:right;background:#0d162080;border-radius:3px;flex-direction:column;align-items:flex-end;gap:1px;padding:3px 7px;display:flex;position:absolute;box-shadow:0 2px 8px #0009}.chart-tooltip-time{font-family:var(--font-numeric);letter-spacing:.3px;color:#8aa8b5;font-size:9px;font-weight:600}.chart-tooltip-value{font-family:var(--font-numeric);font-size:11px;font-weight:700}.chart-tooltip-value.sm{font-size:10px;font-weight:600}.night-overlay{pointer-events:none;z-index:2;position:absolute;inset:0}.night-block{background:#000;position:absolute;top:0;bottom:0}.sun-strip{border-top:1px solid #ffffff0f;flex-shrink:0;height:22px;margin-top:2px;position:relative}.sun-strip-line{background:#ffffff2e;height:1px;position:absolute;top:50%;left:0;right:0}.sun-strip-mark{background:var(--bg-main);pointer-events:none;align-items:center;padding:0 4px;display:flex;position:absolute;top:50%;transform:translate(-50%,-50%)}.weather-strip{align-items:center;width:100%;height:100%;display:flex}.weather-cell{flex-direction:column;flex:1;align-items:center;gap:1px;display:flex}.weather-cell-icon{font-size:14px;line-height:1}.weather-cell-temp{font-family:var(--font-numeric);color:#c8d8e8;font-size:9px;font-weight:500}.home-page{min-height:100vh;color:var(--text-bright);box-sizing:border-box;justify-content:center;align-items:center;padding:64px 48px;display:flex}.home-statement{text-align:center;max-width:620px;transform:translateY(-4vh)}.home-title{font-family:var(--font-ui);color:var(--text-bright);letter-spacing:-1.8px;margin:0 0 36px;font-size:60px;font-weight:700;line-height:1.05}.home-title-brand{color:var(--teal)}.home-mission{text-align:center;max-width:560px;margin:0 auto}.home-subtitle{font-family:var(--font-ui);color:var(--text-muted);margin:0;font-size:15px;line-height:1.7}.home-subtitle+.home-subtitle{margin-top:18px}.home-spot-picker{text-align:center;max-width:560px;margin:32px auto 0}.home-spot-picker-wrap{display:inline-block;position:relative}.home-spot-picker-trigger{font-family:var(--font-ui);color:var(--text-dim);background:var(--bg-card);border:1px solid var(--border-subtle);cursor:pointer;border-radius:5px;justify-content:space-between;align-items:center;gap:10px;min-width:240px;padding:9px 14px;font-size:14px;font-weight:500;transition:border-color .15s,background-color .15s,color .15s;display:inline-flex}.home-spot-picker-trigger:hover,.home-spot-picker-trigger.open{color:var(--text-muted);background-color:#2a2f38;border-color:#7aada066}.home-spot-picker-trigger:focus-visible{border-color:var(--teal);outline:none}.home-spot-picker-trigger-text{text-align:left;flex:1}.home-spot-picker-chevron{color:var(--text-dim);flex-shrink:0;transition:transform .15s}.home-spot-picker-trigger.open .home-spot-picker-chevron{color:var(--teal);transform:rotate(180deg)}.home-spot-picker-menu{background:var(--bg-card);border:1px solid var(--border-subtle);z-index:50;text-align:left;scrollbar-width:thin;scrollbar-color:#7aada066 transparent;border-radius:5px;min-width:240px;max-height:240px;padding:6px 0;position:absolute;top:calc(100% + 6px);bottom:auto;left:0;overflow-y:auto;box-shadow:0 8px 28px #00000073}.home-spot-picker-menu::-webkit-scrollbar{width:6px}.home-spot-picker-menu::-webkit-scrollbar-track{background:0 0}.home-spot-picker-menu::-webkit-scrollbar-thumb{background:#7aada066;border-radius:3px}.home-spot-picker-menu::-webkit-scrollbar-thumb:hover{background:#7aada099}.home-spot-picker-group+.home-spot-picker-group{border-top:1px solid var(--border-subtle);margin-top:4px;padding-top:6px}.home-spot-picker-region{font-family:var(--font-ui);letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);padding:6px 14px 4px;font-size:10px;font-weight:600}.home-spot-picker-option{text-align:left;width:100%;font-family:var(--font-ui);color:var(--text-bright);cursor:pointer;background:0 0;border:0;justify-content:space-between;align-items:center;gap:10px;padding:6px 14px;font-size:14px;font-weight:500;transition:background .12s,color .12s;display:flex}.home-spot-picker-option:hover,.home-spot-picker-option:focus-visible{color:var(--teal);background:#7aada01f;outline:none}.home-spot-picker-option-name{text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.home-spot-picker-option-cam{color:var(--text-dim);flex-shrink:0;transition:color .12s;display:inline-flex}.home-spot-picker-option:hover .home-spot-picker-option-cam,.home-spot-picker-option:focus-visible .home-spot-picker-option-cam{color:var(--teal)}.alerts-page{justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.alerts-card{text-align:left;background:#152532;border:0;border-radius:5px;max-width:460px;padding:28px 32px}.alerts-eyebrow{letter-spacing:1.5px;color:#7aada0;text-transform:uppercase;margin-bottom:8px;font-size:9px;font-weight:700;display:block}.alerts-headline{color:#e8eef5;letter-spacing:-.3px;margin:0 0 12px;font-size:22px;font-weight:700}.alerts-body{color:#a8b8c8;margin:0;font-size:13px;line-height:1.55}.sessions-panel{flex:1;justify-content:center;align-items:flex-start;margin-top:auto;padding:2rem 0;display:flex}.sessions-card{text-align:left;background:#152532;border:0;border-radius:5px;max-width:460px;padding:24px 28px}.sessions-eyebrow{letter-spacing:1.5px;color:#7aada0;text-transform:uppercase;margin-bottom:8px;font-size:9px;font-weight:700;display:block}.sessions-headline{color:#e8eef5;letter-spacing:-.3px;margin:0 0 12px;font-size:20px;font-weight:700}.sessions-body{color:#a8b8c8;margin:0;font-size:13px;line-height:1.55}.viewer-panel{background:#262b37;border-radius:5px;flex-direction:column;height:100%;min-height:360px;display:flex;overflow:hidden;box-shadow:0 8px 40px #0006}.viewer-tabs{background:#3a3a3a;border-bottom:1px solid #3a3a3a;flex-shrink:0;align-items:center;padding:8px 12px;display:flex}.viewer-tab{color:#8a8a8a;font-family:var(--font-ui);letter-spacing:1px;text-transform:uppercase;cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border:none;border-bottom:2px solid #0000;padding:4px 10px;font-size:9px;font-weight:600;transition:color .15s}.viewer-tab:hover:not(.active){color:#c4c4c4}.viewer-tab.active{color:var(--text-bright);border-bottom-color:#fff}.viewer-body{flex:1;min-height:0;position:relative}.viewer-placeholder{color:#5a7080;letter-spacing:.4px;pointer-events:none;justify-content:center;align-items:center;font-size:.85rem;display:flex;position:absolute;inset:0}.compass-container{background-color:#07080a;position:absolute;inset:0;overflow:hidden}.compass-container .viewer-placeholder{align-items:flex-end;padding-bottom:18%}.compass-svg{pointer-events:auto;-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none;width:100%;height:100%;display:block}.sidebar{-webkit-backdrop-filter:blur(24px)saturate(140%);backdrop-filter:blur(24px)saturate(140%);z-index:50;clip-path:inset(-40px 196px -40px 0);will-change:clip-path;background:#161616e0;flex-direction:column;width:260px;height:100vh;padding:28px 0;transition:clip-path .32s cubic-bezier(.4,0,.2,1),box-shadow .32s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0;box-shadow:4px 0 24px #0000}.sidebar.expanded{clip-path:inset(-40px -40px -40px 0);box-shadow:4px 0 24px #00000080}.sidebar-logo{color:#7aada0;white-space:nowrap;height:30px;margin-bottom:36px;padding-top:24px;padding-left:25px;font-family:Noto Sans JP,sans-serif;font-size:24px;line-height:1;position:relative}.sidebar-logo-rest{opacity:0;transition:opacity .18s}.sidebar.expanded .sidebar-logo-rest{opacity:1;transition-delay:.12s}.sidebar-nav{flex-direction:column;flex:1;gap:4px;display:flex}.nav-item{cursor:pointer;color:#909090;white-space:nowrap;height:34px;font-size:14px;transition:color .15s;position:relative}.nav-item:hover{color:#c8c8c8}.nav-item.active{color:#fff}.nav-item.active:before{content:"";background:#fff;border-radius:0 2px 2px 0;width:2px;position:absolute;top:6px;bottom:6px;left:0}.nav-item-icon-wrap{justify-content:center;align-items:center;width:22px;height:22px;display:flex;position:absolute;top:50%;left:21px;transform:translateY(-50%)}.nav-item-status-dot{border:1.5px solid #191818;border-radius:50%;width:7px;height:7px;position:absolute;bottom:-2px;right:-2px}.nav-item-label{opacity:0;padding-left:58px;line-height:34px;transition:opacity .18s,transform .32s cubic-bezier(.4,0,.2,1);display:block;transform:translate(-12px)}.sidebar.expanded .nav-item-label{opacity:1;transition:opacity .18s .1s,transform .32s cubic-bezier(.4,0,.2,1) 50ms;transform:translate(0)}.spot-regions{opacity:0;pointer-events:none;scrollbar-width:thin;scrollbar-color:#2a2a2a transparent;flex-direction:column;max-height:calc(100vh - 280px);margin:4px 0 6px;transition:opacity .18s,transform .32s cubic-bezier(.4,0,.2,1);display:flex;overflow-y:auto;transform:translate(-12px)}.spot-regions.visible{opacity:1;pointer-events:auto;transition:opacity .18s .1s,transform .32s cubic-bezier(.4,0,.2,1) 50ms;transform:translate(0)}.spot-region{margin-top:8px}.spot-region:first-child{margin-top:0}.spot-region-label{color:#555;letter-spacing:1.5px;white-space:nowrap;padding:4px 24px 4px 58px;font-size:9px;font-weight:600}.spot-nav-item{color:#909090;cursor:pointer;white-space:nowrap;align-items:center;gap:8px;padding:5px 24px 5px 58px;font-size:13px;transition:color .15s;display:flex}.spot-nav-item:hover{color:#c8c8c8}.spot-nav-item.active{color:#e8eef5;font-weight:600}.spot-rating-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.spot-nav-name{text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.spot-nav-cam-icon{color:var(--text-dim);flex-shrink:0;transition:color .15s;display:inline-flex}.spot-nav-item:hover .spot-nav-cam-icon,.spot-nav-item.active .spot-nav-cam-icon{color:var(--teal)}.sidebar-footer{padding:12px 0 8px;position:relative}.sidebar-footer:before{content:"";background:#2a2a2a;height:1px;position:absolute;top:0;left:21px;right:22px}.login-item{color:#555;font-size:13px}.conditions-table{background:var(--bg-main);scrollbar-width:none;scroll-snap-type:y mandatory;height:100%;scroll-padding-top:44px;position:relative;overflow-y:auto}.conditions-table::-webkit-scrollbar{display:none}.conditions-header,.conditions-row{grid-template-columns:64px 124px 1fr 1fr 1.4fr;align-items:center;gap:14px;display:grid}.conditions-header{z-index:1;background:var(--bg-header);align-items:center;height:44px;padding:0 14px;position:sticky;top:0}.conditions-header .col{font-family:var(--font-display);letter-spacing:1.4px;color:var(--text-bright);white-space:nowrap;align-items:baseline;padding:0;font-size:15px;font-weight:400;display:flex}.col-unit{font-family:var(--font-ui);letter-spacing:1.5px;text-transform:uppercase;color:var(--teal);white-space:nowrap;opacity:.6;margin-left:3px;font-size:11px;font-weight:600;transform:translateY(-.22em)}.forecast-toolbar{background:#152532;border-radius:5px 5px 0 0;justify-content:space-between;align-items:center;gap:.5rem;max-width:700px;padding:8px 14px;display:flex}.conditions-row{background:var(--bg-card);cursor:pointer;scroll-snap-align:start;border-bottom:1px solid #1f2e35;height:80px;padding:10px 14px;transition:background .12s}.conditions-row:hover{cursor:pointer;background:#2a2f38}.conditions-row.past{opacity:.7}.conditions-row.selected{box-shadow:inset 2px 0 0 var(--teal);background:#7aada01a}.conditions-row.selected:hover{background:#7aada029}.conditions-row.selected .time-label{color:var(--teal);font-weight:700}.conditions-row:last-child{border-bottom:none}.conditions-row .col{padding:0;display:block}.conditions-row .col-time{flex-direction:column;justify-content:center;align-items:flex-start;gap:3px;display:flex!important}.time-label{color:#c4c4c4;letter-spacing:.04em;font-size:.75rem;font-weight:500}.weather-line{align-items:center;gap:4px;display:flex}.weather-icon{font-size:1rem;line-height:1}.weather-temp{color:#c4c4c4;font-size:.7rem;font-weight:500}.conditions-row .col-wave{border-radius:3px;flex-direction:column;justify-content:center;justify-self:start;gap:2px;padding:6px 8px;display:flex}.col-wave.rating-good{background:#7ab87a14}.col-wave.rating-fair-to-good{background:#a8b85a14}.col-wave.rating-fair{background:#d0783814}.col-wave.rating-poor-to-fair{background:#c0582814}.col-wave.rating-poor{background:#a0403014}.wave-main{align-items:center;gap:6px;display:flex}.wave-height{font-family:var(--font-numeric);letter-spacing:-.02em;color:var(--text-bright);white-space:nowrap;flex-shrink:0;font-size:24px;font-weight:900;line-height:1}.wave-detail{font-family:var(--font-numeric);color:var(--text-dim);letter-spacing:.02em;font-size:10px;display:block}.quality-badge{font-family:var(--font-ui);border:1px solid;border-color:color-mix(in srgb, currentColor 60%, transparent);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;opacity:.92;background:0 0;border-radius:3px;flex-shrink:0;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.quality-badge.good{color:var(--rating-good)}.quality-badge.fair-to-good{color:var(--rating-fair-to-good)}.quality-badge.fair{color:var(--rating-fair)}.quality-badge.poor-to-fair{color:var(--rating-poor-to-fair)}.quality-badge.poor{color:var(--rating-poor)}.conditions-row .col-tide{align-items:center;gap:6px;display:flex}.tide-height{font-family:var(--font-numeric);color:var(--text-bright);font-size:20px;font-weight:500;line-height:1}.tide-arrow{font-family:var(--font-ui);font-size:11px;line-height:1}.tide-arrow.rising{color:var(--tide-rising)}.tide-arrow.falling{color:var(--tide-falling)}.conditions-row .col-wind{flex-direction:column;justify-content:center;gap:2px;display:flex}.wind-line{align-items:baseline;gap:3px;display:flex}.wind-speed{font-family:var(--font-numeric);color:inherit;font-size:20px;font-weight:500;line-height:1}.wind-dir{font-family:var(--font-ui);color:inherit;letter-spacing:.04em;font-size:10px}.wind-gust{font-family:var(--font-ui);color:var(--text-dim);font-size:9px;display:block}.conditions-row .col-swell{flex-direction:column;justify-content:center;gap:4px;display:flex}.swell-primary,.swell-secondary{flex-wrap:wrap;align-items:baseline;gap:5px;padding-left:6px;display:flex}.swell-primary{border-left:2px solid var(--swell-primary);color:var(--swell-primary-text)}.swell-secondary{border-left:2px solid var(--swell-secondary);color:var(--swell-secondary-text);opacity:.85}.swell-primary .swell-height{font-family:var(--font-numeric);color:inherit;font-size:16px;font-weight:700;line-height:1}.swell-primary .swell-period,.swell-primary .swell-dir{font-family:var(--font-ui);color:inherit;font-size:10px}.swell-secondary span{font-family:var(--font-ui);color:inherit;font-size:9px}.swell-secondary span:first-child{font-family:var(--font-numeric);font-size:11px;font-weight:500;line-height:1}.date-tiles{overscroll-behavior:contain;scrollbar-width:none;-ms-overflow-style:none;flex-shrink:0;gap:8px;margin-bottom:4px;padding-bottom:4px;display:flex;overflow:auto hidden}.date-tiles::-webkit-scrollbar{display:none}.date-tile{cursor:pointer;box-sizing:border-box;text-align:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1c2e38f2;border:none;border-radius:5px;flex-direction:column;flex-shrink:0;align-items:center;gap:8px;width:88px;padding:14px 8px;transition:background .15s;display:flex;position:relative}.date-tile-stripe{background:var(--orange);opacity:0;border-radius:5px 5px 0 0;height:1.5px;transition:opacity .15s;position:absolute;top:0;left:0;right:0}.date-tile.selected .date-tile-stripe{opacity:1}.date-tile-pointer{border-left:7px solid #0000;border-right:7px solid #0000;border-top:7px solid var(--bg-sidebar);opacity:0;pointer-events:none;width:0;height:0;transition:opacity .15s;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)}.date-tile.selected .date-tile-pointer{opacity:1}.date-tile:hover:not(.selected){background:#263a46f2}.date-tile.selected{background:var(--bg-sidebar)}.date-tile-label{font-family:var(--font-ui);letter-spacing:1px;text-transform:uppercase;white-space:nowrap;color:#ffffffb3;font-size:11px;font-weight:700}.date-tile.selected .date-tile-label{color:var(--text-bright)}.date-tile-range{align-items:baseline;gap:2px;display:flex}.date-tile-range-value{font-family:var(--font-numeric);letter-spacing:-.3px;color:var(--text-bright);font-size:18px;font-weight:700;line-height:1}.date-tile-range-unit{font-family:var(--font-ui);color:var(--text-dim);font-size:9px;font-weight:600}.rating-bars{gap:4px;width:100%;margin-top:2px;display:flex}.rating-bar{border-radius:2px;flex:1;height:3px}.rating-bars.empty{height:3px}.day-summary-card{flex-direction:column;flex:1;min-height:0;margin-bottom:14px;display:flex}.forecast-stack{flex-direction:column;flex:1;min-height:0;display:flex}.forecast-card{flex-direction:column;flex-shrink:0;max-width:700px;margin-top:auto;display:flex}.summary-top{justify-content:space-between;align-items:center;gap:12px;display:flex}.summary-meta-line{font-family:var(--font-ui);letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);align-items:baseline;gap:6px;font-size:11px;font-weight:700;display:flex}.summary-meta-sep{opacity:.5}.summary-meta-state{margin-left:6px}.summary-meta-weather{letter-spacing:.3px;text-transform:none;cursor:help;align-items:center;gap:4px;font-weight:500;display:inline-flex;position:relative}.summary-icons{font-family:var(--font-ui);color:var(--text-muted);align-items:center;gap:14px;margin-bottom:2px;font-size:11px;display:flex}.summary-meta-weather:hover{color:var(--text-bright)}.summary-meta-weather:after{content:attr(data-tooltip);font-family:var(--font-ui);letter-spacing:.3px;text-transform:none;color:var(--text-muted);white-space:nowrap;opacity:0;pointer-events:none;margin-top:4px;font-size:10px;font-weight:500;position:absolute;top:100%;left:50%;transform:translate(-50%)}.summary-meta-weather:hover:after{opacity:1}.summary-live-pill{font-family:var(--font-ui);letter-spacing:1px;text-transform:uppercase;color:var(--text-bright);border:1px solid #ffffff2e;border-radius:999px;align-items:center;gap:5px;padding:3px 8px;font-size:10px;font-weight:700;display:inline-flex}.summary-live-pill-dot{background:var(--rating-good);border-radius:50%;width:6px;height:6px;animation:1.6s ease-in-out infinite summary-live-pulse}@keyframes summary-live-pulse{0%,to{opacity:1}50%{opacity:.4}}.day-summary-card{box-sizing:border-box;position:relative}.day-card-info{background:var(--bg-sidebar);box-sizing:border-box;border-radius:5px;flex-direction:column;flex:1;gap:6px;min-height:0;margin-right:150px;padding:12px 18px;display:flex}.day-card-bulletin{box-sizing:border-box;opacity:.82;flex-direction:column;width:150px;padding:12px 0 12px 14px;display:flex;position:absolute;top:0;bottom:0;right:0}.tide-flip-inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,0,.2,1);position:relative}.summary-body-right.flipped .tide-flip-inner{transform:rotateY(180deg)}.tide-flip-face{background:var(--bg-sidebar);backface-visibility:hidden;box-sizing:border-box;border:1px solid #ffffff14;border-radius:4px;flex-direction:column;padding:6px 10px;display:flex}.tide-flip-front{height:100%;position:relative;overflow:hidden}.tide-flip-back{position:absolute;inset:0;transform:rotateY(180deg)}.tide-flip-face .summary-stat{border:0;gap:2px;padding:0}.tide-flip-face .summary-stat-label{letter-spacing:1px;font-size:8px}.tide-mini{flex-direction:column;gap:4px;height:100%;display:flex}.tide-mini-header{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.tide-mini-live{font-family:var(--font-numeric,ui-monospace, SFMono-Regular, Menlo, monospace);font-variant-numeric:tabular-nums;color:#e8e0d0;align-items:baseline;gap:3px;font-size:12px;display:inline-flex}.tide-mini-live-value{font-weight:600}.tide-mini-live-trend{color:#c8c0b0;font-size:11px}.tide-mini-plot{flex:1;min-height:0;margin:0 -6px;position:relative}.tide-mini-svg{width:100%;height:100%;display:block;overflow:visible}.tide-mini-label{font-family:var(--font-ui);color:var(--text-muted);white-space:nowrap;pointer-events:none;text-align:center;font-size:9px;font-weight:600;line-height:1.1;position:absolute}.tide-mini-label-time{color:var(--text-bright);font-weight:700}.tide-mini-label-height{color:var(--text-muted);font-size:9px}.tide-mini-label--instrument{font-family:var(--font-numeric,ui-monospace, SFMono-Regular, Menlo, monospace);font-variant-numeric:tabular-nums;letter-spacing:.3px;color:#b0a998;font-size:9px}.tide-mini-label--instrument .tide-mini-label-time{color:#e8e0d0;font-weight:500}.tide-mini-label--instrument .tide-mini-label-height{color:#8a8270;font-weight:400}.tide-mini-axis{font-family:var(--font-numeric,ui-monospace, SFMono-Regular, Menlo, monospace);font-variant-numeric:tabular-nums;letter-spacing:.2px;fill:#e8e0d08c;font-size:8px}.tide-mini-axis-y,.tide-mini-axis-x{font-family:var(--font-numeric,ui-monospace, SFMono-Regular, Menlo, monospace);font-variant-numeric:tabular-nums;letter-spacing:.2px;color:#e8e0d099;pointer-events:none;white-space:nowrap;font-size:10px;position:absolute}.tide-mini-axis-y{padding-right:4px;transform:translate(-100%,-50%)}.tide-mini-axis-x{bottom:0;transform:translate(-50%)}.tide-mini-empty{font-family:var(--font-ui);color:var(--text-dim);text-align:center;padding:12px;font-size:10px}.sun-info{border-bottom:1px solid #ffffff0f;flex-direction:column;gap:1px;margin-bottom:5px;padding-bottom:5px;display:flex}.sun-times{font-family:var(--font-ui);color:var(--text-muted);white-space:nowrap;align-items:center;gap:5px;font-size:10px;font-weight:500;display:flex}.sun-times-sep{opacity:.5}.sun-last-light{font-family:var(--font-ui);color:var(--text-muted);font-size:10px;font-weight:500}.sun-last-light strong{color:var(--text-bright);font-weight:700}.summary-headline{font-family:var(--font-ui);color:var(--text-bright);letter-spacing:-.2px;margin:0;font-size:16px;font-weight:600;line-height:1.2}.summary-headline-row{flex-wrap:wrap;align-items:baseline;gap:10px;display:flex}.summary-surface-word{font-family:var(--font-ui);color:var(--text-muted);letter-spacing:.2px;font-size:13px;font-weight:600}.summary-headline-meta{flex-wrap:wrap;align-items:center;gap:12px;margin-left:auto;display:inline-flex}.summary-meta-chip{font-family:var(--font-ui);color:var(--text-muted);white-space:nowrap;background:#ffffff0a;border:1px solid #ffffff14;border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex;position:relative}.summary-top-strip{align-items:center;gap:0;margin-bottom:4px;display:flex}.live-conditions-bar{font-family:var(--font-ui);flex-wrap:nowrap;align-items:center;min-width:0;display:flex}.live-cond-divider{background:#ffffff1f;flex-shrink:0;width:1px;height:14px;margin:0 12px}.live-conditions-bar>.live-cond-divider:first-child{display:none}.live-cond-item{white-space:nowrap;font-variant-numeric:tabular-nums;align-items:center;gap:6px;display:inline-flex}.live-cond-label{letter-spacing:1.2px;color:var(--text-dim);text-transform:uppercase;font-size:10px;font-weight:600}.live-cond-value{color:var(--text-bright);font-size:13px;font-weight:600}.live-cond-arrow{margin-left:2px;font-size:10px;line-height:1}.live-cond-arrow.rising{color:var(--tide-rising)}.live-cond-arrow.falling{color:var(--tide-falling)}.live-cond-qualifier{color:var(--text-dim);font-size:12px;font-weight:500}.summary-live-time{font-family:var(--font-ui);color:var(--text-muted);font-variant-numeric:tabular-nums;letter-spacing:.3px;background:#ffffff0a;border:1px solid #ffffff14;border-radius:999px;align-items:center;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.summary-future-date{font-family:var(--font-ui);color:var(--text-muted);letter-spacing:.3px;font-size:14px;font-weight:400}.summary-meta-chip-glyph{font-size:12px;line-height:1}.summary-meta-chip--sunrise .summary-meta-chip-glyph{color:#e8a870}.summary-meta-chip--sunset .summary-meta-chip-glyph{color:#9aa8c8}.summary-meta-chip[data-tooltip]:after{content:attr(data-tooltip);font-family:var(--font-ui);color:var(--text-muted);white-space:nowrap;opacity:0;pointer-events:none;margin-top:4px;font-size:10px;font-weight:500;transition:opacity .12s;position:absolute;top:100%;left:50%;transform:translate(-50%)}.summary-meta-chip:hover[data-tooltip]:after{opacity:1}.summary-sub{font-family:var(--font-ui);color:var(--text-dim);align-items:baseline;gap:6px;font-size:12px;font-weight:500;display:flex}.summary-sub-sep{opacity:.55}.summary-description{font-family:var(--font-ui);color:var(--text-muted);white-space:pre-line;margin:0;font-size:12px;line-height:1.45}.summary-description-label{font:inherit;color:inherit}.summary-description-swell{color:var(--text-muted);font-weight:500}.summary-notes{flex-direction:column;gap:2px;display:flex}.summary-stats{border:1px solid #ffffff14;border-radius:4px;display:flex;overflow:hidden}.summary-stat{border-right:1px solid #ffffff14;flex-direction:column;flex:1;gap:1px;min-width:0;padding:6px 10px;display:flex}.summary-stat:last-child{border-right:0}.summary-stat-label{font-family:var(--font-ui);letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);font-size:9px;font-weight:600}.summary-stat-value{font-family:var(--font-ui);color:var(--text-bright);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;font-size:12px;font-weight:700;overflow:hidden}.summary-stat-row{align-items:center;gap:8px;min-width:0;display:flex}.summary-stat-sub{font-family:var(--font-ui);color:var(--text-dim);font-size:10px;font-weight:500}.summary-stat-next{font-family:var(--font-ui);color:var(--text-dim);white-space:nowrap;font-size:10px;font-weight:500}.tide-future-list{flex-direction:column;gap:0;margin:0;padding:0;list-style:none;display:flex}.tide-future-row{font-family:var(--font-ui);color:var(--text-dim);white-space:nowrap;align-items:baseline;gap:6px;font-size:10px;font-weight:500;line-height:1.4;display:flex}.tide-future-type{color:var(--text-muted);min-width:26px;font-weight:700}.tide-future-height{color:var(--text-muted);font-weight:600}.tide-future-time{font-variant-numeric:tabular-nums;margin-left:auto}.tide-future-row-empty{visibility:hidden}.day-schedule{flex:1;grid-template-rows:auto minmax(0,1fr);width:100%;min-height:0;display:grid}.day-schedule-header{border-bottom:1px solid #ffffff0f;align-items:center;margin-bottom:4px;padding-bottom:4px;display:flex}.day-schedule-heading{font-family:var(--font-ui);letter-spacing:1px;color:var(--text-dim);text-transform:uppercase;font-size:9px;font-weight:500}.day-schedule-date{font-family:var(--font-ui);letter-spacing:.4px;color:var(--text-muted);text-transform:uppercase;font-size:10px;font-weight:500}.day-schedule-temps{align-items:center;gap:8px;display:inline-flex}.day-schedule-temp{font-family:var(--font-ui);color:var(--text-muted);align-items:center;gap:3px;font-size:11px;font-weight:500;display:inline-flex;position:relative}.day-schedule-temp[data-tooltip]:after{content:attr(data-tooltip);font-family:var(--font-ui);color:var(--text-muted);white-space:nowrap;opacity:0;pointer-events:none;margin-top:4px;font-size:10px;font-weight:500;transition:opacity .12s;position:absolute;top:100%;left:50%;transform:translate(-50%)}.day-schedule-temp:hover:after{opacity:1}.day-schedule-list{scrollbar-width:thin;flex-direction:column;gap:0;min-height:0;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.day-schedule-list::-webkit-scrollbar{background:0 0;width:2px}.day-schedule-list::-webkit-scrollbar-track{background:0 0}.day-schedule-list::-webkit-scrollbar-thumb{background:#e8762e80;border-radius:0}.day-schedule-list::-webkit-scrollbar-thumb:hover{background:#e8762ed9}.day-schedule-list{scrollbar-color:#e8762e80 transparent}.day-schedule-row{font-family:var(--font-ui);color:var(--text-dim);white-space:nowrap;justify-content:space-between;align-items:baseline;gap:8px;font-size:11px;font-weight:400;line-height:1.35;display:flex}.day-schedule-row-labelgroup{font-variant-numeric:tabular-nums;align-items:baseline;gap:4px;display:inline-flex}.day-schedule-row-label{color:var(--text-dim);font-weight:400}.day-schedule-row--sunrise .day-schedule-row-label{color:#b89cc8}.day-schedule-row--sunset .day-schedule-row-label{color:#c8898a}.day-schedule-row-value{color:var(--text-dim)}.day-schedule-row-time{color:var(--text-bright);font-variant-numeric:tabular-nums;letter-spacing:.1px;font-weight:600}.tide-future-empty{font-family:var(--font-ui);color:var(--text-muted);margin:8px 0 0;font-size:12px;line-height:1.4}.summary-stat-prose .summary-stat-value{white-space:pre-line;text-overflow:clip;color:var(--text-dim);font-size:10px;font-weight:500;line-height:1.3;overflow:visible}.live-strip{font-family:var(--font-ui);white-space:nowrap;align-items:center;gap:10px;font-size:11px;display:flex;overflow:hidden}.live-chip{flex-shrink:0;align-items:center;gap:5px;display:flex}.live-chip-icon{font-size:14px;line-height:1}.live-chip-label{font-family:var(--font-ui);color:#5a7080;letter-spacing:1.5px;text-transform:uppercase;font-size:9px;font-weight:700}.live-chip-value{font-family:var(--font-numeric);color:var(--text-bright);font-size:11px;font-weight:600}.live-chip-extra{color:var(--text-dim)}.live-chip-extra.rising{color:#c890b5}.live-chip-extra.falling{color:#9c8cb5}.live-chip+.live-chip:before{content:"";background:#ffffff1f;width:1px;height:10px;display:inline-block}.interval-toggle,.view-toggle{letter-spacing:.3px;text-transform:uppercase;border-radius:2px;font-size:9px;font-weight:600;display:flex;overflow:hidden}.interval-toggle button,.view-toggle button{cursor:pointer;font-family:inherit;font-size:inherit;font-weight:inherit;letter-spacing:inherit;text-transform:inherit;background:0 0;border:none;padding:2px 8px;transition:background .1s,color .1s}.view-toggle{border:1px solid var(--teal)}.view-toggle button{color:var(--teal)}.view-toggle button.active{background:var(--teal);color:var(--teal-on)}.interval-toggle{border:1px solid var(--orange)}.interval-toggle button{color:var(--orange)}.interval-toggle button.active{background:var(--orange);color:var(--orange-on)}.forecast-content{flex-shrink:0;height:444px;transition:opacity .15s;position:relative}.forecast-content.loading{opacity:.4;pointer-events:none}.forecast-spinner{z-index:1;border:3px solid #363c4a;border-top-color:#4c8492;border-radius:50%;width:28px;height:28px;animation:.6s linear infinite spin;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes spin{to{transform:translate(-50%,-50%)rotate(360deg)}}.spot-loading,.spot-error{color:#888;padding:2rem}.spot-cams{flex-direction:column;gap:0;height:100%;display:flex}.cam-frame{flex:1;min-height:0;position:relative;overflow:hidden}.cam-frame.draggable{cursor:grab}.cam-frame.dragging{cursor:grabbing}.cam-rewind{z-index:5;opacity:0;align-items:center;gap:6px;transition:opacity .2s;display:flex;position:absolute;bottom:34px;left:12px}.cam-attribution{z-index:5;color:#1a1a1a;font-family:var(--font-ui);letter-spacing:.2px;pointer-events:auto;background:#8b6f2a;align-items:center;padding:5px 10px;font-size:11px;font-weight:500;display:inline-flex;position:absolute;bottom:0;left:0}.cam-attribution a{color:inherit;text-underline-offset:2px;text-decoration:underline;text-decoration-thickness:1px}.cam-attribution a:hover{text-decoration-thickness:2px}.viewer-body:hover .cam-rewind{opacity:1}.cam-rewind-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-family:var(--font-ui);letter-spacing:1px;text-transform:uppercase;cursor:pointer;text-shadow:0 1px 2px #000000b3;background:#080e14c7;border:1px solid #ffffff2e;border-radius:3px;padding:5px 9px;font-size:9px;font-weight:700;transition:background .15s,color .15s,border-color .15s;box-shadow:0 2px 6px #00000059}.cam-rewind-btn:hover{background:#080e14eb;border-color:#ffffff52}.cam-rewind-btn.live{color:#fff;background:#4cc050a6;border-color:#4cc050f2}.cam-rewind-btn.live:hover{background:#4cc050c7;border-color:#4cc050}.cam-rewind-btn.live.active{background:#4cc050e6;border-color:#4cc050}.cam-rewind-indicator{font-family:var(--font-ui);letter-spacing:1px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);text-shadow:0 1px 2px #000000b3;background:#080e14c7;border:1px solid #ffffff2e;border-radius:3px;margin-left:4px;padding:4px 8px;font-size:9px;font-weight:700;box-shadow:0 2px 6px #00000059}.cam-rewind-indicator.is-live{color:#6fe57a}.cam-rewind-indicator.is-rewound{color:#ffb44a}.cam-time-jump{align-items:center;gap:4px;margin-left:6px;display:flex}.cam-time-jump-input{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-family:var(--font-ui);letter-spacing:.5px;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:#080e14c7;border:1px solid #ffffff2e;border-radius:3px;padding:4px 6px;font-size:10px;font-weight:600;line-height:1;box-shadow:0 2px 6px #00000059}.cam-time-jump-input:focus{border-color:#fff6;outline:none}.cam-time-jump-go{background:var(--orange);color:#fff;border-color:#fff6}.cam-time-jump-go:hover{background:#f3873d;border-color:#fff9}.cam-time-jump-error{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-family:var(--font-ui);letter-spacing:1px;text-transform:uppercase;color:#ff8a8a;white-space:nowrap;background:#0f1b228c;border:1px solid #ff8a8a59;border-radius:3px;padding:5px 9px;font-size:9px;font-weight:700}.cam-frame iframe{pointer-events:none;border:0;width:100vw;height:56.25vw;transition:left .25s;display:block;position:absolute;bottom:0;left:0}.cam-frame.dragging iframe{transition:none}.cam-binoculars{z-index:4;cursor:none;position:absolute;inset:0}.cam-binoculars svg{width:100%;height:100%;display:block}.gate-demo-dropdown-wrap{align-items:center;gap:8px;margin-left:auto;padding-right:4px;display:flex}.gate-demo-dropdown-label{font-family:var(--font-ui);letter-spacing:1.2px;text-transform:uppercase;color:#ffffff73;-webkit-user-select:none;user-select:none;font-size:9px;font-weight:700}.gate-demo-dropdown{appearance:none;color:var(--text-bright);font-family:var(--font-ui);letter-spacing:.4px;cursor:pointer;background:#00000059 url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='8' height='5' viewBox='0 0 8 5' fill='none'><path d='M1 1 L4 4 L7 1' stroke='%23ffffff' stroke-opacity='0.6' stroke-width='1' stroke-linecap='round' stroke-linejoin='round'/></svg>") right 8px center no-repeat;border:1px solid #ffffff2e;border-radius:3px;outline:none;padding:4px 22px 4px 10px;font-size:10px;font-weight:600;transition:border-color .12s,background-color .12s}.gate-demo-dropdown:hover{background-color:#00000080;border-color:#ffffff52}.gate-demo-dropdown:focus-visible{border-color:#ffffff73}.gate-demo-dropdown option{color:var(--text-bright);background:#1a1a1a}.cam-hackysack{z-index:4;pointer-events:none;cursor:none;-webkit-user-select:none;user-select:none;background:0 0;transition:background .7s;position:absolute;inset:0;overflow:hidden}.cam-hackysack.phase-thumbnail,.cam-hackysack.phase-intro{pointer-events:auto;cursor:pointer;background:#000}.hackysack-thumbnail-text{font-family:var(--font-ui);letter-spacing:1.5px;text-transform:uppercase;color:#fff;pointer-events:none;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex;position:absolute;inset:0}.cam-hackysack.phase-locked{pointer-events:auto;cursor:auto;background:#000000f2}.hackysack-intro-text{text-align:center;font-family:var(--font-ui);letter-spacing:1.5px;text-transform:uppercase;color:#fff;justify-content:center;align-items:center;padding:0 48px;font-size:11px;font-weight:600;line-height:1.35;display:flex;position:absolute;inset:0}.hackysack-countdown-num{font-family:var(--font-numeric);letter-spacing:-4px;color:#fff;text-shadow:0 0 30px #e74c3cb3,0 4px 20px #0009;pointer-events:none;justify-content:center;align-items:center;font-size:160px;font-weight:900;line-height:1;animation:.25s ease-out hackysack-pop;display:flex;position:absolute;inset:0}@keyframes hackysack-pop{0%{opacity:0;transform:scale(1.4)}to{opacity:1;transform:scale(1)}}.cam-hackysack~.cam-toggles,.cam-hackysack~.cam-rewind{cursor:pointer}.cam-frame:has(.cam-hackysack){cursor:none}:is(.cam-frame:has(.cam-hackysack.phase-thumbnail),.cam-frame:has(.cam-hackysack.phase-intro)){cursor:pointer}.cam-frame:has(.cam-hackysack.phase-locked){cursor:auto}.hackysack-ball{filter:drop-shadow(0 3px 6px #0000008c);z-index:2;background-image:url(/hackysack.png);background-position:50%;background-repeat:no-repeat;background-size:contain;width:32px;height:32px;margin-top:-16px;margin-left:-16px;position:absolute}.hackysack-knee{-webkit-user-select:none;user-select:none;filter:drop-shadow(0 2px 4px #0009);margin-top:-28px;margin-left:-28px;font-size:56px;line-height:1;position:absolute}.hackysack-powerup{-webkit-user-select:none;user-select:none;pointer-events:none;filter:drop-shadow(0 0 8px #ffc83cb3)drop-shadow(0 2px 4px #0009);margin-top:-16px;margin-left:-16px;font-size:30px;line-height:1;animation:1.2s ease-in-out infinite hackysack-powerup-pulse;position:absolute}@keyframes hackysack-powerup-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.hackysack-counter{z-index:7;font-family:var(--font-numeric);color:#fff;letter-spacing:.5px;text-shadow:0 1px 3px #000c,0 0 8px #0006;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:17px;font-weight:400;position:absolute;top:14px;left:50%;transform:translate(-50%)}.hackysack-misses{font-family:var(--font-ui);letter-spacing:1.5px;text-transform:uppercase;color:#ffffffe6;text-shadow:0 1px 3px #000000b3;align-items:center;gap:8px;font-size:9px;font-weight:700;display:flex;position:absolute;top:12px;right:60px}.hackysack-life{background:#ffffff26;border:1px solid #ffffff40;border-radius:50%;width:10px;height:10px;display:inline-block}.hackysack-life.active{background:#e74c3c;border-color:#e74c3c;box-shadow:0 0 6px #e74c3c99}.hackysack-gameover{color:#fff;font-family:var(--font-ui);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:0 24px;display:flex;position:absolute;inset:0}.hackysack-gameover-title{letter-spacing:0;font-size:22px;font-weight:700}.hackysack-gameover-sub{color:var(--text-muted);letter-spacing:.3px;font-size:12px}.hackysack-gameover-cta{color:#fff;letter-spacing:.3px;margin-top:2px;font-size:14px;font-weight:600}.hackysack-gameover-or{color:var(--text-dim);letter-spacing:1.5px;text-transform:uppercase;margin-top:18px;font-size:11px;font-weight:500}.hackysack-countdown{font-family:var(--font-numeric);letter-spacing:0;color:var(--orange);margin-top:6px;font-size:20px;font-weight:500}.cam-birdhunt{z-index:4;pointer-events:none;cursor:none;background:0 0;transition:background .7s;position:absolute;inset:0;overflow:hidden}.cam-birdhunt.phase-thumbnail,.cam-birdhunt.phase-intro{pointer-events:auto;cursor:pointer;background:#000}.cam-birdhunt.phase-countdown,.cam-birdhunt.phase-playing{pointer-events:auto}.cam-birdhunt.phase-locked{pointer-events:auto;cursor:auto;background:#000000f2}.cam-frame:has(.cam-birdhunt){cursor:none}:is(.cam-frame:has(.cam-birdhunt.phase-thumbnail),.cam-frame:has(.cam-birdhunt.phase-intro)){cursor:pointer}.cam-frame:has(.cam-birdhunt.phase-locked){cursor:auto}.cam-frame:has(.cam-birdhunt.phase-won){cursor:auto}.birdhunt-thumbnail-text{font-family:var(--font-ui);letter-spacing:1.5px;text-transform:uppercase;color:#fff;pointer-events:none;justify-content:center;align-items:center;font-size:18px;font-weight:600;display:flex;position:absolute;inset:0}.birdhunt-intro-text{text-align:center;font-family:var(--font-ui);letter-spacing:.3px;color:#fff;pointer-events:none;justify-content:center;align-items:center;padding:0 48px;font-size:22px;font-weight:600;line-height:1.35;display:flex;position:absolute;inset:0}.birdhunt-countdown-num{font-family:var(--font-numeric);letter-spacing:-4px;color:#fff;text-shadow:0 0 30px #e74c3cb3,0 4px 20px #0009;pointer-events:none;justify-content:center;align-items:center;font-size:160px;font-weight:900;line-height:1;animation:.25s ease-out hackysack-pop;display:flex;position:absolute;inset:0}.birdhunt-bird{-webkit-user-select:none;user-select:none;pointer-events:none;filter:drop-shadow(0 2px 4px #0000008c);will-change:transform, left, top;font-size:30px;line-height:1;position:absolute}.birdhunt-scope{pointer-events:none;filter:drop-shadow(0 0 6px #e74c3c66);margin-top:-30px;margin-left:-30px;position:absolute}.birdhunt-hud{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-family:var(--font-ui);letter-spacing:1px;color:#fff;pointer-events:none;white-space:nowrap;background:#0009;border:1px solid #ffffff1a;border-radius:4px;align-items:center;gap:10px;padding:8px 16px;font-size:11px;font-weight:700;display:flex;position:absolute;top:12px;left:50%;transform:translate(-50%)}.birdhunt-hud-label{color:var(--text-dim);text-transform:uppercase}.birdhunt-hud-emoji{font-size:18px}.birdhunt-hud-name{text-transform:uppercase;color:var(--text-bright)}.birdhunt-hud-sep{color:#ffffff40;font-weight:400}.birdhunt-hud-score{font-family:var(--font-numeric);color:var(--text-bright);font-size:13px}.birdhunt-hud-timer{font-family:var(--font-numeric);color:#e74c3c;text-shadow:0 0 6px #e74c3c99;font-size:13px}.cam-toggles{z-index:5;opacity:0;gap:6px;transition:opacity .2s;display:flex;position:absolute;top:8px;right:8px}.viewer-body:hover .cam-toggles{opacity:1}.cam-toggle{-webkit-backdrop-filter:blur(8px);color:var(--text-bright);cursor:pointer;background:#0f1b228c;border:1px solid #ffffff1a;border-radius:3px;justify-content:center;align-items:center;padding:6px;line-height:0;transition:background .2s,color .2s,border-color .2s;display:flex}.cam-toggle:hover{background:#0f1b22d9;border-color:#ffffff2e}.cam-toggle.active{background:var(--teal);color:var(--teal-on);border-color:var(--teal)}.cam-stats-overlay{z-index:3;pointer-events:none;flex-direction:row;align-items:flex-start;gap:28px;display:flex;position:absolute;top:16px;left:20px}.cam-stats-live-badge{font-family:var(--font-ui);color:#ff4d4d;letter-spacing:1.5px;text-transform:uppercase;text-shadow:0 1px 2px #000000bf;align-items:center;gap:5px;font-size:9px;font-weight:800;display:flex;position:absolute;top:-14px;left:0}.cam-stats-live-dot{background:#ff4d4d;border-radius:50%;width:6px;height:6px;animation:1.6s ease-in-out infinite cam-stats-live-pulse;box-shadow:0 0 6px #ff4d4db3}@keyframes cam-stats-live-pulse{0%,to{opacity:1}50%{opacity:.4}}.cam-stat{white-space:nowrap;flex-direction:column;gap:2px;display:flex}.cam-stat-label{font-family:var(--font-display);color:#f0e4c8;letter-spacing:.4px;text-shadow:0 1px 2px #000000bf,0 0 8px #00000073;font-size:16px;font-weight:400;line-height:1}.cam-stat-value-row{align-items:baseline;gap:4px;display:flex}.cam-stat-value{font-family:var(--font-numeric);color:#fff;letter-spacing:-.8px;text-shadow:0 2px 4px #000000bf,0 0 12px #0006;font-size:38px;font-weight:800;line-height:.9}.cam-stat-unit{font-family:var(--font-ui);color:#fff;letter-spacing:1px;text-transform:uppercase;text-shadow:0 1px 3px #000000bf;font-size:11px;font-weight:700}.cam-stat-trail{font-family:var(--font-ui);color:#a89dcc;letter-spacing:1.2px;text-transform:uppercase;text-shadow:0 1px 2px #000000bf;margin-left:4px;font-size:11px;font-weight:600}.cam-tide-arrow{letter-spacing:0;font-size:11px}.cam-llantera{--tv-left:68%;--tv-top:3%;--tv-width:34%;--tv-height:34%;--tv-rotate-y:-16deg;--tv-rotate-z:-7deg;background:#1a1a1a}.cam-llantera-scene{z-index:2;pointer-events:none;background-image:url(/llantera3.png);background-position:50% 0;background-repeat:no-repeat;background-size:cover;position:absolute;inset:0}.cam-frame.cam-llantera iframe.cam-llantera-tv{left:var(--tv-left);top:var(--tv-top);width:var(--tv-width);height:var(--tv-height);pointer-events:none;z-index:1;transform:perspective(900px) rotateY(var(--tv-rotate-y)) rotateZ(var(--tv-rotate-z));transform-origin:50%;border:0;display:block;position:absolute;bottom:auto}.cam-llantera-tv-button{left:calc(var(--tv-left) + var(--tv-width) * .22);top:calc(var(--tv-top) + var(--tv-height) * .15);width:calc(var(--tv-width) * .56);height:calc(var(--tv-height) * .7);z-index:3;cursor:pointer;transform:perspective(900px) rotateY(var(--tv-rotate-y)) rotateZ(var(--tv-rotate-z));transform-origin:50%;background:0 0;border:0;outline:0;padding:0;position:absolute}.cam-llantera-tv-button:hover,.cam-llantera-tv-button:focus,.cam-llantera-tv-button:focus-visible{outline:0}.cam-llantera-cta{z-index:6;cursor:pointer;font-family:var(--font-ui);color:#fff;letter-spacing:.2px;text-shadow:0 1px 2px #000000d9;background:0 0;border:0;padding:0;font-size:12px;font-weight:500;transition:opacity .15s;position:absolute;bottom:14px;left:16px}.cam-llantera-cta:hover{opacity:.8}.cam-llantera-cta:focus-visible{outline-offset:3px;border-radius:2px;outline:2px solid #fff9}.auth-modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000c7;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.auth-modal{width:260px;max-width:100%;color:var(--text-bright);font-family:var(--font-ui);background:#0a0a0a;border:1px solid #ffffff14;border-radius:6px;padding:22px 20px 18px;position:relative}.auth-modal-close{width:22px;height:22px;color:var(--text-dim);cursor:pointer;background:0 0;border:0;font-size:18px;line-height:1;transition:color .15s;position:absolute;top:4px;right:8px}.auth-modal-close:hover{color:var(--text-bright)}.auth-modal-title{letter-spacing:.2px;margin:0 0 14px;font-size:14px;font-weight:600}.auth-form{flex-direction:column;gap:8px;display:flex}.auth-form input{color:var(--text-bright);background:#050505;border:1px solid #ffffff1a;border-radius:4px;outline:none;padding:8px 10px;font-family:inherit;font-size:13px;transition:border-color .15s}.auth-form input::placeholder{color:#ffffff4d}.auth-form input:focus{border-color:#fff6}.auth-submit{color:var(--text-bright);letter-spacing:.3px;cursor:pointer;background:#262626;border:1px solid #ffffff1f;border-radius:4px;margin-top:4px;padding:8px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:background .15s,border-color .15s}.auth-submit:hover{background:#333;border-color:#ffffff38}.auth-create-link{width:100%;color:var(--text-dim);letter-spacing:.2px;text-align:center;cursor:pointer;background:0 0;border:0;margin-top:12px;padding:4px 0;font-family:inherit;font-size:11px;transition:color .15s;display:block}.auth-create-link:hover{color:var(--text-bright)}
