*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d1117;--surface: #161b22;--surface-2: #21262d;--border: #30363d;--accent: #f0a500;--accent-hover: #d4920a;--bubble-user: #f0a500;--bubble-user-txt: #0d1117;--bubble-ai: #21262d;--bubble-ai-txt: #ffffff;--text: #ffffff;--text-muted: #8b949e;--error-bg: #2d1515;--error-border: #5a2a2a;--error-txt: #f87171;--success: #3fb950;--radius-bubble: 18px;--radius-sm: 6px}html,body,#root{height:100%;overscroll-behavior:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.app{height:var(--app-height, 100dvh);height:var(--app-height, 100svh);display:flex;flex-direction:column;max-width:640px;margin:0 auto;overflow:hidden}.chat-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.chat-title{display:flex;align-items:center;gap:10px}.chat-logo{font-size:24px;line-height:1}.chat-name{font-size:16px;font-weight:700;color:var(--accent);line-height:1.2}.chat-sub{font-size:11px;color:var(--text-muted);margin-top:1px}.header-right{display:flex;align-items:center;gap:10px}.header-auth{display:flex;align-items:center;gap:8px}.pro-badge{font-size:10px;font-weight:800;letter-spacing:.05em;color:var(--bg);background:var(--accent);border-radius:4px;padding:2px 6px}.pro-badge--max{background:var(--success)}.sign-in-btn{font-size:12px;font-weight:600;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:5px 10px;cursor:pointer;transition:color .15s,border-color .15s}.sign-in-btn:hover{color:var(--text);border-color:var(--text-muted)}.query-badge{font-size:11px;font-weight:600;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:20px;padding:4px 10px;white-space:nowrap;transition:border-color .15s,color .15s;-webkit-user-select:none;user-select:none;max-width:160px;overflow:hidden;text-overflow:ellipsis}.query-badge--warn{border-color:var(--accent);color:var(--accent)}button.query-badge{cursor:pointer;font-family:inherit}.success-banner{flex-shrink:0;background:#0d2a0d;border-bottom:1px solid var(--success);color:var(--success);font-size:14px;font-weight:600;text-align:center;padding:10px 16px}.chat-messages{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px 14px 8px;display:flex;flex-direction:column;gap:12px;scroll-padding-bottom:16px}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;color:var(--text-muted);padding:40px 24px}.chat-empty-icon{font-size:52px;line-height:1}.chat-empty p{font-size:17px;line-height:1.6}.chat-empty-sub{font-size:14px!important;color:#6e7681}.message-row{display:flex;align-items:flex-end;gap:8px}.message-row--user{flex-direction:row-reverse}.message-avatar{flex-shrink:0;font-size:16px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--border);border-radius:50%}.message-bubble{max-width:80%;min-width:0;border-radius:var(--radius-bubble);padding:11px 15px;line-height:1.65;word-break:break-word;overflow-wrap:break-word}.message-bubble--user{background:var(--bubble-user);color:var(--bubble-user-txt);border-bottom-right-radius:var(--radius-sm);font-size:15px;font-weight:500}.message-bubble--assistant{background:var(--bubble-ai);color:var(--bubble-ai-txt);border-bottom-left-radius:var(--radius-sm);font-size:15px}.message-text{white-space:pre-wrap;word-break:break-word;overflow-wrap:break-word}.message-cost{margin-top:7px;padding-top:5px;border-top:1px solid var(--border);font-size:10px;color:var(--text-muted);font-variant-numeric:tabular-nums}.data-source-badge{margin-top:8px;padding-top:6px;border-top:1px solid var(--border);font-size:11px;font-weight:500;display:flex;align-items:center;gap:5px}.data-source-badge--verified{color:#3fb950}.data-source-badge--verified:before{content:"✓";font-weight:700}.data-source-badge--webSearch{color:var(--accent)}.data-source-badge--webSearch:before{content:"🔍";margin-right:2px}.data-source-badge--fuzzy{color:var(--accent)}.data-source-badge--fuzzy:before{content:"?";font-weight:700;margin-right:2px}.data-source-badge--ambiguous{color:var(--text-muted)}.data-source-badge--ambiguous:before{content:"⚠";margin-right:2px}.data-source-badge--general{color:var(--text-muted)}.data-source-badge--general:before{content:"💡";margin-right:2px}.typing-indicator{display:flex;gap:5px;align-items:center;padding:4px 2px}.typing-indicator span{display:block;width:7px;height:7px;border-radius:50%;background:var(--text-muted);animation:bounce 1.2s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}.loading-status{font-size:14px;color:var(--text-muted);margin:0 0 8px;font-style:italic}.empty-state{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px 16px;text-align:center}.empty-state-title{font-size:16px;font-weight:600;color:var(--text);margin:0}.empty-state-cards{display:grid;grid-template-columns:1fr;gap:10px;width:100%;max-width:100%}.empty-state-card{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:12px 14px;font-size:14px;color:var(--text);cursor:pointer;transition:all .2s;text-align:left;font-family:inherit}.empty-state-card:hover{background:var(--surface);border-color:var(--accent);color:var(--accent)}.upgrade-nudge{margin-top:8px;padding:8px 10px;background:#f0a50014;border:1px solid rgba(240,165,0,.3);border-radius:8px;display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12px}.upgrade-nudge-text{color:var(--text-muted);flex:1}.upgrade-nudge-btn{font-size:11px;font-weight:600;color:var(--bg);background:var(--accent);border:none;border-radius:6px;padding:4px 10px;cursor:pointer;white-space:nowrap;transition:background .15s;flex-shrink:0}.upgrade-nudge-btn:hover{background:var(--accent-hover)}.suggestions-row{display:flex;flex-direction:column;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.suggestion-chip{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:13px;color:var(--text);cursor:pointer;transition:all .2s;text-align:left;font-family:inherit}.suggestion-chip:hover{background:var(--surface);border-color:var(--accent);color:var(--accent)}.chat-error{align-self:center;font-size:13px;color:var(--error-txt);background:var(--error-bg);border:1px solid var(--error-border);border-radius:8px;padding:10px 14px;max-width:90%;display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center}.chat-error-text{flex:1 1 auto;min-width:0}.chat-error-retry{flex:0 0 auto;background:var(--accent, #f0a500);color:#1a1a1a;border:none;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer}.chat-error-retry:hover{filter:brightness(1.05)}.chat-error-dismiss{flex:0 0 auto;background:transparent;border:none;color:var(--error-txt);cursor:pointer;font-size:14px;padding:2px 6px;opacity:.7}.chat-error-dismiss:hover{opacity:1}.clear-history-btn{align-self:center;background:none;border:none;color:#444d56;font-size:12px;cursor:pointer;padding:4px 8px;border-radius:4px;margin-top:4px;transition:color .15s}.clear-history-btn:hover{color:var(--text-muted)}.chat-input-area{flex-shrink:0;background:var(--surface);border-top:1px solid var(--border);padding:10px 14px calc(12px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:6px}.quick-actions-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding-bottom:2px}.whats-biting-btn,.saved-btn{font-size:12px;font-weight:600;color:var(--bg);background:var(--accent);border:none;border-radius:16px;padding:6px 12px;cursor:pointer;white-space:nowrap;transition:background .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.whats-biting-btn:hover,.saved-btn:hover{background:var(--accent-hover)}.species-buttons{display:flex;gap:4px;flex-wrap:wrap}.species-btn{font-size:11px;font-weight:500;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:14px;padding:4px 10px;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s,background .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.species-btn:hover{color:var(--accent);border-color:var(--accent);background:#f0a5000f}.species-btn--active{color:var(--accent);background:#f0a5001a;border-color:var(--accent)}.chat-input-form{display:flex;align-items:flex-end;gap:8px}.chat-input{flex:1;min-width:0;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;color:var(--text);font-size:16px;font-family:inherit;line-height:1.5;padding:10px 14px;resize:none;outline:none;min-height:44px;max-height:120px;overflow-y:auto;transition:border-color .15s}.chat-input::placeholder{color:var(--text-muted)}.chat-input:focus{border-color:var(--accent)}.chat-input:disabled{opacity:.5}.chat-send-btn{flex-shrink:0;width:48px;height:48px;background:var(--accent);color:var(--bg);border:none;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,opacity .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover)}.chat-send-btn:disabled{opacity:.35;cursor:not-allowed}.send-spinner{width:18px;height:18px;border:2.5px solid rgba(0,0,0,.3);border-top-color:#000;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.input-hint{font-size:11px;color:#444d56;text-align:center}.input-hint-link{color:var(--accent);cursor:pointer;text-decoration:underline;font-size:11px}.paywall-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0 12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.paywall-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:20px 20px 0 0;padding:24px 20px calc(24px + env(safe-area-inset-bottom,0px));width:100%;max-width:480px;text-align:center}.paywall-close{position:absolute;top:14px;right:14px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;transition:color .15s}.paywall-close:hover{color:var(--text)}.paywall-icon{font-size:40px;margin-bottom:10px}.paywall-card h2{font-size:20px;font-weight:700;margin-bottom:8px;color:var(--text)}.paywall-card>p{color:var(--text-muted);font-size:14px;margin-bottom:14px;line-height:1.6}.paywall-price{font-size:32px;font-weight:800;color:var(--accent);margin-bottom:4px}.paywall-price span{font-size:15px;font-weight:400;color:var(--text-muted)}.paywall-features{list-style:none;text-align:left;margin:12px 0 18px;display:flex;flex-direction:column;gap:8px}.paywall-features li{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-muted)}.paywall-features li:before{content:"✓";color:var(--success);font-weight:700;flex-shrink:0}.paywall-btn{display:block;width:100%;padding:14px;background:var(--accent);color:var(--bg);font-size:15px;font-weight:700;border:none;border-radius:10px;cursor:pointer;margin-bottom:8px;transition:background .15s;touch-action:manipulation}.paywall-btn:hover:not(:disabled){background:var(--accent-hover)}.paywall-btn:disabled{opacity:.5;cursor:not-allowed}.paywall-btn--signin{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.paywall-btn--signin:hover{background:var(--border)}.paywall-or{color:var(--text-muted);font-size:12px;margin:4px 0}.paywall-link{display:block;width:100%;background:none;border:none;color:var(--text-muted);font-size:13px;cursor:pointer;padding:6px 10px 10px;text-decoration:underline;text-align:center;transition:color .15s}.paywall-link:hover:not(:disabled){color:var(--text)}.paywall-link:disabled{opacity:.5;cursor:not-allowed;text-decoration:none}.paywall-dismiss{display:block;width:100%;background:none;border:none;color:#444d56;font-size:13px;cursor:pointer;padding:10px;transition:color .15s}.paywall-dismiss:hover{color:var(--text-muted)}.signup-prompt{align-self:center;background:var(--surface-2);border:1px solid var(--border);border-radius:14px;padding:18px 20px;text-align:center;max-width:340px;width:100%}.signup-prompt-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px}.signup-prompt-sub{font-size:12px;color:var(--text-muted);margin-bottom:14px;line-height:1.6}.signup-prompt-btn{display:block;width:100%;padding:12px;background:var(--accent);color:var(--bg);font-size:14px;font-weight:700;border:none;border-radius:8px;cursor:pointer;transition:background .15s;touch-action:manipulation}.signup-prompt-btn:hover{background:var(--accent-hover)}.sign-out-btn{font-size:11px;font-weight:500;color:#555d68;background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:4px;transition:color .15s;white-space:nowrap}.sign-out-btn:hover{color:var(--text-muted)}.slow-hint{font-size:12px;color:var(--text-muted);margin-top:8px;font-style:italic}.info-banner{flex-shrink:0;background:#0d1f35;border-bottom:1px solid #1e6fb5;color:#58a6ff;font-size:13px;font-weight:500;text-align:center;padding:9px 16px}.status-error-banner{flex-shrink:0;background:var(--error-bg);border-bottom:1px solid var(--error-border);color:var(--error-txt);font-size:12px;text-align:center;padding:7px 16px}.trial-banner{flex-shrink:0;background:linear-gradient(90deg,#f0a50026,#f0a5000d);border-bottom:1px solid rgba(240,165,0,.3);color:var(--text);font-size:12px;text-align:center;padding:8px 16px;display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.trial-expired-banner{flex-shrink:0;background:linear-gradient(90deg,#ef44442e,#ef444414);border-bottom:1px solid rgba(239,68,68,.35);color:var(--text);font-size:12px;text-align:center;padding:10px 16px;display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.trial-banner--urgent{background:linear-gradient(90deg,#f59e0b47,#f59e0b14);border-bottom-color:#f59e0b8c;font-weight:600}.trial-banner--critical{background:linear-gradient(90deg,#ef444452,#ef444414);border-bottom-color:#ef444499;color:#fff;font-weight:700;animation:trial-pulse 2.4s ease-in-out infinite}@keyframes trial-pulse{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 14px 2px #ef444473}}.trial-upgrade-btn{background:var(--accent);color:#000;border:none;border-radius:6px;padding:4px 12px;font-size:11px;font-weight:700;cursor:pointer;white-space:nowrap}.trial-banner--critical .trial-upgrade-btn,.trial-expired-banner .trial-upgrade-btn{padding:6px 14px;font-size:12px}.trial-upgrade-btn:hover{opacity:.85}.trial-upgrade-btn:disabled{opacity:.6;cursor:progress}.trial-summary-card{max-width:460px}.trial-summary-sub{margin:6px 0 14px;opacity:.85;font-size:.92rem}.trial-summary-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:12px 0 14px}.trial-summary-stat{background:#f0a50014;border:1px solid rgba(240,165,0,.25);border-radius:10px;padding:12px 6px;text-align:center}.trial-summary-stat-num{font-size:1.65rem;font-weight:800;color:var(--accent);line-height:1}.trial-summary-stat-label{font-size:.72rem;margin-top:4px;opacity:.85}.trial-summary-lakes{font-size:.85rem;opacity:.8;margin:0 0 12px;text-align:center;font-style:italic}.trial-summary-loss{background:#ef444412;border-left:3px solid rgba(239,68,68,.55);padding:10px 12px;border-radius:6px;font-size:.85rem;margin:10px 0 12px}.trial-summary-loss strong{display:block;margin-bottom:4px;color:#f87171}.trial-summary-loss ul{margin:0;padding-left:18px}.trial-summary-loss li{margin:2px 0}.trial-summary-social{font-size:.82rem;opacity:.85;text-align:center;margin:6px 0 12px;font-style:italic}.paywall-social-proof{font-size:.82rem;opacity:.85;text-align:center;margin:10px 0;font-style:italic}.trial-summary-cta{font-size:1rem}.engagement-toast{position:fixed;bottom:96px;left:50%;transform:translate(-50%);background:#0d1117f5;border:1px solid rgba(240,165,0,.45);border-radius:10px;padding:10px 14px;display:flex;align-items:center;gap:10px;z-index:1500;box-shadow:0 10px 30px #00000073;max-width:calc(100% - 32px);animation:toast-in .24s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}.engagement-toast-text{font-size:.85rem;color:var(--text);flex:1;min-width:0}.engagement-toast-cta{background:var(--accent);color:#000;border:none;border-radius:6px;padding:6px 12px;font-size:.78rem;font-weight:700;cursor:pointer;white-space:nowrap}.engagement-toast-cta:hover{opacity:.85}.engagement-toast-cta:disabled{opacity:.6;cursor:progress}.engagement-toast-close{background:transparent;border:none;color:var(--text);opacity:.6;cursor:pointer;font-size:.95rem;padding:4px 6px}.engagement-toast-close:hover{opacity:1}@media (max-width: 480px){.trial-summary-stats{grid-template-columns:repeat(3,1fr);gap:6px}.trial-summary-stat-num{font-size:1.35rem}.engagement-toast{bottom:110px;flex-wrap:wrap}.engagement-toast-text{width:100%}}.hint-warn{color:var(--accent);font-weight:600}.upgrade-inline{display:flex;gap:16px;align-items:flex-start;background:linear-gradient(135deg,#1a1f0a,#1a1400);border:2px solid #f0a500;border-radius:16px;padding:20px 20px 20px 16px;margin:8px 0;animation:upgrade-pop .3s ease-out}@keyframes upgrade-pop{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.upgrade-inline-icon{font-size:28px;line-height:1;flex-shrink:0;margin-top:2px}.upgrade-inline-body{flex:1;min-width:0}.upgrade-inline-title{font-size:15px;font-weight:700;color:#fff;margin-bottom:4px}.upgrade-inline-sub{font-size:13px;color:#8b949e;margin-bottom:14px;line-height:1.4}.upgrade-inline-btns{display:flex;flex-direction:column;gap:8px}.upgrade-inline-btn{display:block;width:100%;padding:12px 16px;border-radius:10px;border:none;cursor:pointer;font-size:14px;font-weight:700;text-align:center;transition:background .15s,transform .1s,opacity .15s}.upgrade-inline-btn:active{transform:scale(.98)}.upgrade-inline-btn:disabled{opacity:.6;cursor:not-allowed}.upgrade-inline-btn--primary{background:#f0a500;color:#0d1117;font-size:15px;padding:14px 16px}.upgrade-inline-btn--primary:hover:not(:disabled){background:#d4920a}.upgrade-inline-btn--secondary{background:#f0a5001a;color:#f0a500;border:1px solid rgba(240,165,0,.3)}.upgrade-inline-btn--secondary:hover:not(:disabled){background:#f0a5002e}.msg-link{color:var(--accent);text-decoration:underline;word-break:break-all}.msg-link:hover{color:var(--accent-hover)}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-header,.skeleton-bubble,.skeleton-footer{background:linear-gradient(90deg,var(--surface-2) 25%,#2d333a 50%,var(--surface-2) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite linear;border-radius:var(--radius-sm)}.skeleton-header{width:80px;height:32px;border-radius:16px}.skeleton-bubble{height:60px;border-radius:var(--radius-bubble)}.skeleton-bubble--ai{width:260px;max-width:75%}.skeleton-bubble--prompt{width:160px;max-width:55%;margin-left:auto}.skeleton-footer{height:44px;border-radius:22px;width:100%}.wx-sol-strip{flex-shrink:0;display:flex;align-items:center;flex-wrap:wrap;gap:4px 0;padding:5px 14px;background:#0d1117;border-bottom:1px solid #1e2630;font-size:11px;color:#6e7681;overflow-x:auto;white-space:nowrap;scrollbar-width:none}.wx-sol-strip::-webkit-scrollbar{display:none}.wx-item{color:#8b949e}.wx-sep{color:#30363d;margin:0 5px}.seasonal-banner{flex-shrink:0;background:linear-gradient(90deg,#0f1f10,#111b0d);border:1px solid #2a3d1a;border-radius:10px;color:#8cc46e;font-size:12px;font-weight:500;padding:8px 13px;line-height:1.4;margin-bottom:2px}.bite-gauge-row{flex-shrink:0;display:flex;align-items:center;gap:8px;padding:5px 14px;background:#0a0e14;border-bottom:1px solid #1e2630;font-size:11px}.bite-gauge-label{color:#6e7681;font-weight:600;white-space:nowrap;flex-shrink:0}.bite-gauge-track{display:flex;gap:2px;flex:1;max-width:260px}.bite-gauge-seg{flex:1;text-align:center;padding:2px 4px;border-radius:3px;font-size:10px;font-weight:600;color:#444d56;background:var(--surface-2);border:1px solid var(--border);transition:background .2s,color .2s;white-space:nowrap}.bite-gauge-seg--active{border-color:transparent;font-weight:700}.forecast-toggle-btn,.forecast-upgrade-btn{font-size:10px;font-weight:600;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:2px 8px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:color .15s,border-color .15s;-webkit-tap-highlight-color:transparent}.forecast-toggle-btn:hover{color:var(--accent);border-color:var(--accent)}.forecast-upgrade-btn{color:var(--accent);border-color:#f0a50066;background:#f0a5000f}.forecast-upgrade-btn:hover{background:#f0a5001f}.forecast-strip{flex-shrink:0;display:flex;overflow-x:auto;scrollbar-width:none;background:#0a0e14;border-bottom:1px solid #1e2630;padding:6px 10px;gap:4px}.forecast-strip::-webkit-scrollbar{display:none}.forecast-card{flex-shrink:0;min-width:64px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:6px 8px;text-align:center;display:flex;flex-direction:column;gap:2px}.forecast-card-day{font-size:11px;font-weight:700;color:var(--text-muted)}.forecast-card-temp{font-size:12px;font-weight:700;color:var(--text)}.forecast-card-temp span{font-weight:400;color:var(--text-muted)}.forecast-card-cond{font-size:9px;color:#6e7681;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.forecast-card-bite{font-size:10px;font-weight:700;margin-top:1px}.best-day-callout{flex-shrink:0;background:#3fb95014;border:1px solid rgba(63,185,80,.2);border-radius:8px;padding:8px 12px;font-size:12px;font-weight:500;color:#3fb950;text-align:center}.fav-lakes{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding-bottom:2px}.fav-lakes-label{font-size:11px;color:var(--accent);font-weight:600;white-space:nowrap;flex-shrink:0}.fav-chip-subtitle{font-size:10px;color:#8b949e;margin-left:3px;font-weight:400}.fav-chip-wrap{display:inline-flex;align-items:center;background:#f0a50014;border:1px solid rgba(240,165,0,.35);border-radius:20px;overflow:hidden}.fav-lake-chip{font-size:12px;font-weight:500;color:var(--accent);background:none;border:none;padding:4px 8px 4px 10px;cursor:pointer;white-space:nowrap;transition:color .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.fav-lake-chip:hover{color:#fff}.fav-lake-remove{font-size:13px;line-height:1;color:#f0a50080;background:none;border:none;border-left:1px solid rgba(240,165,0,.2);padding:0 7px;height:100%;cursor:pointer;display:flex;align-items:center;transition:color .15s;-webkit-tap-highlight-color:transparent}.fav-lake-remove:hover{color:#f87171}.recent-lakes{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding-bottom:4px}.recent-lakes-label{font-size:11px;color:#444d56;font-weight:600;white-space:nowrap;flex-shrink:0}.recent-chip-wrap{display:inline-flex;align-items:center;gap:0}.recent-lake-chip{font-size:12px;font-weight:500;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:20px 0 0 20px;padding:4px 8px 4px 10px;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s,background .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.recent-lake-chip:hover{color:var(--accent);border-color:var(--accent);background:#f0a5000f}.recent-lake-star{font-size:12px;line-height:1;color:#444d56;background:var(--surface-2);border:1px solid var(--border);border-left:none;border-radius:0 20px 20px 0;padding:4px 8px;cursor:pointer;display:flex;align-items:center;transition:color .15s,border-color .15s,background .15s;-webkit-tap-highlight-color:transparent}.recent-lake-star:hover{color:var(--accent);border-color:var(--accent)}.recent-lake-star--active{color:var(--accent);border-color:#f0a50066;background:#f0a5000f}.save-lake-btn{font-size:11px;font-weight:500;color:#444d56;background:none;border:1px solid #30363d;border-radius:20px;padding:3px 10px;cursor:pointer;transition:color .15s,border-color .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;margin-right:4px}.save-lake-btn:hover{color:var(--accent);border-color:var(--accent)}.save-lake-btn--saved{color:var(--accent);border-color:#f0a50080;background:#f0a5000f}.share-btn{font-size:11px;font-weight:500;color:#444d56;background:none;border:1px solid #30363d;border-radius:20px;padding:3px 10px;cursor:pointer;transition:color .15s,border-color .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.share-btn:hover{color:var(--text-muted);border-color:#555d68}.share-btn--copied{color:var(--success);border-color:var(--success)}.save-strategy-btn{font-size:11px;font-weight:500;color:#444d56;background:none;border:1px solid #30363d;border-radius:20px;padding:3px 10px;cursor:pointer;transition:color .15s,border-color .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.save-strategy-btn:hover{color:#58a6ff;border-color:#58a6ff}.save-pdf-btn{font-size:11px;font-weight:500;color:#444d56;background:none;border:1px solid #30363d;border-radius:20px;padding:3px 10px;cursor:pointer;transition:color .15s,border-color .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;margin-left:6px}.save-pdf-btn:hover{color:var(--text-muted);border-color:#555d68}.guide-btn{font-size:11px;font-weight:500;color:#06c;background:none;border:1px solid #30363d;border-radius:20px;padding:3px 10px;cursor:pointer;transition:color .15s,border-color .15s,background .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;margin-left:6px}.guide-btn:hover{color:#05a;border-color:#06c;background:#0066cc0d}.guide-btn:disabled{color:#666;cursor:not-allowed;border-color:#444}.offline-banner{flex-shrink:0;background:#2a1a00;border-bottom:1px solid #7c4a00;color:#f0a500;font-size:13px;font-weight:600;text-align:center;padding:9px 16px;z-index:9}.print-area{display:none}@media print{body>*:not(#root){display:none!important}.app>*:not(.print-area){display:none!important}.app{display:block!important;height:auto!important;overflow:visible!important}.print-area{display:block!important;font-family:Georgia,Times New Roman,serif;max-width:680px;margin:2rem auto;padding:1rem 2rem;color:#111;background:#fff}.print-header{font-size:1.3rem;font-weight:700;border-bottom:2px solid #111;padding-bottom:.5rem;margin-bottom:1.25rem}.print-body{font-size:1rem;line-height:1.7}.print-footer{margin-top:2rem;padding-top:.5rem;border-top:1px solid #ccc;font-size:.8rem;color:#666}}.new-chat-btn{font-size:11px;font-weight:700;color:var(--bg);background:var(--accent);border:none;border-radius:6px;padding:5px 10px;cursor:pointer;transition:background .15s;white-space:nowrap;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.new-chat-btn:hover{background:var(--accent-hover)}.trips-btn{font-size:11px;font-weight:600;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:5px 10px;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap;-webkit-tap-highlight-color:transparent}.trips-btn:hover{color:var(--accent);border-color:var(--accent)}.fish-id-btn{font-size:11px;font-weight:600;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:5px 10px;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap;text-decoration:none;display:inline-block;-webkit-tap-highlight-color:transparent}.fish-id-btn:hover{color:var(--accent);border-color:var(--accent)}.profile-btn{font-size:11px;font-weight:600;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:5px 10px;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap;-webkit-tap-highlight-color:transparent}.profile-btn:hover{color:var(--accent);border-color:var(--accent)}.chat-counter-row{display:flex;align-items:center;gap:8px;padding-bottom:4px}.chat-counter{font-size:11px;color:#444d56;font-variant-numeric:tabular-nums}.chat-counter--warn{color:var(--accent);font-weight:600}.chat-counter-new{font-size:11px;font-weight:700;color:var(--accent);background:none;border:none;cursor:pointer;padding:0;text-decoration:underline}.chat-limit-warning{align-self:center;font-size:12px;color:var(--accent);background:#f0a5000f;border:1px solid rgba(240,165,0,.25);border-radius:8px;padding:8px 14px;text-align:center;max-width:90%;line-height:1.5}.chat-limit-new-btn{background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer;text-decoration:underline;padding:0;font-weight:600}.prev-context-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#58a6ff0f;border:1px solid rgba(88,166,255,.2);border-radius:10px;padding:8px 12px;font-size:12px;color:#58a6ff;margin-bottom:4px}.prev-context-dismiss{background:none;border:none;color:#58a6ff;cursor:pointer;font-size:13px;padding:0 2px;opacity:.7;flex-shrink:0;transition:opacity .15s}.prev-context-dismiss:hover{opacity:1}.loc-banner{display:flex;align-items:center;flex-wrap:wrap;gap:8px;background:#2ea04314;border:1px solid rgba(46,160,67,.25);border-radius:10px;padding:8px 12px;font-size:12px;color:#3fb950;margin-bottom:4px}.loc-banner-text{flex:1;min-width:160px}.loc-banner-actions{display:flex;gap:6px;flex-shrink:0}.loc-banner-yes{background:#2ea04326;border:1px solid rgba(46,160,67,.4);color:#3fb950;border-radius:6px;padding:3px 10px;font-size:12px;cursor:pointer;transition:background .15s}.loc-banner-yes:hover{background:#2ea04340}.loc-banner-no{background:none;border:1px solid var(--border);color:var(--text-muted);border-radius:6px;padding:3px 10px;font-size:12px;cursor:pointer;transition:color .15s}.loc-banner-no:hover{color:var(--text)}.loc-inline-prompt{padding-bottom:10px}.loc-inline-actions{display:flex;gap:8px;margin-top:10px}.loc-inline-yes{background:#2ea04326;border:1px solid rgba(46,160,67,.4);color:#3fb950;border-radius:8px;padding:6px 14px;font-size:13px;cursor:pointer;transition:background .15s}.loc-inline-yes:hover{background:#2ea04340}.loc-inline-no{background:none;border:1px solid var(--border);color:var(--text-muted);border-radius:8px;padding:6px 14px;font-size:13px;cursor:pointer;transition:color .15s}.loc-inline-no:hover{color:var(--text)}.loc-gate{padding-bottom:12px}.loc-gate-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.loc-gate-yes{background:#2ea04326;border:1px solid rgba(46,160,67,.4);color:#3fb950;border-radius:8px;padding:7px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.loc-gate-yes:hover{background:#2ea04347}.loc-gate-no{background:none;border:1px solid var(--border);color:var(--text-muted);border-radius:8px;padding:7px 16px;font-size:14px;cursor:pointer;transition:color .15s}.loc-gate-no:hover{color:var(--text)}.gear-cards{margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}.gear-cards-label{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#444d56;margin-bottom:8px}.gear-cards-grid{display:flex;flex-direction:column;gap:6px}.gear-card{display:flex;flex-direction:column;gap:2px;background:#0d1117;border:1px solid var(--border);border-radius:8px;padding:9px 12px;text-decoration:none;transition:border-color .15s,background .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.gear-card:hover{border-color:var(--accent);background:#f0a5000a}.gear-card-name{font-size:12px;font-weight:700;color:var(--text)}.gear-card-desc{font-size:11px;color:var(--text-muted);line-height:1.4}.gear-card-shop{font-size:11px;font-weight:700;color:var(--accent);margin-top:3px}.share-img-btn{font-size:11px;font-weight:500;color:#444d56;background:none;border:1px solid #30363d;border-radius:20px;padding:3px 10px;cursor:pointer;transition:color .15s,border-color .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;margin-left:6px}.share-img-btn:hover{color:#58a6ff;border-color:#58a6ff}.msg-actions{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0 12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:20px 20px 0 0;padding:24px 20px calc(24px + env(safe-area-inset-bottom,0px));width:100%;max-width:480px;text-align:center}.modal-icon{font-size:40px;margin-bottom:10px}.modal-card h2{font-size:20px;font-weight:700;margin-bottom:8px;color:var(--text)}.modal-card>p{color:var(--text-muted);font-size:14px;margin-bottom:8px;line-height:1.6}.modal-upgrade-hint{font-size:12px;color:#555d68;margin-top:10px}.modal-upgrade-link{background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer;text-decoration:underline;padding:0}.trips-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.trips-panel{background:var(--surface);border:1px solid var(--border);border-radius:20px 20px 0 0;width:100%;max-width:640px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.trips-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.trips-title{font-size:18px;font-weight:700;color:var(--text)}.trips-close{background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;transition:color .15s}.trips-close:hover{color:var(--text)}.trips-subheader{padding:8px 20px;font-size:11px;color:#444d56;border-bottom:1px solid var(--border);flex-shrink:0}.trips-upgrade-link{background:none;border:none;color:var(--accent);font-size:11px;cursor:pointer;text-decoration:underline;padding:0}.trips-limit-note{color:#555d68}.trips-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 24px;color:var(--text-muted);text-align:center;font-size:14px}.trips-empty-icon{font-size:40px}.trips-list{overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;padding:8px 0 env(safe-area-inset-bottom,0px)}.trip-card{border-bottom:1px solid var(--border)}.trip-card:last-child{border-bottom:none}.trip-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 20px;cursor:pointer;transition:background .1s}.trip-card-header:hover{background:#ffffff08}.trip-card-info{flex:1;min-width:0}.trip-card-lake{font-size:14px;font-weight:700;color:var(--text);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trip-card-date{font-size:11px;color:#555d68;margin-bottom:4px}.trip-card-count{color:#3a4149}.trip-card-summary{font-size:12px;color:var(--text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.trip-card-actions{display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0}.trip-card-chevron{font-size:10px;color:#444d56}.trip-delete-btn{background:none;border:none;font-size:14px;cursor:pointer;opacity:.4;padding:2px;transition:opacity .15s;-webkit-tap-highlight-color:transparent}.trip-delete-btn:hover{opacity:.9}.trip-conversation{background:#0a0e14;border-top:1px solid var(--border);padding:12px 20px;display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto}.trip-msg{display:flex;flex-direction:column;gap:2px}.trip-msg-role{font-size:10px;font-weight:700;color:#444d56;text-transform:uppercase;letter-spacing:.05em}.trip-msg--user .trip-msg-role{color:#f0a50099}.trip-msg--assistant .trip-msg-role{color:#58a6ff99}.trip-msg-text{font-size:12px;color:var(--text-muted);line-height:1.5;white-space:pre-wrap;word-break:break-word}.profile-card{max-height:85vh;overflow-y:auto}.profile-form{display:flex;flex-direction:column;gap:18px;text-align:left;margin:20px 0}.profile-field{display:flex;flex-direction:column;gap:8px}.profile-field label{font-size:13px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.5px}.profile-input{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-size:14px;font-family:inherit;transition:border-color .15s,background .15s}.profile-input:focus{outline:none;border-color:var(--accent);background:#f0a5000d}.profile-input::placeholder{color:var(--text-muted)}.profile-select{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-size:14px;font-family:inherit;cursor:pointer;transition:border-color .15s,background .15s}.profile-select:focus{outline:none;border-color:var(--accent);background:#f0a5000d}.profile-select option{background:var(--surface);color:var(--text)}.profile-chips{display:flex;flex-wrap:wrap;gap:8px}.profile-chip{background:var(--surface-2);border:1.5px solid var(--border);border-radius:20px;padding:8px 14px;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.profile-chip:hover{border-color:var(--accent);color:var(--accent)}.profile-chip.selected{background:#f0a5001f;border-color:var(--accent);color:var(--accent);font-weight:600}.profile-actions{display:flex;flex-direction:column;gap:12px;margin-top:20px}.playbook-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-end;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.playbook-modal{background:var(--surface);border:1px solid var(--border);border-radius:20px 20px 0 0;width:100%;max-width:640px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.playbook-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.playbook-title{font-size:18px;font-weight:700;color:var(--text);margin:0}.playbook-close{background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;transition:color .15s}.playbook-close:hover{color:var(--text)}.playbook-content{overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;padding:16px 20px}.playbook-week{font-size:12px;color:var(--text-muted);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.playbook-text{font-size:14px;line-height:1.6;color:var(--text);white-space:pre-wrap;word-wrap:break-word}.playbook-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center;color:var(--error-txt)}.playbook-error p{font-size:14px;margin-bottom:16px}.playbook-retry{background:var(--accent);border:none;color:var(--bubble-user-txt);padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.playbook-retry:hover{background:var(--accent-hover)}.playbook-actions{display:flex;gap:12px;padding:12px 20px 20px;border-top:1px solid var(--border);flex-shrink:0}.playbook-refresh,.playbook-dismiss{flex:1;padding:12px 16px;border-radius:8px;border:1px solid var(--border);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.playbook-refresh{background:var(--surface-2);color:var(--text)}.playbook-refresh:hover:not(:disabled){background:var(--border)}.playbook-refresh:disabled{opacity:.5;cursor:not-allowed}.playbook-dismiss{background:var(--accent);color:var(--bubble-user-txt);border-color:var(--accent)}.playbook-dismiss:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.playbook-btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:8px 14px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;-webkit-tap-highlight-color:transparent}.playbook-btn:hover:not(:disabled){background:var(--border);color:var(--accent)}.playbook-btn:disabled{opacity:.5;cursor:not-allowed}.report-btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:8px 14px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;-webkit-tap-highlight-color:transparent}.report-btn:hover:not(:disabled){background:var(--border);color:var(--accent)}.report-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 480px){.chat-header{padding:10px 12px}.chat-messages{padding:12px 10px 8px}.chat-input-area{padding:8px 10px calc(10px + env(safe-area-inset-bottom,0px))}.message-bubble{max-width:86%}.chat-name{font-size:15px}.wx-sol-strip{font-size:10px;padding:4px 10px}.seasonal-banner{font-size:11px}.bite-gauge-row{font-size:10px;padding:4px 10px}.bite-gauge-track{max-width:200px}.forecast-card{min-width:56px}}.catch-btn,.catches-btn{font-size:12px;font-weight:600;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:5px 10px;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}.catch-btn:hover,.catches-btn:hover{color:var(--text);border-color:var(--text-muted)}.catch-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-end;justify-content:center;z-index:1000;padding:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.catch-modal{background:var(--surface);border:1px solid var(--border);border-radius:20px 20px 0 0;width:100%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.catch-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border);flex-shrink:0}.catch-modal-header h2{font-size:18px;font-weight:700;color:var(--text);margin:0}.catch-modal-close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;transition:color .15s}.catch-modal-close:hover{color:var(--text)}.catch-modal-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.catch-field{display:flex;flex-direction:column;gap:8px}.catch-label{font-size:13px;font-weight:600;color:var(--text)}.catch-chips{display:flex;flex-wrap:wrap;gap:6px}.catch-chip{background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);border-radius:8px;padding:6px 12px;font-size:12px;cursor:pointer;transition:all .15s}.catch-chip:hover{border-color:var(--text-muted);color:var(--text)}.catch-chip--active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.catch-input{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 12px;font-size:14px;font-family:inherit;transition:border-color .15s}.catch-input:focus{outline:none;border-color:var(--accent)}.catch-conditions{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:12px;display:grid;grid-template-columns:1fr 1fr;gap:12px}.catch-condition-item{display:flex;flex-direction:column;gap:4px}.catch-condition-label{font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.catch-condition-value{font-size:14px;color:var(--text);font-weight:600}.catch-modal-footer{display:flex;gap:10px;padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}.catch-cancel-btn,.catch-save-btn{flex:1;padding:10px 16px;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.catch-cancel-btn{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.catch-cancel-btn:hover{color:var(--text);border-color:var(--text-muted)}.catch-save-btn{background:var(--accent);color:var(--bg)}.catch-save-btn:hover:not(:disabled){background:var(--accent-hover)}.catch-save-btn:disabled{opacity:.5;cursor:not-allowed}.catch-log-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-end;justify-content:center;z-index:1000;padding:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.catch-log-panel{background:var(--surface);border:1px solid var(--border);border-radius:20px 20px 0 0;width:100%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.catch-log-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border);flex-shrink:0}.catch-log-title{font-size:18px;font-weight:700;color:var(--text);margin:0}.catch-log-close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;transition:color .15s}.catch-log-close:hover{color:var(--text)}.catch-log-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;color:var(--text-muted);padding:40px 24px}.catch-log-empty-icon{font-size:52px;line-height:1}.catch-log-empty p{font-size:14px;line-height:1.5;margin:0}.catch-insight{background:linear-gradient(135deg,#f0a5001a,#f0a5000d);border:1px solid rgba(240,165,0,.2);border-radius:8px;padding:12px 16px;margin:12px 16px 0;font-size:13px;color:#f0a500;font-weight:600;line-height:1.4}.catch-log-count{font-size:12px;color:var(--text-muted);padding:0 16px;margin-top:4px}.catch-log-list{flex:1;overflow-y:auto;padding:8px 0 env(safe-area-inset-bottom,0px)}.catch-card{border-bottom:1px solid var(--border)}.catch-card:last-child{border-bottom:none}.catch-card-header{display:flex;align-items:flex-start;justify-content:space-between;padding:12px 16px;cursor:pointer;transition:background .1s}.catch-card-header:hover{background:#ffffff08}.catch-card-info{flex:1;min-width:0}.catch-card-species{font-size:14px;font-weight:700;color:var(--text);margin-bottom:4px}.catch-card-meta{font-size:11px;color:#555d68;margin-bottom:4px}.catch-card-lure{font-size:12px;color:var(--text-muted);margin-bottom:2px}.catch-card-size{font-size:12px;color:var(--text-muted);font-weight:600;margin-bottom:4px}.catch-card-conditions{font-size:11px;color:#3a4149;margin-top:4px}.catch-delete-btn{background:none;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:4px 8px;flex-shrink:0;transition:color .15s}.catch-delete-btn:hover{color:var(--error-txt)}.post-btn{padding:8px 12px;background:transparent;border:1px solid #30363d;border-radius:6px;color:#8b949e;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center}.post-btn:hover{background:#f0a5001a;border-color:#f0a500;color:#f0a500}.thumbnail-btn{padding:8px 12px;background:transparent;border:1px solid #30363d;border-radius:6px;color:#8b949e;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center}.thumbnail-btn:hover{background:#f0a5001a;border-color:#f0a500;color:#f0a500}.referral-btn{padding:8px 12px;background:transparent;border:1px solid #30363d;border-radius:6px;color:#8b949e;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.referral-btn:hover{background:#f0a5001a;border-color:#f0a500;color:#f0a500}.calendar-btn{padding:8px 12px;background:transparent;border:1px solid #30363d;border-radius:6px;color:#8b949e;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center}.calendar-btn:hover{background:#f0a5001a;border-color:#f0a500;color:#f0a500}.referral-code-box{background:#ffffff0d;border:1px solid #30363d;border-radius:8px;padding:16px;margin:20px 0;text-align:left}.referral-code-label{font-size:.85rem;color:#8b949e;margin-bottom:8px;display:block;font-weight:600}.referral-code{background:#0003;border:1px solid #30363d;border-radius:6px;padding:10px 12px;color:#f0a500;font-size:.85rem;font-family:Courier New,monospace;word-break:break-all;margin-bottom:0}.referral-count{background:#f0a5001a;border:1px solid rgba(240,165,0,.2);border-radius:8px;padding:12px 16px;margin:20px 0 0;text-align:left}.referral-count p{margin:0;color:#c9d1d9;font-size:.9rem}.referral-count-hint{color:#8b949e;font-size:.85rem!important;margin-top:4px}.catch-analytics{margin:16px 0;padding:16px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;display:flex;flex-direction:column;gap:20px}.analytics-section{display:flex;flex-direction:column;gap:10px}.analytics-title{font-size:13px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.05em;margin:0}.species-breakdown{display:flex;flex-direction:column;gap:8px}.species-bar{display:flex;flex-direction:column;gap:4px}.species-label{font-size:12px;font-weight:600;color:var(--text)}.species-bar-container{height:20px;background:var(--surface);border-radius:4px;overflow:hidden;position:relative}.species-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#d4920a);transition:width .3s ease}.species-percent{position:absolute;top:50%;right:6px;transform:translateY(-50%);font-size:10px;font-weight:700;color:var(--text);line-height:1}.patterns-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pattern-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:10px;display:flex;align-items:center;gap:8px}.pattern-emoji{font-size:20px;flex-shrink:0}.pattern-text{flex:1;min-width:0}.pattern-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;font-weight:600;letter-spacing:.05em}.pattern-value{font-size:13px;font-weight:700;color:var(--accent);margin-top:2px;word-break:break-word}.pattern-count{font-size:11px;color:var(--text-muted);margin-top:2px}.lures-list{display:flex;flex-direction:column;gap:6px}.lure-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--surface);border-radius:4px;font-size:12px}.lure-gear{font-size:14px}.lure-name{flex:1;color:var(--text);font-weight:600}.lure-count{color:var(--accent);font-weight:700;min-width:20px;text-align:right}.monthly-bars{display:flex;align-items:flex-end;gap:4px;height:60px;padding:10px 0}.month-bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:0}.month-bar-container{width:100%;height:40px;background:var(--surface);border-radius:3px;overflow:hidden;display:flex;flex-direction:column-reverse}.month-bar-fill{width:100%;background:linear-gradient(180deg,var(--accent),#d4920a);transition:height .3s ease}.month-label{font-size:10px;color:var(--text-muted);font-weight:600}.compare-lakes-page{min-height:100vh;background:var(--bg);color:var(--text);padding:20px 16px}.compare-container{max-width:900px;margin:0 auto}.back-link{display:inline-block;color:var(--accent);text-decoration:none;font-size:13px;margin-bottom:16px;transition:color .15s}.back-link:hover{color:var(--accent-hover)}.compare-lakes-page h1{font-size:28px;font-weight:700;margin-bottom:4px}.subtitle{color:var(--text-muted);font-size:14px;margin-bottom:20px}.compare-form{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:24px}.form-row{display:grid;grid-template-columns:1fr 60px 1fr;gap:16px;align-items:flex-end;margin-bottom:16px}@media (max-width: 600px){.form-row{grid-template-columns:1fr;gap:12px}.vs-divider{grid-column:1;text-align:center;order:-1;padding:8px 0;font-size:12px}}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:var(--text-muted)}.form-group input,.form-group select{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:10px 12px;color:var(--text);font-size:14px}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #f0a5001a}.vs-divider{text-align:center;color:var(--text-muted);font-size:13px;font-weight:600;white-space:nowrap}.compare-btn{width:100%;background:linear-gradient(135deg,var(--accent),#d4920a);border:none;border-radius:8px;padding:12px 16px;color:#0d1117;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.compare-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-hover),#b67a09);transform:translateY(-1px);box-shadow:0 4px 12px #f0a50033}.compare-btn:disabled{opacity:.6;cursor:not-allowed}.error-banner{background:var(--error-bg);border:1px solid var(--error-border);border-radius:8px;padding:12px 16px;color:var(--error-txt);font-size:13px;margin-bottom:20px}.results-container{display:flex;flex-direction:column;gap:24px}.winner-callout{background:linear-gradient(135deg,#f0a5001a,#f0a5000d);border:2px solid var(--accent);border-radius:12px;padding:16px}.winner-callout h2{font-size:18px;margin-bottom:8px}.winner-callout p{font-size:14px;color:var(--text);line-height:1.6}.comparison-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 700px){.comparison-cards{grid-template-columns:1fr}}.lake-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:16px}.lake-card.card-1{border-left:4px solid #4ade80}.lake-card.card-2{border-left:4px solid #60a5fa}.lake-header h3{font-size:18px;font-weight:700;margin-bottom:4px}.lake-location{font-size:12px;color:var(--text-muted)}.bite-rating-big{display:flex;flex-direction:column;gap:8px}.rating-badge{display:inline-flex;align-items:center;gap:8px;padding:12px 16px;border-radius:8px;color:#0d1117;font-weight:600;font-size:14px;width:fit-content}.rating-badge .emoji{font-size:20px}.score-text{font-size:12px;color:var(--text-muted)}.data-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 500px){.data-grid{grid-template-columns:1fr}}.data-item{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:4px;transition:background .15s}.data-item.full-width{grid-column:1 / -1}.data-item .label{font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.data-item .value{font-size:14px;font-weight:600;color:var(--text)}.reset-btn{align-self:center;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 24px;color:var(--text);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.reset-btn:hover{background:var(--surface-2);border-color:var(--accent)}.reset-btn:active{transform:scale(.98)}.learning-history-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-end;justify-content:center;z-index:1000;padding:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.learning-history-panel{background:var(--surface);border:1px solid var(--border);border-radius:20px 20px 0 0;width:100%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.learning-history-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border);flex-shrink:0}.learning-history-title{font-size:18px;font-weight:700;color:var(--text);margin:0}.learning-history-close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;transition:color .15s}.learning-history-close:hover{color:var(--text)}.learning-history-content{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:20px}.history-section{display:flex;flex-direction:column;gap:10px}.history-section-title{font-size:14px;font-weight:700;color:var(--accent);margin:0;text-transform:uppercase;letter-spacing:.5px}.history-chips{display:flex;flex-wrap:wrap;gap:8px}.history-chip{background:var(--surface-2);border:1px solid var(--border);border-radius:20px;padding:8px 12px;font-size:13px;font-weight:600;color:var(--text);transition:all .15s}.history-chip:hover{background:var(--border);border-color:var(--accent)}.species-chip{background:#3fb9501a;border-color:#3fb9504d}.technique-chip{background:#f0a5001a;border-color:#f0a5004d}.suggestion-section{background:var(--surface-2);border:1px solid rgba(240,165,0,.3);border-radius:12px;padding:16px}.suggestion-card{display:flex;flex-direction:column;gap:12px}.suggestion-text{font-size:13px;color:var(--text);line-height:1.5}.suggestion-btn{background:var(--accent);border:none;border-radius:8px;padding:10px 14px;color:var(--bubble-user-txt);font-size:13px;font-weight:700;cursor:pointer;transition:all .15s}.suggestion-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}.suggestion-btn:active{transform:translateY(0)}.level-section{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:16px;align-items:center;gap:12px}.level-badge{display:flex;align-items:center;justify-content:center;background:var(--border);border-radius:100px;padding:8px 16px;width:fit-content}.level-badge-text{font-size:14px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}.level-description{font-size:12px;color:var(--text-muted);line-height:1.5;margin:0}.learning-history-content>.level-section .history-section-title{align-self:flex-start}.history-meta{font-size:11px;color:var(--text-muted);text-align:center;padding-top:8px;border-top:1px solid var(--border)}.feedback-card{max-width:440px}.feedback-sub{color:var(--text-muted);font-size:13px;margin:0 0 12px;line-height:1.5}.feedback-textarea{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;color:var(--text);font-family:inherit;font-size:14px;line-height:1.5;padding:12px;margin-bottom:12px;resize:vertical;min-height:72px;transition:border-color .15s;box-sizing:border-box}.feedback-textarea:focus{outline:none;border-color:var(--accent)}.feedback-textarea:disabled{opacity:.6;cursor:not-allowed}.feedback-error{color:#e26a6a;font-size:12px;margin:0 0 10px;text-align:left}.feedback-thanks{padding:8px 0}.feedback-thanks h2{color:var(--accent)}@keyframes email-cap-slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.email-cap-banner{position:relative;display:flex;align-items:center;flex-wrap:wrap;gap:10px 14px;background:linear-gradient(135deg,#f0a5001a,#f0a5000a);border:1px solid rgba(240,165,0,.35);border-radius:12px;padding:12px 36px 12px 14px;margin-bottom:8px;animation:email-cap-slide-in .25s ease-out}.email-cap-text{flex:1 1 220px;min-width:0}.email-cap-title{font-size:13px;font-weight:700;color:var(--accent);margin-bottom:2px}.email-cap-sub{font-size:12px;color:var(--text-muted);line-height:1.35}.email-cap-form{display:flex;gap:6px;flex:1 1 260px;min-width:0}.email-cap-input{flex:1;min-width:0;background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 10px;font-size:13px;transition:border-color .15s}.email-cap-input:focus{outline:none;border-color:var(--accent)}.email-cap-input:disabled{opacity:.6;cursor:not-allowed}.email-cap-submit{background:var(--accent);color:var(--bubble-user-txt);border:none;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.email-cap-submit:hover:not(:disabled){background:var(--accent-hover)}.email-cap-submit:disabled{opacity:.6;cursor:not-allowed}.email-cap-close{position:absolute;top:8px;right:8px;background:none;border:none;color:var(--text-muted);font-size:14px;width:22px;height:22px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.email-cap-close:hover{color:var(--text);background:#ffffff0f}.email-cap-error{flex-basis:100%;font-size:12px;color:#e26a6a;margin-top:2px}.email-cap-thanks{display:flex;align-items:center;gap:12px;flex:1}.email-cap-icon{font-size:22px}@media (max-width: 520px){.email-cap-form{flex-basis:100%}}.report-link{display:block;background:none;border:none;color:var(--text-muted);font-size:11px;cursor:pointer;padding:2px 0 4px;text-align:center;opacity:.7;transition:opacity .15s,color .15s}.report-link:hover{opacity:1;color:var(--accent)}.report-modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px;width:92%;max-width:420px;position:relative;margin-bottom:env(safe-area-inset-bottom,0)}.report-title{font-size:18px;font-weight:600;margin-bottom:14px;color:var(--text)}.report-textarea{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:14px;padding:10px 12px;resize:vertical;min-height:100px;max-height:200px}.report-textarea::placeholder{color:var(--text-muted)}.report-textarea:focus{outline:none;border-color:var(--accent)}.report-submit-btn{display:block;width:100%;margin-top:12px;padding:10px 0;background:var(--accent);color:var(--bubble-user-txt);border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:600;cursor:pointer;transition:background .15s}.report-submit-btn:hover:not(:disabled){background:var(--accent-hover)}.report-submit-btn:disabled{opacity:.4;cursor:not-allowed}.report-sent{color:var(--success);font-size:14px;text-align:center;padding:20px 0}
