:root{--color-primary: #b35c1e;--color-primary-dark: #8f4a18;--color-primary-light: #c96d2a;--color-success: #059669;--color-error: #ef4444;--color-text-dark: #333;--color-text-light: #fff;--color-bg-light: #faf6f3;--color-bg-tint: #f8f0ea;--color-border: #e5d8ce}html,body{margin:0;padding:0;height:100%;font-family:Inter,sans-serif;background-color:var(--color-bg-light)}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.main-content{flex-grow:1;position:relative;display:flex}.map-container{flex-grow:1;position:relative}#map{width:100%;height:100%}.map-footer{position:absolute;bottom:4px;left:4px;font-size:10px;color:#00000080;background:#ffffffb3;padding:2px 6px;border-radius:3px;z-index:100}@media (max-width: 768px){.map-footer{bottom:64px}}.maplibregl-ctrl-bottom-left,.maplibregl-ctrl-bottom-right{bottom:70px!important}.data-sources-btn{width:29px;height:29px;display:flex;align-items:center;justify-content:center;cursor:pointer;background:#fff;border:none;border-radius:4px;color:#333}.data-sources-btn:hover{background:#f0f0f0}.data-sources-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.data-sources-modal{background:#fff;border-radius:12px;padding:24px;max-width:420px;max-height:85vh;overflow-y:auto}.data-sources-modal h2{margin:0 0 16px;font-size:20px;color:#333}.data-sources-modal .modal-intro{margin:0 0 12px;font-size:14px;color:#333;line-height:1.5}.data-sources-modal .modal-list{margin:0 0 16px;padding-left:20px;font-size:13px;color:#555;line-height:1.8}.data-sources-modal .modal-footer{background:#f8f9fa;padding:12px;border-radius:8px;margin-bottom:16px}.data-sources-modal .modal-footer p{margin:0;font-size:12px;color:#555;line-height:1.6}.data-sources-modal .modal-close-btn{padding:10px 16px;background:#4a5568;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;width:100%}.data-sources-modal .modal-close-btn:hover{background:#3d4654}.map-error{display:flex;align-items:center;justify-content:center;height:100%;background-color:#eee;color:#666;font-size:1.2rem;padding:2rem;text-align:center}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.navbar,.footer{flex-shrink:0;background-color:var(--color-bg-tint);padding:1rem 1.5rem;box-shadow:0 2px 4px #b35c1e1a;z-index:50}.navbar{height:56px;padding:0 16px;display:flex;align-items:center}.navbar-container{max-width:1200px;width:100%;height:100%;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.navbar-logo{display:flex;align-items:center;text-decoration:none;color:inherit;gap:6px;font-size:1.1rem}.navbar-logo .brand-name{font-weight:700;color:var(--color-primary)}.navbar-logo .brand-divider{font-weight:300;color:#999}.navbar-logo .brand-app{font-weight:500;color:var(--color-text-dark)}.navbar-link{text-decoration:none;color:var(--color-primary);font-weight:500}.navbar-link:hover{text-decoration:underline}.footer{height:36px;padding:0 16px;display:flex;align-items:center;border-top:1px solid var(--color-border);background:var(--color-bg-tint);box-shadow:0 -1px 4px #0000000d}.footer-container{max-width:1200px;width:100%;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.footer-brand{font-size:.75rem;color:#666}.footer-brand a{color:var(--color-primary);text-decoration:none;font-weight:500}.footer-brand a:hover{text-decoration:underline}.footer-links{display:flex;align-items:center;gap:8px}.footer-link{font-size:.75rem;color:#666;text-decoration:none;transition:color .2s}.footer-link:hover{color:var(--color-primary);text-decoration:underline}.footer-divider{font-size:.75rem;color:#ccc}@media (max-width: 768px){.footer{display:none}}.fab{position:fixed;right:20px;bottom:20px;padding:14px 20px;background-color:var(--color-primary);color:#fff;border:none;border-radius:50px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000004d;cursor:pointer;z-index:1000;transition:transform .2s ease,background-color .2s ease;white-space:nowrap}.fab:hover{background-color:var(--color-primary-dark);transform:scale(1.05)}.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;z-index:200;align-items:center;justify-content:center;padding:1rem;box-sizing:border-box}.modal-content{background:#fff;padding:1.5rem 2rem;border-radius:8px;width:100%;max-width:550px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 5px 15px #0000004d}.close-button{position:absolute;top:10px;right:10px;background:none;border:none;font-size:2.5rem;color:#aaa;cursor:pointer;line-height:1}.close-button:hover{color:#333}@media (max-width: 768px){.modal-overlay{padding:.5rem;padding-bottom:80px;align-items:flex-start;padding-top:1rem}.modal-content{padding:2.5rem 1rem 1rem;max-height:calc(100vh - 150px);border-radius:12px;width:calc(100vw - 1rem);max-width:100%}.modal-content h2{font-size:1.25rem;padding-right:35px;margin-top:0}.modal-content>p{font-size:.9rem}.close-button{font-size:2rem;top:.5rem;right:.5rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;z-index:10}}.modal-content h2,.mobile-panel-content h2{margin-top:0;color:var(--color-primary)}.modal-content>p,.mobile-panel-content>p{margin-top:0}.modal-content form>div,.mobile-panel-content form>div{margin-bottom:1rem}.modal-content label,.mobile-panel-content label{display:block;margin-bottom:.5rem;font-weight:600}.modal-content input[type=file],.modal-content input[type=text],.modal-content textarea,.modal-content select,.mobile-panel-content input[type=file],.mobile-panel-content input[type=text],.mobile-panel-content textarea,.mobile-panel-content select{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:4px;box-sizing:border-box;font-family:Inter,sans-serif;font-size:1rem}.file-drop-zone{border:2px dashed var(--color-border);border-radius:8px;padding:1.5rem 1rem;text-align:center;cursor:pointer;transition:background-color .2s,border-color .2s;background-color:#f9fafb}.file-drop-zone:hover{background-color:#f0f4f8;border-color:var(--color-primary)}.file-drop-zone-inner{display:flex;flex-direction:column;align-items:center;gap:.5rem}.file-drop-zone-inner svg{width:40px;height:40px;color:#999}.file-drop-zone-inner span{font-weight:600;color:var(--color-primary);font-size:1rem}.file-drop-zone-inner p{font-size:.8em;margin:0;color:#666}.file-name{font-size:.8em;color:#666;margin-top:8px;text-align:center}.image-preview-container{margin-top:1rem;border:2px solid var(--color-border);border-radius:8px;padding:1rem;background-color:#f9fafb}.image-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.image-preview-header h4{margin:0;color:var(--color-primary);font-size:.9rem;font-weight:600}.clear-image-button{background:none;border:none;color:#999;cursor:pointer;font-size:1.5rem;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.clear-image-button:hover{background-color:#f3f4f6;color:#666}.image-preview{width:100%;max-height:200px;object-fit:cover;border-radius:6px;border:1px solid #e5e7eb;display:block}.image-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-bottom:8px}.image-preview-item{position:relative;aspect-ratio:1;border-radius:6px;overflow:hidden;border:1px solid #e5e7eb}.image-preview-item img{width:100%;height:100%;object-fit:cover}.image-preview-item .remove-image{position:absolute;top:4px;right:4px;width:20px;height:20px;background:#0009;color:#fff;border:none;border-radius:50%;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.image-preview-item .remove-image:hover{background:#dc2626e6}.image-preview-item.has-gps:after{content:"📍";position:absolute;bottom:4px;left:4px;font-size:12px;background:#ffffffe6;padding:2px 4px;border-radius:4px}.image-preview-info{margin:.5rem 0 0;font-size:.8rem;color:#666;text-align:center;font-style:italic}.popup-carousel{position:relative;width:200px;margin-bottom:8px}.popup-carousel-container{position:relative;width:200px;height:200px;border-radius:4px;overflow:hidden}.popup-carousel-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s ease}.popup-carousel-img.active{opacity:1}.popup-carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:28px;height:28px;background:#00000080;color:#fff;border:none;border-radius:50%;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:2}.popup-carousel-btn:hover{background:#000000b3}.popup-carousel-btn.prev{left:4px}.popup-carousel-btn.next{right:4px}.popup-carousel-dots{display:flex;justify-content:center;gap:6px;margin-top:8px}.popup-carousel-dot{width:8px;height:8px;border-radius:50%;background:#ccc;cursor:pointer;transition:background .2s}.popup-carousel-dot.active{background:var(--color-primary)}.popup-carousel-dot:hover{background:#999}.edit-carousel{position:relative;width:100%;margin-bottom:12px}.edit-carousel-images{position:relative;width:100%;aspect-ratio:4/3;border-radius:8px;overflow:hidden;background:#f3f4f6}.edit-carousel-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s ease}.edit-carousel-img.active{opacity:1}.edit-carousel-controls{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:8px}.edit-carousel-btn{width:32px;height:32px;background:#e5e7eb;color:#333;border:none;border-radius:50%;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.edit-carousel-btn:hover{background:#d1d5db}.edit-carousel-counter{font-size:.85rem;color:#666;font-weight:500;min-width:40px;text-align:center}.upload-button,.secondary-button{width:100%;padding:.8rem 1.2rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-align:center;box-sizing:border-box}.upload-button{background-color:var(--color-primary);color:var(--color-text-light)}.upload-button:hover{background-color:#2a64c4}.secondary-button{background-color:#e2e8f0;color:var(--color-text-dark);border:1px solid var(--color-border);margin-top:.5rem}.secondary-button:hover{background-color:#cbd5e1}#status-message{margin-top:1rem;padding:.75rem;border-radius:4px;text-align:center;font-weight:500}.camera-modal-overlay{z-index:1100;display:none;position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;align-items:center;justify-content:center}.camera-modal-content{background-color:#fff;padding:1.5rem;border-radius:8px;width:90%;max-width:500px;text-align:center}#camera-video{width:100%;height:auto;border-radius:4px;margin-bottom:1rem;background-color:#333}.camera-controls{display:flex;gap:1rem}.custom-marker{display:flex!important;align-items:center!important;justify-content:center!important;cursor:pointer;will-change:transform;backface-visibility:hidden;transform:translateZ(0)}.custom-marker:hover{transform:translateZ(0) scale(1.1)}.custom-marker.marker-hidden{display:none!important}.marker-icon-container{width:20px;height:20px;color:#fff;display:flex!important;align-items:center!important;justify-content:center!important;position:relative}.marker-icon-container svg{width:16px;height:16px;min-width:16px;min-height:16px;flex-shrink:0;pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.map-search{position:absolute;top:10px;right:10px;z-index:50}@media (max-width: 768px){.map-search{top:10px;right:10px;left:auto}}.search-toggle-btn{background:#fffffff2;backdrop-filter:blur(5px);border:none;border-radius:4px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 10px #0003;transition:all .2s;color:var(--color-primary)}.search-toggle-btn:hover{background:#fff;transform:scale(1.05)}.search-panel{position:absolute;top:0;right:0;background:#fffffff2;backdrop-filter:blur(5px);border-radius:4px;box-shadow:0 2px 10px #0003;padding:8px;display:flex;flex-direction:column;gap:8px;transition:all .3s ease;width:320px;max-height:400px}.search-panel.hidden{opacity:0;pointer-events:none;transform:translate(20px)}.search-input-row{display:flex;align-items:center;gap:8px}#search-input{flex:1;border:1px solid var(--color-border);border-radius:4px;padding:8px 12px;font-size:.9rem;outline:none}#search-input:focus{border-color:var(--color-primary)}.search-results{max-height:300px;overflow-y:auto;display:none}.search-results.visible{display:block}.search-result-item{padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--color-border);transition:background-color .15s;font-size:.9rem}.search-result-item:last-child{border-bottom:none}.search-result-item:hover,.search-result-item.active{background-color:var(--color-bg-tint)}.search-result-item .result-name{font-weight:500;color:var(--color-text-dark);display:block}.search-result-item .result-details{font-size:.8rem;color:#666;margin-top:2px}.search-loading{padding:12px;text-align:center;color:#666;font-size:.85rem}.search-no-results{padding:12px;text-align:center;color:#999;font-size:.85rem}.search-close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.search-close-btn:hover{background:#f3f4f6;color:#666}@media (max-width: 768px){.search-panel{width:calc(100vw - 80px);max-width:300px}}.map-legend{position:absolute;top:10px;left:10px;background:#fffffff2;backdrop-filter:blur(5px);border-radius:8px;padding:12px;box-shadow:0 2px 10px #0003;max-width:240px;max-height:calc(100vh - 100px);overflow-y:auto;z-index:50;font-size:.8rem}.legend-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.legend-header h4{margin:0;font-size:.9rem;color:var(--color-primary);font-weight:600}.legend-toggle{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.legend-toggle:hover{background:#0000000d}.legend-toggle svg{transition:transform .3s}.legend-toggle.collapsed svg{transform:rotate(-90deg)}.legend-content{max-height:1000px;overflow:hidden;transition:max-height .3s ease-out,opacity .3s;opacity:1}.legend-content.collapsed{max-height:0;opacity:0}.map-legend h5{margin:12px 0 6px;font-size:.75rem;color:#555;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.legend-section{margin-bottom:8px}.legend-section:first-child h5{margin-top:0}.legend-item{display:flex;align-items:center;gap:6px;margin-bottom:3px}.legend-color{width:12px;height:12px;border-radius:50%;border:1px solid rgba(0,0,0,.2)}.legend-list{display:flex;flex-direction:column;gap:4px}.legend-icon-item{display:flex;align-items:center;gap:6px;font-size:.75rem}.legend-icon-preview{width:16px;height:16px;background-color:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.legend-icon-preview svg{width:11px;height:11px}@media (max-width: 768px){.map-legend{position:fixed;inset:auto 10px 90px;padding:8px;max-width:none;z-index:500;margin-top:0}.legend-header h4{display:none}.legend-header{margin-bottom:8px;justify-content:center}.legend-toggle{display:flex;padding:8px;background:#4285f41a;border-radius:50%}.legend-content.collapsed{max-height:0;opacity:0;margin-top:0}.legend-content:not(.collapsed){max-height:300px;opacity:1;margin-top:8px;overflow-y:auto}.legend-toggle.collapsed svg{transform:rotate(-90deg)}.legend-icon-item{font-size:.7rem}.legend-icon-preview{width:14px;height:14px}.map-legend h5{font-size:.7rem}}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}to{transform:scale(1);opacity:1}}.ndvi-gradient-bar{margin-top:8px}.ndvi-gradient{height:12px;border-radius:3px;background:linear-gradient(to right,#1a1a1a,#4a3020 15%,#8b4513,#d2691e,gold,orange,#adff2f,#7cfc00,#0f0 85%,#fff);border:1px solid rgba(0,0,0,.2)}.ndvi-labels{display:flex;justify-content:space-between;font-size:.7rem;color:#666;margin-top:3px}.ndvi-controls{position:absolute;top:10px;right:10px;background:#fff;padding:12px;border-radius:8px;box-shadow:0 2px 8px #00000026;z-index:100;min-width:200px}.ndvi-header{margin-bottom:8px}.ndvi-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--color-primary)}.ndvi-toggle-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.ndvi-settings{padding-top:12px;border-top:1px solid #e5e7eb}.ndvi-control-group{margin-bottom:12px;display:flex;flex-direction:column;gap:6px}.ndvi-control-group:last-child{margin-bottom:0}.ndvi-control-group label{font-size:.75rem;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.5px}.ndvi-control-group input[type=range]{width:100%;height:6px;border-radius:3px;background:#e5e7eb;outline:none;cursor:pointer}.ndvi-control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer}.ndvi-control-group input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none}#ndvi-opacity-value{font-size:.8rem;color:#666;text-align:right}.ndvi-control-group input[type=date]{padding:6px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:.85rem}.ndvi-controls{display:none}.map-search,.fab,.map-legend,#edit-modal-overlay,#submission-modal-overlay{display:none!important}.mobile-bottom-bar{display:flex;position:fixed;bottom:0;left:0;right:0;height:60px;background:var(--color-bg-tint);border-top:1px solid var(--color-border);box-shadow:0 -2px 8px #b35c1e1a;z-index:1000;justify-content:space-around;align-items:center;padding:0 8px}.mobile-bar-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:none;border:none;padding:8px;cursor:pointer;color:#666;transition:color .2s}.mobile-bar-btn.active{color:var(--color-primary)}.mobile-bar-btn:disabled{color:#ccc;cursor:not-allowed;opacity:.5;pointer-events:none}.mobile-bar-btn svg{width:24px;height:24px}.mobile-bar-btn span{font-size:.7rem;font-weight:500}.mobile-panel{position:fixed;left:0;right:0;bottom:-100%;background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -4px 16px #0003;z-index:999;transition:bottom .3s ease;max-height:50vh;overflow-y:auto}.mobile-panel.open{bottom:60px}.mobile-panel.full-height{max-height:calc(100vh - 60px)}.mobile-panel.full-height.open{bottom:0}.mobile-panel-header{position:sticky;top:0;background:#fff;padding:16px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.mobile-panel-header h3{margin:0;font-size:1rem;color:var(--color-primary);font-weight:600}.mobile-panel-close{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:32px;height:32px}.mobile-panel-content{padding:16px 16px 80px}.sighting-info-placeholder{text-align:center;color:#888;padding:40px 20px}.sighting-info-placeholder p{margin:0;font-size:.95rem}.sighting-details p{margin:0 0 8px;font-size:.95rem;line-height:1.5}.sighting-details p strong{color:var(--color-primary)}#mobile-info-content .popup-carousel{border-radius:8px;overflow:hidden}@media (max-width: 768px){#mobile-add-content h2{margin-top:0;margin-bottom:.5rem;color:var(--color-primary);font-size:1.25rem}#mobile-add-content>p{margin-top:0;margin-bottom:1rem;font-size:.9rem}#mobile-add-content form>div{margin-bottom:1rem}#mobile-add-content label{display:block;margin-bottom:.5rem;font-weight:600}#mobile-add-content input[type=file],#mobile-add-content input[type=text],#mobile-add-content textarea,#mobile-add-content select{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:4px;box-sizing:border-box;font-family:Inter,sans-serif;font-size:1rem}#mobile-add-content textarea{resize:vertical}#mobile-add-content .upload-button,#mobile-add-content .secondary-button{width:100%}#mobile-add-content #status-message{margin-top:1rem;padding:.75rem;border-radius:4px;text-align:center;font-weight:500}#mobile-edit-content h2{margin-top:0;margin-bottom:.5rem;color:var(--color-primary);font-size:1.25rem}#mobile-edit-content>p{margin-top:0;margin-bottom:1rem;font-size:.9rem}#mobile-edit-content form>div{margin-bottom:1rem}#mobile-edit-content label{display:block;margin-bottom:.5rem;font-weight:600}#mobile-edit-content input[type=text],#mobile-edit-content textarea,#mobile-edit-content select{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:4px;box-sizing:border-box;font-family:Inter,sans-serif;font-size:1rem}#mobile-edit-content textarea{resize:vertical}#mobile-edit-content .upload-button,#mobile-edit-content .secondary-button{width:100%}#mobile-edit-content #edit-status-message{margin-top:1rem;padding:.75rem;border-radius:4px;text-align:center;font-weight:500}#mobile-edit-content .image-preview{max-width:100%;border-radius:8px}#mobile-edit-content .image-preview-container{margin-bottom:1rem}}@media (min-width: 768px){.fab{bottom:30px;right:30px}}.welcome-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;backdrop-filter:blur(4px)}.welcome-modal.hidden{display:none}.welcome-content{background:#fff;border-radius:16px;padding:32px;max-width:420px;width:100%;box-shadow:0 20px 60px #0000004d;animation:welcomeSlideIn .3s ease-out}@keyframes welcomeSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.welcome-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.welcome-logo{font-size:32px}.welcome-header h2{font-size:24px;font-weight:700;color:#1a202c;margin:0}.welcome-intro{font-size:15px;color:#4a5568;line-height:1.6;margin:0 0 20px}.welcome-features{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.welcome-feature{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#f0fdf4;border-radius:8px;font-size:14px;color:#166534}.welcome-feature span:first-child{font-size:18px}.welcome-cta-text{font-size:13px;color:#718096;margin:0 0 20px;text-align:center}.welcome-cta-text a{color:#059669;text-decoration:none;font-weight:500}.welcome-cta-text a:hover{text-decoration:underline}.welcome-button{width:100%;padding:14px 24px;background:linear-gradient(135deg,#059669,#047857);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.welcome-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #05966966}.welcome-button:active{transform:translateY(0)}@media (max-width: 480px){.welcome-content{padding:24px}.welcome-header h2{font-size:20px}.welcome-intro{font-size:14px}}.gps-marker{width:24px;height:24px;position:relative}.gps-marker-dot{width:16px;height:16px;background:#3b82f6;border:3px solid white;border-radius:50%;box-shadow:0 2px 8px #3b82f680;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2}.gps-marker-pulse{width:40px;height:40px;background:#3b82f64d;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);animation:gpsPulse 2s ease-out infinite;z-index:1}@keyframes gpsPulse{0%{transform:translate(-50%,-50%) scale(.5);opacity:1}to{transform:translate(-50%,-50%) scale(1.5);opacity:0}}.mobile-bar-btn.tracking{color:var(--color-primary);background:#b35c1e1a}.layers-panel{position:absolute;top:10px;right:10px;background:#fffffffa;backdrop-filter:blur(8px);border-radius:12px;padding:12px;box-shadow:0 2px 12px #00000026;max-width:280px;max-height:calc(100vh - 100px);overflow-y:auto;z-index:50;font-size:.85rem}.layers-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.layers-header h4{margin:0;font-size:.95rem;color:var(--color-primary);font-weight:600}.layers-toggle{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.layers-toggle:hover{background:#0000000d}.layers-toggle svg{transition:transform .3s}.layers-toggle.collapsed svg{transform:rotate(-90deg)}.layers-content{max-height:1000px;overflow:hidden;transition:max-height .3s ease-out,opacity .3s;opacity:1}.layers-content.collapsed{max-height:0;opacity:0}.layers-section{margin-bottom:12px}.layers-section:last-child{margin-bottom:0}.layers-section h5{margin:0 0 6px;font-size:.75rem;color:#555;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.layers-hint{font-size:.7rem;color:#888;margin:0 0 8px;font-style:italic}.layers-list{display:flex;flex-direction:column;gap:4px}.layer-item{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;border-radius:6px;background:#f8f9fa;transition:background .2s,opacity .2s}.layer-item:hover{background:#f0f4f8}.layer-item.disabled{opacity:.5}.layer-toggle-label{display:flex;flex-direction:row;align-items:center;gap:8px;cursor:pointer;flex:1;min-width:0}.layer-checkbox{width:16px;height:16px;min-width:16px;min-height:16px;cursor:pointer;accent-color:var(--color-primary);flex-shrink:0;margin:0}.layer-icon{width:24px;height:24px;min-width:24px;min-height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;overflow:hidden}.layer-icon svg{width:14px;height:14px;flex-shrink:0}.layer-icon-emoji{font-size:14px;line-height:1}.layer-name{font-size:.8rem;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layer-info-btn{font-size:16px;color:var(--color-primary);cursor:pointer;padding:4px;flex-shrink:0;transition:color .2s}.layer-info-btn:hover{color:var(--color-primary-dark)}.condition-legend{display:flex;gap:12px;flex-wrap:wrap}.condition-item{display:flex;align-items:center;gap:6px;font-size:.75rem}.condition-color{width:12px;height:12px;border-radius:50%;border:1px solid rgba(0,0,0,.1)}.layer-info-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;z-index:2000;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px)}.layer-info-modal.open{display:flex}.layer-info-content{background:#fff;border-radius:16px;padding:24px;max-width:440px;width:100%;max-height:85vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.layer-info-close{position:absolute;top:12px;right:12px;background:none;border:none;font-size:28px;cursor:pointer;color:#999;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.layer-info-close:hover{background:#f3f4f6;color:#333}.layer-info-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.layer-info-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.layer-info-icon svg{width:28px;height:28px}.layer-info-header h2{margin:0;font-size:1.5rem;color:#1a202c;font-weight:700}.layer-info-description{font-size:1rem;color:#4a5568;line-height:1.5;margin:0 0 20px}.layer-info-benefits h4,.layer-info-details h4{font-size:.85rem;color:#059669;margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px}.layer-info-benefits ul{margin:0 0 20px;padding-left:20px}.layer-info-benefits li{font-size:.9rem;color:#4a5568;line-height:1.6;margin-bottom:4px}.layer-info-details p{font-size:.85rem;color:#718096;line-height:1.6;margin:0;background:#f7fafc;padding:12px;border-radius:8px;border-left:3px solid #059669}@media (max-width: 768px){.layers-panel{display:none!important}}#mobile-layers-content .layers-section{margin-bottom:16px}#mobile-layers-content .layer-item{padding:10px 12px}#mobile-layers-content .layer-name{font-size:.85rem}#mobile-layers-content .layer-icon{width:28px;height:28px;min-width:28px;min-height:28px}#mobile-layers-content .layer-icon svg{width:16px;height:16px;flex-shrink:0}#mobile-layers-content .layer-icon-emoji{font-size:16px}.sighting-info-placeholder{text-align:center;padding:40px 20px;color:#888}.sighting-info-placeholder p{margin:0;font-size:.9rem}.sighting-details p{margin:0 0 8px;font-size:.9rem;line-height:1.5}.sighting-details p:last-child{margin-bottom:0}.sighting-details p strong{color:#333}#mobile-info-content .popup-carousel{width:100%}#mobile-info-content .popup-carousel-container{width:100%;height:auto;aspect-ratio:4/3}#desktop-sidebar{display:none}@media (min-width: 769px){.mobile-bottom-bar,.mobile-panel,.fab{display:none!important}#desktop-sidebar{display:flex;position:fixed;top:56px;right:0;width:360px;height:calc(100vh - 92px);background:#fff;box-shadow:-2px 0 12px #00000026;z-index:900;flex-direction:row;overflow:hidden}#desktop-sidebar .sidebar-tabs{width:56px;display:flex;flex-direction:column;background:var(--color-bg-tint);border-right:1px solid var(--color-border);flex-shrink:0}#desktop-sidebar .sidebar-tab{width:56px;height:56px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;border:none;background:transparent;color:#666;transition:all .2s;position:relative}#desktop-sidebar .sidebar-tab svg{width:22px;height:22px}#desktop-sidebar .sidebar-tab span{font-size:9px;font-weight:500}#desktop-sidebar .sidebar-tab:hover:not(:disabled){background:#b35c1e1a;color:var(--color-primary)}#desktop-sidebar .sidebar-tab.active{background:#fff;color:var(--color-primary)}#desktop-sidebar .sidebar-tab.active:after{content:"";position:absolute;right:0;top:8px;bottom:8px;width:3px;background:var(--color-primary);border-radius:2px 0 0 2px}#desktop-sidebar .sidebar-tab:disabled{opacity:.4;cursor:not-allowed}#desktop-sidebar .sidebar-content{flex:1;overflow-y:auto;overflow-x:hidden}#desktop-sidebar .tab-panel{display:none;padding:16px}#desktop-sidebar .tab-panel.active{display:block}#desktop-sidebar .tab-panel-title{margin:0 0 16px;font-size:16px;font-weight:600;color:var(--color-primary)}#desktop-sidebar .tab-panel-intro{font-size:14px;color:#555;line-height:1.5;margin-bottom:16px}#desktop-sidebar .primary-btn{width:100%;padding:12px 16px;background:var(--color-primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s}#desktop-sidebar .primary-btn:hover{background:var(--color-primary-dark)}#desktop-sidebar .search-input-row input{width:100%;padding:12px;border:1px solid var(--color-border);border-radius:8px;font-size:14px;outline:none}#desktop-sidebar .search-input-row input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #b35c1e1a}#desktop-sidebar .search-results{display:block;max-height:300px;overflow-y:auto;margin-top:8px}#desktop-sidebar .search-result-item{padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--color-border);transition:background-color .15s}#desktop-sidebar .search-result-item:last-child{border-bottom:none}#desktop-sidebar .search-result-item:hover{background-color:var(--color-bg-tint)}#desktop-sidebar .search-result-item .result-name{font-weight:500;color:var(--color-text-dark);display:block;font-size:13px}#desktop-sidebar .search-result-item .result-details{font-size:11px;color:#666;margin-top:2px;display:block}#desktop-sidebar .locate-status{background:var(--color-bg-tint);border-radius:8px;padding:12px;margin-bottom:16px}#desktop-sidebar .locate-status p{margin:0;font-size:13px;color:#555;line-height:1.5}#desktop-sidebar .gps-toggle-btn{width:100%;padding:12px 16px;background:var(--color-primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s}#desktop-sidebar .gps-toggle-btn:hover{background:var(--color-primary-dark)}#desktop-sidebar .gps-toggle-btn.tracking{background:#3b82f6}#desktop-sidebar .gps-toggle-btn.tracking:hover{background:#2563eb}#desktop-sidebar .locate-details{margin-top:16px;padding:12px;background:var(--color-bg-tint);border-radius:8px}#desktop-sidebar .locate-details.hidden{display:none}#desktop-sidebar .locate-detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--color-border)}#desktop-sidebar .locate-detail-row:last-child{border-bottom:none}#desktop-sidebar .locate-label{font-size:13px;color:#666}#desktop-sidebar .locate-value{font-size:13px;font-weight:500;color:var(--color-text-dark)}#desktop-sidebar .sighting-info-placeholder{text-align:center;color:#888;padding:40px 20px}#desktop-sidebar .sighting-info-placeholder p{margin:0;font-size:.95rem}#desktop-layers-content .layers-section{margin-bottom:16px}#desktop-layers-content .layer-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:6px;background:var(--color-bg-tint);transition:background .2s}#desktop-layers-content .layer-item:hover{background:var(--color-bg-light)}#desktop-layers-content .layer-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;flex:1}#desktop-layers-content .layer-checkbox{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}#desktop-layers-content .layer-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}#desktop-layers-content .layer-icon svg{width:14px;height:14px}#desktop-layers-content .layer-icon-emoji{font-size:14px}#desktop-layers-content .layer-name{font-size:13px;font-weight:500;color:#333}#desktop-layers-content .condition-legend{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}#desktop-layers-content .condition-item{display:flex;align-items:center;gap:6px;font-size:12px}#desktop-layers-content .condition-color{width:12px;height:12px;border-radius:50%;border:1px solid rgba(0,0,0,.1)}#desktop-about-content .about-section{margin-bottom:16px}#desktop-about-content .about-section h4{margin:0 0 8px;font-size:14px;color:#333}#desktop-about-content .about-list{margin:0;padding-left:20px;font-size:13px;color:#666;line-height:1.6}#desktop-about-content .about-list li{margin-bottom:4px}#desktop-about-content a{color:var(--color-primary);text-decoration:none}#desktop-about-content a:hover{text-decoration:underline}#desktop-add-content h2{margin:0 0 8px;font-size:16px;font-weight:600;color:var(--color-primary)}#desktop-add-content>p{font-size:13px;color:#555;line-height:1.5;margin:0 0 12px}#desktop-add-content form{display:flex;flex-direction:column;gap:12px}#desktop-add-content form label{font-size:13px;font-weight:500;color:#333;margin-bottom:4px;display:block}#desktop-add-content form input[type=text],#desktop-add-content form textarea,#desktop-add-content form select{width:100%;padding:10px;border:1px solid var(--color-border);border-radius:6px;font-size:13px;box-sizing:border-box}#desktop-add-content form textarea{min-height:60px;resize:vertical}#desktop-add-content .file-drop-zone{border:2px dashed var(--color-border);border-radius:8px;padding:16px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}#desktop-add-content .file-drop-zone:hover{border-color:var(--color-primary);background:#b35c1e0d}#desktop-add-content .file-drop-zone-inner svg{width:32px;height:32px;color:#999;margin-bottom:6px}#desktop-add-content .file-drop-zone-inner span{font-size:13px;color:var(--color-primary);font-weight:500}#desktop-add-content .file-drop-zone-inner p{font-size:12px;color:#888;margin:2px 0 0}#desktop-add-content .secondary-button{width:100%;padding:10px;background:#fff;border:1px solid var(--color-border);border-radius:6px;font-size:13px;cursor:pointer;transition:background .2s}#desktop-add-content .secondary-button:hover{background:var(--color-bg-tint)}#desktop-add-content .upload-button{width:100%;padding:12px;background:var(--color-primary);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}#desktop-add-content .upload-button:hover{background:var(--color-primary-dark)}#desktop-add-content .upload-button:disabled{background:#ccc;cursor:not-allowed}#desktop-add-content .image-preview-container{background:var(--color-bg-tint);border-radius:8px;padding:12px}#desktop-add-content .image-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}#desktop-add-content .image-preview-header h4{margin:0;font-size:13px;color:#333}#desktop-add-content .image-preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}#desktop-add-content .image-preview-grid img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:4px}#desktop-add-content>div[style*="background: #e3f2fd"]{font-size:12px;padding:10px!important;margin-bottom:12px!important}#desktop-info-content img{max-width:100%;height:auto;display:block}#desktop-info-content .popup-carousel{width:100%;margin-bottom:12px}#desktop-info-content .popup-carousel-container{width:100%;height:auto;aspect-ratio:4/3}#desktop-info-content .sighting-details{margin-top:12px}}
