*{box-sizing:border-box}body,html{margin:0;padding:0;width:100%;max-width:100%;overflow-x:hidden;font-family:'Segoe UI',Arial,sans-serif;background:#f0f4f8;color:#1a2332;-webkit-text-size-adjust:100%;overscroll-behavior-y:none;touch-action:pan-y}body.dark,html.dark{background:#020617;color:#dbeafe}#pullIndicator{position:fixed;top:0;left:50%;transform:translateX(-50%) translateY(-60px);z-index:9999;background:#0f172a;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px rgba(0,0,0,.35);transition:transform .2s,opacity .2s;opacity:0;pointer-events:none}#pullIndicator.pulling{opacity:1}#pullIndicator.refreshing{transform:translateX(-50%) translateY(12px);opacity:1}#pullIndicator.refreshing svg{animation:.7s linear infinite ptr-spin}@keyframes ptr-spin{to{transform:rotate(-360deg)}}header{background:linear-gradient(135deg,#0f172a,#1e3a5f);color:#fff;padding:calc(14px + env(safe-area-inset-top,0px)) calc(20px + env(safe-area-inset-right,0px)) 14px calc(20px + env(safe-area-inset-left,0px));display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;box-shadow:0 4px 16px rgba(0,0,0,.25);position:sticky;top:0;z-index:1000;margin-top:calc(-1 * env(safe-area-inset-top,0px));padding-top:calc(14px + env(safe-area-inset-top,0px))}.header-left{display:flex;align-items:center;gap:10px}.logo{font-size:26px}.logo-img{width:36px;height:36px;object-fit:contain}header h1{margin:0;font-size:20px;font-weight:700;letter-spacing:-.3px}nav{display:flex;gap:8px;flex-wrap:wrap}.nav-btn{background:rgba(255,255,255,.1);color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.15);padding:8px 14px;border-radius:999px;cursor:pointer;font-size:13px;font-weight:500;transition:.2s}.nav-btn:hover{background:rgba(255,255,255,.18);color:#fff;transform:translateY(-1px)}.nav-btn.active{background:#38bdf8;color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(56,189,248,.4)}.page{display:none;padding:90px calc(20px + var(--safe-right)) calc(20px + var(--safe-bottom)) calc(20px + var(--safe-left));will-change:transform,opacity;opacity:0;transform:translateY(10px)}.page.active{display:block;animation:.22s forwards pageIn}@keyframes pageIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page.snap-back{transition:transform .45s cubic-bezier(.25, .46, .45, .94)}#map{width:100%;height:70vh;border-radius:16px;overflow:hidden;box-shadow:0 6px 20px rgba(0,0,0,.15)}.panel{background:#fff;padding:14px 18px;border-radius:14px;box-shadow:0 2px 12px rgba(0,0,0,.07);margin-bottom:16px;border-left:4px solid #38bdf8}.controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}button,input,select,textarea{padding:9px 12px;border-radius:10px;border:1px solid #d1d9e0;font-size:16px;font-family:inherit}button{font-size:14px;cursor:pointer;background:#f1f5f9;color:#1a2332}input,select{background:#fff}.danger-btn{background:#dc2626;color:#fff;border:none}.danger-btn:hover{background:#b91c1c}.fish-list{display:grid;gap:12px}.fish-card{background:#fff;border-radius:14px;padding:14px 16px;box-shadow:0 2px 12px rgba(0,0,0,.07);cursor:pointer;transition:.2s;border-left:4px solid #38bdf8}.fish-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.12)}.fish-card h3{margin:0 0 8px;font-size:16px}.muted{color:#64748b;font-size:14px}.empty{background:#fff;padding:24px;border-radius:14px;box-shadow:0 2px 12px rgba(0,0,0,.07);color:#64748b;text-align:center}.small-note{margin-top:8px;color:#0369a1;font-size:12px;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:24px}.stat-card{background:#fff;border-radius:14px;padding:18px;box-shadow:0 2px 12px rgba(0,0,0,.07);text-align:center;border-top:3px solid #38bdf8}.stat-card .stat-icon{font-size:30px;margin-bottom:6px}.stat-card .stat-number{font-size:28px;font-weight:800;color:#0f172a}.stat-card .stat-label{font-size:12px;color:#64748b;margin-top:2px;text-transform:uppercase;letter-spacing:.5px}.stats-section-title{font-size:15px;font-weight:700;color:#1e3a5f;margin:20px 0 10px;text-transform:uppercase;letter-spacing:.5px}.top-list{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.07);margin-bottom:20px}.top-list-row{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid #f1f5f9;gap:12px;cursor:pointer;transition:background .15s}.top-list-row:last-child{border-bottom:none}.top-list-row:hover{background:#f8fafc}.top-rank{font-size:18px;width:28px;text-align:center}.top-info{flex:1}.top-name{font-weight:600;font-size:14px}.top-meta{font-size:12px;color:#64748b}.top-value{font-weight:800;color:#0f172a;font-size:16px}.chart-bar-wrap{margin-bottom:20px}.chart-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.chart-label{width:100px;font-size:13px;color:#334155;font-weight:500;flex-shrink:0}.chart-bar-bg{flex:1;height:22px;background:#f1f5f9;border-radius:999px;overflow:hidden}.chart-bar-fill{height:100%;background:linear-gradient(90deg,#38bdf8,#0ea5e9);border-radius:999px;transition:width .6s}.chart-count{width:28px;text-align:right;font-size:13px;font-weight:700;color:#0f172a}.filter-group{display:flex;gap:8px;flex-wrap:wrap}.enc-filter{padding:7px 16px;border-radius:999px;border:1px solid #d1d9e0;background:#fff;color:#64748b;font-size:12px;font-weight:500;cursor:pointer;transition:.2s}.enc-filter:hover{border-color:#38bdf8;color:#0ea5e9}.enc-filter.on{background:#0ea5e9;color:#fff;border-color:transparent;box-shadow:0 3px 10px rgba(14,165,233,.3)}.search-box{margin-left:auto}.search-box input{width:220px;background:#fff;transition:width .2s}.search-box input:focus{width:260px;outline:0;border-color:#38bdf8}.enc-section-title{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:#94a3b8;margin:24px 0 12px;display:flex;align-items:center;gap:12px}.enc-section-title::after{content:'';flex:1;height:1px;background:#e2e8f0}.enc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}.enc-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.07);transition:.25s;border:1px solid #e8f0f6}.enc-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(0,0,0,.12);border-color:#bae6fd}.enc-card.enc-hide{display:none}.enc-card-top{padding:20px 20px 0;display:flex;justify-content:space-between;align-items:flex-start}.enc-icon{font-size:44px;line-height:1;transition:transform .3s}.enc-card:hover .enc-icon{transform:scale(1.1) rotate(-4deg)}.enc-badges{display:flex;flex-direction:column;align-items:flex-end;gap:5px}.enc-badge{font-size:9px;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:999px;font-weight:600;white-space:nowrap}.b-fresh{background:#e0f2fe;color:#0369a1}.b-sea{background:#dbeafe;color:#1d4ed8}.b-river{background:#dcfce7;color:#166534}.b-both{background:#ede9fe;color:#7c3aed}.diff-lett{background:#dcfce7;color:#166534}.diff-middels{background:#fef9c3;color:#854d0e}.diff-krevende{background:#fee2e2;color:#991b1b}.enc-card-body{padding:14px 20px 20px}.enc-name{font-size:20px;font-weight:800;color:#0f172a;margin-bottom:2px}.enc-latin{font-size:11px;font-style:italic;color:#94a3b8;margin-bottom:10px}.enc-desc{font-size:13px;line-height:1.65;color:#475569;margin-bottom:16px}.enc-stats{display:grid;grid-template-columns:1fr 1fr;gap:7px}.enc-stat{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:8px 10px}.enc-stat-l{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:#94a3b8;margin-bottom:2px}.enc-stat-v{font-size:12px;font-weight:600;color:#1e293b}.enc-record{grid-column:1/-1;background:linear-gradient(90deg,#fefce8,#fefbe8);border:1px solid #fde68a;border-radius:8px;padding:8px 10px;display:flex;align-items:center;gap:8px}.enc-record-l{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:#92400e;opacity:.7}.enc-record-v{font-size:12px;font-weight:700;color:#92400e}.enc-log-btn{width:100%;margin-top:12px;padding:10px;border-radius:9px;background:#f0f9ff;border:1px solid #bae6fd;color:#0369a1;font-weight:600;font-size:13px;cursor:pointer;transition:.2s}.enc-log-btn:hover{background:#e0f2fe;border-color:#38bdf8}.leaflet-popup-content-wrapper{border-radius:14px}.leaflet-popup-content{width:min(260px,70vw);max-height:60vh;overflow-y:auto;overflow-x:hidden;margin:12px;padding-right:6px;touch-action:pan-y;overscroll-behavior:contain}.fish-picker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;max-height:180px;overflow-y:auto;scrollbar-gutter:stable;margin-bottom:4px}.fish-picker-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 4px;border:1.5px solid #e2e8f0;border-radius:8px;background:#f8fafc;cursor:pointer;font-size:10px;font-weight:700;color:#334155;line-height:1.2;text-align:center}.fish-picker-btn.selected{border-color:#38bdf8;background:#e0f2fe;color:#0369a1;font-weight:700}.fish-picker-name{font-size:9px;word-break:break-word}.popup-form{max-height:55vh;overflow-y:auto;overflow-x:hidden;padding-right:4px;touch-action:pan-y;overscroll-behavior:contain}.popup-form label{display:block;margin-top:8px;margin-bottom:4px;font-weight:600;font-size:12px;color:#334155}.popup-form button,.popup-form input,.popup-form select,.popup-form textarea{width:100%;box-sizing:border-box}.popup-form button{margin-top:10px;background:linear-gradient(135deg,#0f172a,#1e3a5f);color:#fff;border:none;cursor:pointer;border-radius:10px;font-weight:600;padding:10px}.popup-form button:hover{background:#0f172a}.lure-card{background:#fff;border-radius:14px;padding:16px;box-shadow:0 2px 12px rgba(0,0,0,.07);transition:.2s;border-left:4px solid #f59e0b;color:#0f172a}.fb-archive-btn{display:flex;align-items:center;gap:8px;width:100%;background:var(--card-bg,#f8fafc);border:1.5px solid var(--border,#e2e8f0);border-radius:10px;padding:10px 12px;cursor:pointer;font-size:13px;font-weight:600;color:inherit}.fb-archive-header{display:flex;align-items:center;gap:10px;padding:12px 16px 10px;border-bottom:1px solid var(--border,#e2e8f0)}.fb-archive-title{font-size:15px;font-weight:700;color:inherit}.fb-back-btn{background:0 0;border:none;cursor:pointer;padding:4px;color:inherit;display:flex;align-items:center}.lure-card:hover{transform:translateY(-2px)}.lure-card h3{margin:0 0 10px;font-size:15px}.lure-meta{margin:5px 0;font-size:13px}.lure-tag{display:inline-block;background:#fef3c7;color:#92400e;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;margin-bottom:8px}.lure-note{margin-top:10px;font-style:italic;color:#64748b;font-size:13px}.lure-funfact{margin-top:8px;font-size:12px;color:#0369a1;background:#f0f9ff;border-left:3px solid #38bdf8;padding:6px 10px;border-radius:0 8px 8px 0}.lure-card-body{display:flex;gap:14px;align-items:flex-start}.lure-card-content{flex:1;min-width:0}.lure-img{width:120px;height:120px;object-fit:contain;background:#f8f9fa;border-radius:10px;padding:6px;flex-shrink:0}.lure-bait-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:80px}.lure-bait-icon svg{width:72px;height:72px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.12))}.fish-svg-icon{display:inline-block;width:26px;height:26px;vertical-align:middle;margin-right:4px}.fish-svg-icon svg{width:26px;height:26px}.enc-icon svg{width:44px;height:44px;transition:transform .3s}.enc-card:hover .enc-icon svg{transform:scale(1.1) rotate(-4deg)}.fish-filter-scroll{display:flex;gap:8px;overflow-x:auto;padding:10px 16px;scrollbar-width:none;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;background:#fff;border-bottom:1px solid #e2e8f0}.fish-filter-scroll::-webkit-scrollbar{display:none}.fish-filter-chip{display:flex;align-items:center;gap:5px;flex-shrink:0;padding:6px 12px;border-radius:999px;border:2px solid #e2e8f0;background:#f8fafc;color:#475569;font-size:13px;font-weight:600;cursor:pointer;transition:.15s;white-space:nowrap;user-select:none}.fish-filter-chip:hover{border-color:#38bdf8;color:#0ea5e9}.fish-filter-chip.active{background:#0ea5e9;border-color:transparent;color:#fff;box-shadow:0 3px 10px rgba(14,165,233,.3)}.fish-chip-icon{display:inline-flex;align-items:center;width:20px;height:20px;flex-shrink:0}.fish-chip-icon svg{width:20px;height:20px}.auth-overlay{position:fixed;inset:0;background:linear-gradient(160deg,#0f172a 0,#1e3a5f 100%);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}.auth-box{background:#fff;border-radius:24px;padding:32px 28px;width:100%;max-width:380px;text-align:center}.auth-logo{font-size:44px;margin-bottom:6px}.auth-title{margin:0 0 4px;font-size:28px;font-weight:800;color:#0f172a}.auth-sub{margin:0 0 24px;color:#64748b;font-size:14px}.auth-tabs{display:flex;background:#f1f5f9;border-radius:10px;padding:4px;margin-bottom:18px}.auth-tab{flex:1;padding:8px;border:none;background:0 0;border-radius:7px;font-weight:600;font-size:14px;cursor:pointer;color:#64748b;transition:.15s}.auth-tab.active{background:#fff;color:#1a2332;box-shadow:0 1px 4px rgba(0,0,0,.1)}.auth-input{width:100%;padding:11px 14px;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;font-family:inherit;outline:0;transition:border-color .2s;box-sizing:border-box;text-align:left}.auth-input:focus{border-color:#38bdf8}.auth-submit{width:100%;margin-top:4px;padding:13px;font-size:15px}.auth-error{background:#fee2e2;color:#dc2626;padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:14px;text-align:left}.auth-divider{text-align:center;color:#94a3b8;font-size:13px;margin:16px 0;position:relative}.auth-divider::after,.auth-divider::before{content:'';position:absolute;top:50%;width:40%;height:1px;background:#e2e8f0}.auth-divider::before{left:0}.auth-divider::after{right:0}.google-btn{width:100%;padding:11px 16px;border:2px solid #e2e8f0;border-radius:10px;background:#fff;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:border-color .15s;font-family:inherit}.google-btn:hover{border-color:#94a3b8}.apple-signin-btn{width:100%;padding:11px 16px;border:none;border-radius:10px;background:#000;color:#fff;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:opacity .15s;font-family:inherit;margin-top:10px}.apple-signin-btn:hover{opacity:.85}html.dark .apple-signin-btn{background:#fff;color:#000}.user-badge{display:flex;align-items:center;gap:8px;margin-left:auto}.user-display-name{color:rgba(255,255,255,.75);font-size:12px;max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{background:rgba(255,255,255,.08);color:rgba(255,255,255,.75);border:1px solid rgba(255,255,255,.18);border-radius:6px;padding:5px 11px;font-size:12px;cursor:pointer;transition:background .15s;font-family:inherit}.logout-btn:hover{background:rgba(255,255,255,.18)}.feed-container{display:flex;flex-direction:column;gap:0;padding:0;max-width:600px;margin:0 auto;background:#fafafa}#pullRefreshIndicator{display:flex;align-items:center;justify-content:center;height:0;overflow:hidden;transition:height .2s;color:#64748b;font-size:13px;gap:8px}#pullRefreshIndicator svg{transition:transform .3s}#pullRefreshIndicator.ready svg{transform:rotate(180deg)}#pullRefreshIndicator.refreshing svg{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.post-card{background:#fff;border-bottom:1px solid #efefef;margin-bottom:8px;border-radius:12px;overflow:hidden;box-shadow:0 1px 6px rgba(0,0,0,.06);content-visibility:auto;contain-intrinsic-size:0 400px}.napp-announcement-card{border:1.5px solid rgba(249,115,22,.3);box-shadow:0 2px 12px rgba(249,115,22,.12)}.group-card{background:#f8fafc;border:1px solid rgba(0,0,0,.09);border-radius:12px;padding:14px;cursor:pointer;transition:background .15s;overflow:hidden;color:#1e293b}.group-card:active{background:#e2e8f0}html.dark .group-card{background:#161b22;border-color:rgba(255,255,255,.08);color:#f1f5f9}html.dark .group-card:active{background:#1e293b}.group-menu-item{display:block;width:100%;background:0 0;border:none;color:#e2e8f0;font-size:14px;text-align:left;padding:10px 14px;border-radius:7px;cursor:pointer;white-space:nowrap}.group-menu-item:active{background:rgba(255,255,255,.08)}#groupDetailOverlay .post-body,#groupDetailOverlay .post-card{background:#161b22;border-bottom-color:#30363d;box-shadow:none}#groupDetailOverlay .post-author{color:#e6edf3}#groupDetailOverlay .post-time{color:#8b949e}#groupDetailOverlay .post-text{color:#e2e8f0}.post-header{display:flex;align-items:center;gap:10px;padding:12px 14px}.post-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#0ea5e9,#0f172a);color:#fff;font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.post-meta{flex:1}.post-author{font-size:14px;font-weight:700;color:#1a2332}.post-like-hint{font-size:13px;color:#64748b;cursor:pointer;margin-top:4px}.post-like-hint:hover{color:#0ea5e9}.dark .post-like-hint{color:#94a3b8}.dark .post-like-hint:hover{color:#38bdf8}.post-time{font-size:12px;color:#94a3b8}.post-delete-btn{background:0 0;border:none;font-size:16px;cursor:pointer;opacity:.5;padding:4px}.post-delete-btn:hover{opacity:1}#cropModal{z-index:10000}.post-edit-btn{background:0 0;border:none;cursor:pointer;opacity:.5;padding:4px;color:#4fc3f7}.post-edit-btn:hover{opacity:1}.post-photo{width:100%;aspect-ratio:4/5;object-fit:cover;display:block;cursor:pointer;background:#e2e8f0;opacity:0;transition:opacity .3s}.post-photo.img-loaded{opacity:1}.post-body{padding:10px 14px 14px}.slideshow{position:relative;width:100%;overflow:hidden;background:#000}.slideshow .slide-track{display:flex;will-change:transform;transition:transform .32s cubic-bezier(.25, .46, .45, .94)}.slideshow .slide-img{width:100%;flex-shrink:0;aspect-ratio:4/5;object-fit:cover;cursor:pointer;background:#e2e8f0}.slide-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.45);color:#fff;border:none;border-radius:50%;width:32px;height:32px;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2}.slide-prev{left:6px}.slide-next{right:6px}.slide-dots{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);display:flex;gap:5px;z-index:2}.slide-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.45);cursor:pointer}.slide-dot.active{background:#fff}.slide-counter{position:absolute;top:8px;right:10px;background:rgba(0,0,0,.5);color:#fff;font-size:11px;padding:2px 7px;border-radius:10px;z-index:2}.post-actions{display:flex;align-items:center;gap:10px;margin-bottom:8px}.like-btn{background:0 0;border:none;font-size:22px;cursor:pointer;padding:0;line-height:1;display:flex;align-items:center;gap:5px;transition:transform .1s}.like-btn:active{transform:scale(1.3)}.like-btn .like-count{font-size:14px;font-weight:600;color:#334155}.post-share-btn{background:0 0;border:none;font-size:18px;cursor:pointer;color:#64748b;margin-left:auto;padding:4px}.post-photo-wrap{position:relative}.post-fish-badge{position:absolute;bottom:10px;left:10px;background:rgba(0,0,0,.52);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-radius:20px;padding:4px 10px 4px 4px;display:flex;align-items:center;gap:4px;color:#fff;font-size:12px;font-weight:700;pointer-events:none}.post-fish-badge-icon{display:inline-flex;width:22px;height:22px;flex-shrink:0}.post-fish-badge-icon svg{width:22px;height:22px}.post-fish{font-size:15px;font-weight:700;color:#1a2332;margin-bottom:5px;display:flex;align-items:center;gap:5px}.post-chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:7px}.post-chip{background:#f1f5f9;color:#475569;font-size:12px;font-weight:600;padding:3px 9px;border-radius:999px}.post-diary{font-size:14px;color:#334155;line-height:1.55;margin-top:4px}.post-diary strong{color:#1a2332}.feed-loading{text-align:center;padding:40px;color:#94a3b8;font-size:14px}@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9 50%,#e2e8f0 75%);background-size:800px 100%;animation:1.4s linear infinite shimmer;border-radius:8px}.skeleton-card{background:#fff;border-bottom:1px solid #e2e8f0;padding:16px;margin-bottom:0}.skeleton-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.skeleton-avatar{width:38px;height:38px;border-radius:50%;flex-shrink:0}.skeleton-meta{flex:1;display:flex;flex-direction:column;gap:6px}.skeleton-name{height:13px;width:120px;border-radius:6px}.skeleton-time{height:11px;width:60px;border-radius:6px}.skeleton-photo{width:100%;aspect-ratio:4/3;border-radius:10px;margin-bottom:12px}.skeleton-line{height:12px;border-radius:6px;margin-bottom:8px}.skeleton-line.short{width:60%}html.dark .skeleton-card{background:#161b22;border-bottom-color:#30363d}html.dark .skeleton{background:linear-gradient(90deg,#21262d 25%,#30363d 50%,#21262d 75%);background-size:800px 100%}.user-search-input{width:100%;padding:11px 14px;border:2px solid #e2e8f0;border-radius:12px;font-size:15px;font-family:inherit;outline:0;transition:border-color .2s;box-sizing:border-box}.user-search-input:focus{border-color:#38bdf8}.social-section-label{padding:14px 16px 6px;font-size:13px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.user-card{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-bottom:1px solid #f1f5f9}.user-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#0ea5e9,#0f172a);color:#fff;font-weight:700;font-size:17px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-info{flex:1}.user-name{font-size:14px;font-weight:700;color:#1a2332}.user-sub{font-size:12px;color:#94a3b8}.follow-btn{background:#0ea5e9;color:#fff;border:none;border-radius:8px;padding:7px 16px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .15s}.follow-btn:hover{opacity:.85}.unfollow-btn{background:#f1f5f9;color:#475569;border:none;border-radius:8px;padding:7px 16px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s}.unfollow-btn:hover{background:#e2e8f0}.profile-header{text-align:center;padding:24px 20px 16px;background:#fff;border-bottom:1px solid #f1f5f9;overflow-x:hidden;max-width:100%}.skeleton-profile{text-align:center;padding:24px 20px 16px;background:#fff;border-bottom:1px solid #f1f5f9}.skeleton-profile-avatar{width:80px;height:80px;border-radius:50%;margin:0 auto 12px}.skeleton-profile-name{height:18px;width:140px;border-radius:8px;margin:0 auto 8px}.skeleton-profile-bio{height:13px;width:200px;border-radius:6px;margin:0 auto 8px}.skeleton-profile-stats{display:flex;justify-content:center;gap:24px;margin-top:16px}.skeleton-profile-stat{width:48px;height:36px;border-radius:8px}.skeleton-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:2px}.skeleton-grid-item{aspect-ratio:1;border-radius:0}html.dark .skeleton-profile{background:#0d1117;border-bottom-color:#21262d}.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#0ea5e9,#0f172a);color:#fff;font-weight:700;font-size:32px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}.profile-name-row{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:14px}.profile-name{font-size:18px;font-weight:700;color:#0f172a}.edit-name-btn{background:0 0;border:none;font-size:15px;cursor:pointer;opacity:.5;padding:2px}.edit-name-btn:hover{opacity:1}.profile-stats{display:flex;justify-content:center;gap:32px}.profile-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.profile-stat strong{font-size:18px;font-weight:700;color:#1a2332}.profile-stat span{font-size:12px;color:#64748b}.profile-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;padding:3px}.profile-thumb{width:100%;aspect-ratio:1;object-fit:cover;cursor:pointer}.chat-view{display:flex;flex-direction:column;height:calc(100vh - 60px)}.chat-topbar{display:flex;align-items:center;gap:10px;padding:calc(12px + env(safe-area-inset-top)) 16px 14px;background:rgba(255,255,255,.92);border-bottom:1px solid rgba(226,232,240,.8);position:sticky;top:0;z-index:1000;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 12px rgba(0,0,0,.06)}.dark .chat-topbar{background:rgba(13,17,23,.92);border-bottom-color:rgba(48,54,61,.8);box-shadow:0 1px 12px rgba(0,0,0,.3)}.post-delete-btn{color:#ef4444}.dark .post-delete-btn{color:#ef4444;opacity:1}img{touch-action:manipulation;-webkit-user-drag:none;user-select:none}body{-webkit-tap-highlight-color:transparent}.dark .chat-messages{background:0 0/24px 24px #0b1220;background-image:radial-gradient(circle at 1px 1px,rgba(14,165,233,.04) 1px,transparent 0)}.dark .chat-input-bar{background:rgba(13,17,23,.95);border-top-color:rgba(48,54,61,.8)}.dark .chat-input{background:#1e293b;border-color:#334155;color:#f1f5f9}.dark .chat-input::placeholder{color:#64748b}.dark .chat-input:focus{border-color:#38bdf8;background:#1e293b}.dark .chat-bubble-row.other .chat-bubble{background:#1e293b;color:#e2e8f0;box-shadow:0 1px 6px rgba(0,0,0,.3)}.dark .chat-bubble-row.own .chat-bubble{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff}.chat-back-btn{background:0 0;border:none;font-size:14px;font-weight:600;color:#0ea5e9;cursor:pointer;font-family:inherit;padding:4px 8px 4px 0}.chat-topbar-avatar{width:38px;height:38px;border-radius:50%;overflow:hidden;flex-shrink:0;box-shadow:0 0 0 2px rgba(14,165,233,.25)}.chat-topbar-avatar img{width:100%;height:100%;object-fit:cover}.chat-topbar-avatar .mini-initial{width:38px;height:38px;background:linear-gradient(135deg,#0ea5e9,#0c4a6e);color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;border-radius:50%}.chat-topbar-name{font-size:15px;font-weight:700;color:#1a2332}.dark .chat-topbar-name{color:#e6edf3}.chat-messages{flex:1;overflow-y:auto;padding:16px 14px;display:flex;flex-direction:column;gap:4px;background:0 0/24px 24px #eef2f7;background-image:radial-gradient(circle at 1px 1px,rgba(14,165,233,.06) 1px,transparent 0)}.chat-bubble-row{display:flex;align-items:flex-end;gap:6px;animation:.2s bubbleIn}.chat-bubble-row.own{flex-direction:row-reverse}@keyframes bubbleIn{from{opacity:0;transform:translateY(6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.chat-bubble{max-width:72%;padding:10px 14px;border-radius:20px;font-size:14px;line-height:1.5;word-break:break-word;position:relative}.chat-bubble-row.own .chat-bubble{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;border-bottom-right-radius:5px;box-shadow:0 2px 8px rgba(14,165,233,.35)}.chat-bubble-row.other .chat-bubble{background:#fff;color:#1a2332;border-bottom-left-radius:5px;box-shadow:0 1px 6px rgba(0,0,0,.08)}.bubble-time{font-size:10px;color:#94a3b8;padding:0 2px;white-space:nowrap;margin-bottom:2px}.chat-input-bar{display:flex;align-items:center;gap:8px;padding:10px 12px calc(10px + env(safe-area-inset-bottom,0px));background:rgba(255,255,255,.95);border-top:1px solid rgba(226,232,240,.8);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.chat-input{flex:1;padding:10px 16px;border:1.5px solid #e2e8f0;border-radius:24px;font-size:14px;font-family:inherit;outline:0;background:#f8fafc;transition:border-color .2s,box-shadow .2s}.chat-input:focus{border-color:#38bdf8;box-shadow:0 0 0 3px rgba(56,189,248,.12);background:#fff}.chat-send-btn{width:38px;height:38px;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;border:none;border-radius:50%;font-size:16px;font-weight:700;cursor:pointer;flex-shrink:0;transition:transform .15s,opacity .15s;box-shadow:0 2px 8px rgba(14,165,233,.4);display:flex;align-items:center;justify-content:center}.chat-send-btn:active{transform:scale(.9);opacity:.85}.conv-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fff;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .1s}.conv-item:hover{background:#f8fafc}.conv-item-info{flex:1;overflow:hidden}.conv-item-name{font-size:14px;font-weight:700;color:#1a2332}.conv-item-last{font-size:13px;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conv-item-time{font-size:11px;color:#94a3b8}.conv-unread-dot{width:10px;height:10px;background:linear-gradient(135deg,#0ea5e9,#0284c7);border-radius:50%;flex-shrink:0;box-shadow:0 1px 4px rgba(14,165,233,.4)}.nav-badge{background:#ef4444;color:#fff;font-size:10px;font-weight:700;padding:1px 5px;border-radius:999px;margin-left:3px;vertical-align:middle}.profile-avatar-wrap{position:relative;width:86px;margin:0 auto 12px;cursor:pointer}.profile-avatar-wrap:hover .profile-pic-overlay{opacity:1}.profile-pic-overlay{position:absolute;inset:0;border-radius:50%;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;opacity:0;transition:opacity .2s;cursor:pointer}.profile-avatar-img{width:86px;height:86px;border-radius:50%;object-fit:cover;border:3px solid #e2e8f0}.avatar-img{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.invite-btn{width:100%;padding:13px;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .15s}.invite-btn:hover{opacity:.88}.msg-btn{background:#f1f5f9;color:#475569;border:none;border-radius:8px;padding:7px 12px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;margin-left:6px}.msg-btn:hover{background:#e2e8f0}.feed-card{display:flex;flex-direction:column;gap:18px;padding:16px;max-width:560px;margin:0 auto;background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 2px 18px rgba(0,0,0,.09)}.feed-photo{width:100%;max-height:420px;object-fit:cover;display:block;background:#e2e8f0;opacity:0;transition:opacity .3s}.feed-photo.img-loaded{opacity:1}.feed-info{padding:14px 16px 16px}.feed-fish{font-size:17px;font-weight:700;color:#1a2332;margin-bottom:4px;display:flex;align-items:center;gap:6px}.feed-date{font-size:12px;color:#94a3b8;margin-bottom:8px}.feed-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.feed-chip{display:inline-flex;align-items:center;gap:4px;background:#f1f5f9;color:#334155;font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px}.feed-diary{font-size:13px;color:#475569;line-height:1.55;margin-bottom:10px;font-style:italic;border-left:3px solid #e2e8f0;padding-left:10px}.feed-actions{display:flex;gap:8px;justify-content:flex-end}.feed-share-btn{background:#0ea5e9;color:#fff;border:none;border-radius:8px;padding:7px 16px;font-size:13px;font-weight:700;cursor:pointer;transition:opacity .15s}.feed-share-btn:hover{opacity:.85}.feed-delete-btn{background:#fee2e2;color:#dc2626;border:none;border-radius:8px;padding:7px 12px;font-size:13px;cursor:pointer}.feed-delete-btn:hover{background:#fecaca}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:2000;display:flex;align-items:center;justify-content:center;padding:16px}.modal-box{background:#fff;border-radius:20px;padding:24px;width:100%;max-width:460px;max-height:92vh;overflow-y:auto}.modal-box h3{margin:0 0 12px;font-size:18px}.share-hint{margin:0 0 10px;font-size:13px;color:#64748b}.share-row{border:1px solid #e2e8f0;border-radius:10px;margin-bottom:8px;overflow:hidden}.share-row-header{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#f8fafc;cursor:pointer}.share-label{font-size:14px;font-weight:600;color:#334155;flex:1}.share-privacy{font-size:11px;color:#94a3b8;background:#f1f5f9;padding:2px 7px;border-radius:999px}.share-row-input{padding:10px 12px;background:#fff;border-top:1px solid #e2e8f0}.share-input-field{width:100%;padding:8px 11px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:14px;font-family:inherit;outline:0;transition:border-color .2s;box-sizing:border-box}.share-input-field:focus{border-color:#38bdf8}textarea.share-input-field{resize:vertical}.toggle-switch{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-switch input:checked+.toggle-slider{background:#0ea5e9}.toggle-switch input:checked+.toggle-slider::before{transform:translateX(16px)}.feed-preview{width:100%;max-height:260px;object-fit:cover;border-radius:12px;margin-bottom:18px}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:13px;font-weight:600;color:#475569;margin-bottom:5px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:9px 12px;border:2px solid #e2e8f0;border-radius:9px;font-size:14px;font-family:inherit;outline:0;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#38bdf8}.form-group textarea{resize:vertical}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}.primary-btn{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;border:none;border-radius:10px;padding:10px 22px;font-size:14px;font-weight:700;cursor:pointer;transition:opacity .15s}.primary-btn:hover{opacity:.88}.disclaimer-box{margin:12px 16px 4px;padding:12px 16px;background:#fffbeb;border:1px solid #fcd34d;border-radius:10px;font-size:12px;color:#78350f;line-height:1.5}.disclaimer-box p{margin:0 0 6px}.disclaimer-box p:last-child{margin-bottom:0}@media (max-width:640px){header{flex-direction:column;align-items:flex-start}nav{width:100%;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}.nav-btn{white-space:nowrap;font-size:12px;padding:7px 12px}#map{height:60vh}.enc-grid{grid-template-columns:1fr}.search-box{width:100%}.search-box input{width:100%!important}.stats-grid{grid-template-columns:1fr 1fr}.leaflet-popup-content{width:min(240px,75vw);max-height:50vh}.popup-form{max-height:45vh}}.ban-screen{position:fixed;inset:0;z-index:9999;background:#0f172a;display:flex;align-items:center;justify-content:center}.ban-box{background:#1e293b;border-radius:20px;padding:40px 32px;max-width:380px;width:90%;text-align:center;border:1px solid #ef444433}.ban-icon{font-size:52px;margin-bottom:16px}.ban-box h2{color:#ef4444;margin:0 0 12px;font-size:22px}.ban-msg{color:#e2e8f0;margin:0 0 8px;font-size:15px;line-height:1.5}.ban-sub{color:#64748b;font-size:13px;margin:0}.terms-box{max-width:480px;max-height:90vh;display:flex;flex-direction:column}.terms-scroll{overflow-y:auto;max-height:55vh;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;margin:12px 0;font-size:14px;color:#334155;line-height:1.6}.terms-scroll ol{padding-left:20px;margin:8px 0}.terms-scroll li{margin-bottom:8px}.report-target-name{color:#64748b;font-size:13px;margin:-4px 0 14px}.profile-stat-link{cursor:pointer}.profile-stat-link:hover span,.profile-stat-link:hover strong{color:#2563eb}.follow-requests-section{width:100%;margin:4px 0 8px;border-top:1px solid #e2e8f0;padding-top:8px}.pending-req-btn{background:#f1f5f9;color:#64748b;border:1px solid #cbd5e1;border-radius:8px;padding:7px 12px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap}.pending-req-btn:hover{background:#fee2e2;color:#dc2626;border-color:#fca5a5}.report-btn{background:0 0;border:none;color:#ef4444;font-size:12px;cursor:pointer;padding:4px 6px;font-family:inherit;border-radius:6px;transition:color .15s,background .15s}.report-btn:hover{color:#b91c1c;background:#fee2e2}.admin-tabs{display:flex;gap:8px;padding:12px 16px 0}.admin-tab{background:#f1f5f9;border:none;border-radius:8px 8px 0 0;padding:8px 20px;font-size:14px;font-weight:600;color:#64748b;cursor:pointer;font-family:inherit;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.admin-tab.active{color:#2563eb;border-color:#2563eb;background:#eff6ff}.report-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin:10px 16px;padding:14px 16px}.report-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}.report-card-info{font-size:13px;color:#475569;line-height:1.5}.report-card-info strong{color:#0f172a}.report-card-note{font-size:13px;color:#64748b;font-style:italic;margin:6px 0 10px}.report-card-reason{display:inline-block;background:#fff7ed;color:#c2410c;border:1px solid #fed7aa;border-radius:20px;padding:2px 10px;font-size:12px;font-weight:600;margin-bottom:10px}.ban-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.ban-btn{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:8px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s}.ban-btn:hover{background:#fee2e2}.ban-btn.permanent{background:#1e293b;color:#f87171;border-color:#ef444433}.ban-btn.permanent:hover{background:#0f172a}.dismiss-btn{background:#f1f5f9;color:#64748b;border:1px solid #e2e8f0;border-radius:8px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s}.dismiss-btn:hover{background:#e2e8f0}.admin-nav-btn{background:#1e293b!important}.profile-social-row{display:flex;flex-wrap:wrap;gap:8px;padding:14px 16px 4px;width:100%;box-sizing:border-box}.profile-social-btn{flex:1 1 auto;min-width:0;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border-radius:10px;border:1px solid #e2e8f0;background:#f8fafc;font-size:12px;font-weight:600;color:#1e293b;cursor:pointer;position:relative;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.profile-social-btn:active{opacity:.75}.bio-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin:14px 0 6px}.bio-bubble{background:#f1f5f9;border-radius:14px 14px 14px 4px;padding:10px 14px;font-size:14px;color:#334155;line-height:1.5;max-width:100%;word-break:break-word;white-space:pre-wrap}.bio-fish-row{display:flex;gap:8px;flex-wrap:wrap}.bio-fish-card{display:flex;flex-direction:column;align-items:center;gap:4px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:8px 12px;min-width:72px;font-size:12px;font-weight:600;color:#334155;text-align:center}.bio-fish-card svg{width:28px;height:28px;color:#3b82f6}.bio-lure-row{display:flex;gap:6px;flex-wrap:wrap}.bio-lure-chip{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}#utstyrKnotList .lure-card-body ol li:last-child{border-bottom:none}.comment-btn{background:0 0;border:none;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:8px;color:inherit}.comment-btn:hover{background:rgba(0,0,0,.06)}.comment-section{border-top:1px solid rgba(0,0,0,.07);margin-top:10px;padding-top:12px}.comment-list{margin-bottom:10px}.comment-input-row{display:flex;gap:8px;align-items:center}.comment-input{flex:1;border:1px solid #ddd;border-radius:20px;padding:8px 14px;font-size:14px;outline:0;background:var(--card-bg,#fff);color:inherit}.comment-input:focus{border-color:#4a90d9}.comment-send-btn{background:#4a90d9;color:#fff;border:none;border-radius:50%;width:34px;height:34px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.post-photo,.profile-thumb{cursor:zoom-in}:root{--safe-top:env(safe-area-inset-top, 0px);--safe-right:env(safe-area-inset-right, 0px);--safe-bottom:env(safe-area-inset-bottom, 0px);--safe-left:env(safe-area-inset-left, 0px);--card-bg:#ffffff;--border:#e2e8f0;--text:#1e293b;--bg:#f8fafc}html.dark{color-scheme:dark;--card-bg:#161b22;--border:#30363d;--text:#e6edf3;--bg:#0d1117}html.dark,html.dark body{background:#0d1117;color:#e6edf3}html.dark .panel{background:#161b22;border-color:#30363d;color:#e6edf3}html.dark .page{background:#0d1117}html.dark .enc-card,html.dark .feed-card,html.dark .fish-card,html.dark .lure-card,html.dark .post-card{background:#161b22;border-color:#30363d;color:#e6edf3}html.dark nav{background:0 0;border-top:none}html.dark .nav-btn{background:rgba(255,255,255,.08);color:rgba(255,255,255,.75);border-color:rgba(255,255,255,.12)}html.dark .nav-btn.active{background:#38bdf8;color:#fff;border-color:transparent}html.dark .controls{background:#161b22;border-color:#30363d}html.dark .filter-group{background:#21262d;border-color:#30363d}html.dark input,html.dark select,html.dark textarea{background:#21262d;color:#e6edf3;border-color:#30363d}html.dark input::placeholder,html.dark textarea::placeholder{color:#6e7681}html.dark .secondary-btn{background:#21262d;color:#e6edf3;border-color:#30363d}html.dark .secondary-btn:hover{background:#30363d}html.dark .modal-overlay{background:rgba(0,0,0,.75)}html.dark .modal-box{background:#161b22;color:#e6edf3;border:1px solid #30363d}html.dark .terms-scroll{color:#c9d1d9;border-color:#30363d;background:#0d1117}html.dark .modal-box input,html.dark .modal-box select,html.dark .modal-box textarea{background:#21262d;color:#e6edf3;border-color:#30363d}html.dark .modal-box input::placeholder,html.dark .modal-box textarea::placeholder{color:#6e7681}html.dark .modal-box .form-label,html.dark .modal-box label{color:#c9d1d9}html.dark .post-body,html.dark .post-header{border-color:#30363d}html.dark .feed-chip,html.dark .post-chip{background:#21262d;color:#c9d1d9}html.dark .post-avatar,html.dark .user-avatar{background:#1f6feb}html.dark .comment-btn,html.dark .like-btn,html.dark .post-share-btn{color:#e6edf3}html.dark .post-card{background:#161b22;border-bottom-color:#30363d;box-shadow:none}html.dark .post-author,html.dark .post-fish{color:#e6edf3}html.dark .post-body{background:#161b22}html.dark .post-diary{color:#c9d1d9}html.dark .post-diary strong{color:#fff}html.dark .feed-card{background:#161b22;box-shadow:none}html.dark .feed-info{background:#161b22}html.dark .feed-date,html.dark .feed-fish{color:#c9d1d9}html.dark #feedContainer,html.dark .feed-container{background:#0d1117}html.dark .profile-stats{border-color:#30363d}html.dark .bio-bubble{background:#21262d;color:#c9d1d9}html.dark .comment-section{border-top-color:#30363d}html.dark .comment-input{background:#21262d;color:#e6edf3;border-color:#30363d}#postDetailModal,#userProfileModal{background:#fff}html.dark #postDetailModal,html.dark #userProfileModal{background:#0d1117;color:#e6edf3}html.dark #postDetailModal .panel,html.dark #userProfileModal .panel{background:#161b22}html.dark #postDetailModal .panel button,html.dark #postDetailModal .post-author,html.dark #postDetailModal .post-diary,html.dark #postDetailModal .post-fish,html.dark #userProfileModal .panel button,html.dark #userProfileModal .post-author,html.dark #userProfileModal .post-fish{color:#e6edf3}html.dark #postDetailModal .post-diary strong,html.dark #userProfileModal .post-diary strong{color:#c9d1d9}html.dark #postDetailModal .post-time,html.dark #userProfileModal .post-time{color:#8b949e}html.dark #postDetailModal .post-chip,html.dark #userProfileModal .post-chip{background:#21262d;color:#c9d1d9}html.dark #postDetailModal .post-header,html.dark #userProfileModal .post-header{border-color:#30363d}html.dark #postDetailModal .comment-section,html.dark #userProfileModal .comment-section{border-top-color:#30363d;background:0 0}html.dark #postDetailModal .comment-input,html.dark #userProfileModal .comment-input{background:#161b22;color:#e6edf3;border-color:#30363d}html.dark .feed-date,html.dark .muted,html.dark .post-time{color:#8b949e}html.dark .comment-username{color:#e6edf3}html.dark .comment-text{color:#c9d1d9}html.dark .fb-archive-btn{background:#161b22;border-color:#30363d;color:#e6edf3}html.dark .fb-archive-header{border-color:#30363d;color:#e6edf3}html.dark .fb-archive-title,html.dark .fb-back-btn{color:#e6edf3}html.dark .fish-filter-chip{background:#1c2128;border-color:#444c56;color:#e6edf3}html.dark .fish-filter-chip:hover{background:#2d333b;border-color:#768390;color:#fff}html.dark .fish-filter-chip.active{background:#e6edf3;border-color:transparent;color:#0d1117}html.dark .enc-filter{background:#21262d;color:#c9d1d9;border-color:#30363d}html.dark .enc-filter.on{background:#1f6feb;color:#fff;border-color:transparent}html.dark .fish-filter-scroll{background:#0d1117;border-bottom-color:#30363d}html.dark .enc-name{color:#e6edf3}html.dark .enc-stat{background:#f8fafc;border-color:#e2e8f0}html.dark .enc-stat-v{color:#1e293b}html.dark .enc-stat-l{color:#64748b}html.dark .enc-card-body,html.dark .enc-card-body li,html.dark .enc-card-body p,html.dark .enc-card-body span{color:#c9d1d9}html.dark .lure-card h3{color:#e6edf3}html.dark .lure-card-body,html.dark .lure-card-content{color:#c9d1d9}html.dark .lure-funfact{background:#1f2d3d;color:#93c5fd;border-left-color:#3b82f6}html.dark .b-fresh{background:#0c2840;color:#7dd3fc}html.dark .b-sea{background:#0c1f40;color:#93c5fd}html.dark .b-river,html.dark .diff-lett{background:#0c2818;color:#86efac}html.dark .diff-middels{background:#2d1f00;color:#fde68a}html.dark .diff-krevende{background:#2d0c0c;color:#fca5a5}html.dark .small-note{color:#7dd3fc}html.dark .enc-card-body .enc-log-btn{background:#1f2d3d;color:#7dd3fc;border-color:#2563eb}html.dark .stat-card{background:#0d1117;box-shadow:none;border-top-color:#38bdf8}html.dark .stat-card .stat-number{color:#e6edf3}html.dark .stat-card .stat-label{color:#8b949e}html.dark .stat-card h3{color:#c9d1d9}html.dark .top-name{color:#1a2332}html.dark .top-meta{color:#475569}html.dark .top-value{color:#1a2332}html.dark .chart-count,html.dark .chart-label{color:#e6edf3}html.dark .chart-bar-bg{background:#1e293b}html.dark .user-card{background:#0d1117;border-bottom-color:#21262d}html.dark .user-name{color:#e6edf3}html.dark .user-sub{color:#8b949e}html.dark .conv-item{background:#0d1117;border-bottom-color:#21262d}html.dark .conv-item:hover{background:#161b22}html.dark .conv-item-name{color:#e6edf3}html.dark .conv-item-last,html.dark .conv-item-time{color:#8b949e}html.dark .profile-header{background:#0d1117;border-bottom-color:#21262d}html.dark .profile-name{color:#fff}html.dark .profile-stat strong{color:#e6edf3}html.dark .bio-section-label,html.dark .profile-stat span{color:#8b949e}html.dark .bio-fish-card,html.dark .profile-social-btn{background:#161b22;border-color:#30363d;color:#e6edf3}html.dark .bio-fish-card svg{color:#58a6ff}html.dark .bio-lure-chip{background:#0c1f40;border-color:#1f6feb;color:#93c5fd}html.dark .report-btn{color:#ef4444}html.dark .report-btn:hover{color:#fca5a5;background:#450a0a}.admin-badge{display:inline-block;background:0 0;color:#94a3b8;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:lowercase;padding:0}.fiskeboks-locked{flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 24px;gap:12px}.fiskeboks-locked h3{margin:0;font-size:18px}.fiskeboks-locked p{margin:0;color:#94a3b8;font-size:14px;max-width:280px}.lure-tab{flex:1;padding:6px 12px;border:1px solid var(--border);border-radius:8px;background:0 0;color:#94a3b8;font-size:13px;cursor:pointer}.lure-tab.active{background:#1d4ed8;border-color:#1d4ed8;color:#fff;font-weight:600}.cancel-btn{padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:0 0;color:#94a3b8;font-size:15px;cursor:pointer}.premium-stats-header{display:flex;align-items:center;gap:8px;padding:10px 16px;margin:16px 0 4px;background:linear-gradient(135deg,#1a1f2e,#0d1117);border:1px solid #f4a261;border-radius:10px;font-size:13px;font-weight:700;color:#f4a261;letter-spacing:.04em;text-transform:uppercase}.premium-stats-locked{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 24px;margin:16px;border:1px dashed #30363d;border-radius:14px}.fav-spot-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.fav-spot-chip{padding:4px 10px;border-radius:20px;border:1px solid #1f6feb;background:#0c1f40;color:#93c5fd;font-size:12px;cursor:pointer}.fav-spot-chip:active{background:#1d4ed8;color:#fff}.notif-item{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer}.notif-item:hover{background:rgba(79,195,247,.05)}.notif-unread{background:rgba(79,195,247,.06)}.notif-avatar{flex-shrink:0}#notifPanel,#settingsPanel{color:var(--text);top:calc(56px + var(--safe-top))!important;right:var(--safe-right)!important;max-width:calc(100vw - var(--safe-left) - var(--safe-right))}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.settings-row-link{padding:8px 12px}.settings-label{display:flex;align-items:center;gap:8px;font-size:14px}.settings-select{background:var(--card-bg);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:4px 8px;font-size:13px;cursor:pointer}.settings-link-btn{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:0 0;color:var(--text);font-size:14px;font-weight:600;cursor:pointer}.settings-link-btn:hover{background:rgba(79,195,247,.08)}.settings-toggle{position:relative;display:inline-block;width:40px;height:22px}.settings-toggle input{opacity:0;width:0;height:0}.toggle-slider{inset:0;position:absolute;inset:0;background:#30363d;border-radius:22px;cursor:pointer;transition:.2s}.toggle-slider::before{content:'';top:3px;box-shadow:0 1px 3px rgba(0,0,0,.2);content:'';position:absolute;width:16px;height:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}.settings-toggle input:checked+.toggle-slider{background:#4fc3f7}.settings-toggle input:checked+.toggle-slider::before{transform:translateX(18px)}.premium-hero-card{margin-bottom:16px;padding:22px;border-radius:18px;background:linear-gradient(135deg,#0f172a,#1e3a5f);color:#fff;box-shadow:0 12px 30px rgba(15,23,42,.18)}.premium-hero-card h2{margin:0 0 10px;font-size:26px;letter-spacing:-.02em}.premium-badge-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:12px}.premium-badge,.premium-status-pill{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700}.premium-badge{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18)}.premium-status-pill{background:rgba(56,189,248,.18);border:1px solid rgba(125,211,252,.32);color:#e0f2fe}.premium-status-pill.active{background:rgba(74,222,128,.18);border-color:rgba(134,239,172,.35);color:#dcfce7}.premium-copy,.premium-note{margin:0 0 10px;color:rgba(255,255,255,.9);line-height:1.6}.premium-cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.premium-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.premium-feature-card{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;padding:16px}.premium-feature-card h3{margin:0 0 8px;font-size:16px;color:var(--text)}.premium-feature-card p{margin:0;color:#64748b;line-height:1.55}.premium-legal-card{margin-top:14px}.premium-plan-card{border:2px solid #e2e8f0;border-radius:12px;padding:14px 16px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:border-color .15s,background .15s}.premium-plan-card.active{border-color:#1d4ed8;background:#eff6ff}.plan-name{font-weight:600;font-size:15px;display:flex;align-items:center;gap:8px}.plan-badge{background:#22c55e;color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:20px}.plan-price{font-weight:700;font-size:18px;color:#1d4ed8}.plan-price span{font-size:13px;font-weight:400;color:#64748b}html.dark .premium-plan-card{border-color:#30363d}html.dark .premium-plan-card.active{border-color:#4fc3f7;background:#1a2332}.premium-legal-list{margin:10px 0 0;padding-left:18px;line-height:1.6}.feedback-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px;padding:12px 14px;border-radius:14px;background:var(--card-bg);border:1px solid var(--border)}.feedback-intro{display:flex;flex-direction:column;gap:4px}.feedback-intro span{color:#64748b;font-size:14px;line-height:1.5}.feedback-toolbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.feedback-sort-pill{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#e0f2fe;color:#0369a1;font-size:12px;font-weight:700}.feedback-list{display:flex;flex-direction:column;gap:12px}.feedback-card{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;padding:16px;box-shadow:0 6px 18px rgba(15,23,42,.06)}.feedback-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.feedback-badges{display:flex;flex-wrap:wrap;gap:6px}.feedback-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#eef6ff;color:#1d4ed8;font-size:12px;font-weight:700}.feedback-badge.soft{background:#f1f5f9;color:#475569}.feedback-card h3{margin:8px 0 6px;font-size:17px}.feedback-meta{color:#64748b;font-size:13px}.feedback-body{margin:10px 0 14px;line-height:1.6;color:var(--text)}.feedback-actions{display:flex;justify-content:flex-end}.feedback-like-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:0 0;color:var(--text);cursor:pointer;font-size:13px;font-weight:700}.feedback-like-btn.liked{border-color:rgba(249,115,22,.4);background:rgba(249,115,22,.08);color:#c2410c}.feedback-empty{padding:30px 18px;text-align:center;border-radius:14px;border:1px dashed var(--border);background:var(--card-bg);color:#64748b}html.dark .feedback-empty,html.dark .feedback-intro span,html.dark .feedback-meta,html.dark .premium-feature-card p{color:#8b949e}html.dark .feedback-sort-pill{background:#0c2840;color:#7dd3fc}html.dark .feedback-badge{background:#0c1f40;color:#93c5fd}html.dark .feedback-badge.soft{background:#21262d;color:#c9d1d9}html.dark .feedback-like-btn.liked{background:rgba(249,115,22,.16);color:#fdba74;border-color:rgba(249,115,22,.45)}.map-source-filter{display:flex;gap:6px;padding:4px 12px 0}.map-source-btn{flex:1;padding:5px 0;border-radius:20px;border:1px solid var(--border);background:0 0;color:#94a3b8;font-size:12px;cursor:pointer;font-weight:500}.map-source-btn.active{background:#1d4ed8;border-color:#1d4ed8;color:#fff;font-weight:600}.map-date-filter{display:flex;gap:6px;padding:6px 12px;overflow-x:auto;scrollbar-width:none}.map-date-btn{padding:4px 12px;border-radius:20px;border:1px solid var(--border);background:0 0;color:#94a3b8;font-size:12px;cursor:pointer;white-space:nowrap;flex-shrink:0}.map-date-btn.active{background:#1d4ed8;border-color:#1d4ed8;color:#fff;font-weight:600}.location-dot{width:16px;height:16px;border-radius:50%;background:#3b82f6;border:2.5px solid #fff;box-shadow:0 0 0 4px rgba(59,130,246,.25);animation:2.4s ease-in-out infinite locationPulse}@keyframes locationPulse{0%,100%{box-shadow:0 0 0 4px rgba(59,130,246,.25)}50%{box-shadow:0 0 0 9px rgba(59,130,246,.08)}}.my-location-btn{flex-shrink:0;width:36px;height:36px;border-radius:50%;border:1.5px solid #3b82f6;background:0 0;color:#3b82f6;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.my-location-btn:active{background:#3b82f6;color:#fff}.fiskekort-toggle-btn{width:100%;padding:7px 14px;border-radius:20px;border:1.5px solid #f97316;background:0 0;color:#f97316;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:background .15s,color .15s}.fiskekort-toggle-btn.active{background:#f97316;color:#fff}.share-catch-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:8px;border:1px solid #30363d;background:0 0;color:#4fc3f7;font-size:13px;cursor:pointer}.share-catch-btn:hover{background:rgba(79,195,247,.08)}.chat-img-btn{width:40px;height:40px;background:0 0;border:none;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;padding:0;flex-shrink:0}.chat-img-btn:active{background:#f1f5f9}.dark .chat-img-btn{color:#94a3b8}.dark .chat-img-btn:active{background:#1e293b}.chat-bubble img.chat-img-msg{max-width:200px;max-height:200px;border-radius:12px;display:block;object-fit:cover;cursor:pointer}.msg-thumbup-btn{background:0 0;border:none;cursor:pointer;opacity:.35;padding:2px 4px;line-height:1;display:flex;align-items:center;gap:3px;transition:opacity .15s,transform .1s}.msg-thumbup-btn.active{opacity:1}.msg-thumbup-btn:active{transform:scale(1.3)}.lure-stats-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #e2e8f0;font-size:14px}.dark .lure-stats-row{border-bottom-color:#334155}.lure-stats-row:last-child{border-bottom:none}.lure-stats-val{font-weight:700;color:#0ea5e9}#bottomTabBar{position:fixed;bottom:0;left:0;right:0;height:calc(56px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0);background:#0d1b2e;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:stretch;z-index:1100;box-shadow:0 -4px 20px rgba(0,0,0,.3)}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:0 0;border:none;color:rgba(255,255,255,.45);font-size:10px;font-weight:500;cursor:pointer;transition:color .15s;position:relative;padding:0}.tab-btn.active{color:#38bdf8}.tab-btn svg{transition:stroke .15s}.tab-badge{position:absolute;top:6px;right:calc(50% - 18px);background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;padding:0 3px;line-height:16px;text-align:center}.page{padding-bottom:calc(64px + env(safe-area-inset-bottom,0px))}html.dark #bottomTabBar{background:#0d1117;border-top-color:rgba(255,255,255,.06)}