:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{color:#213547;background-color:#fff}@media (prefers-color-scheme: dark){:root{color:#ffffffde;background-color:#242424}}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;justify-content:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}button{background-color:#f9f9f9;color:#213547}@media (prefers-color-scheme: dark){button{background-color:#1a1a1a;color:#ffffffde}a:hover{color:#535bf2}}a:hover{color:#747bff}.app{max-width:1200px;margin:0 auto;padding:1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app-header{text-align:center;margin-bottom:1rem;border-bottom:1px solid #e0e0e0}@media (prefers-color-scheme: dark){.app-header{border-bottom:1px solid #444}}.app-header h1{margin:0;color:#2c5530;font-size:clamp(1.8rem,5vw,2.5rem)}.app-header p{margin:.5rem 0 0;color:#666;font-size:clamp(1rem,3vw,1.1rem)}.location-picker{margin-bottom:2rem;position:relative}.location-picker-container{display:flex;gap:1rem;max-width:500px;margin:0 auto;position:relative}.location-input{flex:1;padding:.75rem;border:2px solid #ddd;border-radius:8px;font-size:1rem;min-height:44px;box-sizing:border-box;background:#fff;color:#213547}.location-input:focus{outline:none;border-color:#4caf50}.quick-start-btn{padding:.75rem 1rem;background:#f0f0f0;border:2px solid #ddd;border-radius:8px;cursor:pointer;white-space:nowrap;min-height:44px;box-sizing:border-box;color:#213547}.quick-start-btn:hover{background:#e0e0e0}.suggestions-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:120px;background:#fff;border:1px solid #ddd;border-radius:8px;max-height:400px;overflow-y:auto;z-index:1000;box-shadow:0 8px 16px #00000026;scroll-behavior:smooth}.suggestions-dropdown::-webkit-scrollbar{width:6px}.suggestions-dropdown::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.suggestions-dropdown::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.suggestions-dropdown::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.suggestion-item{padding:.5rem .75rem;cursor:pointer;border-bottom:1px solid #f0f0f0}.suggestion-item:hover{background:#f8f9fa}.suggestion-item:last-child{border-bottom:none}.place-name{font-weight:600;line-height:1.2;margin-bottom:.2rem}.place-display-name{font-size:.85rem;color:#666;line-height:1.2}.selected-location{text-align:center;margin-top:1rem;color:#4caf50}.taxon-name{font-weight:600;line-height:1.2;margin-bottom:.2rem}.scientific-name{font-size:.85rem;color:#666;line-height:1.2;display:flex;align-items:center;gap:.5rem}.latin-name{font-style:italic}.taxon-rank{font-style:normal;color:#888;font-size:.8rem;text-transform:capitalize}.more-suggestions{padding:.5rem .75rem;text-align:center;color:#666;font-size:.85rem;font-style:italic;border-top:1px solid #f0f0f0;background:#f8f9fa}.category-selector{margin-bottom:2rem}.category-selector h3{text-align:center;margin:0 0 1.5rem;color:#333}@media (prefers-color-scheme: dark){.category-selector h3{color:#ffffffde}}.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;max-width:800px;margin:0 auto}.category-card{padding:1.5rem;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .2s;text-align:left;min-height:44px;box-sizing:border-box;color:#333}.category-card:hover{border-color:#4caf50;background:#f8f9fa}.category-card.selected{border-color:#4caf50;background:#e8f5e8}.category-name{font-size:1.2rem;font-weight:600;margin-bottom:.5rem;color:#333}.category-description{font-size:.9rem;color:#666;line-height:1.4}.selected-category{text-align:center;margin-top:1rem;color:#4caf50}.quiz-section{max-width:800px;margin:0 auto}.quiz-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.back-btn{padding:.5rem 1rem;background:#f0f0f0;border:1px solid #ddd;border-radius:6px;cursor:pointer}.back-btn:hover{background:#e0e0e0}.quiz-progress{font-weight:600;color:#666}.quiz-question h3{text-align:center;margin:0 0 1.5rem;color:#333}.quiz-image{max-width:100%;max-height:400px;border-radius:12px;box-shadow:0 4px 12px #00000026}.clickable-photo{cursor:pointer;transition:transform .2s}.clickable-photo:hover{transform:scale(1.02)}.photo-count{margin-top:.5rem;font-size:.9rem;color:#666}.no-photo-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:300px;background:#f8f9fa;border:2px dashed #ddd;border-radius:12px;font-size:1.2rem;color:#666}.observation-info{background:#f8f9fa;padding:1rem;border-radius:8px;margin-bottom:2rem}.observation-info p{margin:.25rem 0;color:inherit}.answer-section{position:relative}.input-container{display:flex;gap:1rem;margin-bottom:1rem}.answer-input{flex:1;padding:.75rem;border:2px solid #ddd;border-radius:8px;font-size:1rem;min-height:44px;box-sizing:border-box}.answer-input:focus{outline:none;border-color:#4caf50}.answer-input.correct{border-color:#4caf50;background:#e8f5e8}.answer-input.incorrect{border-color:#f44336;background:#ffe8e8}.submit-btn{padding:.75rem 1.5rem;background:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;min-height:44px;box-sizing:border-box}.submit-btn:hover:not(:disabled){background:#45a049}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.result{background:#fff;border-radius:12px;padding:1.5rem;margin-top:1rem;border:2px solid}.result.correct{border-color:#4caf50;background:#e8f5e8}.result.incorrect{border-color:#f44336;background:#ffe8e8}.result-message{font-size:1.2rem;font-weight:600;margin-bottom:1rem}.partial-credit-info{background:#fff3cd;border:1px solid #ffeeba;border-radius:6px;padding:.75rem;margin-bottom:1rem;color:#856404}.correct-answer{margin-bottom:1.5rem}.taxon-info{background:#fff;padding:1rem;border-radius:8px;margin-top:.5rem}.common-name{font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.scientific-name{color:#666;margin-bottom:.25rem}.rank{font-size:.9rem;color:#888;text-transform:capitalize}.result-actions{display:flex;gap:1rem;align-items:center;justify-content:center;flex-wrap:wrap}.observation-link{display:inline-block;padding:.5rem 1rem;background:#f8f9fa;color:#495057;text-decoration:none;border:1px solid #ddd;border-radius:6px;font-size:.9rem;transition:all .2s}.observation-link:hover{background:#e9ecef;color:#495057;text-decoration:none}.next-btn{padding:.75rem 2rem;background:#2196f3;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;min-height:44px;box-sizing:border-box}.next-btn:hover{background:#1976d2}.score-display{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:1.5rem;margin-top:2rem}.score-display h3{margin:0 0 1rem;text-align:center;color:#333}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:1rem;margin-bottom:1rem}.stat-item{text-align:center}.stat-value{font-size:2rem;font-weight:700;color:#4caf50;margin-bottom:.25rem}.stat-label{font-size:.9rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.reset-btn{display:block;margin:0 auto;padding:.5rem 1rem;background:#f44336;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;min-height:44px;box-sizing:border-box}.reset-btn:hover{background:#d32f2f}.photo-carousel{margin-bottom:1.5rem}.main-photo-container{position:relative;text-align:center;margin-bottom:1rem;display:flex;justify-content:center}.image-loading-placeholder,.image-error-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:300px;background:#f8f9fa;border:2px dashed #ddd;border-radius:12px;color:#666}.image-loading-placeholder .loading-spinner{font-size:2rem;margin-bottom:.5rem;animation:spin 1s linear infinite}.image-error-placeholder .error-icon{font-size:2rem;margin-bottom:.5rem;opacity:.5}.quiz-image.loading{opacity:0;transition:opacity .3s ease}.photo-nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:#000000b3;color:#fff;border:none;width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .2s}.photo-nav-btn:hover{background:#000000e6}.photo-nav-prev{left:10px}.photo-nav-next{right:10px}.photo-counter{position:absolute;bottom:10px;right:10px;background:#000000b3;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.85rem}.photo-thumbnails{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;max-width:600px;margin:0 auto}.photo-thumbnail{background:none;border:2px solid transparent;border-radius:6px;cursor:pointer;padding:2px;transition:border-color .2s;overflow:hidden;position:relative}.photo-thumbnail:hover{border-color:#ddd}.photo-thumbnail.active{border-color:#4caf50}.photo-thumbnail img{width:60px;height:60px;object-fit:cover;border-radius:4px;display:block}.thumbnail-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;width:60px;height:60px;background:#f8f9fa;border-radius:4px;color:#666}.loading-spinner-small{font-size:.8rem;animation:spin 1s linear infinite}.photo-thumbnail img:not([style*="display: none"])+.thumbnail-loading{display:none}.observation-photo{text-align:center;margin-bottom:1.5rem}.photo-zoom-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:pointer}.photo-zoom-overlay{position:relative;max-width:95vw;max-height:95vh;display:flex;flex-direction:column;align-items:center}.photo-zoom-close{position:absolute;top:-50px;right:0;background:#ffffffe6;border:none;width:40px;height:40px;border-radius:50%;font-size:24px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1001;transition:background .2s}.photo-zoom-close:hover{background:#fff}.photo-zoom-container{cursor:default;max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center;position:relative}.zoom-loading-placeholder,.zoom-error-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;width:300px;height:200px;background:#ffffffe6;border-radius:12px;color:#333;text-align:center;box-shadow:0 4px 12px #0000004d}.zoom-loading-placeholder .loading-spinner,.zoom-error-placeholder .error-icon{font-size:2rem;margin-bottom:.5rem}.zoom-loading-placeholder .loading-spinner{animation:spin 1s linear infinite}.zoom-error-placeholder .error-icon{opacity:.5}.photo-zoom-image{max-width:95vw;max-height:85vh;object-fit:contain;border-radius:8px;box-shadow:0 8px 32px #00000080}.photo-zoom-hint{position:absolute;bottom:-40px;color:#fffc;font-size:.9rem;text-align:center;white-space:nowrap}.start-section{text-align:center;margin-top:2rem}.start-quiz-btn{padding:1rem 2rem;background:#4caf50;color:#fff;border:none;border-radius:12px;cursor:pointer;font-size:1.1rem;font-weight:600;min-height:44px;box-sizing:border-box}.start-quiz-btn:hover:not(:disabled){background:#45a049}.start-quiz-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#ffe8e8;border:1px solid #f44336;border-radius:8px;padding:1rem;margin:1rem 0;color:#d32f2f;text-align:center}.loading-section{text-align:center;padding:4rem 0}.loading-spinner{font-size:3rem;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.app{padding:.5rem}.app-header{margin-bottom:.75rem;padding:.5rem 0}.app-header h1{font-size:1.8rem}.app-header p{font-size:1rem}.location-picker-container{flex-direction:column;gap:.75rem}.location-input,.quick-start-btn{padding:1rem;font-size:1rem}.suggestions-dropdown{right:0;max-height:300px}.suggestion-item{padding:.75rem;font-size:1rem}.category-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem}.category-card{padding:1rem}.category-name{font-size:1.1rem}.category-description{font-size:.85rem}.quiz-header{flex-direction:column;gap:.5rem;align-items:flex-start}.quiz-progress{align-self:center}.quiz-image{max-height:300px}.photo-nav-btn{width:48px;height:48px;font-size:1.4rem}.photo-nav-prev{left:5px}.photo-nav-next{right:5px}.photo-thumbnails{gap:.25rem}.photo-thumbnail img{width:50px;height:50px}.back-btn{padding:.75rem 1rem;font-size:1rem}.input-container{flex-direction:column;gap:.75rem}.answer-input{padding:1rem;font-size:1rem}.submit-btn,.next-btn{padding:1rem 1.5rem;font-size:1rem}.start-quiz-btn{padding:1rem 2rem;font-size:1rem}.reset-btn{padding:.75rem 1rem;font-size:1rem}.location-picker,.category-selector{margin-bottom:1.5rem}.quiz-section{padding:0}.observation-photo{margin-bottom:1rem}.observation-info{padding:.75rem;margin-bottom:1rem}.result{padding:1rem;margin-top:.75rem}.result-actions{flex-direction:column;gap:.5rem}.score-display{padding:1rem;margin-top:1rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(60px,1fr));gap:.5rem}.stat-value{font-size:1.5rem}.image-loading-placeholder,.image-error-placeholder{height:250px}.zoom-loading-placeholder,.zoom-error-placeholder{width:280px;height:180px}.thumbnail-loading,.photo-thumbnail img{width:50px;height:50px}}@media (max-width: 480px){.app{padding:.25rem}.app-header h1{font-size:1.5rem}.app-header p{font-size:.9rem;padding:0 .5rem}.category-grid{grid-template-columns:1fr;gap:.5rem}.category-card{padding:.75rem}.category-name{font-size:1rem}.category-description{font-size:.8rem}.quiz-image{max-height:250px}.photo-nav-btn{width:40px;height:40px;font-size:1.2rem}.photo-thumbnails{gap:.125rem}.photo-thumbnail img{width:40px;height:40px}.quiz-header{padding-bottom:.5rem}.back-btn{padding:.5rem .75rem;font-size:.9rem}.answer-input{padding:.75rem;font-size:1rem}.submit-btn,.next-btn{padding:.75rem 1rem;font-size:1rem}.start-quiz-btn{padding:.75rem 1.5rem;font-size:1rem}.location-picker,.category-selector{margin-bottom:1rem}.observation-photo{margin-bottom:.75rem}.observation-info{padding:.5rem;margin-bottom:.75rem}.result{padding:.75rem;margin-top:.5rem}.score-display{padding:.75rem;margin-top:.75rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(50px,1fr));gap:.25rem}.stat-value{font-size:1.25rem}.start-section{margin-top:1rem}.image-loading-placeholder,.image-error-placeholder{height:200px}.zoom-loading-placeholder,.zoom-error-placeholder{width:250px;height:150px}.thumbnail-loading,.photo-thumbnail img{width:40px;height:40px}}@media (prefers-color-scheme: dark){.app-header h1{color:#4caf50}.app-header p{color:#aaa}.location-input.location-input{background:#333;color:#ffffffde;border-color:#555}.location-input.location-input:focus{border-color:#4caf50}.quick-start-btn.quick-start-btn{background:#333;color:#ffffffde;border-color:#555}.quick-start-btn.quick-start-btn:hover{background:#444}.suggestions-dropdown.suggestions-dropdown{background:#333;border-color:#555;color:#ffffffde}.suggestion-item{border-bottom-color:#555}.suggestion-item:hover{background:#444}.place-display-name,.scientific-name{color:#aaa}.taxon-rank{color:#999}.more-suggestions{color:#aaa;border-top-color:#555;background:#444}.category-card.category-card{background:#333;border-color:#555;color:#ffffffde}.category-card.category-card:hover{background:#444;border-color:#4caf50}.category-card.category-card.selected{background:#2e4a2e;border-color:#4caf50}.category-name.category-name{color:#ffffffde}.category-description{color:#aaa}.quiz-header{border-bottom-color:#555}.quiz-progress{color:#aaa}.quiz-question.quiz-question h3{color:#ffffffde}.back-btn.back-btn{background:#333;border-color:#555;color:#ffffffde}.back-btn.back-btn:hover{background:#444}.answer-input.answer-input{background:#333;border-color:#555;color:#ffffffde}.answer-input.answer-input:focus{border-color:#4caf50}.observation-info.observation-info{background:#333;color:#ffffffde}.observation-info.observation-info p{color:#ffffffde}.no-photo-placeholder{background:#333;border-color:#555;color:#aaa}.photo-count{color:#aaa}.result.result{background:#333;color:#ffffffde}.result.result.correct{background:#2e4a2e}.result.result.incorrect{background:#4a2e2e}.partial-credit-info{background:#4a4a2e;border-color:#666;color:#ddd}.taxon-info.taxon-info{background:#444;color:#ffffffde}.scientific-name{color:#aaa}.rank{color:#999}.observation-link{background:#333;color:#ffffffde;border-color:#555}.observation-link:hover{background:#444;color:#ffffffde}.score-display.score-display{background:#333;border-color:#555;color:#ffffffde}.score-display.score-display h3{color:#ffffffde}.stat-value.stat-value{color:#4caf50}.stat-label.stat-label{color:#aaa}.reset-btn.reset-btn{background:#f44336;color:#fff}.reset-btn.reset-btn:hover{background:#d32f2f}.error-message.error-message{background:#4a2e2e;border-color:#f44336;color:#faa}}
