body,html{height:100%;margin:0;padding:0;overflow:hidden}#__next{height:100%;overflow:auto}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}a,button{text-decoration:none!important;color:inherit}:root{--color-primary:#4a7c42;--color-primary-dark:#2d5a27;--color-primary-light:#5d9a54;--color-success:#e8f5e9;--color-warning:#fff3e0;--color-error:#ffebee;--color-text:#333;--color-text-light:#888;--color-border:#e0e0e0;--color-background:#fafafa;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-full:9999px;--shadow-sm:0 2px 8px rgba(0,0,0,.1);--shadow-md:0 4px 12px rgba(0,0,0,.15);--shadow-lg:0 8px 24px rgba(0,0,0,.2)}.discoveries-app{max-width:420px;margin:0 auto;background:var(--color-background);min-height:100%;position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;overscroll-behavior-y:contain;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.discoveries-app [contenteditable=true],.discoveries-app input,.discoveries-app select,.discoveries-app textarea{-webkit-user-select:text;-moz-user-select:text;user-select:text;-webkit-touch-callout:default}.discoveries-header{background:linear-gradient(135deg,var(--color-primary-dark) 0,var(--color-primary) 100%);color:#fff;padding:16px;display:flex;align-items:center;gap:12px;position:-webkit-sticky;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}.discoveries-header h1{margin:0;font-size:18px;font-weight:600}.discoveries-header .back-btn{background:hsla(0,0%,100%,.2);border:none;color:#fff;width:36px;height:36px;border-radius:var(--radius-full);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .2s}.discoveries-header .back-btn:hover{background:hsla(0,0%,100%,.3)}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:420px;background:#fff;border-top:1px solid var(--color-border);display:flex;justify-content:space-around;padding:8px 0 max(8px,env(safe-area-inset-bottom));z-index:100}.nav-btn{background:none;border:none;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 16px;cursor:pointer;color:var(--color-text-light);font-size:12px;transition:color .2s}.nav-btn.active{color:var(--color-primary-dark);font-weight:600}.nav-btn .icon{font-size:20px}.nav-btn.add-btn{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);color:#fff;padding:12px 24px;border-radius:24px;transform:translateY(-8px);box-shadow:0 4px 12px rgba(74,124,66,.4)}.nav-btn.add-btn .icon{font-size:24px}.content{padding:16px 16px 100px}.stats-card{background:linear-gradient(135deg,var(--color-success) 0,#c8e6c9 100%);border-radius:var(--radius-lg);padding:20px;margin-bottom:20px;display:flex;justify-content:space-around;align-items:center}.stats-year{text-align:center;flex:1 1}.stats-year .year-label{font-size:13px;color:#666;margin-bottom:4px}.stats-year .year-number{font-size:32px;font-weight:700;color:var(--color-primary-dark)}.stats-year.previous .year-number{font-size:24px;color:var(--color-text-light)}.stats-divider{width:1px;height:50px;background:rgba(0,0,0,.1);margin:0 10px}.stats-trend{font-size:12px;color:var(--color-primary);margin-top:4px}.group-card{width:100%;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;margin-bottom:8px;transition:all .2s}.group-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.group-card .left{display:flex;align-items:center;gap:12px}.group-card .group-icon{font-size:28px}.group-card .group-name{font-weight:600;color:var(--color-text)}.group-card .arrow,.group-card .group-count{font-size:12px;color:var(--color-text-light)}.group-card .arrow{transition:transform .2s}.group-card .arrow.open{transform:rotate(180deg)}.expanded-content{background:#fafafa;border-radius:0 0 var(--radius-md) var(--radius-md);margin-top:-8px;margin-bottom:8px;padding:16px;border-left:3px solid var(--color-primary);margin-left:20px}.family-name{font-size:13px;font-weight:600;color:#555;margin-bottom:12px}.species-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(85px,1fr));grid-gap:10px;gap:10px}.species-card{background:#fff;border-radius:var(--radius-md);padding:10px 6px;text-align:center;cursor:pointer;border:2px solid #e8e8e8;transition:all .2s}.species-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.species-card .card-icon{width:46px;height:46px;border-radius:var(--radius-full);border:3px solid var(--color-primary);background:linear-gradient(135deg,var(--color-success) 0,#c8e6c9 100%);display:flex;align-items:center;justify-content:center;font-size:20px;margin:0 auto 6px;overflow:hidden}.species-card .card-icon img{width:100%;height:100%;object-fit:cover}.species-card.no-photo .card-icon{background:#f5f5f5;border-style:dashed}.species-card .card-name{font-size:10px;color:var(--color-text);font-weight:500;line-height:1.25;margin-bottom:3px;min-height:25px;display:flex;align-items:center;justify-content:center;word-wrap:break-word}.species-card .card-count{font-size:9px;color:var(--color-text-light)}.species-card .card-dots{display:flex;justify-content:center;gap:3px;margin-top:5px}.species-card .dot{width:5px;height:5px;border-radius:var(--radius-full);background:var(--color-primary)}.photo-area{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);border:3px dashed #ccc;border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;margin-bottom:20px;transition:all .2s;overflow:hidden;position:relative}.photo-area:hover{border-color:var(--color-primary);background:linear-gradient(135deg,var(--color-success) 0,#c8e6c9 100%)}.photo-area.has-photo{border-style:solid;border-color:var(--color-primary)}.photo-area .preview-image{position:absolute;width:100%;height:100%;object-fit:cover}.photo-area .icon{font-size:48px;margin-bottom:12px}.photo-area .text{font-size:16px;color:#666;font-weight:500}.photo-area .subtext{font-size:12px;color:#999;margin-top:4px}.form-label{display:block;margin-bottom:8px;font-weight:600;color:var(--color-text)}.form-input{width:100%;padding:14px 16px;font-size:16px;border:2px solid var(--color-border);border-radius:var(--radius-md);outline:none;transition:border-color .2s;box-sizing:border-box}.form-input:focus{border-color:var(--color-primary)}.search-results{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);margin-top:8px;max-height:250px;overflow-y:auto;box-shadow:var(--shadow-md)}.search-result-item{width:100%;padding:12px 16px;display:flex;align-items:center;gap:12px;background:#fff;border:none;border-bottom:1px solid #f0f0f0;cursor:pointer;text-align:left}.search-result-item:hover{background:var(--color-success)}.search-result-item .result-icon{font-size:24px}.search-result-item .result-name{font-weight:500;color:var(--color-text)}.search-result-item .result-scientific{font-size:12px;color:var(--color-text-light);font-style:italic}.location-badge{background:var(--color-success);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:20px;display:flex;align-items:center;gap:12px;cursor:pointer;border:2px solid transparent;transition:all .2s}.location-badge:hover{border-color:var(--color-primary)}.location-badge.no-location{background:var(--color-warning)}.location-badge .loc-icon{font-size:20px}.location-badge .loc-title{font-weight:500;color:var(--color-primary-dark)}.location-badge.no-location .loc-title{color:#e65100}.location-badge .loc-detail{font-size:12px;color:#666}.location-badge .loc-status{margin-left:auto;color:var(--color-primary)}.details-toggle{width:100%;padding:14px 16px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:space-between;cursor:pointer;color:#666}.details-toggle.open{border-bottom-left-radius:0;border-bottom-right-radius:0}.details-panel{background:#fafafa;border:1px solid var(--color-border);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);padding:16px;margin-bottom:20px}.counter{gap:12px}.counter,.counter-btn{display:flex;align-items:center}.counter-btn{width:40px;height:40px;border-radius:var(--radius-full);border:2px solid var(--color-primary);background:#fff;font-size:20px;cursor:pointer;color:var(--color-primary);justify-content:center;transition:all .2s}.counter-btn.plus{background:var(--color-primary);color:#fff}.counter-btn:hover{transform:scale(1.1)}.counter-value{font-size:24px;font-weight:600;min-width:40px;text-align:center}.option-buttons{display:flex;gap:8px;flex-wrap:wrap}.option-btn{flex:1 1;min-width:80px;padding:10px;border-radius:var(--radius-sm);border:2px solid var(--color-border);background:#fff;cursor:pointer;font-size:13px;color:#666;transition:all .2s}.option-btn.selected{border-color:var(--color-primary);background:var(--color-success);color:var(--color-primary-dark)}.btn-primary{width:100%;padding:16px;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-size:16px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px rgba(74,124,66,.4);transition:all .2s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(74,124,66,.5)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{padding:12px 20px;background:#fff;border:2px solid var(--color-primary);border-radius:var(--radius-md);color:var(--color-primary);font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--color-success)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:flex-end;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s}.modal-overlay.show{opacity:1;pointer-events:auto}.modal-content{background:#fff;width:100%;max-width:420px;max-height:85vh;border-radius:20px;transform:translateY(100%);transition:transform .3s;display:flex;flex-direction:column;margin:0 16px 16px}.modal-overlay.show .modal-content{transform:translateY(0)}.modal-header{padding:16px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.modal-header h2{margin:0;font-size:18px;color:var(--color-text)}.modal-close{background:none;border:none;font-size:24px;color:var(--color-text-light);cursor:pointer;padding:4px 8px}.modal-body{flex:1 1;overflow-y:auto;padding:16px}.modal-footer{padding:16px;border-top:1px solid var(--color-border)}.success-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(45,90,39,.95);flex-direction:column;color:#fff;z-index:1000}.success-icon,.success-overlay{display:flex;align-items:center;justify-content:center}.success-icon{width:80px;height:80px;border-radius:var(--radius-full);background:#fff;margin-bottom:20px;font-size:40px;color:var(--color-primary)}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:40px}.spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.error-message{background:var(--color-error);border:1px solid #ef5350;border-radius:var(--radius-md);padding:12px 16px;color:#c62828;margin-bottom:16px}.info-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.info-row{padding:14px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid #f0f0f0}.info-row:last-child{border-bottom:none}.info-row .info-icon{font-size:20px}.info-row .info-label{font-size:12px;color:var(--color-text-light)}.info-row .info-value{font-weight:500;color:var(--color-text)}#location-map{width:100%;height:250px;border-radius:var(--radius-md);margin-bottom:16px}.auth-container{min-height:100vh;background:linear-gradient(135deg,var(--color-primary-dark) 0,var(--color-primary) 100%);display:flex;align-items:center;justify-content:center;padding:20px}.auth-card{background:#fff;border-radius:var(--radius-lg);padding:32px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.auth-card h1{text-align:center;color:var(--color-primary-dark);margin-bottom:8px}.auth-card .subtitle{text-align:center;color:var(--color-text-light);margin-bottom:32px}.auth-card .form-group{margin-bottom:20px}.auth-card .form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--color-text)}.auth-card .switch-link{text-align:center;margin-top:24px;color:var(--color-text-light)}.auth-card .switch-link a{color:var(--color-primary);text-decoration:none;font-weight:600}.auth-card .switch-link a:hover{text-decoration:underline}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.error-banner{background:#ffebee;border:1px solid #ef5350;border-radius:12px;padding:16px;margin-bottom:20px;position:relative;animation:slideDown .3s ease-out}.error-banner.warning{background:#fff8e1;border-color:#ffb300}.error-banner__dismiss{position:absolute;top:8px;right:8px;background:none;border:none;font-size:20px;cursor:pointer;color:#c62828;padding:4px 8px;line-height:1;opacity:.7;transition:opacity .2s}.error-banner__dismiss:hover{opacity:1}.error-banner.warning .error-banner__dismiss{color:#f57c00}.error-banner__header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.error-banner__icon{font-size:24px}.error-banner__title{margin:0;color:#c62828;font-size:16px;font-weight:600}.error-banner.warning .error-banner__title{color:#e65100}.error-banner__message{margin:0 0 12px;color:#c62828;font-size:14px;padding-right:24px}.error-banner.warning .error-banner__message{color:#e65100}.error-banner__details{background:rgba(0,0,0,.05);border-radius:8px;padding:12px;margin-top:12px}.error-banner__item{display:flex;align-items:flex-start;gap:8px;padding:6px 0;font-size:13px}.error-banner__item:not(:last-child){border-bottom:1px solid rgba(0,0,0,.1)}.error-banner__item-icon{flex-shrink:0}.error-banner__item-name{font-weight:500;color:#333}.error-banner__item-reason{color:#666;font-size:12px;margin-top:2px}.error-banner__tip{margin:12px 0 0;font-size:12px;color:#666;font-style:italic}@keyframes disputePulse{0%,to{box-shadow:0 0 0 0 rgba(255,152,0,.5)}50%{box-shadow:0 0 0 6px rgba(255,152,0,0)}}@keyframes disputeBorderPulse{0%,to{border-color:#ff9800}50%{border-color:#ffb74d}}.group-card.has-disputes{border:2px solid #ff9800!important;animation:disputePulse 2s ease-in-out infinite,disputeBorderPulse 1s ease-in-out infinite}.group-card.has-disputes:before{content:"";background:#ff9800;border-radius:50%}.group-card.has-disputes:after,.group-card.has-disputes:before{position:absolute;top:-2px;right:-2px;width:18px;height:18px;display:flex;align-items:center;justify-content:center}.group-card.has-disputes:after{content:"!";color:#fff;font-size:12px;font-weight:700;z-index:1}.species-card.has-disputes{border:2px solid #ff9800!important;animation:disputePulse 2s ease-in-out infinite;position:relative}.species-card.has-disputes .card-icon{border-color:#ff9800!important}.species-bubble-dispute-badge{position:absolute;top:-4px;right:-4px;width:20px;height:20px;background:#ff9800;border-radius:50%;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid #fff;box-shadow:0 2px 4px rgba(0,0,0,.2);animation:disputePulse 2s ease-in-out infinite}.discovery-item.has-disputes{border:2px solid #ff9800!important;animation:disputePulse 2s ease-in-out infinite}.family-header.has-disputes{background:linear-gradient(135deg,#fff3e0,#ffe0b2)!important}.family-header.has-disputes span{color:#e65100!important}canvas,img{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none;user-drag:none;-webkit-touch-callout:none;pointer-events:auto}.blurhash-container canvas,.blurhash-container img{-webkit-user-select:none!important;-moz-user-select:none!important;user-select:none!important;-webkit-user-drag:none!important;user-drag:none!important;-webkit-touch-callout:none!important}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-in{animation:fadeInUp .4s ease both}.animate-fade{animation:fadeIn .3s ease both}.animate-scale{animation:scaleIn .3s ease both}.animate-slide-up{animation:slideUp .5s ease both}.animate-slide-left{animation:slideInLeft .4s ease both}.animate-slide-right{animation:slideInRight .4s ease both}.animate-bounce{animation:bounceIn .5s ease both}.animate-fade-delay-1,.animate-in-delay-1,.animate-scale-delay-1,.animate-slide-up-delay-1{animation-delay:.05s}.animate-fade-delay-2,.animate-in-delay-2,.animate-scale-delay-2,.animate-slide-up-delay-2{animation-delay:.1s}.animate-fade-delay-3,.animate-in-delay-3,.animate-scale-delay-3,.animate-slide-up-delay-3{animation-delay:.15s}.animate-fade-delay-4,.animate-in-delay-4,.animate-scale-delay-4,.animate-slide-up-delay-4{animation-delay:.2s}.animate-fade-delay-5,.animate-in-delay-5,.animate-scale-delay-5,.animate-slide-up-delay-5{animation-delay:.25s}.animate-fade-delay-6,.animate-in-delay-6,.animate-scale-delay-6,.animate-slide-up-delay-6{animation-delay:.3s}.animate-fade-delay-7,.animate-in-delay-7,.animate-scale-delay-7,.animate-slide-up-delay-7{animation-delay:.35s}.animate-fade-delay-8,.animate-in-delay-8,.animate-scale-delay-8,.animate-slide-up-delay-8{animation-delay:.4s}.animate-fade-delay-9,.animate-in-delay-9,.animate-scale-delay-9,.animate-slide-up-delay-9{animation-delay:.45s}.animate-fade-delay-10,.animate-in-delay-10,.animate-scale-delay-10,.animate-slide-up-delay-10{animation-delay:.5s}.animate-stagger>*{animation:fadeInUp .4s ease both}.animate-stagger>:first-child{animation-delay:0s}.animate-stagger>:nth-child(2){animation-delay:.05s}.animate-stagger>:nth-child(3){animation-delay:.1s}.animate-stagger>:nth-child(4){animation-delay:.15s}.animate-stagger>:nth-child(5){animation-delay:.2s}.animate-stagger>:nth-child(6){animation-delay:.25s}.animate-stagger>:nth-child(7){animation-delay:.3s}.animate-stagger>:nth-child(8){animation-delay:.35s}.animate-stagger>:nth-child(9){animation-delay:.4s}.animate-stagger>:nth-child(10){animation-delay:.45s}.animate-stagger-fast>*{animation:fadeInUp .3s ease both}.animate-stagger-fast>:first-child{animation-delay:0s}.animate-stagger-fast>:nth-child(2){animation-delay:.03s}.animate-stagger-fast>:nth-child(3){animation-delay:.06s}.animate-stagger-fast>:nth-child(4){animation-delay:.09s}.animate-stagger-fast>:nth-child(5){animation-delay:.12s}.animate-stagger-fast>:nth-child(6){animation-delay:.15s}.animate-stagger-fast>:nth-child(7){animation-delay:.18s}.animate-stagger-fast>:nth-child(8){animation-delay:.21s}.animate-stagger-fast>:nth-child(9){animation-delay:.24s}.animate-stagger-fast>:nth-child(10){animation-delay:.27s}.page-animate{animation:fadeIn .3s ease}.page-slide-in{animation:fadeInUp .4s ease}.animate-none{animation:none!important}.animate-once{animation-fill-mode:forwards}@media (prefers-reduced-motion:reduce){.animate-bounce,.animate-fade,.animate-in,.animate-scale,.animate-slide-left,.animate-slide-right,.animate-slide-up,.animate-stagger-fast>*,.animate-stagger>*,.page-animate,.page-slide-in{animation:none!important;opacity:1!important;transform:none!important}}.card-animate{animation:scaleIn .3s ease both}.card-hover{transition:transform .2s ease,box-shadow .2s ease}.card-hover:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,.1)}.card-hover:active{transform:translateY(0)}.skeleton-shimmer{background:linear-gradient(90deg,#e8e8e8 25%,#f5f5f5 50%,#e8e8e8 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.pulse-subtle{animation:pulse 2s ease-in-out infinite}