*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-deep:#0b1310;--bg-base:#121c18;--bg-surface:#192420;--bg-elevated:#232f2a;--bg-hover:#2b3b34;--primary:#28af60;--primary-light:#37d278;--primary-dark:#1e8549;--primary-glow:#28af6040;--primary-soft:#28af601a;--accent:#f6b828;--accent-light:#f8c859;--accent-glow:#f6b82833;--danger:#df3a3a;--danger-dark:#b81e1e;--text-primary:#e9ece9;--text-secondary:#a0aba0;--text-muted:#6e776e;--text-inverse:#0b1310;--border:#3d5c4a4d;--border-light:#527a6326;--glass-bg:#182520a6;--glass-border:#47856133;--glass-blur:16px;--shadow-sm:0 2px 8px #00000040;--shadow-md:0 4px 20px #00000059;--shadow-lg:0 8px 40px #00000073;--shadow-glow:0 0 30px var(--primary-glow);--font-heading:"Outfit", sans-serif;--font-body:"Inter", sans-serif;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s;--nav-height:64px;--sidebar-width:360px}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}html,body{max-width:100vw;overflow-x:hidden}body{font-family:var(--font-body);background:var(--bg-deep);color:var(--text-primary);min-height:100dvh;line-height:1.6}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20% 20%,#19663914 0%,#0000 50%),radial-gradient(at 80% 80%,#e6a81a0d 0%,#0000 50%),radial-gradient(#1736291a 0%,#0000 70%);position:fixed;inset:0}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text-primary);font-weight:600;line-height:1.2}a{color:var(--primary-light);transition:color var(--duration-fast) ease;text-decoration:none}a:hover{color:var(--accent)}img{max-width:100%;height:auto}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.glass-nav{-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);background:#101915cc}.top-nav{height:var(--nav-height);padding:0 var(--space-lg);z-index:1000;align-items:center;gap:var(--space-md);display:flex;position:fixed;top:0;left:0;right:0}.nav-brand{align-items:center;gap:var(--space-sm);flex-shrink:0;display:flex}.brand-icon{filter:drop-shadow(0 0 8px var(--primary-glow));font-size:1.6rem}.brand-text{font-family:var(--font-heading);background:linear-gradient(135deg, var(--primary-light), var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700}.nav-links{align-items:center;gap:var(--space-xs);margin:0 auto;display:flex}.nav-link{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--duration-normal) var(--ease-out);white-space:nowrap;font-size:.875rem;font-weight:500;display:flex;position:relative}.nav-link:hover{color:var(--text-primary);background:var(--primary-soft)}.nav-link.active{color:var(--primary-light);background:var(--primary-soft)}.nav-link.active:after{content:"";background:var(--primary);border-radius:var(--radius-full);width:20px;height:3px;box-shadow:0 0 10px var(--primary-glow);position:absolute;bottom:-2px;left:50%;transform:translate(-50%)}.nav-icon{flex-shrink:0;width:18px;height:18px}.nav-profile-link{display:none!important}@media (width<=768px){.nav-profile-link.nav-profile-visible{display:flex!important}}.nav-actions{align-items:center;gap:var(--space-sm);flex-shrink:0;display:flex}.mobile-menu-btn{cursor:pointer;padding:var(--space-sm);background:0 0;border:none;flex-direction:column;gap:5px;display:none}.mobile-menu-btn span{background:var(--text-primary);width:22px;height:2px;transition:all var(--duration-normal) var(--ease-out);border-radius:2px;display:block}.mobile-menu-btn.open span:first-child{transform:translateY(7px)rotate(45deg)}.mobile-menu-btn.open span:nth-child(2){opacity:0}.mobile-menu-btn.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.user-menu{position:relative}.user-avatar-btn{cursor:pointer;border-radius:var(--radius-full);transition:box-shadow var(--duration-fast) ease;background:0 0;border:none;padding:2px}.user-avatar-btn:hover{box-shadow:0 0 0 2px var(--primary)}.dropdown-menu{top:calc(100% + var(--space-sm));background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);min-width:200px;box-shadow:var(--shadow-lg);animation:dropdown-in var(--duration-normal) var(--ease-out);z-index:1001;position:absolute;right:0;overflow:hidden}.dropdown-header{padding:var(--space-md);color:var(--text-primary);border-bottom:1px solid var(--border-light);font-size:.875rem;font-weight:600}.dropdown-item{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);color:var(--text-secondary);text-align:left;cursor:pointer;width:100%;transition:all var(--duration-fast) ease;font-size:.875rem;font-family:var(--font-body);background:0 0;border:none;display:flex}.dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:#df3a3a1a}.dropdown-item svg{flex-shrink:0;width:16px;height:16px}.dropdown-divider{background:var(--border-light);height:1px;margin:var(--space-xs) 0}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-8px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.app-container{margin-top:var(--nav-height);min-height:calc(100vh - var(--nav-height));z-index:1;position:relative}button,.btn-primary,.btn-secondary,.btn-accent,.btn-danger,.btn-google{font-family:var(--font-body);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);border:none;outline:none;font-weight:500}.btn-primary{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;border-radius:var(--radius-md);box-shadow:0 2px 12px var(--primary-glow);font-size:.9rem;display:inline-flex;position:relative;overflow:hidden}.btn-primary:before{content:"";opacity:0;transition:opacity var(--duration-fast) ease;background:linear-gradient(135deg,#0000,#ffffff1a);position:absolute;inset:0}.btn-primary:hover:before{opacity:1}.btn-primary:hover{box-shadow:0 4px 20px var(--primary-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-md);background:0 0;font-size:.9rem;display:inline-flex}.btn-secondary:hover{border-color:var(--primary);color:var(--primary-light);background:var(--primary-soft)}.btn-accent{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:linear-gradient(135deg, var(--accent), #cf9717);color:var(--text-inverse);border-radius:var(--radius-md);box-shadow:0 2px 12px var(--accent-glow);font-size:.9rem;font-weight:600;display:inline-flex}.btn-accent:hover{box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}.btn-danger{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);color:var(--danger);border-radius:var(--radius-md);background:0 0;border:1px solid #df3a3a4d;font-size:.9rem;display:inline-flex}.btn-danger:hover{border-color:var(--danger);background:#df3a3a1a}.btn-google{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);font-size:.9rem;display:inline-flex}.btn-google:hover{background:var(--bg-hover);border-color:var(--text-muted)}.btn-sm{padding:6px var(--space-md);font-size:.8rem}.btn-xs{padding:4px var(--space-sm);font-size:.75rem}.btn-full{width:100%}.btn-icon{border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-secondary);border:1px solid var(--border-light);background:0 0;justify-content:center;align-items:center;padding:0;display:inline-flex}.btn-icon:hover{background:var(--primary-soft);color:var(--primary-light);border-color:var(--primary)}.form-group{margin-bottom:var(--space-md)}.form-label{color:var(--text-secondary);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:500;display:block}.input-field,.textarea-field{box-sizing:border-box;width:100%;max-width:100%;padding:var(--space-sm) var(--space-md);background:var(--bg-base);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);transition:all var(--duration-fast) ease;-webkit-appearance:none;outline:none;font-size:1rem}.input-field:focus,.textarea-field:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.input-field::placeholder,.textarea-field::placeholder{color:var(--text-muted)}.textarea-field{resize:vertical;min-height:80px}.form-hint{color:var(--text-muted);margin-top:var(--space-xs);font-size:.75rem;display:block}.form-actions{justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg);display:flex}.form-section{margin-top:var(--space-lg)}.checkbox-label{align-items:center;gap:var(--space-sm);cursor:pointer;color:var(--text-secondary);-webkit-user-select:none;user-select:none;font-size:.875rem;display:flex}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.toggle-group{background:var(--bg-base);border-radius:var(--radius-md);border:1px solid var(--border-light);gap:2px;padding:3px;display:flex}.toggle-btn{justify-content:center;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);background:0 0;border:none;flex:1;font-size:.8rem;font-weight:500;display:flex}.toggle-btn.active{background:var(--primary-soft);color:var(--primary-light);box-shadow:0 1px 4px #00000026}.toggle-btn:hover:not(.active){color:var(--text-secondary)}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:2000;padding:var(--space-md);animation:modal-bg-in var(--duration-normal) ease;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes modal-bg-in{0%{opacity:0}to{opacity:1}}.modal-content{width:100%;max-width:480px;max-height:90vh;padding:var(--space-xl);position:relative;overflow-y:auto}.modal-lg{max-width:640px}.modal-close{top:var(--space-md);right:var(--space-md);background:var(--bg-hover);border-radius:var(--radius-full);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) ease;z-index:1;border:none;justify-content:center;align-items:center;font-size:1.2rem;display:flex;position:absolute}.modal-close:hover{background:var(--danger);color:#fff}.modal-title{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg);font-size:1.3rem;display:flex}.title-icon{font-size:1.4rem}.profile-settings-modal{max-width:520px;max-height:85vh;overflow-y:auto}.profile-avatar-section{margin-bottom:var(--space-lg);flex-direction:column;align-items:center;display:flex}.profile-avatar-wrapper{cursor:pointer;border-radius:50%;width:96px;height:96px;position:relative;overflow:visible}.profile-avatar-img{object-fit:cover;border:3px solid var(--primary-soft);border-radius:50%;width:96px;height:96px}.profile-avatar-placeholder{background:var(--bg-elevated);border:3px dashed var(--border-light);width:96px;height:96px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;display:flex}.profile-avatar-edit{background:var(--primary);color:#fff;cursor:pointer;border:2px solid var(--bg-surface);width:30px;height:30px;transition:background var(--duration-fast) ease;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;bottom:0;right:0}.profile-avatar-edit:hover{background:var(--primary-light)}.profile-avatar-hint{margin-top:var(--space-sm);color:var(--text-muted);font-size:.75rem}.profile-section{padding-top:var(--space-md);margin-top:var(--space-md);border-top:1px solid var(--border-light)}.profile-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-md);font-size:.75rem;font-weight:700}.profile-textarea{resize:vertical;min-height:80px;font-family:inherit;line-height:1.5}.char-count{text-align:right;color:var(--text-muted);margin-top:4px;font-size:.7rem}.form-hint{color:var(--text-muted);margin-top:4px;font-size:.75rem;line-height:1.4}.auth-header{text-align:center;margin-bottom:var(--space-xl)}.auth-logo{margin-bottom:var(--space-sm);filter:drop-shadow(0 0 12px var(--primary-glow));font-size:3rem;display:inline-block}.auth-header h2{margin-bottom:var(--space-xs);font-size:1.5rem}.auth-divider{align-items:center;gap:var(--space-md);margin:var(--space-lg) 0;color:var(--text-muted);font-size:.8rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border-light);flex:1;height:1px}.auth-footer{text-align:center;color:var(--text-muted);margin-top:var(--space-md);font-size:.85rem}.error-msg{color:var(--danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-top:var(--space-md);background:#df3a3a1a;border:1px solid #df3a3a4d;font-size:.85rem}.avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;width:40px;height:40px;font-family:var(--font-heading);flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:600;display:inline-flex}.avatar-sm{width:32px;height:32px;font-size:.8rem}.avatar-lg{width:56px;height:56px;font-size:1.3rem}.avatar-xl{width:72px;height:72px;font-size:1.6rem}.badge{background:var(--danger);color:#fff;border-radius:var(--radius-full);justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:.65rem;font-weight:700;line-height:1;display:inline-flex}.badge-accent{background:var(--accent);color:var(--text-inverse)}.badge-tag{background:var(--primary-soft);color:var(--primary-light);border:1px solid #28af6033;padding:2px 8px;font-size:.72rem;font-weight:500}.loading-spinner{padding:var(--space-xl);justify-content:center;align-items:center;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.spinner-sm{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-skeleton{background:linear-gradient(90deg, var(--bg-surface) 25%, var(--bg-elevated) 50%, var(--bg-surface) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.toast-container{bottom:var(--space-lg);right:var(--space-lg);gap:var(--space-sm);z-index:3000;pointer-events:none;flex-direction:column;display:flex;position:fixed}.toast{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);color:var(--text-primary);animation:toast-in var(--duration-slow) var(--ease-spring);pointer-events:auto;max-width:360px;font-size:.875rem;display:flex}.toast.success{border-left:3px solid var(--primary)}.toast.error{border-left:3px solid var(--danger)}.toast.info{border-left:3px solid var(--accent)}.toast-icon{flex-shrink:0;font-size:1.1rem}.toast.removing{animation:toast-out var(--duration-normal) var(--ease-out) forwards}@keyframes toast-in{0%{opacity:0;transform:translate(40px)scale(.95)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes toast-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(40px)}}.fab{bottom:var(--space-xl);right:var(--space-xl);border-radius:var(--radius-full);background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;width:56px;height:56px;box-shadow:0 4px 20px var(--primary-glow), 0 0 40px #28af6026;cursor:pointer;z-index:900;transition:all var(--duration-normal) var(--ease-spring);border:none;justify-content:center;align-items:center;display:flex;position:fixed}.fab svg{width:24px;height:24px}.fab:hover{box-shadow:0 6px 30px var(--primary-glow), 0 0 60px #28af6033;transform:scale(1.1)translateY(-2px)}.fab:active{transform:scale(.95)}.fab:after{content:"";border-radius:var(--radius-full);border:2px solid var(--primary);pointer-events:none;animation:2s infinite fab-pulse;position:absolute;inset:-4px}@keyframes fab-pulse{0%,to{opacity:0;transform:scale(1)}50%{opacity:.4;transform:scale(1.15)}}.leaflet-container{background:var(--bg-deep)!important}.leaflet-control-zoom{box-shadow:var(--shadow-md)!important;border:none!important}.leaflet-control-zoom a{background:var(--bg-elevated)!important;color:var(--text-primary)!important;border:1px solid var(--border)!important;width:36px!important;height:36px!important;font-size:1.1rem!important;line-height:36px!important}.leaflet-control-zoom a:hover{background:var(--bg-hover)!important}.leaflet-popup-content-wrapper{background:var(--bg-elevated)!important;color:var(--text-primary)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important;border:1px solid var(--border)!important}.leaflet-popup-tip{background:var(--bg-elevated)!important;border:1px solid var(--border)!important;box-shadow:none!important}.leaflet-popup-close-button{color:var(--text-muted)!important;font-size:1.2rem!important}.leaflet-popup-close-button:hover{color:var(--text-primary)!important}.custom-marker{background:linear-gradient(135deg, var(--primary), var(--primary-dark));border-radius:var(--radius-full);width:36px;height:36px;animation:marker-drop .5s var(--ease-spring);border:3px solid #fff;justify-content:center;align-items:center;font-size:1rem;display:flex;box-shadow:0 2px 12px #0006}.custom-marker.public-marker{background:linear-gradient(135deg, var(--accent), #cf9717)}@keyframes marker-drop{0%{opacity:0;transform:translateY(-20px)scale(.5)}to{opacity:1;transform:translateY(0)scale(1)}}.marker-popup{padding:var(--space-sm);min-width:180px}.marker-popup h4{margin-bottom:var(--space-xs);color:var(--text-primary);font-size:.95rem}.marker-popup .popup-species{color:var(--primary-light);margin-bottom:var(--space-xs);font-size:.8rem;font-style:italic}.marker-popup .popup-desc{color:var(--text-secondary);margin-bottom:var(--space-sm);font-size:.8rem;line-height:1.4}.marker-popup .popup-user{color:var(--text-muted);font-size:.75rem}.marker-popup .popup-img{object-fit:cover;border-radius:var(--radius-sm);width:100%;height:120px;margin-bottom:var(--space-sm)}.map-controls{top:var(--space-md);left:var(--space-md);z-index:800;gap:var(--space-sm);flex-direction:column;display:flex;position:absolute}.map-filter-bar{gap:var(--space-xs);background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);padding:var(--space-xs);border-radius:var(--radius-md);border:1px solid var(--glass-border);display:flex}.map-filter-btn{border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--duration-fast) ease;white-space:nowrap;background:0 0;border:none;padding:6px 12px;font-size:.75rem;font-weight:500}.map-filter-btn.active{background:var(--primary-soft);color:var(--primary-light)}.map-filter-btn:hover:not(.active){color:var(--text-secondary)}.location-info{margin-top:var(--space-xs);justify-content:space-between;align-items:center;display:flex}.photo-section{text-align:center}.photo-preview{justify-content:center;align-items:center;gap:var(--space-sm);background:var(--bg-base);border:2px dashed var(--border);border-radius:var(--radius-md);width:100%;height:200px;color:var(--text-muted);cursor:pointer;transition:all var(--duration-normal) ease;flex-direction:column;font-size:.85rem;display:flex}.photo-actions{gap:var(--space-sm);margin-top:var(--space-sm);justify-content:center;display:flex}.ai-result{text-align:left;margin-top:var(--space-md);padding:var(--space-md);border:1px solid var(--accent-glow);background:#e6a81a0d}.ai-icon{font-size:1.1rem;animation:2s infinite sparkle}@keyframes sparkle{0%,to{opacity:1}50%{opacity:.5;transform:scale(1.2)}}#ai-result-content strong{color:var(--text-primary)}.collection-view{padding:var(--space-lg);max-width:1200px;margin:0 auto}.collection-header h1{align-items:center;gap:var(--space-sm);font-size:1.8rem;display:flex}.search-bar input{width:100%;padding:var(--space-sm) var(--space-md) var(--space-sm) 40px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-primary);transition:all var(--duration-fast) ease;font-size:.875rem;font-family:var(--font-body);outline:none}.search-bar .search-icon{width:18px;height:18px;color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.tab-bar{background:var(--bg-base);border-radius:var(--radius-md);border:1px solid var(--border-light);margin-bottom:var(--space-lg);gap:2px;padding:3px;display:flex}.tab-item{padding:var(--space-sm) var(--space-md);text-align:center;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);font-size:.85rem;font-weight:500;font-family:var(--font-body);background:0 0;border:none;flex:1}.tab-item:hover:not(.active){color:var(--text-secondary)}.plant-card{border-radius:var(--radius-lg);background:var(--bg-surface);border:1px solid var(--border-light);transition:all var(--duration-normal) var(--ease-out);cursor:pointer;overflow:hidden}.plant-card-img{object-fit:cover;background:var(--bg-base);width:100%;height:180px;position:relative}.plant-card-name{font-family:var(--font-heading);margin-bottom:var(--space-xs);font-size:1.05rem;font-weight:600}.plant-card-desc{color:var(--text-secondary);-webkit-line-clamp:2;margin-bottom:var(--space-sm);-webkit-box-orient:vertical;font-size:.8rem;display:-webkit-box;overflow:hidden}.plant-card-footer{color:var(--text-muted);justify-content:space-between;align-items:center;font-size:.75rem;display:flex}.plant-card-tags{gap:var(--space-xs);flex-wrap:wrap;display:flex}.plant-card-visibility{align-items:center;gap:4px;display:flex}.plant-card-visibility svg{width:12px;height:12px}.explore-view{height:calc(100vh - var(--nav-height));position:relative;overflow:hidden}.explore-map{z-index:1;position:absolute;inset:0}.explore-overlay{z-index:800;padding:var(--space-md);pointer-events:none;position:absolute;top:0;left:0;right:0}.explore-search-float{pointer-events:auto;max-width:420px;margin:0 auto;position:relative}.explore-search-float input{box-sizing:border-box;-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-full);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;background:#121615d9;outline:none;padding:12px 16px 12px 44px;font-size:.9rem;box-shadow:0 4px 20px #0000004d}.explore-search-float input:focus{border-color:var(--primary);box-shadow:0 4px 20px #0000004d, 0 0 0 3px var(--primary-glow)}.explore-search-float input::placeholder{color:var(--text-muted)}.explore-search-icon{width:18px;height:18px;color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.explore-sheet{z-index:800;-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);border-radius:var(--radius-xl) var(--radius-xl) 0 0;background:#121615eb;flex-direction:column;max-height:30%;transition:max-height .35s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;bottom:0;left:0;right:0;box-shadow:0 -4px 30px #0006}.explore-sheet.expanded{max-height:65%}.explore-sheet-handle{padding:10px var(--space-md) var(--space-sm);cursor:pointer;-webkit-user-select:none;user-select:none;flex-direction:column;flex-shrink:0;align-items:center;display:flex}.explore-sheet-pill{background:#ffffff40;border-radius:2px;width:36px;height:4px;margin-bottom:8px}.explore-sheet-title{color:var(--text-secondary);letter-spacing:.02em;font-size:.85rem;font-weight:600}.explore-feed{gap:var(--space-sm);padding:0 var(--space-md) var(--space-md);-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.explore-card{gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-md);border:1px solid var(--border-light);cursor:pointer;transition:all var(--duration-fast) ease;background:#20272599;flex-shrink:0;display:flex}.explore-card:hover,.explore-card:active{border-color:var(--primary);background:var(--primary-soft)}.explore-card-img{border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-base);flex-shrink:0;width:52px;height:52px}.explore-card-info{flex:1;min-width:0}.explore-card-name{white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:.85rem;font-weight:600;overflow:hidden}.explore-card-user{color:var(--text-muted);font-size:.75rem}.explore-empty{text-align:center;padding:var(--space-md);color:var(--text-muted);font-size:.85rem}.explore-empty span{vertical-align:middle;margin-right:4px;font-size:1.2rem}.messages-view{height:calc(100vh - var(--nav-height));max-width:1000px;margin:0 auto;display:flex;position:relative}.chat-back-btn{color:var(--text-primary);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--duration-fast) ease;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:none}.chat-back-btn:hover{background:var(--bg-hover)}.conversations-list{border-right:1px solid var(--border-light);flex-shrink:0;width:300px;overflow-y:auto}.conversations-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-light)}.conversation-item{align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);cursor:pointer;border-bottom:1px solid var(--border-light);transition:background var(--duration-fast) ease;display:flex}.conversation-item:hover,.conversation-item.active{background:var(--primary-soft)}.conversation-item .avatar{flex-shrink:0}.conversation-name{font-size:.875rem;font-weight:600}.conversation-time{color:var(--text-muted);flex-shrink:0;font-size:.7rem}.chat-area{flex-direction:column;flex:1;display:flex}.chat-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-light);align-items:center;gap:var(--space-sm);display:flex}.chat-bubble{max-width:70%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);animation:chat-in var(--duration-normal) var(--ease-out);font-size:.875rem;line-height:1.5}.chat-bubble-time{color:#ffffff80;margin-top:var(--space-xs);text-align:right;font-size:.65rem}@keyframes chat-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-input-area{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-light);gap:var(--space-sm);display:flex}.chat-input-area input{padding:var(--space-sm) var(--space-md);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-primary);font-size:.875rem;font-family:var(--font-body);outline:none;flex:1}.chat-input-area input:focus{border-color:var(--primary)}.chat-send-btn{border-radius:var(--radius-full);background:var(--primary);color:#fff;cursor:pointer;width:40px;height:40px;transition:all var(--duration-fast) ease;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.community-view{flex-direction:column;height:100%;display:flex}.community-tabs{padding:var(--space-md) var(--space-lg) 0;box-sizing:border-box;gap:4px;width:100%;max-width:800px;margin:0 auto;display:flex}.community-tab{border:1px solid var(--border-light);border-radius:var(--radius-md) var(--radius-md) 0 0;color:var(--text-muted);cursor:pointer;transition:all var(--duration-fast) ease;background:0 0;border-bottom:none;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 16px;font-size:.85rem;font-weight:500;display:flex}.community-tab:hover{color:var(--text-primary);background:#ffffff08}.community-tab.active{color:var(--primary-light);background:var(--bg-surface);border-color:var(--primary-soft);font-weight:600}.community-tab svg{flex-shrink:0}.community-content{flex:1;overflow-y:auto}.board-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.board-header h1{align-items:center;gap:var(--space-sm);font-size:1.8rem;display:flex}.new-post-form{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl)}.new-post-form .form-group:last-of-type{margin-bottom:0}.post-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md);transition:border-color var(--duration-fast) ease}.post-author{font-size:.9rem;font-weight:600}.post-author-link{color:var(--primary-light);transition:all var(--duration-fast) ease;font-size:.9rem;font-weight:600;text-decoration:none}.post-author-link:hover{filter:brightness(1.2);text-decoration:underline}.post-content{color:var(--text-secondary);margin-bottom:var(--space-md);white-space:pre-wrap;font-size:.9rem;line-height:1.7}.post-actions{gap:var(--space-md);padding-top:var(--space-sm);border-top:1px solid var(--border-light);display:flex}.post-action-btn{align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--duration-fast) ease;font-size:.8rem;font-family:var(--font-body);background:0 0;border:none;display:flex}.post-action-btn:hover{color:var(--primary-light);background:var(--primary-soft)}.post-delete-btn:hover{color:#ed5e5e!important;background:#e61a1a1a!important;border-color:#a32929!important}.reply{gap:var(--space-sm);padding:var(--space-sm) 0;display:flex}.reply-content{flex:1}.reply-author{font-size:.8rem;font-weight:600}.reply-text{color:var(--text-secondary);margin-top:2px;font-size:.8rem}.reply-time{color:var(--text-muted);font-size:.7rem}.reply-form input{padding:6px var(--space-md);background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-primary);font-size:.8rem;font-family:var(--font-body);outline:none;flex:1}.empty-state{padding:var(--space-3xl) var(--space-lg);text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{margin-bottom:var(--space-md);opacity:.3;font-size:4rem}.empty-state h3{color:var(--text-secondary);margin-bottom:var(--space-sm);font-size:1.2rem}.empty-state p{max-width:360px;font-size:.875rem}.profile-view{max-width:900px;padding:var(--space-lg);margin:0 auto}.profile-card{align-items:center;gap:var(--space-lg);padding:var(--space-xl);margin-bottom:var(--space-xl);display:flex}.profile-info h2{margin-bottom:var(--space-xs);font-size:1.5rem}.avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%}.avatar-img.avatar-sm{width:32px;height:32px}.profile-avatar-lg{object-fit:cover;border:3px solid var(--primary-soft);border-radius:50%;flex-shrink:0;width:80px;height:80px}.profile-details{margin:var(--space-sm) 0}.profile-detail-row{align-items:flex-start;gap:var(--space-sm);color:var(--text-secondary);margin-bottom:6px;font-size:.85rem;display:flex}.profile-detail-icon{flex-shrink:0;font-size:.9rem}.profile-detail-text{line-height:1.4}.profile-stats{gap:var(--space-lg);margin-top:var(--space-sm);display:flex}.profile-stat{text-align:center}.profile-stat-value{font-family:var(--font-heading);color:var(--primary-light);font-size:1.3rem;font-weight:700}.profile-stat-label{color:var(--text-muted);text-transform:uppercase;font-size:.75rem}.profile-badges-section{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-light)}.profile-badges-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:var(--space-sm);font-size:.75rem;font-weight:700}.profile-badges-row{margin-bottom:var(--space-sm);flex-wrap:wrap;gap:6px;display:flex}.profile-badge{background:#ffffff0a;border:1.5px solid;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.profile-badge-next{color:var(--text-muted);font-size:.72rem}.fade-in{animation:fadeIn var(--duration-slow) var(--ease-out)}.slide-up{animation:slideUp var(--duration-slow) var(--ease-out)}.slide-in-left{animation:slideInLeft var(--duration-slow) var(--ease-out)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.plant-card:first-child{animation-delay:0s}.plant-card:nth-child(2){animation-delay:50ms}.plant-card:nth-child(3){animation-delay:.1s}.plant-card:nth-child(4){animation-delay:.15s}.plant-card:nth-child(5){animation-delay:.2s}.plant-card:nth-child(6){animation-delay:.25s}.plant-card{animation:slideUp var(--duration-slow) var(--ease-out) backwards}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}.text-muted{color:var(--text-muted)}.text-primary-color{color:var(--primary-light)}.text-accent{color:var(--accent)}.text-center{text-align:center}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.flex-center{justify-content:center;align-items:center;display:flex}.map-view{width:100%;height:calc(100vh - var(--nav-height));position:relative}.map-container{width:100%;height:100%}.map-controls{top:var(--space-md);left:var(--space-md);z-index:800;gap:var(--space-xs);display:flex;position:absolute}.map-filter-btn{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-full);color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);min-height:36px;padding:8px 16px;font-size:.8rem;font-weight:500}.map-filter-btn:hover{background:var(--primary-soft);color:var(--primary-light);border-color:var(--primary)}.map-filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 12px var(--primary-glow)}.map-locate-btn{bottom:90px;left:var(--space-md);z-index:800;background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-md);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;display:flex;position:absolute}.map-locate-btn:hover{background:var(--primary-soft);color:var(--primary-light)}.custom-marker{background:linear-gradient(135deg, var(--primary), var(--primary-dark));border-radius:var(--radius-full);border:2px solid var(--primary-light);width:36px;height:36px;box-shadow:0 2px 10px var(--primary-glow);justify-content:center;align-items:center;font-size:1rem;transition:transform .2s;display:flex}.custom-marker:hover{transform:scale(1.15)}.public-marker{background:linear-gradient(135deg, var(--accent), #c18d15);border-color:var(--accent-light);box-shadow:0 2px 10px var(--accent-glow)}.marker-popup{font-family:var(--font-body);color:var(--text-primary)}.marker-popup img{border-radius:var(--radius-sm);object-fit:cover;width:100%;max-height:120px;margin-bottom:8px}.marker-popup h4{font-family:var(--font-heading);margin:0 0 4px}.marker-popup p{color:var(--text-secondary);margin:0;font-size:.8rem}.leaflet-popup-content-wrapper{background:var(--bg-elevated)!important;color:var(--text-primary)!important;border:1px solid var(--glass-border)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important}.leaflet-popup-tip{background:var(--bg-elevated)!important}.leaflet-popup-close-button{color:var(--text-muted)!important}.leaflet-top.leaflet-left{top:52px}.leaflet-control-zoom{overflow:hidden;border:1px solid var(--glass-border)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-md)!important}.leaflet-control-zoom a{background:var(--bg-elevated)!important;color:var(--text-primary)!important;border-bottom:1px solid var(--glass-border)!important;width:36px!important;height:36px!important;font-size:16px!important;line-height:36px!important}.leaflet-control-zoom a:hover{background:var(--primary-soft)!important;color:var(--primary-light)!important}.collection-view{max-width:1200px;padding:var(--space-lg);margin:0 auto}.collection-header{justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.collection-header h1{white-space:nowrap;font-size:1.5rem}.search-bar{flex:1;max-width:320px;position:relative}.search-bar input,.search-bar input.input-field{box-sizing:border-box;background:var(--bg-surface);width:100%;color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-full);font-family:var(--font-body);transition:border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;outline:none;padding:10px 12px 10px 40px;font-size:.875rem}.search-bar input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.search-icon{width:18px;height:18px;color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.tab-bar{background:var(--bg-base);border-radius:var(--radius-md);border:1px solid var(--border-light);margin-bottom:var(--space-lg);-webkit-overflow-scrolling:touch;gap:2px;padding:3px;display:flex;overflow-x:auto}.tab-item{border-radius:var(--radius-sm);font-family:var(--font-body);color:var(--text-muted);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);white-space:nowrap;background:0 0;border:none;flex:1;min-height:44px;padding:10px 16px;font-size:.85rem;font-weight:500}.tab-item:hover{color:var(--text-secondary)}.tab-item.active{background:var(--primary-soft);color:var(--primary-light)}.plant-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.plant-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);animation:slideUp var(--duration-slow) var(--ease-out) backwards;position:relative;overflow:hidden}.plant-card:hover{box-shadow:var(--shadow-lg), var(--shadow-glow);border-color:var(--primary);transform:translateY(-4px)}.plant-card-img{object-fit:cover;width:100%;height:180px;display:block}.plant-card-img-placeholder{background:var(--bg-surface);opacity:.3;justify-content:center;align-items:center;width:100%;height:180px;font-size:3rem;display:flex}.plant-card-body{padding:var(--space-md)}.plant-card-name{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:2px;font-size:1.05rem;font-weight:600}.plant-card-species{color:var(--primary-light);margin-bottom:var(--space-sm);font-size:.8rem;font-style:italic}.plant-card-desc{color:var(--text-secondary);margin-bottom:var(--space-sm);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.825rem;line-height:1.5;display:-webkit-box;overflow:hidden}.plant-card-footer{justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.plant-card-tags{flex-wrap:wrap;flex:1;gap:4px;display:flex;overflow:hidden}.plant-card-visibility{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:.75rem}.plant-card-delete{top:var(--space-sm);right:var(--space-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;opacity:.6;transition:all var(--duration-fast) ease;background:#00000080;border:none;justify-content:center;align-items:center;display:flex;position:absolute}.plant-card:hover .plant-card-delete{opacity:1}.plant-card-delete:hover{background:var(--danger);color:#fff;opacity:1}.hunt-banner{padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-md);border-radius:var(--radius-lg);color:var(--text-primary);border:1px solid var(--primary-soft);transition:all var(--duration-fast) ease;cursor:pointer;background:linear-gradient(135deg,#1f472c66,#172b364d);justify-content:space-between;align-items:center;text-decoration:none;display:flex}.hunt-banner:hover{border-color:var(--primary);transform:translateY(-1px);box-shadow:0 4px 20px #29a35226}.hunt-banner-left{align-items:center;gap:var(--space-md);display:flex}.hunt-banner-icon{font-size:1.6rem}.hunt-banner-title{font-size:.95rem;font-weight:600}.hunt-banner-subtitle{color:var(--text-muted);margin-top:2px;font-size:.8rem}.hunt-banner-arrow{color:var(--primary);transition:transform var(--duration-fast) ease;font-size:1.2rem}.hunt-banner:hover .hunt-banner-arrow{transform:translate(3px)}.hunt-view{max-width:800px;padding:var(--space-lg);padding-bottom:calc(var(--space-xl) * 2);margin:0 auto}.hunt-header{margin-bottom:var(--space-lg)}.hunt-back-link{color:var(--text-muted);margin-bottom:var(--space-sm);transition:color var(--duration-fast) ease;font-size:.85rem;text-decoration:none;display:inline-block}.hunt-back-link:hover{color:var(--primary-light)}.hunt-title{margin-bottom:4px;font-size:1.6rem;font-weight:700}.hunt-subtitle{color:var(--text-muted);font-size:.9rem}.hunt-tier-section{align-items:center;gap:var(--space-lg);padding:var(--space-lg);margin-bottom:var(--space-lg);border-radius:var(--radius-lg);display:flex}.hunt-tier-ring{background:conic-gradient(var(--tier-color) 0deg, var(--tier-color) var(--progress), #ffffff14 var(--progress), #ffffff14 360deg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:100px;animation:.8s ease-out ringFadeIn;display:flex}@keyframes ringFadeIn{0%{opacity:0;transform:scale(.8)rotate(-90deg)}to{opacity:1;transform:scale(1)rotate(0)}}.hunt-tier-inner{background:var(--bg-surface);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;display:flex}.hunt-tier-emoji{font-size:2rem}.hunt-tier-info{flex:1}.hunt-tier-name{margin-bottom:4px;font-size:1.2rem;font-weight:700}.hunt-tier-stats{margin-bottom:var(--space-sm);align-items:baseline;gap:6px;display:flex}.hunt-stat-big{color:var(--primary-light);font-size:1.8rem;font-weight:800;line-height:1}.hunt-stat-label{color:var(--text-muted);font-size:.8rem}.hunt-tier-next-label{color:var(--text-secondary);margin-bottom:4px;font-size:.8rem}.hunt-tier-bar{background:#ffffff14;border-radius:3px;height:6px;overflow:hidden}.hunt-tier-bar-fill{border-radius:3px;height:100%;transition:width .8s}.hunt-tier-complete{color:var(--accent);font-size:.9rem;font-weight:600}.hunt-milestones{gap:var(--space-sm);margin-bottom:var(--space-xl);padding-bottom:var(--space-xs);display:flex;overflow-x:auto}.hunt-milestone{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:var(--bg-surface);border:1px solid var(--border-light);text-align:center;opacity:.5;min-width:100px;transition:all var(--duration-fast) ease;flex-direction:column;flex:1;align-items:center;gap:4px;display:flex;position:relative}.hunt-milestone.achieved{opacity:1;border-color:var(--primary);background:linear-gradient(135deg, #1f472c4d, var(--bg-surface))}.hunt-milestone-icon{font-size:1.4rem}.hunt-milestone-name{color:var(--text-secondary);font-size:.7rem;font-weight:600}.hunt-milestone-threshold{color:var(--text-muted);font-size:.75rem}.hunt-milestone-check{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.6rem;font-weight:700;display:flex;position:absolute;top:-6px;right:-6px}.hunt-section-title{margin-bottom:var(--space-md);color:var(--text-primary);font-size:1.1rem;font-weight:700}.hunt-challenges-grid{gap:var(--space-md);flex-direction:column;display:flex}.hunt-challenge-card{padding:var(--space-lg);border-radius:var(--radius-lg);transition:all var(--duration-fast) ease}.hunt-challenge-card.complete{border-color:var(--primary)}.hunt-challenge-header{align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md);display:flex}.hunt-challenge-icon{flex-shrink:0;font-size:1.8rem}.hunt-challenge-name{margin-bottom:2px;font-size:1rem;font-weight:700}.hunt-challenge-desc{color:var(--text-muted);font-size:.8rem}.hunt-challenge-progress{margin-bottom:var(--space-md)}.hunt-challenge-bar{background:#ffffff14;border-radius:4px;height:8px;margin-bottom:6px;overflow:hidden}.hunt-challenge-bar-fill{border-radius:4px;height:100%;transition:width .6s}.hunt-challenge-count{align-items:baseline;gap:4px;font-size:.85rem;display:flex}.hunt-found-count{font-size:1rem;font-weight:700}.hunt-total-count{color:var(--text-muted)}.hunt-complete-badge{color:var(--accent);margin-left:auto;font-size:.8rem;font-weight:600}.hunt-challenge-toggle{border:1px solid var(--border-light);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast) ease;background:0 0;width:100%;padding:6px 12px;font-size:.8rem}.hunt-challenge-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.hunt-checklist{margin-top:var(--space-md);border-radius:var(--radius-md);max-height:400px;padding:var(--space-sm);background:#00000026;flex-direction:column;gap:2px;display:none;overflow-y:auto}.hunt-checklist.open{display:flex}.hunt-checklist-item{align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);transition:background var(--duration-fast) ease;padding:6px 8px;font-size:.85rem;display:flex}.hunt-checklist-item:hover{background:#ffffff0a}.hunt-checklist-item.found{opacity:1}.hunt-checklist-item:not(.found){opacity:.5}.hunt-check{text-align:center;flex-shrink:0;width:22px;font-size:.85rem}.hunt-plant-name{color:var(--text-primary);flex:1;font-weight:500}.hunt-plant-sci{color:var(--text-muted);font-size:.75rem;font-style:italic}.hunt-loading{justify-content:center;align-items:center;gap:var(--space-md);min-height:300px;color:var(--text-muted);flex-direction:column;display:flex}.hunt-leaderboard{padding:var(--space-sm);border-radius:var(--radius-lg);margin-bottom:var(--space-xl)}.lb-row{align-items:center;gap:var(--space-md);padding:10px var(--space-md);border-radius:var(--radius-md);transition:background var(--duration-fast) ease;display:flex}.lb-row:hover{background:#ffffff0a}.lb-row.lb-me{background:#26734026;border:1px solid #33995540}.lb-medal{text-align:center;flex-shrink:0;width:32px;font-size:1.3rem}.lb-rank-num{color:var(--text-muted);font-size:.85rem;font-weight:700}.lb-avatar{background:var(--primary-soft);width:36px;height:36px;color:var(--primary-light);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.lb-info{flex:1;align-items:center;gap:6px;min-width:0;display:flex}.lb-name{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.lb-you{color:var(--primary-light);font-size:.75rem;font-weight:400}.lb-tier{flex-shrink:0;font-size:.9rem}.lb-count{color:var(--primary-light);text-align:right;flex-shrink:0;min-width:36px;font-size:1.1rem;font-weight:800}.skeleton-card{background:var(--bg-surface);border-radius:var(--radius-lg);overflow:hidden}.skeleton-img{background:linear-gradient(90deg, var(--bg-surface) 25%, var(--bg-elevated) 50%, var(--bg-surface) 75%);background-size:200% 100%;width:100%;height:180px;animation:1.5s infinite shimmer}.skeleton-body{padding:var(--space-md)}.skeleton-line{background:linear-gradient(90deg, var(--bg-surface) 25%, var(--bg-elevated) 50%, var(--bg-surface) 75%);background-size:200% 100%;border-radius:4px;height:14px;margin-bottom:8px;animation:1.5s infinite shimmer}.skeleton-line:last-child{width:60%}.messages-view{height:calc(100vh - var(--nav-height));display:flex;overflow:hidden}.conversations-list{border-right:1px solid var(--border-light);flex-direction:column;flex-shrink:0;width:340px;display:flex;overflow:hidden}.conversations-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-light);flex-shrink:0}.conversations-header h2{font-size:1.2rem}#conversations-container{flex:1;overflow-y:auto}.conversation-item{align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);cursor:pointer;transition:background var(--duration-fast) ease;border-bottom:1px solid var(--border-light);min-height:64px;display:flex}.conversation-item:hover{background:var(--bg-hover)}.conversation-item.active{background:var(--primary-soft)}.conversation-info{flex:1;min-width:0}.conversation-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.conversation-preview{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.conversation-time{color:var(--text-muted);white-space:nowrap;font-size:.7rem}.chat-area{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.chat-header{align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-light);background:var(--bg-base);flex-shrink:0;display:flex}.chat-messages{padding:var(--space-md) var(--space-lg);gap:var(--space-sm);flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-bubble{border-radius:var(--radius-lg);word-wrap:break-word;max-width:75%;animation:fadeIn var(--duration-fast) ease;padding:10px 14px;font-size:.9rem;line-height:1.5}.chat-bubble.sent{background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.chat-bubble.received{background:var(--bg-elevated);color:var(--text-primary);border-bottom-left-radius:4px;align-self:flex-start}.chat-bubble-time{color:#ffffff8c;text-align:right;margin-top:4px;font-size:.65rem}.chat-bubble.received .chat-bubble-time{color:var(--text-muted)}.chat-input-area{gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-light);background:var(--bg-base);flex-shrink:0;display:flex}.chat-input-area input{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-full);font-family:var(--font-body);outline:none;flex:1;min-height:44px;padding:12px 16px;font-size:.9rem}.chat-input-area input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.chat-send-btn{background:var(--primary);border-radius:var(--radius-full);color:#fff;cursor:pointer;width:44px;height:44px;transition:all var(--duration-fast) ease;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.chat-send-btn:hover{background:var(--primary-light);transform:scale(1.05)}.chat-send-btn svg{width:18px;height:18px}.board-view{max-width:700px;padding:var(--space-lg);margin:0 auto}.board-header{margin-bottom:var(--space-lg)}.board-header h1{margin-bottom:var(--space-xs);font-size:1.5rem}.new-post-form{padding:var(--space-lg);margin-bottom:var(--space-lg)}.post-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md);transition:border-color var(--duration-fast) ease}.post-card:hover{border-color:var(--primary)}.post-header{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);display:flex}.post-author{color:var(--primary-light);font-size:.9rem;font-weight:600}.post-time{color:var(--text-muted);font-size:.75rem}.post-content{color:var(--text-primary);margin-bottom:var(--space-md);white-space:pre-wrap;word-wrap:break-word;font-size:.9rem;line-height:1.6}.post-actions{gap:var(--space-sm);display:flex}.post-action-btn{border:1px solid var(--border-light);border-radius:var(--radius-full);color:var(--text-muted);font-family:var(--font-body);cursor:pointer;transition:all var(--duration-fast) ease;background:0 0;align-items:center;gap:6px;min-height:36px;padding:8px 14px;font-size:.8rem;display:flex}.post-action-btn:hover{background:var(--primary-soft);border-color:var(--primary);color:var(--primary-light)}.post-action-btn svg{width:16px;height:16px}.replies-section{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-light)}.reply-item{gap:var(--space-sm);padding:var(--space-sm) 0;font-size:.85rem;display:flex}.reply-form{gap:var(--space-sm);margin-top:var(--space-sm);display:flex}.reply-form input{background:var(--bg-base);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-full);font-family:var(--font-body);outline:none;flex:1;min-height:36px;padding:8px 14px;font-size:.825rem}.reply-form input:focus{border-color:var(--primary)}.plant-map-container{border-radius:var(--radius-md);border:1px solid var(--border);overflow:hidden}.plant-map{width:100%;height:200px}.location-info{justify-content:space-between;align-items:center;gap:var(--space-sm);margin-top:var(--space-sm);display:flex}.photo-section{margin-bottom:var(--space-lg)}.photo-preview{justify-content:center;align-items:center;gap:var(--space-sm);background:var(--bg-surface);border:2px dashed var(--border);border-radius:var(--radius-lg);cursor:pointer;width:100%;height:200px;color:var(--text-muted);transition:all var(--duration-fast) ease;flex-direction:column;font-size:.85rem;display:flex}.photo-preview:hover{border-color:var(--primary);color:var(--primary-light);background:var(--primary-soft)}.photo-placeholder-icon{opacity:.4;width:48px;height:48px}.photo-img{object-fit:contain;border-radius:var(--radius-md);width:100%;max-height:300px}.photo-actions{gap:var(--space-sm);margin-top:var(--space-sm);flex-wrap:wrap;display:flex}.ai-result{margin-top:var(--space-md);padding:var(--space-md)}.ai-result-header{align-items:center;gap:var(--space-sm);color:var(--accent);margin-bottom:var(--space-sm);font-size:.9rem;font-weight:600;display:flex}.ai-icon{font-size:1.2rem}#ai-result-content{color:var(--text-secondary);font-size:.85rem;line-height:1.6}@media (width<=768px){:root{--nav-height:56px}.top-nav{border-bottom:none;border-top:1px solid var(--glass-border);height:auto;padding:0;padding-bottom:env(safe-area-inset-bottom,0);flex-direction:column;top:auto;bottom:0}.nav-brand,.nav-actions,.mobile-menu-btn{display:none}.nav-links{background:0 0;border:none;flex-direction:row;gap:0;width:100%;padding:0;position:static;display:flex!important}.nav-link{text-align:center;border-radius:0;flex-direction:column;flex:1;justify-content:center;gap:2px;min-height:52px;padding:8px 4px 6px;font-size:.65rem}.nav-link.active:after{display:none}.nav-icon{width:20px;height:20px}.app-container{min-height:calc(100dvh - 52px);padding-bottom:env(safe-area-inset-bottom,0);margin-top:0;margin-bottom:52px}.map-view,.messages-view,.explore-view{height:calc(100dvh - 52px)}.map-controls{top:var(--space-sm);left:var(--space-sm);flex-wrap:wrap}.map-filter-btn{min-height:32px;padding:6px 12px;font-size:.75rem}.map-locate-btn{bottom:24px}.collection-view{padding:var(--space-md)}.collection-header{flex-direction:column;align-items:stretch}.collection-header h1{font-size:1.3rem}.search-bar{width:100%;max-width:100%}.plant-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.plant-card-img,.plant-card-img-placeholder{height:150px}.messages-view{flex-direction:column;height:calc(100dvh - 52px)}.messages-view .conversations-list{border-bottom:none;border-right:none;flex:1;width:100%;min-height:0;max-height:none}.messages-view .chat-area{z-index:10;background:var(--bg-base);flex-direction:column;display:none;position:absolute;inset:0}.messages-view .chat-area.mobile-active{display:flex}.messages-view .chat-area .empty-state{display:none}.conversation-item{padding:var(--space-sm) var(--space-md)}.chat-bubble{max-width:85%}.chat-header,.chat-messages{padding:var(--space-sm) var(--space-md)}.chat-input-area{padding:var(--space-sm) var(--space-md);padding-bottom:calc(var(--space-sm) + env(safe-area-inset-bottom,0))}.chat-back-btn{display:flex!important}.explore-view{height:calc(100dvh - 52px)}.explore-sheet{bottom:calc(56px + env(safe-area-inset-bottom,0))}.board-view{padding:var(--space-md)}.board-header h1{font-size:1.3rem}.post-card,.new-post-form{padding:var(--space-md)}.fab{bottom:calc(60px + env(safe-area-inset-bottom,0));right:var(--space-md)}.toast-container{bottom:calc(60px + env(safe-area-inset-bottom,0));right:var(--space-md);left:var(--space-md)}.toast{max-width:100%}.modal-content{padding:var(--space-lg);max-height:85vh;margin:var(--space-sm)}.modal-lg{max-width:100%}.plant-map,.photo-preview{height:160px}.profile-view{padding:var(--space-md)}.profile-card{text-align:center;padding:var(--space-lg);flex-direction:column}.profile-stats{justify-content:center}#btn-login,#user-menu{top:var(--space-md);right:var(--space-md);z-index:900;position:fixed}.dropdown-menu{top:56px;right:var(--space-md);z-index:901;position:fixed}}@media (width<=480px){.plant-grid{grid-template-columns:1fr}.modal-content{padding:var(--space-md);border-radius:var(--radius-md)}.collection-header h1{font-size:1.1rem}.tab-item{padding:8px 10px;font-size:.8rem}.plant-card-img,.plant-card-img-placeholder{height:140px}.conversations-list{max-height:30vh}.chat-bubble{max-width:90%;font-size:.85rem}.post-card{padding:var(--space-sm) var(--space-md)}.nav-link span{font-size:.6rem}}@media (hover:none) and (pointer:coarse){.btn-primary,.btn-secondary,.btn-accent,.btn-danger,.btn-google{min-height:44px}.conversation-item{min-height:64px}.explore-card{min-height:56px}.plant-card:hover{transform:none}.plant-card-delete{opacity:1}.post-card:hover{border-color:var(--glass-border)}*{-webkit-tap-highlight-color:transparent}.chat-messages,.explore-feed,#conversations-container,.modal-content{-webkit-overflow-scrolling:touch}}.splash-screen{z-index:99999;background:var(--bg-deep);justify-content:center;align-items:center;transition:opacity .8s cubic-bezier(.4,0,.2,1),visibility .8s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;inset:0}.splash-screen.fade-out{opacity:0;visibility:hidden;pointer-events:none}.splash-screen.hidden{display:none}.splash-video{object-fit:contain;object-position:center;width:100%;height:100%;position:absolute;inset:0}.splash-skip{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-full);color:#ffffffd9;font-family:var(--font-body);letter-spacing:.03em;cursor:pointer;z-index:10;transition:all .3s var(--ease-out);animation:splash-skip-appear .6s 1.5s both var(--ease-out);background:#ffffff1a;border:1px solid #fff3;align-items:center;gap:6px;min-height:44px;padding:10px 20px;font-size:.85rem;font-weight:500;display:flex;position:absolute;bottom:48px;right:40px}.splash-skip:hover{color:#fff;background:#fff3;border-color:#fff6;transform:translate(4px)}.splash-skip svg{transition:transform .3s var(--ease-out);flex-shrink:0}.splash-skip:hover svg{transform:translate(3px)}@keyframes splash-skip-appear{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.splash-progress{z-index:10;background:#ffffff14;height:3px;position:absolute;bottom:0;left:0;right:0}.splash-progress-bar{background:linear-gradient(90deg, var(--primary), var(--accent));width:0%;height:100%;box-shadow:0 0 12px var(--primary-glow), 0 0 4px var(--accent-glow);border-radius:0 2px 2px 0;transition:width .25s linear}.splash-active .top-nav,.splash-active .app-container,.splash-active .fab,.splash-active .toast-container{opacity:0;transition:opacity .5s .3s}body:not(.splash-active) .top-nav,body:not(.splash-active) .app-container,body:not(.splash-active) .fab,body:not(.splash-active) .toast-container{opacity:1;transition:opacity .6s}@media (width<=768px){.splash-skip{padding:8px 16px;font-size:.8rem;bottom:32px;right:24px}}
