:root{--void:#05070d;--void-2:#080b16;--neon-cyan:#38f0ff;--neon-blue:#4aa8ff;--neon-pink:#ff3ea5;--text-dim:#6f7d99}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;background:var(--void);color:#e8eefc;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;overflow:hidden;-webkit-font-smoothing:antialiased}#map{position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 42%,#0b1022 0,#070912 48%,#04050a 100%)}.maplibregl-canvas{outline:none}.hud{position:absolute;z-index:10;pointer-events:none}.hud-top-left{top:22px;left:24px}.brand{font-weight:700;letter-spacing:.14em;font-size:15px;text-transform:uppercase;color:#cfe8ff;text-shadow:0 0 14px rgba(56,240,255,.55)}.brand .o{color:var(--neon-cyan)}.sub{margin-top:4px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim)}.controls{position:absolute;z-index:10;bottom:26px;right:24px;display:flex;flex-direction:column;gap:10px;align-items:flex-end}.mode-toggle{pointer-events:auto;display:inline-flex;border:1px solid rgba(74,168,255,.35);border-radius:999px;overflow:hidden;background:rgba(8,12,24,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.mode-toggle button{pointer-events:auto;border:none;background:transparent;color:var(--text-dim);font-size:12px;letter-spacing:.12em;text-transform:uppercase;padding:9px 16px;cursor:pointer;transition:color .2s,background .2s,text-shadow .2s}.mode-toggle button.active{color:#eaf6ff;background:rgba(56,240,255,.12);text-shadow:0 0 10px rgba(56,240,255,.7)}.stat-card{pointer-events:none;margin-top:2px;text-align:right;font-size:11px;letter-spacing:.08em;color:var(--text-dim)}.stat-card b{color:#bcd4f5;font-weight:600}.data-panel{position:absolute;z-index:10;top:74px;left:24px;width:212px;padding:14px 14px 12px;border:1px solid rgba(74,168,255,.22);border-radius:14px;background:rgba(8,12,24,.62);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 30px rgba(0,0,0,.45)}.dp-title{display:flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:#cfe0f7;margin-bottom:12px}.badge{font-size:9px;font-weight:700;letter-spacing:.12em;color:#07101e;background:linear-gradient(90deg,#ffd35a,#ff9e3d);padding:2px 6px;border-radius:5px}.dp-row{display:block;margin-bottom:11px}.dp-label{display:block;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);margin-bottom:5px}.dp-select{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:rgba(20,30,52,.85);color:#e8eefc;border:1px solid rgba(74,168,255,.3);border-radius:9px;padding:8px 10px;font-size:13px;cursor:pointer}.dp-select:focus{outline:none;border-color:var(--neon-cyan)}.dp-chips{display:flex;gap:8px;margin-bottom:9px}.chip{flex:1 1;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid rgba(120,140,175,.25);border-radius:999px;background:rgba(14,20,36,.5);color:var(--text-dim);font-size:11px;letter-spacing:.04em;padding:7px 6px;cursor:pointer;transition:color .18s,border-color .18s,background .18s}.chip i{width:8px;height:8px;border-radius:50%;background:currentColor;opacity:.4;transition:opacity .18s,box-shadow .18s}.chip.cyan.on{color:#b6f3ff;border-color:rgba(56,240,255,.6);background:rgba(56,240,255,.12)}.chip.pink.on{color:#ffc2e4;border-color:rgba(255,62,165,.6);background:rgba(255,62,165,.12)}.chip.on i{opacity:1;box-shadow:0 0 9px currentColor}.dp-hint{font-size:10px;letter-spacing:.03em;color:#586781;text-align:center}.oa-confetti{position:fixed;inset:0;z-index:120;pointer-events:none}.log-entry{position:absolute;z-index:30;bottom:26px;left:50%;transform:translateX(-50%);display:flex;gap:12px}.log-btn{pointer-events:auto;border:none;border-radius:999px;padding:14px 26px;font-size:15px;font-weight:700;letter-spacing:.04em;cursor:pointer;color:#04121a;box-shadow:0 8px 26px rgba(0,0,0,.5);transition:transform .12s ease,filter .12s ease}.log-btn:active{transform:scale(.94)}.log-btn.catch{background:linear-gradient(90deg,#38f0ff,#4aa8ff);box-shadow:0 8px 26px rgba(56,240,255,.4)}.log-btn.sighting{background:rgba(14,22,40,.7);color:#b6f3ff;border:1px solid rgba(56,240,255,.4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.oa-pin{width:22px;height:22px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:radial-gradient(circle at 50% 40%,#eafcff,#38f0ff 60%,#1f6bff);box-shadow:0 0 16px rgba(56,240,255,.9),0 6px 10px rgba(0,0,0,.5);border:2px solid #eafcff;cursor:-webkit-grab;cursor:grab}.oa-pin:active{cursor:-webkit-grabbing;cursor:grabbing}.log-panel{position:absolute;z-index:40;left:50%;bottom:0;transform:translateX(-50%);width:min(440px,100%);background:rgba(8,12,22,.92);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid rgba(74,168,255,.25);border-bottom:none;border-radius:20px 20px 0 0;padding:16px 20px 26px;box-shadow:0 -10px 40px rgba(0,0,0,.55);animation:lp-up .28s cubic-bezier(.2,.9,.3,1)}@keyframes lp-up{0%{transform:translate(-50%,100%)}to{transform:translate(-50%)}}.lp-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.lp-title{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:#cfe0f7}.lp-x{background:none;border:none;color:var(--text-dim);font-size:18px;cursor:pointer;line-height:1}.lp-body{display:flex;flex-direction:column;gap:14px}.lp-hint{font-size:14px;color:#9fb6d8;line-height:1.4}.lp-label{font-size:15px;color:#dbe8fb}.lp-label b{color:#38f0ff;font-size:18px}.lp-when{font-size:12px;color:#6f8099;letter-spacing:.02em}.fish-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:8px;gap:8px}.fish-chip{pointer-events:auto;border:1px solid rgba(120,140,175,.25);background:rgba(16,24,42,.6);color:#c4d6f2;border-radius:12px;padding:13px 10px;font-size:14px;cursor:pointer;transition:border-color .15s,background .15s,color .15s,transform .1s}.fish-chip:active{transform:scale(.96)}.fish-chip.on{color:#eafcff;border-color:rgba(56,240,255,.7);background:rgba(56,240,255,.14);box-shadow:inset 0 0 16px rgba(56,240,255,.25)}.fish-chip.other{grid-column:1/-1;color:#9fb6d8}.size-slider{width:100%;accent-color:#38f0ff;height:28px}.lp-next,.lp-save{pointer-events:auto;margin-top:4px;border:none;border-radius:14px;padding:15px;font-size:16px;font-weight:700;letter-spacing:.03em;cursor:pointer;transition:transform .1s,filter .15s}.lp-next:active,.lp-save:active{transform:scale(.97)}.lp-next{background:rgba(56,240,255,.16);color:#d6f6ff;border:1px solid rgba(56,240,255,.4)}.lp-next:disabled{opacity:.4;cursor:default}.lp-save{background:linear-gradient(90deg,#38f0ff,#4aa8ff);color:#04121a;box-shadow:0 6px 22px rgba(56,240,255,.4)}.lp-save:disabled{opacity:.6}.celebrate{position:fixed;inset:0;z-index:110;display:grid;place-items:center;background:radial-gradient(80% 60% at 50% 45%,rgba(10,30,50,.7),rgba(3,5,10,.92));-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);cursor:pointer;animation:cel-in .3s ease}@keyframes cel-in{0%{opacity:0}to{opacity:1}}.cel-inner{text-align:center;animation:cel-pop .5s cubic-bezier(.2,1.4,.4,1)}@keyframes cel-pop{0%{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}.cel-burst{font-size:64px;font-weight:900;letter-spacing:.04em;color:#eafcff;text-shadow:0 0 40px rgba(56,240,255,.8),0 0 80px rgba(56,240,255,.4)}.cel-fish{margin-top:8px;font-size:26px;font-weight:700;color:#38f0ff;letter-spacing:.02em}.cel-weather{margin-top:14px;font-size:14px;color:#9fc6ee;letter-spacing:.03em}.cel-tap{margin-top:34px;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#5d728f}.adv-toggle{pointer-events:auto;align-self:flex-start;background:none;border:none;color:#6fb6e6;font-size:13px;cursor:pointer;padding:2px 0}.adv-opt{color:#5d728f;font-size:11px;margin-left:4px}.adv-body{display:flex;flex-direction:column;gap:12px;margin-top:2px}.adv-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:6px}.adv-chips{display:flex;flex-wrap:wrap;gap:6px}.adv-chip{pointer-events:auto;border:1px solid rgba(120,140,175,.25);background:rgba(16,24,42,.55);color:#b9cbe6;border-radius:999px;padding:7px 12px;font-size:12px;cursor:pointer;transition:color .15s,border-color .15s,background .15s,transform .1s}.adv-chip:active{transform:scale(.95)}.adv-chip.on{color:#eafcff;border-color:rgba(56,240,255,.6);background:rgba(56,240,255,.13)}.feed-tab{z-index:30;top:22px;right:22px;pointer-events:auto;border:1px solid rgba(56,240,255,.4);background:rgba(8,12,24,.7);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#b6f3ff;border-radius:999px;padding:9px 16px;font-size:13px;letter-spacing:.04em;cursor:pointer}.feed,.feed-tab{position:absolute}.feed{z-index:20;top:16px;right:16px;bottom:16px;width:312px;display:flex;flex-direction:column;border:1px solid rgba(74,168,255,.22);border-radius:16px;background:rgba(7,11,20,.78);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 10px 40px rgba(0,0,0,.5);overflow:hidden}.feed-head{justify-content:space-between;padding:13px 14px 10px}.feed-head,.feed-title{display:flex;align-items:center}.feed-title{gap:8px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#cfe0f7}.feed-live{width:8px;height:8px;border-radius:50%;background:#38f0ff;box-shadow:0 0 9px #38f0ff;animation:feedpulse 1.6s ease-in-out infinite}@keyframes feedpulse{0%,to{opacity:1}50%{opacity:.35}}.feed-count{margin-left:4px;font-size:11px;color:#5d728f;letter-spacing:0}.feed-collapse{background:none;border:none;color:var(--text-dim);font-size:15px;cursor:pointer}.feed-scope{display:flex;gap:6px;padding:0 12px 8px}.feed-scope button{flex:1 1;pointer-events:auto;border:1px solid rgba(120,140,175,.22);background:rgba(16,24,42,.5);color:var(--text-dim);border-radius:9px;padding:7px 6px;font-size:12px;cursor:pointer;transition:all .15s}.feed-scope button.on{color:#eafcff;border-color:rgba(56,240,255,.6);background:rgba(56,240,255,.12)}.demo-tag{font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:#ffb86b;vertical-align:middle}.feed-filters{display:flex;flex-wrap:wrap;gap:6px;padding:0 12px 8px}.feed-filters select{flex:1 1;min-width:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:rgba(20,30,52,.85);color:#dbe8fb;border:1px solid rgba(74,168,255,.25);border-radius:8px;padding:6px 8px;font-size:12px;cursor:pointer}.feed-type{display:flex;gap:5px;width:100%}.feed-type button{flex:1 1;pointer-events:auto;border:1px solid rgba(120,140,175,.2);background:rgba(16,24,42,.5);color:var(--text-dim);border-radius:8px;padding:6px 4px;font-size:11px;cursor:pointer;transition:all .15s}.feed-type button.on{color:#eafcff;border-color:rgba(56,240,255,.5);background:rgba(56,240,255,.1)}.feed-sub{padding:0 14px 6px;font-size:11px;color:#ffb86b;letter-spacing:.04em}.feed-list{flex:1 1;overflow-y:auto;padding:4px 10px 12px;display:flex;flex-direction:column;gap:7px}.feed-list::-webkit-scrollbar{width:6px}.feed-list::-webkit-scrollbar-thumb{background:rgba(74,168,255,.25);border-radius:3px}.feed-empty{color:#5d728f;font-size:12px;text-align:center;padding:24px 0}.feed-card{border:1px solid rgba(80,100,140,.18);border-left:3px solid #2fe08a;background:rgba(14,20,34,.6);border-radius:10px;padding:9px 11px}.feed-card.catch{border-left-color:#38f0ff}.feed-card.just{animation:justin .5s ease}@keyframes justin{0%{background:rgba(56,240,255,.22);transform:translateY(-4px)}to{background:rgba(14,20,34,.6);transform:none}}.fc-top{display:flex;align-items:center;gap:6px;font-size:13px}.fc-dot{width:7px;height:7px;border-radius:50%;background:#2fe08a;box-shadow:0 0 7px #2fe08a;flex:none}.fc-dot.catch{background:#38f0ff;box-shadow:0 0 7px #38f0ff}.fc-species{color:#eaf3ff;font-weight:600}.fc-size{color:#38f0ff;font-weight:600;font-size:12px}.fc-kind{color:#7e8fab;font-size:11px}.fc-time{margin-left:auto;color:#5d728f;font-size:11px;white-space:nowrap}.fc-lake{margin-top:3px;font-size:12px;color:#9fc6ee}.fc-wx{margin-top:3px;font-size:11px;color:#6f8099;letter-spacing:.01em}.splash{position:fixed;inset:0;display:grid;place-items:center;overflow:hidden;background:radial-gradient(120% 90% at 50% 38%,#0b1428 0,#070a14 52%,#03040a 100%)}.splash-glow{position:absolute;width:680px;height:680px;border-radius:50%;top:-180px;background:radial-gradient(circle,rgba(56,240,255,.16),rgba(56,240,255,0) 60%);filter:blur(20px);animation:splashfloat 7s ease-in-out infinite;pointer-events:none}@keyframes splashfloat{0%,to{transform:translateY(0);opacity:.9}50%{transform:translateY(26px);opacity:1}}.splash-card{position:relative;z-index:2;text-align:center;padding:0 26px;width:min(380px,92vw)}.splash-brand{font-size:46px;font-weight:800;letter-spacing:.04em;color:#dff4ff;text-shadow:0 0 40px rgba(56,240,255,.55)}.splash-brand .o{color:var(--neon-cyan)}.splash-tag{margin-top:10px;font-size:16px;letter-spacing:.34em;color:#9fc6ee}.splash-sub,.splash-tag{text-transform:uppercase}.splash-sub{margin-top:8px;font-size:12px;letter-spacing:.16em;color:#5d728f}.splash-form{margin-top:34px;display:flex;flex-direction:column;gap:12px}.splash-form.err{animation:shake .4s}@keyframes shake{0%,to{transform:translateX(0)}20%{transform:translateX(-9px)}40%{transform:translateX(8px)}60%{transform:translateX(-6px)}80%{transform:translateX(4px)}}.splash-input{width:100%;background:rgba(14,22,40,.85);border:1px solid rgba(74,168,255,.32);border-radius:12px;padding:15px 16px;font-size:16px;color:#eaf3ff;text-align:center;letter-spacing:.04em;outline:none;transition:border-color .18s,box-shadow .18s}.splash-input::placeholder{color:#5d728f;letter-spacing:.02em}.splash-input:focus{border-color:var(--neon-cyan);box-shadow:0 0 0 3px rgba(56,240,255,.14)}.splash-btn{width:100%;border:none;border-radius:12px;padding:15px;font-size:16px;font-weight:700;letter-spacing:.05em;color:#04121a;cursor:pointer;background:linear-gradient(90deg,#38f0ff,#4aa8ff);box-shadow:0 8px 26px rgba(56,240,255,.4);transition:transform .1s,filter .15s}.splash-btn:active{transform:scale(.97)}.splash-btn:disabled{opacity:.6;cursor:default}.splash-err{margin-top:14px;font-size:13px;color:#ff7aa8;letter-spacing:.02em}.splash-foot{position:absolute;bottom:22px;z-index:2;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#3f4d63}