:root{--color-green: #22c55e;--color-amber: #f59e0b;--color-red: #ef4444;--color-surface: rgba(15, 20, 30, .85);--color-surface-border: rgba(255, 255, 255, .12);--color-text: #f0f4f8;--color-text-muted: #94a3b8;--radius: 10px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}.app{position:relative;width:100%;height:100%;font-family:var(--font)}.error-toast{position:fixed;top:16px;left:50%;transform:translate(-50%);background:var(--color-red);color:#fff;padding:10px 18px;border-radius:var(--radius);font-size:14px;z-index:100;white-space:nowrap;box-shadow:0 4px 16px #0006}.spearmap-container{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.spearmap-pin{width:16px;height:16px;border-radius:50%;background:#ef4444;border:3px solid #ffffff;box-shadow:0 2px 8px #00000073;cursor:pointer}.spearmap-pin:after{content:"";position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:50%;border:2px solid rgba(239,68,68,.5);animation:pin-pulse 1.8s ease-out infinite}@keyframes pin-pulse{0%{transform:scale(.8);opacity:1}to{transform:scale(2);opacity:0}}.spearmap-no-token{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0a1628;color:#f0f4f8;font-family:var(--font, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);padding:24px}.spearmap-no-token__inner{max-width:420px;text-align:center}.spearmap-no-token__icon{font-size:48px;margin-bottom:16px}.spearmap-no-token__inner h2{font-size:20px;font-weight:700;margin-bottom:12px;color:#f0f4f8}.spearmap-no-token__inner p{font-size:14px;color:#94a3b8;margin-bottom:12px;line-height:1.5}.spearmap-no-token__inner pre{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px 16px;font-size:13px;color:#22c55e;text-align:left;margin:0 0 14px;overflow-x:auto}.spearmap-no-token__inner code{background:#ffffff14;border-radius:4px;padding:2px 6px;font-size:13px;color:#f0f4f8}.spearmap-no-token__hint{font-size:13px!important;color:#64748b!important}.spearmap-no-token__hint a{color:#38bdf8;text-decoration:none}.spearmap-no-token__hint a:hover{text-decoration:underline}.mapboxgl-ctrl-bottom-right{bottom:154px}.mapboxgl-popup-content{background:#0f141eeb;color:#f0f4f8;border-radius:10px;padding:12px 14px;border:1px solid rgba(255,255,255,.12);box-shadow:0 8px 32px #00000080;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.mapboxgl-popup-close-button{color:#94a3b8;font-size:18px;top:6px;right:8px}.popup-score{font-size:14px;font-weight:700;margin-bottom:8px;letter-spacing:.01em}.popup-table{width:100%;border-collapse:collapse;font-size:12px}.popup-table td{padding:3px 0}.popup-table td:first-child{color:#94a3b8;padding-right:12px;white-space:nowrap}.popup-table td:last-child{color:#f0f4f8;font-weight:500}.popup-section{padding-top:6px!important;padding-bottom:2px!important;color:#94a3b8;font-size:10px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.popup-field--dangerous{color:#f87171!important;font-weight:700}.popup-field--caution{color:#fbbf24!important;font-weight:600}.popup-arrow{display:inline-block;line-height:1;vertical-align:middle;color:#cbd5e1}.popup-arrow-none{display:inline-block;color:#64748b;vertical-align:middle}.station-arrow{display:flex;flex-direction:column;align-items:center;cursor:default}.station-arrow__icon{color:#fff;line-height:1;text-shadow:0 0 3px rgba(0,0,0,.9),0 0 6px rgba(0,0,0,.6)}.station-arrow__label{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:9px;font-weight:600;color:#fff;text-align:center;white-space:pre;line-height:1.3;margin-top:3px;text-shadow:0 0 3px rgba(0,0,0,1),0 0 6px rgba(0,0,0,.8)}.popup-danger{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 7px;border-radius:4px;margin-bottom:8px}.popup-danger--red{background:#ef44442e;color:#f87171;border:1px solid rgba(239,68,68,.4)}.popup-danger--amber{background:#f59e0b2e;color:#fbbf24;border:1px solid rgba(245,158,11,.4)}.time-slider{position:fixed;bottom:0;left:0;right:0;padding:10px 16px max(env(safe-area-inset-bottom,0px),12px);background:var(--color-surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--color-surface-border);z-index:10;display:grid;grid-template-columns:1fr 88px;grid-template-rows:auto auto;column-gap:12px;align-items:center}.time-slider__label{grid-column:2;grid-row:2;font-size:11px;font-weight:500;color:var(--color-text-muted);text-align:center;white-space:nowrap;margin-top:4px}.time-slider__play-btn{grid-column:2;grid-row:1;width:100%;min-height:44px;background:#ffffff14;border:1px solid var(--color-surface-border);border-radius:8px;color:var(--color-text);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.time-slider__play-btn:hover{background:#ffffff26}.time-slider__play-btn--playing{background:#22c55e33;border-color:#22c55e66}.time-slider__track-wrap{grid-column:1;grid-row:1;position:relative;height:68px;display:flex;align-items:center}.time-slider__daylight{position:absolute;left:0;right:0;width:100%;height:60px;pointer-events:none;border-radius:6px;overflow:hidden}.time-slider__range{position:absolute;left:0;width:100%;height:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer;z-index:1;margin:0;padding:0}.time-slider__range::-webkit-slider-runnable-track{height:60px;border-radius:6px;background:transparent}.time-slider__range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:#fff;margin-top:19px;box-shadow:0 2px 8px #00000080,0 0 0 2px #fff3;cursor:grab}.time-slider__range:active::-webkit-slider-thumb{cursor:grabbing}.time-slider__range::-moz-range-track{height:60px;border-radius:6px;background:transparent}.time-slider__range::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:#fff;border:none;box-shadow:0 2px 8px #00000080,0 0 0 2px #fff3}.time-slider__ticks{grid-column:1;grid-row:2;display:flex;justify-content:space-between;margin-top:4px;font-size:11px;color:var(--color-text-muted)}.legend-root{position:fixed;top:10px;right:10px;z-index:10;user-select:none;-webkit-user-select:none}.legend-card{display:flex;flex-direction:column;width:280px;background:var(--color-surface, rgba(15, 20, 30, .88));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-surface-border, rgba(255, 255, 255, .12));border-radius:var(--radius, 10px);box-shadow:0 4px 16px #0006;overflow:hidden;flex-shrink:0}.legend__header{display:flex;flex-shrink:0;border-bottom:1px solid var(--color-surface-border, rgba(255, 255, 255, .12))}.legend__header-tab{flex:1;min-height:44px;padding:0 8px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-muted, #94a3b8);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:color .12s,border-color .12s;display:flex;align-items:center;justify-content:center;gap:5px}.legend__header-tab:hover{color:var(--color-text, #f0f4f8)}.legend__header-tab--active{color:var(--color-text, #f0f4f8);border-bottom-color:#f59e0b}.legend__body{overflow-y:auto;max-height:calc(100vh - 160px);flex:1}.legend{padding:12px 14px;display:flex;flex-direction:column}.legend__content,.legend__default-grid{display:block}.legend__footer{margin-top:10px;padding-top:8px;border-top:1px solid var(--color-surface-border);display:flex;justify-content:flex-end}.legend__powered-by{display:inline-flex;align-items:center;gap:6px;color:var(--color-text-muted);text-decoration:none;font-size:12px;white-space:nowrap}.legend__powered-by:hover{color:var(--color-text)}.legend__powered-logo{height:20px;width:auto;display:block}.legend__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:8px}.legend__list{list-style:none;display:flex;flex-direction:column;gap:6px}.legend__item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--color-text)}.legend__swatch{width:52px;height:14px;border-radius:3px;flex-shrink:0}.legend__swatch--green{background:linear-gradient(to right,#86efac,#16a34a)}.legend__swatch--amber{background:linear-gradient(to right,#fde68a,#f59e0b)}.legend__swatch--red{background:linear-gradient(to right,#fca5a5,#ef4444)}.legend__swatch--habitat-high{background:linear-gradient(to right,#38bdf8,#0369a1)}.legend__swatch--habitat-mid{background:linear-gradient(to right,#bae6fd,#38bdf8);opacity:.85}.legend__swatch--habitat-low{background:#bae6fd4d;border:1px solid rgba(56,189,248,.3)}.legend__swatch--outline-amber{background:transparent;border:2px solid #f59e0b}.legend__swatch--outline-red{background:transparent;border:2px solid #ef4444}.legend__warn{font-size:13px;flex-shrink:0;width:14px;text-align:center}.legend__warn--amber{color:#f59e0b}.legend__warn--red{color:#ef4444}.legend__divider{border:none;border-top:1px solid var(--color-surface-border);margin:10px 0}.legend__arrows{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--color-text)}.legend__arrow{color:var(--color-text-muted)}.legend__arrow--sm{font-size:14px}.legend__arrow--lg{font-size:24px}.legend__arrow-label{font-size:11px;color:var(--color-text-muted)}.legend__cell-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.legend__score{font-size:13px;font-weight:700}.legend__score--prime{color:#4ade80}.legend__score--marginal{color:#fbbf24}.legend__score--poor{color:#f87171}.legend__close{background:none;border:none;color:var(--color-text-muted);font-size:18px;line-height:1;cursor:pointer;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin:-10px -10px -10px 0}.legend__close:hover{color:var(--color-text)}.legend__danger-badge{font-size:11px;font-weight:600;padding:3px 7px;border-radius:4px;margin-bottom:8px;display:inline-block}.legend__danger-badge--amber{background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.legend__danger-badge--red{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3)}.legend__section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin:8px 0 4px}.legend__conditions-grid{display:flex;flex-direction:column;gap:3px;margin-bottom:2px}.legend__cond-row{display:flex;align-items:center;justify-content:space-between;font-size:12px}.legend__cond-name{color:var(--color-text-muted);flex-shrink:0}.legend__cond-value{color:var(--color-text);font-weight:500;text-align:right;display:flex;align-items:center;gap:3px}.legend__cell-value--dangerous{color:#f87171!important;font-weight:700}.legend__cell-value--caution{color:#fbbf24!important;font-weight:600}.legend__species-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:2px}.legend__species-table td{padding:3px 0;color:var(--color-text-muted);vertical-align:middle}.legend__species-header td{padding-bottom:2px!important}.legend__species-col-head{font-size:10px!important;font-weight:600!important;color:var(--color-text-muted)!important;text-align:right!important;letter-spacing:.03em;width:36px}.legend__conditions-score{color:var(--color-text)!important;font-weight:500;text-align:right!important;width:36px}.legend__habitat-score{color:#7dd3fc!important;font-weight:500;text-align:right!important;width:44px}.legend__hunt-score{color:#fbbf24!important;font-weight:500;text-align:right!important;width:36px}.legend__cell-none{color:var(--color-text-muted)}.legend__arrow-icon{display:inline-block;line-height:1;vertical-align:middle}.legend__awaiting{font-size:12px;color:var(--color-text-muted);padding:12px 0 8px}.legend__layers{display:flex;flex-direction:column;gap:2px}.btw__tabs{display:flex;border-bottom:1px solid var(--color-surface-border, rgba(255, 255, 255, .08))}.btw__tab{flex:1;min-height:44px;padding:0;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-muted, #94a3b8);font-size:12px;font-weight:600;cursor:pointer;transition:color .12s,border-color .12s;letter-spacing:.02em}.btw__tab:hover{color:var(--color-text, #f0f4f8)}.btw__tab--active{color:var(--color-text, #f0f4f8);border-bottom-color:#f59e0b}.btw__filter-bar{padding:7px 10px 4px;border-bottom:1px solid var(--color-surface-border, rgba(255, 255, 255, .08))}.btw__filter-btn{display:inline-flex;align-items:center;gap:5px;min-height:44px;padding:0 12px;border-radius:20px;border:1px solid rgba(239,68,68,.3);background:transparent;color:var(--color-text-muted, #94a3b8);font-size:11px;font-weight:500;cursor:pointer;transition:background .12s,color .12s}.btw__filter-btn:hover{background:#ef44441a;color:#f0f4f8}.btw__filter-btn--active{background:#ef44442e;border-color:#ef4444b3;color:#fca5a5}.btw__filter-icon{font-size:10px}.btw__state{padding:14px 12px;font-size:12px;color:var(--color-text-muted, #94a3b8);text-align:center}.btw__state--error{color:var(--color-red, #ef4444)}.btw-row{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;border-top:1px solid var(--color-surface-border, rgba(255, 255, 255, .08));color:var(--color-text, #f0f4f8);cursor:pointer;text-align:left;transition:background .12s;min-height:44px}.btw-row:first-child{border-top:none}.btw-row:hover{background:#ffffff0f}.btw-row--selected{background:#ef44441f;border-left:2px solid #ef4444;padding-left:10px}.btw-row--selected:hover{background:#ef44442e}.btw-rank{font-size:11px;font-weight:700;color:var(--color-text-muted, #94a3b8);width:14px;flex-shrink:0;text-align:center}.btw-row__body{flex:1;min-width:0}.btw-row__top{display:flex;align-items:center;gap:7px;margin-bottom:3px}.btw-row__time{font-size:12px;font-weight:500;color:var(--color-text, #f0f4f8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btw-row__time--wrap{white-space:normal;overflow:visible;text-overflow:unset}.btw-row__location{font-size:11px;color:var(--color-text-muted, #94a3b8)}.score-pill{display:inline-flex;align-items:center;justify-content:center;min-width:28px;padding:1px 6px;border-radius:4px;font-size:11px;font-weight:700;flex-shrink:0}.score-pill--green{background:#22c55e33;color:#22c55e}.score-pill--amber{background:#f59e0b33;color:#f59e0b}.score-pill--red{background:#ef444433;color:#ef4444}.score-display{display:inline-flex;align-items:center;padding:1px 6px;border-radius:4px;font-size:11px;font-weight:700;flex-shrink:0}.score-display.score-pill--green{background:#22c55e33;color:#22c55e}.score-display.score-pill--amber{background:#f59e0b33;color:#f59e0b}.score-display.score-pill--red{background:#ef444433;color:#ef4444}.score-display__avg{font-weight:700}.score-display__peak{font-weight:500;opacity:.75}.btw-danger{font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;margin-left:auto;flex-shrink:0;white-space:nowrap}.btw-danger--caution{background:#f59e0b33;color:#f59e0b}.btw-danger--dangerous{background:#ef444433;color:#ef4444}.btw__footnote{font-size:10px;color:var(--color-text-muted, #94a3b8);padding:8px 12px;border-top:1px solid var(--color-surface-border, rgba(255, 255, 255, .08));margin:0;opacity:.7;line-height:1.4}.btw-panel{overflow:hidden}@media (max-width: 600px){.legend-root{top:auto;bottom:116px;right:0;left:0;padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}.legend-card{width:100%;border-radius:var(--radius, 10px) var(--radius, 10px) 0 0;border-bottom:none;border-left:none;border-right:none}.legend__body{max-height:45vh}.legend__default-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}.legend__divider--default{display:none}.legend__default-section .legend__title{margin-bottom:6px}.legend__default-section .legend__item{gap:6px;font-size:11px}.legend__default-section .legend__swatch{width:34px}}.layer-control{position:fixed;bottom:200px;left:10px;background:var(--color-surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-surface-border);border-radius:var(--radius);z-index:10;min-width:170px;box-shadow:0 4px 16px #0006;overflow:hidden}.layer-control__header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:9px 12px;background:none;border:none;cursor:pointer;color:var(--color-text);gap:8px}.layer-control__header:hover{background:#ffffff0a}.layer-control__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.layer-control__chevron{font-size:10px;color:var(--color-text-muted);line-height:1}.layer-control__body{display:flex;flex-direction:column;gap:2px;padding:4px 12px 10px;border-top:1px solid var(--color-surface-border)}.layer-control__row{display:flex;align-items:center;gap:8px;padding:5px 0;cursor:pointer;-webkit-user-select:none;user-select:none}.layer-control__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.layer-control__dot--conditions{background:linear-gradient(135deg,#86efac,#16a34a)}.layer-control__dot--bathy{background:linear-gradient(135deg,#93c5fd,#1d4ed8)}.layer-control__dot--habitat{background:linear-gradient(135deg,#bae6fd,#0369a1)}.layer-control__label{flex:1;font-size:12px;color:var(--color-text);display:flex;align-items:center;gap:5px}.layer-control__loading{font-size:10px;line-height:1}.layer-control__toggle{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:30px;height:16px;border-radius:8px;background:var(--color-surface-border);border:1px solid rgba(255,255,255,.1);cursor:pointer;position:relative;flex-shrink:0;transition:background .2s}.layer-control__toggle:after{content:"";position:absolute;width:12px;height:12px;border-radius:50%;background:#94a3b8;top:1px;left:1px;transition:transform .2s,background .2s}.layer-control__toggle:checked{background:#0369a1}.layer-control__toggle:checked:after{background:#fff;transform:translate(14px)}.layer-control__toggle:disabled{opacity:.4;cursor:not-allowed}.layer-control__species-wrap{display:flex;flex-wrap:wrap;gap:4px;padding:4px 0 2px;margin-left:18px}.layer-control__species-btn{font-size:10px;padding:6px 10px;min-height:34px;border-radius:4px;border:1px solid rgba(255,255,255,.12);background:#ffffff0d;color:var(--color-text-muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s;font-weight:500}.layer-control__species-btn:hover{background:#0369a133;color:var(--color-text);border-color:#0369a180}.layer-control__species-btn--active{background:#0369a14d;color:#7dd3fc;border-color:#0369a1;font-weight:600}
