*,: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:100vh;position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.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:4/3;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 20px 0 0;transform:translateY(100%);transition:transform .3s;display:flex;flex-direction:column}.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}