@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.76dcb0b2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_bace89c4-module__09p2wq__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_bace89c4-module__09p2wq__variable{--font-inter:"Inter","Inter Fallback"}
:root{--color-primary-900:#0b2218;--color-primary-800:#1b4332;--color-primary-700:#2d6a4f;--color-primary-600:#40916c;--color-primary-500:#52b788;--color-primary-400:#74c69d;--color-primary-300:#95d5b2;--color-primary-200:#b7e4c7;--color-primary-100:#d8f3dc;--color-accent-brown:#5c4033;--color-accent-brown-light:#8b6914;--color-accent-cream:#f5f0e8;--color-accent-gold:gold;--color-accent-amber:#f4a261;--color-accent-coral:#e76f51;--color-bg-primary:#0a0f0d;--color-bg-secondary:#111916;--color-bg-tertiary:#1a2420;--color-bg-card:#162019;--color-bg-card-hover:#1e2e25;--color-bg-input:#1a2420;--color-bg-overlay:#0a0f0dd9;--color-border:#2d3d35;--color-border-light:#3a4f44;--color-border-focus:#40916c;--color-text-primary:#e8f0ec;--color-text-secondary:#a8b8ae;--color-text-muted:#6b7b72;--color-text-inverse:#0a0f0d;--color-success:#52b788;--color-warning:#e9c46a;--color-error:#e76f51;--color-info:#40916c;--color-danger-harmless:#52b788;--color-danger-low:#74c69d;--color-danger-moderate:#e9c46a;--color-danger-high:#e76f51;--color-danger-extreme:#d62828;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 30px #00000080;--shadow-glow:0 0 20px #40916c26;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--header-height:64px;--max-width:1200px;--sidebar-width:280px}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background-color:var(--color-bg-primary);color:var(--color-text-primary);min-height:100vh;line-height:1.6}a{color:var(--color-primary-400);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-300)}img{max-width:100%;height:auto}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border-light);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-700)}.container{max-width:var(--max-width);padding:0 var(--space-md);margin:0 auto}.page{min-height:calc(100vh - var(--header-height));padding-top:calc(var(--header-height) + var(--space-lg));padding-bottom:var(--space-3xl)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);transition:all var(--transition-base);cursor:pointer;white-space:nowrap;border:none;padding:10px 20px;font-size:.925rem;font-weight:600;line-height:1.4;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-primary-700),var(--color-primary-600));color:#fff;box-shadow:0 2px 8px #2d6a4f4d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-600),var(--color-primary-500));transform:translateY(-1px);box-shadow:0 4px 16px #2d6a4f66}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-card-hover);border-color:var(--color-border-light)}.btn-ghost{color:var(--color-text-secondary);background:0 0;padding:8px 14px}.btn-ghost:hover:not(:disabled){background:var(--color-bg-tertiary);color:var(--color-text-primary)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background:#d4533d;transform:translateY(-1px)}.btn-sm{padding:6px 14px;font-size:.825rem}.btn-lg{padding:14px 28px;font-size:1.05rem}.btn-icon{border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:8px;display:inline-flex}.btn-icon:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.form-group{gap:var(--space-xs);margin-bottom:var(--space-md);flex-direction:column;display:flex}.form-label{color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.form-input{background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;padding:10px 14px;font-size:.95rem}.form-input:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px #40916c26}.form-input::placeholder{color:var(--color-text-muted)}.form-input.error{border-color:var(--color-error)}.form-error{color:var(--color-error);font-size:.8rem}textarea.form-input{resize:vertical;min-height:80px}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base)}.card:hover{border-color:var(--color-border-light)}.card-clickable:hover{box-shadow:var(--shadow-md);cursor:pointer;transform:translateY(-2px)}.badge{border-radius:var(--radius-full);align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;font-weight:600;line-height:1.4;display:inline-flex}.badge-success{color:var(--color-success);background:#52b78826}.badge-warning{color:var(--color-warning);background:#e9c46a26}.badge-danger{color:var(--color-error);background:#e76f5126}.badge-info{color:var(--color-info);background:#40916c26}.avatar{border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary-700),var(--color-primary-500));color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;font-weight:700;display:flex;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-sm{width:32px;height:32px;font-size:.8rem}.avatar-lg{width:64px;height:64px;font-size:1.5rem}.avatar-xl{width:96px;height:96px;font-size:2rem}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--color-bg-tertiary)25%,var(--color-bg-card-hover)50%,var(--color-bg-tertiary)75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}.toast-container{top:calc(var(--header-height) + var(--space-md));right:var(--space-md);z-index:10000;gap:var(--space-sm);pointer-events:none;flex-direction:column;display:flex;position:fixed}.toast-container>*{pointer-events:auto}.modal-overlay{background:var(--color-bg-overlay);z-index:9000;padding:var(--space-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-xl);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-lg);overflow-y:auto}.empty-state{padding:var(--space-3xl)var(--space-lg);text-align:center;justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.empty-state-icon{opacity:.4;font-size:3.5rem}.empty-state h3{color:var(--color-text-secondary);font-size:1.15rem;font-weight:600}.empty-state p{color:var(--color-text-muted);max-width:340px;font-size:.9rem}.grid-2{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}@media (max-width:768px){.grid-2,.grid-3{grid-template-columns:1fr}.container{padding:0 var(--space-sm)}.page{padding-top:calc(var(--header-height) + var(--space-md))}}@media (max-width:1024px){.grid-3{grid-template-columns:repeat(2,1fr)}}.xp-bar{background:var(--color-bg-tertiary);border-radius:var(--radius-full);width:100%;height:8px;overflow:hidden}.xp-bar-fill{background:linear-gradient(90deg,var(--color-primary-600),var(--color-primary-400));border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}.status-least-concern{color:#52b788;background:#52b78826}.status-near-threatened{color:#e9c46a;background:#e9c46a26}.status-vulnerable{color:#f4a261;background:#f4a26126}.status-endangered{color:#e76f51;background:#e76f5126}.status-critically-endangered{color:#d62828;background:#d6282826}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.animate-fade-in{animation:fadeIn var(--transition-base)ease forwards}.animate-slide-up{animation:slideUp var(--transition-slow)ease forwards}.animate-slide-down{animation:slideDown var(--transition-base)ease forwards}.animate-scale-in{animation:scaleIn var(--transition-base)ease forwards}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary-500);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spinner-lg{border-width:4px;width:40px;height:40px}.page-loader{justify-content:center;align-items:center;min-height:60vh;display:flex}.onboarding-overlay{z-index:9500;padding:var(--space-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a0f0de6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.onboarding-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-2xl)var(--space-xl)var(--space-xl);width:100%;max-width:480px;box-shadow:var(--shadow-lg),0 0 60px #2d6a4f1a;position:relative}.onboarding-illustration{border-radius:var(--radius-xl);width:100px;height:100px;margin-bottom:var(--space-lg);border:2px solid;justify-content:center;align-items:center;display:flex}.onboarding-step-dots{justify-content:center;gap:var(--space-sm);margin-top:var(--space-lg);display:flex}.onboarding-dot{border-radius:var(--radius-full);cursor:pointer;width:8px;height:8px;transition:all var(--transition-base);border:none;padding:0}.onboarding-dot.active{width:24px}@media (max-width:768px){.onboarding-card{padding:var(--space-xl)var(--space-md)var(--space-md);margin:var(--space-sm)}.onboarding-illustration{width:80px;height:80px}}.map-page{padding-top:var(--header-height);flex-direction:column;height:100vh;display:flex}.map-container{flex:1;height:calc(100vh - 80px);position:relative}.map-sidebar{top:var(--space-md);left:var(--space-md);width:var(--sidebar-width);max-height:calc(100% - var(--space-xl));background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);z-index:500;box-shadow:var(--shadow-lg);transition:transform var(--transition-base);position:absolute;overflow-y:auto}.map-sidebar.collapsed{transform:translateX(calc(-100% - var(--space-md)))}.map-sidebar-toggle{top:var(--space-md);left:var(--space-md);z-index:501;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);position:absolute}.map-sidebar-toggle:hover{background:var(--color-bg-tertiary)}.map-pin{border:3px solid var(--color-primary-500);width:40px;height:40px;box-shadow:var(--shadow-md);cursor:pointer;transition:transform var(--transition-fast);border-radius:50%;overflow:hidden}.map-pin:hover{transform:scale(1.15)}.map-pin img{object-fit:cover;width:100%;height:100%}.map-popup{padding:var(--space-md);min-width:220px}.map-popup .species-name{color:var(--color-text-primary);margin-bottom:var(--space-xs);font-size:1rem;font-weight:600}.map-popup .scientific-name{color:var(--color-text-muted);margin-bottom:var(--space-sm);font-size:.8rem;font-style:italic}.map-popup img{object-fit:cover;border-radius:var(--radius-md);width:100%;height:120px;margin-bottom:var(--space-sm)}.map-filters{top:var(--space-md);right:var(--space-md);gap:var(--space-sm);z-index:500;flex-wrap:wrap;display:flex;position:absolute}.map-filters .filter-chip{border-radius:var(--radius-full);background:var(--color-bg-secondary);border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:6px 14px;font-size:.825rem;font-weight:500}.map-filters .filter-chip:hover{border-color:var(--color-border-light);color:var(--color-text-primary)}.map-filters .filter-chip.active{background:var(--color-primary-700);border-color:var(--color-primary-600);color:#fff}.map-stats-bar{bottom:var(--space-md);gap:var(--space-md);padding:var(--space-sm)var(--space-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);z-index:500;color:var(--color-text-secondary);font-size:.825rem;display:flex;position:absolute;left:50%;transform:translate(-50%)}.map-stats-bar .stat{align-items:center;gap:var(--space-xs);display:flex}.map-stats-bar .stat strong{color:var(--color-primary-400)}.leaflet-container{background:var(--color-bg-primary)}.leaflet-popup-content-wrapper{background:var(--color-bg-secondary);color:var(--color-text-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.leaflet-popup-tip{background:var(--color-bg-secondary)}.leaflet-control-zoom a{background:var(--color-bg-secondary)!important;color:var(--color-text-primary)!important;border-color:var(--color-border)!important}.leaflet-control-zoom a:hover{background:var(--color-bg-tertiary)!important}.custom-marker{border:3px solid var(--color-primary-500);width:40px;height:40px;box-shadow:var(--shadow-md);border-radius:50%;overflow:hidden}.custom-marker img{object-fit:cover;width:100%;height:100%}@media (max-width:768px){.map-sidebar{width:calc(100vw - var(--space-xl));max-width:320px}.map-filters{top:auto;bottom:60px;right:var(--space-sm);left:var(--space-sm);justify-content:center}.map-stats-bar{left:var(--space-sm);right:var(--space-sm);flex-wrap:wrap;justify-content:center;transform:none}}.collections-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.collection-card{border-radius:var(--radius-lg);aspect-ratio:16/10;cursor:pointer;transition:transform var(--transition-base),box-shadow var(--transition-base);background:var(--color-bg-card);border:1px solid var(--color-border);position:relative;overflow:hidden}.collection-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.collection-card .cover{object-fit:cover;width:100%;height:100%}.collection-card .overlay{padding:var(--space-md);background:linear-gradient(#0000,#000000d9);position:absolute;bottom:0;left:0;right:0}.collection-card .name{color:#fff;font-size:1.125rem;font-weight:600}.collection-card .count{color:#ffffffb3;font-size:.875rem}.collection-create-card{justify-content:center;align-items:center;gap:var(--space-sm);border:2px dashed var(--color-border);border-radius:var(--radius-lg);aspect-ratio:16/10;cursor:pointer;color:var(--color-text-muted);transition:all var(--transition-base);flex-direction:column;display:flex}.collection-create-card:hover{border-color:var(--color-primary-600);color:var(--color-primary-400);background:#2d6a4f0d}.add-discovery-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(120px,1fr));max-height:400px;display:grid;overflow-y:auto}.add-discovery-item{border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast),transform var(--transition-fast);border:2px solid #0000;overflow:hidden}.add-discovery-item:hover{transform:scale(1.03)}.add-discovery-item.selected{border-color:var(--color-primary-500)}.add-discovery-item img{aspect-ratio:1;object-fit:cover;width:100%}.explore-tabs{gap:var(--space-sm);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border);scrollbar-width:none;display:flex;overflow-x:auto}.explore-tabs::-webkit-scrollbar{display:none}.explore-tab{padding:var(--space-sm)var(--space-md);border-radius:var(--radius-full);white-space:nowrap;transition:all var(--transition-fast);cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;font-size:.875rem;font-weight:500}.explore-tab.active{background:var(--color-primary-600);color:#fff}.explore-tab:hover:not(.active){background:var(--color-bg-tertiary)}.category-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(150px,1fr));display:grid}.category-card{padding:var(--space-lg);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:transform var(--transition-base),box-shadow var(--transition-base);position:relative;overflow:hidden}.category-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.category-card .emoji{margin-bottom:var(--space-sm);font-size:3rem;display:block}.category-card .name{color:var(--color-text-primary);font-weight:600}.category-card .count{color:var(--color-text-muted);font-size:.875rem}.category-card.birds{background:linear-gradient(135deg,#3b82f626,#3b82f60d)}.category-card.mammals{background:linear-gradient(135deg,#b4783c26,#b4783c0d)}.category-card.reptiles{background:linear-gradient(135deg,#22c55e26,#22c55e0d)}.category-card.insects{background:linear-gradient(135deg,#eab30826,#eab3080d)}.category-card.amphibians{background:linear-gradient(135deg,#a855f726,#a855f70d)}.category-card.marine{background:linear-gradient(135deg,#06b6d426,#06b6d40d)}.category-card.arachnids{background:linear-gradient(135deg,#e76f5126,#e76f510d)}.trending-card{align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border);transition:all var(--transition-fast);display:flex}.trending-card:hover{border-color:var(--color-border-light)}.trending-rank{color:var(--color-primary-400);min-width:40px;font-size:1.5rem;font-weight:700}.comparison-container{gap:var(--space-lg);grid-template-columns:1fr auto 1fr;align-items:start;display:grid}.comparison-vs{color:var(--color-accent-amber);align-self:center;font-size:1.5rem;font-weight:700}.comparison-card{padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border)}.seasonal-card{padding:var(--space-md);border-radius:var(--radius-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border);gap:var(--space-md);transition:all var(--transition-fast);display:flex}.seasonal-card:hover{border-color:var(--color-border-light)}.likelihood-badge{border-radius:var(--radius-full);padding:2px 10px;font-size:.75rem;font-weight:600}.likelihood-badge.common{color:#22c55e;background:#22c55e26}.likelihood-badge.uncommon{color:#eab308;background:#eab30826}.likelihood-badge.rare{color:#a855f7;background:#a855f726}@media (max-width:768px){.comparison-container{text-align:center;grid-template-columns:1fr}.comparison-vs{justify-self:center}.category-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.challenges-hero{text-align:center;padding:var(--space-xl)0}.challenge-section-title{margin:var(--space-lg)0 var(--space-md);align-items:center;gap:var(--space-sm);font-size:1.25rem;font-weight:600;display:flex}.challenge-card{padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border);transition:all var(--transition-base)}.challenge-card:hover{border-color:var(--color-border-light);box-shadow:var(--shadow-md)}.challenge-card.completed{border-color:var(--color-accent-gold);background:linear-gradient(135deg,#ffd7000d,#0000)}.challenge-icon{font-size:2rem}.challenge-progress{background:var(--color-bg-tertiary);border-radius:var(--radius-full);height:8px;margin:var(--space-sm)0;overflow:hidden}.challenge-progress-fill{border-radius:var(--radius-full);background:linear-gradient(90deg,var(--color-primary-600),var(--color-primary-400));height:100%;transition:width .5s}.challenge-progress-fill.complete{background:linear-gradient(90deg,var(--color-accent-gold),#f59e0b)}.challenge-xp-badge{border-radius:var(--radius-full);color:var(--color-accent-gold);background:#ffd70026;align-items:center;gap:4px;padding:2px 10px;font-size:.8rem;font-weight:600;display:inline-flex}.challenge-timer{color:var(--color-text-muted);font-size:.8rem}.challenge-complete-badge{color:var(--color-accent-gold);align-items:center;gap:4px;font-weight:600;display:inline-flex}.stats-overview{gap:var(--space-md);grid-template-columns:repeat(4,1fr);display:grid}@media (max-width:768px){.stats-overview{grid-template-columns:repeat(2,1fr)}}.stat-card{padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border);text-align:center}.stat-card .value{color:var(--color-primary-400);font-size:2.5rem;font-weight:700}.stat-card .label{color:var(--color-text-secondary);margin-top:var(--space-xs);font-size:.875rem}.bar-chart{gap:var(--space-sm);flex-direction:column;display:flex}.bar-chart-row{align-items:center;gap:var(--space-sm);display:flex}.bar-chart-label{width:100px;color:var(--color-text-secondary);text-align:right;flex-shrink:0;font-size:.875rem}.bar-chart-bar{border-radius:var(--radius-full);background:var(--color-bg-tertiary);flex:1;height:28px;overflow:hidden}.bar-chart-fill{border-radius:var(--radius-full);height:100%;padding-left:var(--space-sm);color:#fff;align-items:center;font-size:.75rem;font-weight:600;transition:width 1s;display:flex}.timeline-chart{height:200px;padding:var(--space-md)0;align-items:flex-end;gap:4px;display:flex}.timeline-bar{border-radius:var(--radius-sm)var(--radius-sm)0 0;background:var(--color-primary-600);cursor:pointer;flex:1;min-height:4px;transition:height 1s;position:relative}.timeline-bar:hover{background:var(--color-primary-400)}.timeline-bar.current{background:var(--color-accent-amber)}.timeline-label{color:var(--color-text-muted);text-align:center;margin-top:4px;font-size:.65rem}.heatmap-container{padding:var(--space-md)0;overflow-x:auto}.heatmap-grid{grid-template-rows:repeat(7,1fr);grid-auto-flow:column;gap:3px;display:grid}.heatmap-cell{background:var(--color-bg-tertiary);cursor:pointer;width:14px;height:14px;transition:outline var(--transition-fast);border-radius:3px}.heatmap-cell:hover{outline:2px solid var(--color-primary-400);outline-offset:1px}.heatmap-tooltip{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);pointer-events:none;z-index:10;white-space:nowrap;color:var(--color-text-primary);padding:4px 8px;font-size:.75rem;position:absolute}.notification-bell{cursor:pointer;position:relative}.notification-badge{color:#fff;border:2px solid var(--color-bg-primary);background:#ef4444;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.7rem;font-weight:700;animation:.3s notif-bounce;display:flex;position:absolute;top:-4px;right:-4px}@keyframes notif-bounce{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}.notification-dropdown{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:360px;max-height:400px;box-shadow:var(--shadow-lg);z-index:100;position:absolute;top:100%;right:0;overflow-y:auto}.notification-header{padding:var(--space-sm)var(--space-md);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.notification-header h4{font-size:.9rem;font-weight:600}.notification-item{gap:var(--space-sm);padding:var(--space-sm)var(--space-md);border-bottom:1px solid var(--color-border);cursor:pointer;transition:background var(--transition-fast);display:flex}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:var(--color-bg-tertiary)}.notification-item.unread{background:#2d6a4f14}.notification-item.unread:before{content:"";background:var(--color-primary-500);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.notification-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;display:flex}.notification-icon.like{background:#ef444426}.notification-icon.comment{background:#3b82f626}.notification-icon.follow{background:#22c55e26}.notification-icon.badge{background:#ffd70026}.notification-icon.challenge{background:#a855f726}.notification-text{flex:1;min-width:0}.notification-text .message{color:var(--color-text-primary);font-size:.875rem;line-height:1.4}.notification-text .time{color:var(--color-text-muted);margin-top:2px;font-size:.75rem}.notification-see-all{text-align:center;padding:var(--space-sm);color:var(--color-primary-400);border-top:1px solid var(--color-border);transition:background var(--transition-fast);font-size:.875rem;font-weight:500;text-decoration:none;display:block}.notification-see-all:hover{background:var(--color-bg-tertiary)}@media (max-width:480px){.notification-dropdown{width:calc(100vw - var(--space-md));right:calc(-1*var(--space-md))}}.bookmark-btn{color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast),transform var(--transition-fast);padding:var(--space-xs);background:0 0;border:none}.bookmark-btn:hover{color:var(--color-accent-amber);transform:scale(1.1)}.bookmark-btn.active{color:var(--color-accent-amber)}.bookmarks-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.landing-hero{justify-content:center;align-items:center;min-height:90vh;display:flex;position:relative;overflow:hidden}.hero-bg-layer{position:absolute;inset:0}.hero-bg-layer.trees{background:linear-gradient(#0000 0%,#1b43324d 100%)}.hero-bg-layer.mist{background:radial-gradient(at 50% 80%,#2d6a4f1a 0%,#0000 70%);animation:8s ease-in-out infinite mist-drift}@keyframes mist-drift{0%,to{opacity:.5;transform:translate(-5%)}50%{opacity:1;transform:translate(5%)}}.fireflies{pointer-events:none;position:absolute;inset:0}.firefly{background:var(--color-accent-gold);width:4px;height:4px;animation:firefly-float var(--duration,6s)ease-in-out infinite;border-radius:50%;position:absolute;box-shadow:0 0 8px 2px #ffd70066}@keyframes firefly-float{0%{opacity:0;transform:translate(0)}25%{opacity:1}50%{transform:translate(var(--dx,30px),var(--dy,-40px));opacity:.6}75%{opacity:1}to{opacity:0;transform:translate(0)}}.counter-animated{color:var(--color-primary-400);font-variant-numeric:tabular-nums;font-size:4rem;font-weight:800}.feature-showcase{gap:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}@media (max-width:768px){.feature-showcase{grid-template-columns:1fr}}.feature-card{padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border);cursor:default;transition:all .3s;position:relative;overflow:hidden}.feature-card:before{content:"";background:linear-gradient(90deg,var(--color-primary-500),var(--color-primary-300));height:3px;transition:transform .3s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.feature-card:hover:before{transform:scaleX(1)}.feature-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.feature-icon{border-radius:var(--radius-md);width:48px;height:48px;margin-bottom:var(--space-md);justify-content:center;align-items:center;font-size:1.5rem;display:flex}.dashboard-grid{gap:var(--space-lg);display:grid}.quick-actions{gap:var(--space-md);grid-template-columns:repeat(4,1fr);display:grid}@media (max-width:640px){.quick-actions{grid-template-columns:repeat(2,1fr)}}.quick-action-card{padding:var(--space-lg);border-radius:var(--radius-lg);text-align:center;cursor:pointer;align-items:center;gap:var(--space-sm);background:var(--color-bg-secondary);border:1px solid var(--color-border);color:var(--color-text-primary);flex-direction:column;text-decoration:none;transition:all .2s;display:flex}.quick-action-card:hover{box-shadow:var(--shadow-lg);border-color:var(--color-border-light);transform:translateY(-3px)}.quick-action-icon{border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.5rem;display:flex}.horizontal-scroll{gap:var(--space-md);padding-bottom:var(--space-sm);-webkit-overflow-scrolling:touch;scrollbar-width:thin;display:flex;overflow-x:auto}.horizontal-scroll::-webkit-scrollbar{height:4px}.horizontal-scroll::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.discovery-mini-card{text-align:center;cursor:pointer;flex-shrink:0;width:140px}.discovery-mini-card img{object-fit:cover;border:3px solid var(--color-border);width:100px;height:100px;margin-bottom:var(--space-sm);transition:border-color var(--transition-fast),transform var(--transition-fast);border-radius:50%}.discovery-mini-card:hover img{border-color:var(--color-primary-500);transform:scale(1.05)}.section-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.section-header h3{font-size:1.125rem;font-weight:600}.section-header a{color:var(--color-primary-400);font-size:.875rem;text-decoration:none}.section-header a:hover{text-decoration:underline}.header-nav-links{align-items:center;gap:var(--space-xs);display:flex}.nav-link{padding:var(--space-sm)var(--space-sm);border-radius:var(--radius-md);color:var(--color-text-secondary);white-space:nowrap;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s}.nav-link:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.nav-link.active{color:var(--color-primary-400);background:#2d6a4f26}.nav-more-dropdown{position:relative}.nav-more-menu{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);min-width:200px;box-shadow:var(--shadow-lg);padding:var(--space-sm);z-index:50;position:absolute;top:100%;right:0}.nav-more-item{align-items:center;gap:var(--space-sm);padding:var(--space-sm)var(--space-sm);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.875rem;text-decoration:none;transition:all .15s;display:flex}.nav-more-item:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.mobile-menu-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:998;background:#00000080;position:fixed;inset:0}.mobile-menu{background:var(--color-bg-secondary);z-index:999;width:300px;max-width:85vw;padding:var(--space-lg);animation:.25s slideInRight;position:fixed;top:0;bottom:0;right:0;overflow-y:auto}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.mobile-menu-section{margin-bottom:var(--space-lg)}.mobile-menu-section-title{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:var(--space-sm);font-size:.7rem}.mobile-menu-link{align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);font-size:.95rem;text-decoration:none;display:flex}.mobile-menu-link:hover,.mobile-menu-link.active{background:var(--color-bg-tertiary);color:var(--color-primary-400)}.xp-mini{align-items:center;gap:var(--space-sm);color:var(--color-text-secondary);font-size:.8rem;display:flex}.xp-mini-bar{background:var(--color-bg-tertiary);border-radius:2px;width:60px;height:4px;overflow:hidden}.xp-mini-fill{background:var(--color-primary-500);border-radius:2px;height:100%}.streak-fire{align-items:center;gap:var(--space-xs);display:inline-flex}.streak-fire .flame{animation:.5s ease-in-out infinite alternate flame-flicker}@keyframes flame-flicker{0%{transform:scale(1)rotate(-2deg)}to{transform:scale(1.1)rotate(2deg)}}.streak-fire.blue .flame{color:#3b82f6;filter:drop-shadow(0 0 4px #3b82f680)}.streak-fire.purple .flame{color:#a855f7;filter:drop-shadow(0 0 4px #a855f780)}.streak-fire.gold .flame{color:var(--color-accent-gold);filter:drop-shadow(0 0 6px #ffd70099)}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-100vh)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}.level-up-overlay{z-index:9999;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.level-up-content{text-align:center;animation:.6s level-up-bounce}@keyframes level-up-bounce{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.confetti-piece{width:10px;height:10px;animation:2s ease-in forwards confetti-fall;position:absolute}.page-enter{animation:.3s page-fade-in}@keyframes page-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.reveal{opacity:0;transition:all .6s;transform:translateY(20px)}.reveal.visible{opacity:1;transform:translateY(0)}.gradient-text{background:linear-gradient(135deg,var(--color-primary-400),var(--color-primary-200));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.card-glass{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1a242099;border:1px solid #ffffff14}.glow-primary{box-shadow:0 0 20px #2d6a4f4d}.glow-gold{box-shadow:0 0 20px #ffd70033}.pulse-ring{position:relative}.pulse-ring:after{content:"";border-radius:inherit;border:2px solid var(--color-primary-500);animation:2s ease-in-out infinite pulse-ring-anim;position:absolute;inset:-4px}@keyframes pulse-ring-anim{0%,to{opacity:0;transform:scale(.95)}50%{opacity:.5;transform:scale(1.05)}}.shimmer-hover{position:relative;overflow:hidden}.shimmer-hover:after{content:"";background:linear-gradient(135deg,#0000 40%,#ffffff08 50%,#0000 60%);width:200%;height:200%;transition:transform .6s;position:absolute;top:-50%;left:-50%;transform:rotate(45deg)translate(-100%)}.shimmer-hover:hover:after{transform:rotate(45deg)translate(100%)}.tab-underline{position:relative}.tab-underline:after{content:"";background:var(--color-primary-500);height:2px;transition:transform .2s;position:absolute;bottom:-2px;left:0;right:0;transform:scaleX(0)}.tab-underline.active:after{transform:scaleX(1)}.custom-scrollbar::-webkit-scrollbar{width:6px}.custom-scrollbar::-webkit-scrollbar-track{background:0 0}.custom-scrollbar::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}@keyframes count-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.hide-mobile{display:block}.show-mobile{display:none}@media (max-width:768px){.hide-mobile{display:none}.show-mobile{display:block}}.search-page{max-width:900px;margin:0 auto;padding:2rem 1rem}.search-hero{text-align:center;padding:3rem 0 2rem}.search-hero h1{color:var(--color-text-primary);margin-bottom:1.5rem;font-size:2rem}.search-hero-input{width:100%;height:60px;color:var(--color-text-primary);background:var(--color-bg-input);border:2px solid var(--color-primary-700);border-radius:16px;outline:none;padding:0 1.5rem;font-size:1.25rem;transition:border-color .2s,box-shadow .2s}.search-hero-input::placeholder{color:var(--color-text-muted)}.search-hero-input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 4px #52b78826}.search-results-section{margin-top:2rem}.search-results-section h2{color:var(--color-text-secondary);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.1rem;display:flex}.search-results-count{min-width:24px;height:24px;color:var(--color-text-inverse);background:var(--color-primary-500);border-radius:12px;justify-content:center;align-items:center;padding:0 8px;font-size:.75rem;font-weight:600;display:inline-flex}.search-result-item{background:var(--color-bg-card);border:1px solid var(--color-border);cursor:pointer;border-radius:12px;align-items:center;gap:1rem;margin-bottom:.75rem;padding:1rem;transition:background .2s,border-color .2s,transform .15s;display:flex}.search-result-item:hover{background:var(--color-bg-card-hover);border-color:var(--color-primary-700);transform:translateY(-2px)}.search-result-item img{object-fit:cover;border-radius:10px;flex-shrink:0;width:56px;height:56px}.search-result-item h3{color:var(--color-text-primary);margin:0 0 .25rem;font-size:1rem}.search-result-item p{color:var(--color-text-muted);margin:0;font-size:.85rem}.recent-searches{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.recent-search-pill{color:var(--color-text-secondary);background:var(--color-bg-tertiary);border:1px solid var(--color-border);cursor:pointer;border-radius:20px;align-items:center;gap:.4rem;padding:.4rem .85rem;font-size:.8rem;transition:background .2s,color .2s;display:inline-flex}.recent-search-pill:hover{background:var(--color-primary-800);color:var(--color-text-primary)}@media (max-width:768px){.search-hero{padding:2rem 0 1.5rem}.search-hero h1{font-size:1.5rem}.search-hero-input{height:52px;font-size:1rem}.search-result-item img{width:44px;height:44px}}.not-found-page{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:70vh;padding:2rem 1rem;display:flex;position:relative;overflow:hidden}.not-found-code{background:linear-gradient(180deg,var(--color-primary-400)0%,var(--color-primary-700)100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:8rem;font-weight:800;line-height:1}.not-found-page h2{color:var(--color-text-primary);margin-bottom:.75rem;font-size:1.5rem}.not-found-page p{color:var(--color-text-muted);max-width:400px;margin-bottom:2rem}.not-found-forest{width:320px;height:160px;margin-bottom:2rem;position:relative}.tree{position:absolute;bottom:0}.tree-trunk{background:var(--color-accent-brown);border-radius:2px;width:12px;margin:0 auto}.tree-canopy{background:var(--color-primary-700);border-radius:50%}.tree:first-child{left:40px}.tree:first-child .tree-trunk{height:40px}.tree:first-child .tree-canopy{width:50px;height:60px;margin-bottom:-8px}.tree:nth-child(2){left:120px}.tree:nth-child(2) .tree-trunk{height:55px}.tree:nth-child(2) .tree-canopy{background:var(--color-primary-600);width:65px;height:75px;margin-bottom:-10px}.tree:nth-child(3){left:220px}.tree:nth-child(3) .tree-trunk{height:35px}.tree:nth-child(3) .tree-canopy{width:45px;height:55px;margin-bottom:-6px}.tree-pine{border-left:25px solid #0000;border-right:25px solid #0000;border-bottom:60px solid var(--color-primary-800);width:0;height:0}.tree:nth-child(4){left:170px}.tree:nth-child(4) .tree-trunk{height:30px}.cloud{background:#a8b8ae26;border-radius:50px;animation:6s ease-in-out infinite cloud-float;position:absolute}.cloud:before,.cloud:after{content:"";background:inherit;border-radius:inherit;position:absolute}.cloud:nth-child(5){width:60px;height:20px;animation-delay:0s;top:10px;left:30px}.cloud:nth-child(5):before{width:30px;height:30px;top:-14px;left:8px}.cloud:nth-child(6){width:50px;height:16px;animation-delay:-2s;top:25px;left:200px}.cloud:nth-child(6):before{width:25px;height:25px;top:-12px;left:6px}@keyframes cloud-float{0%,to{transform:translate(0)}50%{transform:translate(20px)}}@media (max-width:768px){.not-found-code{font-size:5rem}.not-found-forest{width:240px;height:120px}}.lightbox-overlay{z-index:1000;cursor:pointer;background:#000000f2;justify-content:center;align-items:center;animation:.25s lightbox-fade-in;display:flex;position:fixed;inset:0}.lightbox-overlay.closing{animation:.2s forwards lightbox-fade-out}.lightbox-image{object-fit:contain;cursor:default;border-radius:8px;max-width:90vw;max-height:90vh}.lightbox-close{width:40px;height:40px;color:var(--color-text-secondary);cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;transition:background .2s;display:flex;position:absolute;top:1rem;right:1rem}.lightbox-close:hover{background:#fff3}@keyframes lightbox-fade-in{0%{opacity:0}to{opacity:1}}@keyframes lightbox-fade-out{0%{opacity:1}to{opacity:0}}.step-indicator{justify-content:center;align-items:center;gap:0;margin-bottom:2rem;display:flex}.step-indicator-item{align-items:center;gap:0;display:flex}.step-dot{width:36px;height:36px;color:var(--color-text-muted);background:var(--color-bg-tertiary);border:2px solid var(--color-border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:600;transition:all .3s;display:flex}.step-dot.active{color:var(--color-text-inverse);background:var(--color-primary-500);border-color:var(--color-primary-500)}.step-dot.completed{color:var(--color-text-inverse);background:var(--color-primary-700);border-color:var(--color-primary-600)}.step-line{background:var(--color-border);width:60px;height:2px;transition:background .3s}.step-line.completed{background:var(--color-primary-600)}.step-label{color:var(--color-text-muted);text-align:center;margin-top:.4rem;font-size:.7rem;display:block}.step-label.active{color:var(--color-primary-400)}.confidence-gauge{width:120px;height:60px;margin:0 auto;position:relative;overflow:hidden}.confidence-gauge-arc{background:conic-gradient(var(--color-primary-500)0deg,var(--color-primary-500)calc(var(--gauge-value,0)*1.8deg),var(--color-bg-tertiary)calc(var(--gauge-value,0)*1.8deg),var(--color-bg-tertiary)180deg,transparent 180deg);border-radius:50%;width:120px;height:120px;-webkit-mask:radial-gradient(circle,#0000 40px,#000 41px);mask:radial-gradient(circle,#0000 40px,#000 41px)}.confidence-gauge-value{color:var(--color-primary-400);font-size:1.1rem;font-weight:700;position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.camera-preview{background:var(--color-bg-primary);border-radius:16px;width:100%;position:relative;overflow:hidden}.camera-preview video{border-radius:16px;width:100%;display:block}.camera-capture-btn{border:4px solid var(--color-primary-500);cursor:pointer;background:#fff;border-radius:50%;width:64px;height:64px;transition:transform .15s,box-shadow .15s;position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%)}.camera-capture-btn:hover{transform:translate(-50%)scale(1.08);box-shadow:0 0 20px #52b78866}.camera-capture-btn:active{transform:translate(-50%)scale(.95)}.id-history-sidebar{background:var(--color-bg-secondary);border-left:1px solid var(--color-border);z-index:200;width:320px;height:100vh;padding:1.5rem;transition:transform .3s;position:fixed;top:0;right:0;overflow-y:auto;transform:translate(100%)}.id-history-sidebar.open{transform:translate(0)}.id-history-sidebar h3{color:var(--color-text-primary);margin-bottom:1rem;font-size:1rem}.similar-species{scroll-snap-type:x mandatory;gap:1rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.similar-species::-webkit-scrollbar{height:4px}.similar-species::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.similar-species-card{background:var(--color-bg-card);border:1px solid var(--color-border);scroll-snap-align:start;border-radius:12px;flex-shrink:0;width:140px;transition:border-color .2s;overflow:hidden}.similar-species-card:hover{border-color:var(--color-primary-700)}.similar-species-card img{object-fit:cover;width:100%;height:100px}.similar-species-card span{color:var(--color-text-secondary);text-align:center;padding:.5rem;font-size:.8rem;display:block}@media (max-width:768px){.step-line{width:32px}.id-history-sidebar{width:100%}}.topic-cards{grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem;display:grid}.topic-card{background:var(--color-bg-card);border:1px solid var(--color-border);text-align:center;cursor:pointer;border-radius:12px;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem .75rem;transition:transform .2s,border-color .2s,box-shadow .2s;display:flex}.topic-card:hover{border-color:var(--color-primary-600);transform:translateY(-4px);box-shadow:0 8px 24px #0003}.topic-card-icon{font-size:1.75rem}.topic-card-label{color:var(--color-text-secondary);font-size:.8rem}.message-reactions{gap:.35rem;margin-top:.5rem;display:flex}.message-reaction-btn{color:var(--color-text-muted);background:var(--color-bg-tertiary);border:1px solid var(--color-border);cursor:pointer;border-radius:12px;align-items:center;gap:.25rem;padding:.2rem .5rem;font-size:.75rem;transition:background .2s,border-color .2s;display:inline-flex}.message-reaction-btn:hover{background:var(--color-bg-card-hover);border-color:var(--color-border-light)}.message-reaction-btn.active{border-color:var(--color-primary-600);color:var(--color-primary-400);background:#52b78826}.voice-input-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);width:44px;height:44px;color:var(--color-text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:background .2s;display:flex;position:relative}.voice-input-btn:hover{background:var(--color-bg-card-hover)}.voice-input-btn.recording{border-color:var(--color-error);color:var(--color-error);background:#e76f5126}.voice-input-btn.recording:after{content:"";border:2px solid var(--color-error);border-radius:50%;animation:1.2s ease-in-out infinite voice-pulse;position:absolute;inset:-6px}@keyframes voice-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:0;transform:scale(1.3)}}.markdown-content strong{color:var(--color-text-primary);font-weight:600}.markdown-content em{color:var(--color-primary-300);font-style:italic}.markdown-content ul,.markdown-content ol{margin:.5rem 0;padding-left:1.25rem}.markdown-content li{color:var(--color-text-secondary);margin-bottom:.3rem}.markdown-content code{background:var(--color-bg-tertiary);color:var(--color-primary-300);border-radius:4px;padding:.15rem .4rem;font-size:.85em}.context-pill{color:var(--color-primary-300);border:1px solid var(--color-primary-700);background:#2d6a4f33;border-radius:10px;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.7rem;font-weight:500;display:inline-flex}@media (max-width:768px){.topic-cards{grid-template-columns:repeat(2,1fr)}}.timeline-view{padding:2rem 0;position:relative}.timeline-view:before{content:"";background:var(--color-border);width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.timeline-item{width:45%;margin-bottom:2rem;position:relative}.timeline-item:nth-child(odd){margin-left:5%}.timeline-item:nth-child(2n){margin-left:50%}.timeline-dot{background:var(--color-primary-500);border:3px solid var(--color-bg-primary);z-index:1;border-radius:50%;width:14px;height:14px;position:absolute;top:1.25rem}.timeline-item:nth-child(odd) .timeline-dot{right:-7%;transform:translate(50%)}.timeline-item:nth-child(2n) .timeline-dot{left:-7%;transform:translate(-50%)}.timeline-date{color:var(--color-text-muted);margin-bottom:.5rem;font-size:.75rem}.timeline-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1rem;transition:border-color .2s,transform .2s}.timeline-card:hover{border-color:var(--color-primary-700);transform:translateY(-2px)}.bulk-action-bar{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--color-border);z-index:100;background:#1a2420d9;justify-content:space-between;align-items:center;padding:1rem 1.5rem;transition:transform .3s;display:flex;position:fixed;bottom:0;left:0;right:0;transform:translateY(100%)}.bulk-action-bar.visible{transform:translateY(0)}.bulk-action-bar span{color:var(--color-text-secondary);font-size:.85rem}.filter-pills{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:.5rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.filter-pills::-webkit-scrollbar{display:none}.filter-pill{color:var(--color-text-secondary);background:var(--color-bg-tertiary);border:1px solid var(--color-border);cursor:pointer;scroll-snap-align:start;white-space:nowrap;border-radius:20px;flex-shrink:0;padding:.4rem 1rem;font-size:.8rem;transition:background .2s,color .2s,border-color .2s}.filter-pill:hover{background:var(--color-bg-card-hover)}.filter-pill.active{background:var(--color-primary-700);border-color:var(--color-primary-600);color:var(--color-text-primary)}@media (max-width:768px){.timeline-view:before{left:20px}.timeline-item,.timeline-item:nth-child(odd),.timeline-item:nth-child(2n){width:calc(100% - 48px);margin-left:48px}.timeline-item:nth-child(odd) .timeline-dot,.timeline-item:nth-child(2n) .timeline-dot{left:-34px;right:auto;transform:none}}.profile-cover{background:linear-gradient(135deg,var(--color-primary-900)0%,var(--color-primary-700)50%,var(--color-primary-800)100%);border-radius:0 0 24px 24px;width:100%;height:200px;position:relative}.profile-tabs{border-bottom:1px solid var(--color-border);gap:0;margin-bottom:1.5rem;display:flex}.profile-tab{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:.75rem 1.25rem;font-size:.9rem;transition:color .2s;position:relative}.profile-tab:hover{color:var(--color-text-secondary)}.profile-tab.active{color:var(--color-primary-400)}.profile-tab.active:after{content:"";background:var(--color-primary-500);border-radius:2px 2px 0 0;height:2px;position:absolute;bottom:-1px;left:0;right:0}.activity-heatmap{grid-template-rows:repeat(7,1fr);grid-template-columns:repeat(52,1fr);gap:3px;display:grid}.heatmap-cell{aspect-ratio:1;background:var(--color-bg-tertiary);border-radius:2px;width:100%;transition:background .15s}.heatmap-cell.level-1{background:var(--color-primary-900)}.heatmap-cell.level-2{background:var(--color-primary-700)}.heatmap-cell.level-3{background:var(--color-primary-500)}.heatmap-cell.level-4{background:var(--color-primary-300)}.diversity-chart{flex-direction:column;gap:.75rem;display:flex}.diversity-bar-row{align-items:center;gap:.75rem;display:flex}.diversity-bar-label{width:100px;color:var(--color-text-secondary);text-align:right;flex-shrink:0;font-size:.8rem}.diversity-bar-track{background:var(--color-bg-tertiary);border-radius:5px;flex:1;height:10px;overflow:hidden}.diversity-bar-fill{border-radius:5px;height:100%;transition:width .6s}.diversity-bar-fill.mammals{background:var(--color-primary-500)}.diversity-bar-fill.birds{background:var(--color-accent-amber)}.diversity-bar-fill.reptiles{background:var(--color-accent-coral)}.diversity-bar-fill.insects{background:var(--color-warning)}.diversity-bar-fill.fish{background:#48bfe3}.diversity-bar-fill.amphibians{background:#9b5de5}.diversity-bar-count{width:36px;color:var(--color-text-muted);flex-shrink:0;font-size:.8rem}.bio-section{margin-bottom:1.5rem}.bio-section p{color:var(--color-text-secondary);font-size:.9rem;line-height:1.6}.bio-section textarea{width:100%;min-height:80px;color:var(--color-text-primary);background:var(--color-bg-input);border:1px solid var(--color-border);resize:vertical;border-radius:10px;padding:.75rem;font-family:inherit;font-size:.9rem;line-height:1.6;transition:border-color .2s}.bio-section textarea:focus{border-color:var(--color-primary-500);outline:none}.bio-edit-toggle{color:var(--color-primary-400);cursor:pointer;background:0 0;border:none;margin-top:.5rem;padding:0;font-size:.8rem}.bio-edit-toggle:hover{text-decoration:underline}@media (max-width:768px){.profile-cover{border-radius:0 0 16px 16px;height:140px}.profile-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.profile-tab{white-space:nowrap;padding:.65rem 1rem;font-size:.85rem}.activity-heatmap{gap:2px}.diversity-bar-label{width:72px;font-size:.75rem}}
