@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&display=swap');
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{font-family:'Outfit',sans-serif;background:#0a1f12;color:#e8f5ec;height:100%;overflow:hidden;user-select:none}
:root{
  --green:#3eb870;--green2:#2d8a52;--gold:#c8a84b;
  --bg:#0a1f12;--surface:#112518;--surface2:#1a3520;--surface3:#223d28;
  --border:rgba(62,184,112,0.15);--border2:rgba(62,184,112,0.28);
  --text:#e8f5ec;--text2:#9abfa8;--text3:#5a8068;
  --danger:#e05252;--warning:#e0a030;--info:#4fc3f7;
  --r:14px;--rs:8px;--font:'Outfit',sans-serif;
}

/* SPLASH */
#splash{position:fixed;inset:0;z-index:1000;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;overflow-y:auto}
.splash-logo{font-size:52px;margin-bottom:10px;animation:float 3s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.splash-title{font-size:30px;font-weight:700;color:var(--green);letter-spacing:-.5px;margin-bottom:3px}
.splash-sub{font-size:13px;color:var(--text2);margin-bottom:20px}
.splash-countdown{font-size:13px;color:var(--text2);margin-bottom:10px}
.splash-countdown span{color:var(--green);font-weight:600}
.splash-actions{display:flex;flex-direction:column;gap:10px;width:min(100%,320px)}
.splash-skip{font-size:14px;color:var(--green);font-weight:600;cursor:pointer;padding:12px 32px;border:1px solid var(--border2);border-radius:var(--r);background:var(--surface);display:none}
.splash-install{font-size:14px;color:#fff;font-weight:600;cursor:pointer;padding:12px 32px;border:1px solid rgba(62,184,112,.4);border-radius:var(--r);background:var(--green)}
.lang-toggle{font-size:11px;color:var(--text3);cursor:pointer;border:1px solid var(--border);border-radius:4px;padding:2px 6px;background:var(--surface)}

/* APP */
#app{display:none;flex-direction:column;height:100%;overflow:hidden}
#app.visible{display:flex}
#leaflet-map{position:absolute;inset:0;cursor:crosshair}
.leaflet-container{background:#1a3a5c!important}
.leaflet-control-zoom{display:none}

/* TOP BAR */
.top-bar{position:absolute;top:0;left:0;right:0;z-index:500;padding:6px 9px;display:flex;align-items:center;gap:5px;background:linear-gradient(to bottom,rgba(10,31,18,.95) 0%,transparent 100%);pointer-events:none}
.top-bar-content{pointer-events:all;display:flex;align-items:center;gap:5px;width:100%}
.gw-sel{flex:1;min-width:0;background:var(--surface);border:1px solid var(--border2);border-radius:var(--rs);padding:5px 22px 5px 7px;color:var(--text);font-family:var(--font);font-size:12px;font-weight:500;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%233eb870' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;cursor:pointer;max-width:160px}
.icon-btn{width:34px;height:34px;background:var(--surface);border:1px solid var(--border2);border-radius:var(--rs);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;color:var(--text);flex-shrink:0}
.icon-btn:active{background:var(--surface2)}

/* SEARCH */
.search-wrap{position:absolute;top:54px;left:11px;right:11px;z-index:501;display:none}
.search-wrap.visible{display:block}
.search-inp{width:100%;background:var(--surface);border:1px solid var(--green);border-radius:var(--rs);padding:9px 13px;color:var(--text);font-family:var(--font);font-size:14px;outline:none}
.search-results{background:var(--surface);border:1px solid var(--border2);border-radius:var(--rs);margin-top:3px;max-height:180px;overflow-y:auto}
.srch-item{padding:9px 13px;font-size:12px;cursor:pointer;border-bottom:1px solid var(--border);display:flex;gap:7px;align-items:center;color:var(--text2)}
.srch-item:active{background:var(--surface2)}

/* PROXIMITY */
.prox-bar{position:absolute;bottom:76px;left:11px;right:11px;z-index:500;background:rgba(10,31,18,.92);border:1px solid var(--border2);border-radius:var(--rs);padding:6px 11px;display:none;cursor:pointer;backdrop-filter:blur(4px)}
.prox-bar.visible{display:block}
.prox-bar:active{background:var(--surface2)}

/* CACHE PROGRESS */
.cache-prog{position:absolute;bottom:76px;left:11px;right:72px;z-index:501;background:var(--surface);border:1px solid var(--gold);border-radius:var(--rs);padding:9px 11px;display:none}
.cache-prog.visible{display:block}
.prog-track{height:5px;background:var(--surface3);border-radius:3px;margin-top:5px}
.prog-fill{height:100%;background:var(--gold);border-radius:3px;transition:width .3s}

/* FABs */
.map-fabs{position:absolute;bottom:20px;right:11px;z-index:500;display:flex;flex-direction:column;gap:8px}
.fab{width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:21px;box-shadow:0 4px 14px rgba(0,0,0,.4);transition:transform .15s}
.fab:active{transform:scale(.93)}
.fab-p{background:var(--green);color:#fff;font-size:22px}
.fab-s{background:var(--surface2);border:1px solid var(--border2);color:var(--text);width:42px;height:42px}

/* NAV BAR */
.nav-bar{background:var(--surface);border-top:1px solid var(--border);display:flex;padding-bottom:env(safe-area-inset-bottom,0);flex-shrink:0}
.nav-item{flex:1;padding:7px 2px;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;border:none;background:transparent;color:var(--text3);font-family:var(--font);font-size:9px;min-width:0}
.nav-item.active{color:var(--green)}
.nav-icon{font-size:17px}

/* PANELS */
.panel{position:fixed;inset:0;z-index:600;background:var(--bg);display:flex;flex-direction:column;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1)}
#p-help{z-index:650}
.panel.open{transform:translateY(0)}
.ph{padding:13px 13px 10px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);flex-shrink:0}
.pt{font-size:16px;font-weight:600}
.pc{width:28px;height:28px;border-radius:50%;background:var(--surface2);border:none;cursor:pointer;color:var(--text2);font-size:16px;display:flex;align-items:center;justify-content:center}
.pb{flex:1;overflow-y:auto;padding:13px}

/* CARDS */
.spot-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:12px;margin-bottom:8px;cursor:pointer}
.spot-card:active{border-color:var(--border2)}
.scn{font-size:14px;font-weight:600}
.scm{font-size:11px;color:var(--text3);margin-top:2px}
.scnote{font-size:11px;color:var(--text2);margin-top:4px;font-style:italic;border-left:2px solid var(--green2);padding-left:7px}
.sthumb{width:44px;height:44px;border-radius:7px;object-fit:cover;border:1px solid var(--border);flex-shrink:0}

/* FORMS */
.fg{margin-bottom:13px}
.fl{font-size:10px;color:var(--text3);font-weight:500;margin-bottom:4px;display:block;text-transform:uppercase;letter-spacing:.5px}
.fi{width:100%;background:var(--surface);border:1px solid var(--border2);border-radius:var(--rs);padding:10px 12px;color:var(--text);font-family:var(--font);font-size:14px;outline:none}
.fi:focus{border-color:var(--green)}
textarea.fi{resize:vertical;min-height:66px}
.coords{background:var(--surface2);border-radius:var(--rs);padding:8px 12px;font-size:12px;color:#a8e6c0;font-weight:500;margin-bottom:13px;text-align:center}

/* BUTTONS */
.btn{width:100%;padding:12px;border:none;border-radius:var(--r);font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}
.btn:active{transform:scale(.98)}
.btn-g{background:var(--green);color:#fff}
.btn-o{background:transparent;border:1px solid var(--border2);color:var(--text2);margin-top:7px}
.btn-d{background:transparent;border:1px solid rgba(224,82,82,.3);color:var(--danger);margin-top:7px}
.btn-gold{background:transparent;border:1px solid rgba(200,168,75,.4);color:var(--gold);margin-top:7px}

/* PHOTO */
.photo-area{border:2px dashed var(--border2);border-radius:var(--r);padding:18px;text-align:center;cursor:pointer;margin-bottom:13px;position:relative;overflow:hidden}
.photo-area img{width:100%;max-height:220px;object-fit:cover;border-radius:var(--rs);display:block}
.photo-ph{color:var(--text3);font-size:12px}
.photo-ph span{font-size:28px;display:block;margin-bottom:4px}
.photo-rm{position:absolute;top:7px;right:7px;background:rgba(0,0,0,.65);border:none;border-radius:50%;width:26px;height:26px;color:#fff;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center}

/* FANGBUCH */
.cc{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:11px 12px;margin-bottom:8px;cursor:pointer}
.cn{font-weight:600;font-size:13px}
.cd{font-size:11px;color:var(--text3);margin-top:2px}
.cw{font-size:19px;font-weight:700;color:var(--gold)}
.cthumb{width:40px;height:40px;border-radius:7px;object-fit:cover;border:1px solid var(--border)}

/* STATS */
.sg{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:14px}
.sc{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:12px;text-align:center}
.sv{font-size:24px;font-weight:700;color:var(--gold)}
.sl{font-size:10px;color:var(--text3);margin-top:2px}
.br{margin-bottom:9px}
.bl{display:flex;justify-content:space-between;font-size:12px;color:var(--text2);margin-bottom:3px}
.bt{height:6px;background:var(--surface3);border-radius:3px;overflow:hidden}
.bf{height:100%;border-radius:3px}

/* NAVIGATION */
.nic{display:flex;gap:8px;margin-bottom:13px}
.niv{flex:1;background:var(--surface);border:1px solid var(--border2);border-radius:var(--r);padding:10px;text-align:center}
.niv-val{font-size:20px;font-weight:700;color:var(--gold)}
.niv-lbl{font-size:10px;color:var(--text3);margin-top:2px}
.compass{width:100px;height:100px;margin:0 auto 14px;border-radius:50%;background:var(--surface);border:2px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:52px;transition:transform .3s}

/* GEWÄSSER */
.gi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:12px;margin-bottom:8px;display:flex;align-items:center;gap:10px}
.gi.active-g{border-color:var(--green)}

/* SHARE */
#qr-box{background:#fff;border-radius:10px;padding:12px;display:flex;justify-content:center;margin-bottom:14px}
.share-url{background:var(--surface2);border-radius:var(--rs);padding:9px 12px;font-size:11px;color:var(--text2);word-break:break-all;margin-bottom:11px;font-family:monospace}

/* FISH GRID */
.fish-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:13px}
.fo{background:var(--surface);border:1px solid var(--border2);border-radius:var(--rs);padding:9px 5px;text-align:center;cursor:pointer}
.fo.sel{border-color:var(--green);background:var(--surface3)}
.fo span{font-size:20px;display:block;margin-bottom:2px}
.fo div{font-size:10px;color:var(--text2)}

/* SECTION HDR */
.shdr{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.7px;padding:2px 0 8px;margin-top:5px}

/* EMPTY */
.empty{text-align:center;padding:36px 18px;color:var(--text3);font-size:13px;line-height:1.6}
.ei{font-size:40px;margin-bottom:8px;display:block}

/* TOAST */
.toast{position:fixed;bottom:72px;left:50%;transform:translateX(-50%) translateY(18px);background:var(--surface2);border:1px solid var(--border2);border-radius:var(--rs);padding:8px 15px;font-size:12px;color:var(--text);z-index:900;white-space:nowrap;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* TOGGLE */
.toggle-track{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--surface3);border-radius:22px;border:1px solid var(--border2);transition:.3s}
.toggle-track:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background:var(--text3);border-radius:50%;transition:.3s}
input:checked+.toggle-track{background:var(--green);border-color:var(--green)}
input:checked+.toggle-track:before{transform:translateX(18px);background:#fff}

/* NATIVE AD */
.native-ad{background:var(--surface);border:1px solid rgba(200,168,75,.2);border-radius:var(--r);padding:0;margin-bottom:8px;overflow:hidden}
.native-ad-label{font-size:9px;color:var(--text3);text-align:right;padding:4px 10px 0;text-transform:uppercase;letter-spacing:.5px}
.native-ad-inner{padding:10px 12px 12px;display:flex;gap:10px;align-items:center;cursor:pointer;text-decoration:none}
.native-ad-img{width:48px;height:48px;border-radius:7px;background:var(--surface3);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:22px}
.native-ad-brand{font-size:9px;color:var(--green);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1px}
.native-ad-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.3}
.native-ad-desc{font-size:11px;color:var(--text2);margin-top:2px}
.native-ad-cta{display:inline-block;margin-top:5px;font-size:10px;font-weight:600;color:var(--gold);background:rgba(200,168,75,.1);border:1px solid rgba(200,168,75,.2);border-radius:4px;padding:2px 7px}

/* WETTER */
.wetter-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;margin-bottom:14px}
.wetter-card-title{font-size:10px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}

/* KI BERATER */
.ki-msg{display:flex;gap:10px;margin-bottom:14px;align-items:flex-end}
.ki-msg-bot{flex-direction:row}
.ki-msg-user{flex-direction:row-reverse}
.ki-avatar{width:30px;height:30px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.ki-bubble{max-width:82%;padding:10px 13px;border-radius:14px;font-size:13px;line-height:1.5;color:var(--text)}
.ki-msg-bot .ki-bubble{background:var(--surface2);border:1px solid var(--border);border-bottom-left-radius:4px}
.ki-msg-user .ki-bubble{background:var(--green);color:#fff;border-bottom-right-radius:4px}
.ki-typing span{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--text3);margin:0 2px;animation:ki-bounce .8s infinite}
.ki-typing span:nth-child(2){animation-delay:.15s}
.ki-typing span:nth-child(3){animation-delay:.3s}
@keyframes ki-bounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-6px)}}

