@import "https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap";:root{--color-primary:#2d5016;--color-primary-light:#4a7c2c;--color-secondary:#7a9b6e;--color-danger:#c53030;--color-bg:#f5f5f0;--color-card:#fff;--color-border:#e0e0d8;--color-text:#2d3748;--color-text-light:#718096;--color-success:#38a169;--color-gold:#c8a84b;--spacing-xs:.5rem;--spacing-sm:.75rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--radius:12px;--shadow:0 2px 8px #00000014;--shadow-lg:0 4px 16px #0000001f}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg);color:var(--color-text);font-family:Roboto,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--color-primary);color:#fff;padding:var(--spacing-sm) var(--spacing-lg);box-shadow:var(--shadow);z-index:100;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.app-header-logo{align-items:center;gap:var(--spacing-sm);display:flex}.header-logo-img{filter:brightness(0)invert();width:auto;height:36px}.header-wordmark{flex-direction:column;line-height:1.1;display:flex}.header-birding{letter-spacing:3px;color:#fff;font-family:Roboto,sans-serif;font-size:1rem;font-weight:700}.header-tracker{letter-spacing:4px;color:var(--color-gold);font-family:Roboto,sans-serif;font-size:.6rem;font-weight:300}.app-header h1{font-size:1.1rem;font-weight:500}.btn-back{color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius);cursor:pointer;white-space:nowrap;background:#fff3;border:1px solid #fff6;flex-shrink:0;font-size:.95rem;transition:background .2s}.btn-back:hover{background:#ffffff4d}.voice-error{margin-top:var(--spacing-sm);color:var(--color-danger);padding:var(--spacing-sm);border-radius:var(--radius);background:#fff5f5;border:1px solid #fed7d7;font-size:.88rem}.firefox-voice-hint{color:#075985;padding:var(--spacing-sm);border-radius:var(--radius);margin-bottom:var(--spacing-md);background:#e0f2fe;border:1px solid #7dd3fc;font-size:.9rem}.app-main{padding:var(--spacing-lg);flex:1;width:100%;max-width:800px;margin:0 auto}.btn{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius);cursor:pointer;justify-content:center;align-items:center;gap:var(--spacing-xs);border:none;min-height:44px;font-size:1rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-large{padding:var(--spacing-md) var(--spacing-xl);min-height:54px;font-size:1.1rem}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-light)}.btn-secondary{background:var(--color-secondary);color:#fff}.btn-secondary:hover:not(:disabled){opacity:.9}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.9}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-small{min-height:32px;padding:6px 12px;font-size:.9rem}.btn-tiny{border-radius:6px;min-height:28px;padding:4px 8px;font-size:.85rem}.modal-overlay{z-index:1000;padding:var(--spacing-lg);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-card);border-radius:var(--radius);padding:var(--spacing-lg);width:100%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-lg);overflow-y:auto}.modal-content h3{margin-bottom:var(--spacing-md)}.button-group{gap:var(--spacing-md);grid-template-columns:1fr 1fr;display:grid}.button-group .btn{width:100%}.input-field{width:100%;padding:var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--radius);background:#fff;font-size:1rem;transition:border-color .2s}.input-field:focus{border-color:var(--color-primary);outline:none}.input-large{padding:var(--spacing-lg);min-height:54px;font-size:1.1rem}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{margin-bottom:var(--spacing-xs);color:var(--color-text-light);font-weight:500;display:block}.loading,.empty-state,.error-state{text-align:center;padding:var(--spacing-xl);color:var(--color-text-light);flex-direction:column;justify-content:center;align-items:center;min-height:300px;display:flex}.loading p{color:var(--color-text);margin-top:var(--spacing-md);font-size:1.1rem;font-weight:500}.spinner{border:4px solid var(--color-border);border-top-color:var(--color-primary);width:60px;height:60px;margin:0 auto var(--spacing-md);border-radius:50%;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.session-manager{gap:var(--spacing-xl);flex-direction:column;display:flex}.new-session,.resume-prompt{background:var(--color-card);padding:var(--spacing-xl);border-radius:var(--radius);box-shadow:var(--shadow)}.auto-ended-notice{padding:var(--spacing-xl);border-radius:var(--radius);margin-bottom:var(--spacing-xl);background:#fff9e6;border:2px solid #f59e0b}.auto-ended-notice h2{color:#92400e;margin-bottom:var(--spacing-md)}.new-session h2,.resume-prompt h2{margin-bottom:var(--spacing-md);font-size:1.5rem}.resume-prompt p{margin-bottom:0}.resume-prompt p:first-of-type{margin-bottom:var(--spacing-xs);font-size:1.1rem}.gps-hint{text-align:center;color:var(--color-text-light);margin-top:var(--spacing-md);font-size:.9rem}.location-name{color:var(--color-primary);margin:var(--spacing-sm) 0;font-weight:500}.recent-sessions{background:var(--color-card);padding:var(--spacing-lg);border-radius:var(--radius);box-shadow:var(--shadow)}.recent-sessions h3{margin-bottom:var(--spacing-md)}.session-list{margin-bottom:var(--spacing-lg);list-style:none}.session-item{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);gap:var(--spacing-sm);flex-direction:column;font-size:.95rem;display:flex}.session-item:last-child{border-bottom:none}.session-item-row-clickable{gap:var(--spacing-sm);cursor:pointer;padding:var(--spacing-xs) 0;border-radius:var(--radius-sm);flex-wrap:wrap;transition:background .2s;display:flex}.session-item-row-clickable:hover{background:#00000005}.session-item-row-controls{align-items:center;gap:var(--spacing-sm);justify-content:space-between;display:flex}.session-date{color:var(--color-text);font-weight:500}.session-location{color:var(--color-primary)}.session-stats{color:var(--color-primary);margin-left:auto;font-weight:600}.active-session{gap:var(--spacing-xl);flex-direction:column;display:flex}.session-header{background:var(--color-card);padding:var(--spacing-lg);border-radius:var(--radius);box-shadow:var(--shadow);justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.session-info h2{margin-bottom:var(--spacing-xs)}.session-info .location{color:var(--color-primary);margin-bottom:var(--spacing-sm);font-size:.95rem}.session-stats{gap:var(--spacing-lg);color:var(--color-text-light);flex-wrap:wrap;font-size:.9rem;display:flex}.stat{align-items:center;gap:var(--spacing-xs);display:flex}.bird-input{background:var(--color-card);padding:var(--spacing-xl);border-radius:var(--radius);box-shadow:var(--shadow)}.bird-input h3{margin-bottom:var(--spacing-lg)}.search-container{position:relative}.suggestions-list{border:2px solid var(--color-border);border-radius:0 0 var(--radius) var(--radius);z-index:10;max-height:300px;box-shadow:var(--shadow-lg);background:#fff;border-top:none;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.suggestion-item{padding:var(--spacing-md);cursor:pointer;border-bottom:1px solid var(--color-border);gap:var(--spacing-xs);flex-direction:column;transition:background .2s;display:flex}.suggestion-item:hover{background:var(--color-bg)}.suggestion-item:last-child{border-bottom:none}.bird-name{color:var(--color-text);font-weight:500}.bird-scientific{color:var(--color-text-light);font-size:.85rem;font-style:italic}.no-results{padding:var(--spacing-lg);text-align:center;color:var(--color-text-light);border:2px solid var(--color-border);border-radius:0 0 var(--radius) var(--radius);background:#fff;border-top:none}.search-input-row{gap:var(--spacing-sm);align-items:stretch;display:flex}.search-input-row .input-field{flex:1}.btn-voice{border:2px solid var(--color-border);border-radius:var(--radius);cursor:pointer;background:#fff;flex-shrink:0;justify-content:center;align-items:center;width:54px;min-height:54px;font-size:1.4rem;transition:all .2s;display:flex}.btn-voice:hover{border-color:var(--color-primary)}.btn-voice.listening{border-color:var(--color-danger);background:#fee2e2;animation:1s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.voice-hint{margin-top:var(--spacing-sm);color:var(--color-danger);text-align:center;font-size:.9rem}.bird-info-compact{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius);margin-bottom:var(--spacing-md);display:flex}.bird-name-large{color:var(--color-primary);font-size:1.2rem;font-weight:600}.count-row{align-items:center;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.count-row label{color:var(--color-text-light);white-space:nowrap;font-weight:500}.selected-bird{gap:var(--spacing-lg);flex-direction:column;display:flex}.bird-info{padding:var(--spacing-lg);background:var(--color-bg);border-radius:var(--radius)}.bird-info h4{margin-bottom:var(--spacing-xs);color:var(--color-primary)}.scientific-name{color:var(--color-text-light);margin-bottom:var(--spacing-sm);font-size:.9rem;font-style:italic}.category-badge{padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-primary);color:#fff;border-radius:20px;font-size:.8rem;font-weight:500;display:inline-block}.count-selector label{margin-bottom:var(--spacing-sm);color:var(--color-text-light);font-weight:500;display:block}.count-input{align-items:center;gap:var(--spacing-md);display:flex}.btn-count{border:2px solid var(--color-primary);width:44px;height:44px;color:var(--color-primary);cursor:pointer;background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;transition:all .2s;display:flex}.btn-count:hover{background:var(--color-primary);color:#fff}.input-count{text-align:center;width:80px;padding:var(--spacing-sm);border:2px solid var(--color-border);border-radius:var(--radius);font-size:1.1rem;font-weight:500}.sightings-list{background:var(--color-card);padding:var(--spacing-lg);border-radius:var(--radius);box-shadow:var(--shadow)}.sightings-list h3{margin-bottom:var(--spacing-md)}.sightings{list-style:none}.sighting-item{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);align-items:center;gap:8px;display:flex}.sighting-item:last-child{border-bottom:none}.sighting-time{color:var(--color-text-light);flex-shrink:0;min-width:50px;font-size:.9rem}.sighting-name{flex:1;font-weight:500}.sighting-count{color:var(--color-primary);margin-left:auto;font-weight:600}.notes-section{background:var(--color-card);padding:var(--spacing-lg);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:var(--spacing-lg)}.notes-header h3{-webkit-user-select:none;user-select:none;margin-bottom:0}.note-input-section{margin-top:var(--spacing-md);margin-bottom:var(--spacing-md)}.note-textarea{width:100%;padding:var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--radius);resize:vertical;margin-bottom:var(--spacing-sm);font-family:inherit;font-size:1rem;transition:border-color .2s}.note-textarea:focus{border-color:var(--color-primary);outline:none}.notes-list{margin-top:var(--spacing-md);list-style:none}.note-item{gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--color-border);background:var(--color-bg);border-radius:var(--radius);margin-bottom:var(--spacing-sm);align-items:flex-start;display:flex}.note-time{color:var(--color-text-light);white-space:nowrap;font-size:.85rem;font-weight:500}.note-text{flex:1;line-height:1.5}.note-gps{opacity:.6;font-size:.9rem}.session-list-container h2{margin-bottom:var(--spacing-lg)}.session-cards{gap:var(--spacing-lg);list-style:none;display:grid}.session-card{background:var(--color-card);padding:var(--spacing-lg);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;transition:all .2s}.session-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.session-card-header{margin-bottom:var(--spacing-sm);justify-content:space-between;align-items:center;display:flex}.status-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:20px;font-size:.8rem;font-weight:500}.status-badge.active{background:var(--color-success);color:#fff}.session-card-stats{gap:var(--spacing-md);margin-top:var(--spacing-md);color:var(--color-text-light);flex-wrap:wrap;font-size:.9rem;display:flex}.session-detail{gap:var(--spacing-xl);flex-direction:column;display:flex}.session-detail-header{background:var(--color-card);padding:var(--spacing-lg);border-radius:var(--radius);box-shadow:var(--shadow)}.session-header-row{margin-bottom:var(--spacing-sm);justify-content:space-between;align-items:baseline;display:flex}.session-header-row h2{margin:0;font-size:1.3rem}.session-time{color:#64748b;margin-bottom:var(--spacing-lg);font-size:.95rem;font-weight:400}.session-detail-header .location{color:var(--color-text-light);margin:0}.session-detail-header h2{margin-bottom:var(--spacing-xs)}.stats-grid{gap:var(--spacing-md);grid-template-columns:repeat(2,1fr);display:grid}.stat-card{background:var(--color-card);padding:var(--spacing-lg);border-radius:var(--radius);box-shadow:var(--shadow);text-align:center}.stat-value{color:var(--color-primary);margin-bottom:var(--spacing-xs);font-size:2rem;font-weight:700;display:block}.stat-label{color:var(--color-text-light);font-size:.9rem;display:block}.map-section{background:var(--color-card);padding:var(--spacing-lg);border-radius:var(--radius);box-shadow:var(--shadow)}.map-placeholder{margin-top:var(--spacing-lg);padding:var(--spacing-xl);background:var(--color-bg);border-radius:var(--radius);text-align:center;color:var(--color-text-light)}.map-hint{margin-top:var(--spacing-sm);font-size:.9rem}.species-list,.all-sightings{background:var(--color-card);padding:var(--spacing-lg);border-radius:var(--radius);box-shadow:var(--shadow)}.species-list h3,.all-sightings h3{margin-bottom:var(--spacing-md)}.species-cards{gap:var(--spacing-sm);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.species-card{align-items:center;gap:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius);padding:var(--spacing-sm);display:flex;overflow:hidden}.species-photo{object-fit:cover;border-radius:8px;flex-shrink:0;width:80px;min-width:80px;height:60px;min-height:60px}.species-photo[src="/logo.svg"],.species-photo[src*=logo\.svg]{object-fit:contain;background:var(--color-border);padding:8px}.species-info{flex:1;min-width:0}.species-info h4{color:var(--color-primary);margin:0;font-size:1.05rem;font-weight:600;line-height:1.2}.species-count-line{color:var(--color-primary);opacity:.7;font-size:.9rem;font-weight:700;line-height:1.2}.species-info .scientific-name{color:var(--color-text-light);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.8rem;font-style:italic;line-height:1.2;overflow:hidden}.species-count{color:var(--color-primary);font-size:1.5rem;font-weight:700}.timeline-list{list-style:none}.timeline-item{gap:var(--spacing-xs);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border);flex-direction:column;display:flex}.timeline-item:last-child{border-bottom:none}.timeline-row-main{align-items:center;gap:8px;display:flex}.timeline-time{color:var(--color-text-light);min-width:55px;font-size:.9rem}.timeline-bird{flex:1;font-weight:500}.timeline-count{color:var(--color-primary);font-weight:600}.timeline-edit-buttons{flex-shrink:0;gap:4px;padding-left:76px;display:flex}@media (width<=640px){.app-main{padding:var(--spacing-md)}.session-header,.button-group{flex-direction:column}.button-group .btn{width:100%}}.import-session{background:var(--color-card);padding:var(--spacing-xl);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:var(--spacing-xl)}.import-session h3{margin-bottom:var(--spacing-sm)}.import-hint{color:var(--color-text-light);margin-bottom:var(--spacing-lg);font-size:.9rem}.import-status{margin-top:var(--spacing-md);color:var(--color-primary);font-weight:500}.import-error{margin-top:var(--spacing-md);color:var(--color-danger);padding:var(--spacing-sm);border-radius:var(--radius);background:#fff5f5;border:1px solid #fed7d7}.header-controls{align-items:center;gap:var(--spacing-md);display:flex}.theme-switcher{gap:var(--spacing-xs);background:#ffffff26;border-radius:8px;padding:4px;display:flex}.theme-btn{color:#ffffffb3;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:6px 12px;font-size:.85rem;font-weight:500;transition:all .2s}.theme-btn:hover{color:#fff;background:#ffffff1a}.theme-btn.active{color:#fff;background:#ffffff40}@media (width<=640px){.theme-switcher{flex-direction:column;gap:2px}.theme-btn{padding:4px 8px;font-size:.75rem}}.species-list-header{margin-bottom:var(--spacing-md);justify-content:space-between;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.species-list-header h3{margin:0}.stat-card-action{cursor:pointer;flex-direction:column;justify-content:center;transition:all .2s}.stat-card-action:hover{background:var(--color-primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #2d50164d}.stat-card-action .stat-icon{margin-bottom:var(--spacing-xs);font-size:2rem}.stat-card-action .stat-label{font-size:.9rem;font-weight:500}.session-controls{gap:var(--spacing-md);margin-top:var(--spacing-md);display:flex}.session-controls .btn{flex:1}.btn-large{padding:var(--spacing-md) var(--spacing-lg);font-size:1rem}.map-controls-wrapper{gap:var(--spacing-sm);flex-direction:column;display:flex}.map-controls-row{gap:var(--spacing-sm);grid-template-columns:1fr 1fr;display:grid}.btn-full-width{width:100%}@media (width>=768px){.map-controls-row .btn{min-width:auto}}.icon-play,.icon-pause,.icon-end{color:#000;text-shadow:0 0 1px #0000004d;margin-right:.4em;font-weight:700;display:inline-block}.icon-play{font-size:.9em}.icon-pause{font-size:1em}.icon-end{vertical-align:middle;font-size:.7em}.heard-only-row{padding:0}.gender-row{margin:var(--spacing-md) 0;padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius)}.checkbox-label{align-items:center;gap:var(--spacing-sm);cursor:pointer;-webkit-user-select:none;user-select:none;display:flex}.checkbox-input{cursor:pointer;width:18px;height:18px}.checkbox-label span{color:var(--color-text);font-size:.95rem}.heard-icon{opacity:.8;font-size:.9em}.sightings-header{margin-bottom:var(--spacing-md);justify-content:space-between;align-items:baseline;display:flex}.sightings-header h3{margin:0}.total-count{color:var(--color-primary);font-size:.9rem;font-weight:600}.wiki-link:hover{text-decoration:underline}.no-info{color:var(--color-text-light);font-style:italic}@media (width>=768px){.species-cards{gap:var(--spacing-md);grid-template-columns:repeat(2,1fr);display:grid}.species-photo{width:120px;min-width:120px;height:120px;min-height:120px}.species-info h4{font-size:1.3rem}.species-count-inline{font-size:1.4rem}}.bird-detail{max-width:800px;padding:0 var(--spacing-md) var(--spacing-md);margin:0 auto}.bird-detail .btn-back{margin-bottom:var(--spacing-lg)}.bird-detail-content h2{margin:var(--spacing-lg) 0 var(--spacing-xs) 0;color:var(--color-primary);font-size:2rem}.seen-icon{opacity:.7;font-size:.9em}.bird-detail-photo{border-radius:var(--radius);width:100%;max-width:500px;height:auto;box-shadow:0 4px 12px #00000026}.photo-modal{z-index:9999;cursor:pointer;padding:var(--spacing-lg);background:#000000f2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.photo-modal-content{justify-content:center;align-items:center;max-width:100%;max-height:100%;display:flex;position:relative}.photo-modal-content img{object-fit:contain;border-radius:var(--radius);cursor:zoom-in;width:auto;max-width:90vw;height:auto;max-height:90vh;box-shadow:0 8px 32px #00000080}.photo-modal-close{color:#000;cursor:pointer;z-index:10000;background:#fffffff2;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.5rem;transition:all .2s;display:flex;position:absolute;top:-50px;right:0;box-shadow:0 2px 8px #0000004d}.photo-modal-close:hover{background:#fff;transform:scale(1.1)}.bird-info-grid{margin:var(--spacing-lg) 0;gap:var(--spacing-md);flex-direction:column;display:flex}.bird-info-item{gap:var(--spacing-xs);flex-direction:column;display:flex}.info-label{color:var(--color-primary);font-size:.9rem;font-weight:600}.info-value{color:var(--color-text);line-height:1.5}.bird-facts{margin:var(--spacing-lg) 0;gap:var(--spacing-md);flex-direction:column;display:flex}.bird-fact{flex-direction:column;gap:.25rem;display:flex}.fact-label{color:var(--color-primary);text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;font-weight:700}.fact-value{color:var(--color-text);font-size:.95rem;line-height:1.5}@media (width<=767px){.sightings-header{align-items:flex-start;gap:var(--spacing-xs);flex-direction:column}.sightings-header h3{margin:0}.total-count{font-size:.9rem}}@media (width>=768px){.sightings-header{flex-direction:row;justify-content:space-between;align-items:baseline}}.bird-audio-section{margin:var(--spacing-lg) 0;padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius)}.audio-loading{align-items:center;gap:var(--spacing-sm);color:var(--color-text-secondary);display:flex}.spinner-small{border:2px solid #0000001a;border-top-color:var(--color-primary);border-radius:50%;width:16px;height:16px;animation:1s linear infinite spin}.audio-error{color:var(--color-text-secondary);font-style:italic}.audio-player{gap:var(--spacing-sm);flex-direction:column;display:flex}.audio-credit{color:var(--color-text-secondary);margin:0;font-size:.85rem}.audio-credit a{color:var(--color-primary);text-decoration:none}.audio-credit a:hover{text-decoration:underline}.audio-player audio{width:100%;height:40px}.session-item-clickable{cursor:pointer;transition:background-color .2s}.session-item-clickable:hover{background-color:#4c7e4c1a}.photo-credits{width:100%;max-width:800px;margin:0 auto}.credits-content{padding:var(--spacing-md);gap:var(--spacing-lg);flex-direction:column;display:flex}.credits-intro{background:var(--color-bg);padding:var(--spacing-md);border-radius:var(--radius-lg);border-left:4px solid var(--color-primary)}.credits-intro p{margin:.5rem 0;line-height:1.6}.license-info,.source-link,.attribution-note,.app-license{padding:var(--spacing-md);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff}.license-info h2,.source-link h2,.attribution-note h2,.app-license h2{color:var(--color-primary);margin:0 0 1rem;font-size:1.1rem}.license-info ul{margin:.5rem 0;padding-left:1.5rem}.license-info li{margin:.5rem 0}.external-link{color:var(--color-primary);font-weight:600;text-decoration:none}.external-link:hover{text-decoration:underline}.app-footer{margin-top:var(--spacing-xl);padding:var(--spacing-md);text-align:center;border-top:1px solid var(--color-border)}.btn-link{color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-sm);background:0 0;border:none;font-size:.9rem;transition:color .2s}.btn-link:hover{color:var(--color-primary);text-decoration:underline}.photo-loading{background:var(--color-bg);border-radius:var(--radius-lg);justify-content:center;align-items:center;min-height:200px;display:flex}.photo-attribution{color:var(--color-text-secondary);text-align:left;padding:0 var(--spacing-xs);opacity:.7;margin-top:.25rem;font-size:.65rem;font-style:italic}.bird-photo-container{margin-bottom:var(--spacing-lg);position:relative;display:block!important}.photo-attribution{color:var(--color-text-secondary);text-align:left;opacity:.7;width:100%;margin-top:.5rem;padding:0;font-size:.65rem;font-style:italic;display:block}.bird-scientific-name{font-weight:700!important}.sighting-item-info h3{margin:0;font-size:1rem;font-weight:600}.sighting-item-info p{color:var(--color-text-secondary);margin:.25rem 0 0;font-size:.8rem}.checkbox-wrapper{margin:.5rem 0!important;padding:.5rem 0!important}.app-footer-credit{color:var(--color-text-secondary);text-align:center;margin-top:var(--spacing-md);opacity:.6;margin-bottom:1rem;font-size:.65rem}.photo-nav{color:#fff;cursor:pointer;z-index:10;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:24px;transition:background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.photo-nav:hover{background:#000000b3}.photo-dots{justify-content:center;gap:8px;margin-top:12px;display:flex}.photo-dot{background:var(--color-border);cursor:pointer;border-radius:50%;width:8px;height:8px;transition:all .2s}.photo-dot.active{background:var(--color-primary);transform:scale(1.3)}.photo-dot:hover{background:var(--color-primary);opacity:.7}.modal-nav{color:#000;cursor:pointer;z-index:1001;background:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:32px;transition:background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.modal-nav:hover{background:#fff}.modal-nav-prev{left:20px}.modal-nav-next{right:20px}.modal-photo-counter{color:#fff;background:#000000b3;border-radius:20px;padding:8px 16px;font-size:14px;font-weight:600;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}@media (width<=768px){.photo-nav,.modal-nav{display:none}}html,body{max-width:100vw;overflow-x:hidden}html{width:100vw;max-width:100vw;overflow-x:hidden}body{width:100%;max-width:100vw;margin:0;padding:0;overflow-x:hidden}.app{width:100%;max-width:100vw;overflow-x:hidden}.app-main{box-sizing:border-box;width:100%;max-width:100%;overflow-x:hidden}img,video,iframe{max-width:100%;height:auto}.app-header,.session-card,.species-card,.bird-detail,.bird-detail-content{box-sizing:border-box;max-width:100%}.bird-photo-container{width:100%;max-width:100%;overflow:hidden;position:relative!important}.photo-nav{position:absolute!important}.photo-nav-prev{left:5px!important}.photo-nav-next{right:5px!important}.photo-modal{position:fixed;inset:0;overflow:hidden}.photo-modal-content{max-width:100vw;max-height:100vh;position:relative;overflow:hidden}