/* COMMUNITY FEED */
.feed-chip{flex-shrink:0;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;background:var(--surface);border:1px solid var(--border2);color:var(--text3);white-space:nowrap}
.feed-chip.active{background:var(--green);border-color:var(--green);color:#fff}
.feed-card{padding:14px;border-bottom:1px solid var(--border)}
.feed-card-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.feed-avatar{width:36px;height:36px;border-radius:50%;background:var(--surface2);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--green);flex-shrink:0}
.feed-username{font-size:13px;font-weight:600;color:var(--text)}
.feed-date{font-size:11px;color:var(--text3)}
.feed-photo{width:100%;border-radius:var(--rs);margin-bottom:8px;max-height:220px;object-fit:cover;display:block}
.feed-fish-emoji{font-size:48px;text-align:center;padding:16px;background:var(--surface2);border-radius:var(--rs);margin-bottom:8px}
.feed-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:6px}
.feed-badge{font-size:11px;padding:3px 9px;border-radius:20px;background:var(--surface2);color:var(--text2);border:1px solid var(--border)}
.feed-badge.highlight{background:rgba(200,168,75,.12);color:var(--gold);border-color:rgba(200,168,75,.3)}
.feed-note{font-size:12px;color:var(--text2);line-height:1.5;font-style:italic}
.feed-actions{display:flex;gap:12px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.feed-action-btn{background:none;border:none;cursor:pointer;font-size:12px;color:var(--text3);display:flex;align-items:center;gap:4px;padding:0}
.feed-action-btn.liked{color:var(--danger)}
.feed-load-more{width:100%;padding:14px;background:transparent;border:none;color:var(--green);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;border-top:1px solid var(--border)}
