:root{--bg:#0a0a0f;--bg-card:#12121a;--bg-sidebar:#0e0e16;--border:#1e1e2e;--text:#e0e0e8;--text-dim:#8585a0;--accent:#4ade80;--accent-dim:#22543d;--warn:#fbbf24;--danger:#f87171;--font:"SF Mono","Fira Code","JetBrains Mono",monospace;--accent-light:#6ee7b7;--danger-dark:#dc2626;--cyan:#22d3ee;--amber:#f59e0b;--call-song:#4caf50;--call-alarm:#f44336;--call-contact:#2196f3;--call-flight:#9c27b0;--call-begging:#ff9800;--call-drumming:#795548;--ct-song:#6fcf97;--ct-song-bg:#2d5a3d;--ct-alarm:#eb5757;--ct-alarm-bg:#5a2d2d;--ct-contact:#56ccf2;--ct-contact-bg:#2d3a5a;--ct-call:#bb6bd9;--ct-call-bg:#3a3a5a;--ct-flight:#f2994a;--ct-flight-bg:#4a3a2a;--ct-begging:#f2c94c;--ct-begging-bg:#4a4a2a;--ct-drumming:#d98ec6;--ct-drumming-bg:#3a2a3a;--ct-other:#828282;--ct-other-bg:#2a2a2a;--protocol-ws:#60a5fa;--protocol-reticulum:#a855f7;--source-acoustic:#4ecdc4;--source-visual:#ff6b6b;--source-fused:#ffe66d;--source-visual-light:#ce93d8;--source-fused-light:#f48fb1;--grade-verified:#4ade80;--grade-verified-bg:#4ade8026;--grade-research:#60a5fa;--grade-research-bg:#60a5fa26;--grade-confirmed:#a78bfa;--grade-confirmed-bg:#a78bfa26;--grade-probable:#fbbf24;--grade-probable-bg:#fbbf2426;--grade-needs-review:#f87171;--grade-needs-review-bg:#f8717126;--grade-casual:#6b7280;--grade-casual-bg:#6b728026}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:13px;line-height:1.5}.app{min-height:100vh;display:flex}.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:220px;padding:1.5rem 0;display:flex}.sidebar-header{border-bottom:1px solid var(--border);padding:0 1.25rem 1.5rem}.logo{letter-spacing:.15em;color:var(--accent);font-size:1.25rem;font-weight:700}.logo-sub{color:var(--text-dim);letter-spacing:.05em;margin-top:.15rem;font-size:.7rem;display:block}.nav-list{flex:1;padding:1rem 0;list-style:none}.nav-item{cursor:pointer;color:var(--text-dim);align-items:center;gap:.75rem;padding:.6rem 1.25rem;font-size:.85rem;transition:all .15s;display:flex}.nav-item:hover{color:var(--text);background:#ffffff08}.nav-item.active{color:var(--accent);border-right:2px solid var(--accent);background:#4ade800d}.nav-icon{text-align:center;width:1.5rem;font-size:.8rem}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:.6rem;padding:1rem 1.25rem;display:flex}.sidebar-stat{align-items:baseline;gap:.4rem;display:flex}.sidebar-stat-value{color:var(--accent);font-variant-numeric:tabular-nums;font-size:1.1rem;font-weight:700}.sidebar-stat-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem}.connection-status{color:var(--text-dim);align-items:center;gap:.5rem;font-size:.75rem;display:flex}.status-dot{background:var(--danger);border-radius:50%;width:6px;height:6px;display:inline-block}.status-dot.connected{background:var(--accent);box-shadow:0 0 6px var(--accent)}.content{scroll-behavior:smooth;flex:1;min-width:0;max-height:100vh;padding:2rem;overflow:hidden auto}.page-title{letter-spacing:.05em;margin-bottom:1.5rem;font-size:1rem;font-weight:600}.node-strip{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.node-chip{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;align-items:center;gap:.4rem;padding:.3rem .6rem;transition:border-color .15s;display:flex}.node-chip:hover{border-color:var(--accent)}.node-chip-name{color:var(--text);font-size:.75rem}.node-chip-count{color:var(--text-dim);font-size:.65rem}.stats-row{flex-wrap:wrap;gap:1rem;margin-bottom:2rem;display:flex}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;flex:1;min-width:120px;padding:1rem 1.25rem}.stat-value{color:var(--accent);font-size:1.5rem;font-weight:700}.stat-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem;font-size:.7rem}.stat-value-sm{font-size:1rem}.detection-feed{flex-direction:column;gap:.5rem;display:flex}.detection-card{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:.75rem 1rem;transition:border-color .15s}.detection-card:hover{border-color:var(--accent-dim)}.detection-header{justify-content:space-between;align-items:center;margin-bottom:.35rem;display:flex}.species-name{font-size:.9rem;font-weight:600}.detection-time-group{align-items:center;gap:.5rem;display:flex}.detection-time-rel{color:var(--accent);font-variant-numeric:tabular-nums;font-size:.75rem}.detection-time{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:.75rem}.detection-body{flex-direction:column;gap:.35rem;display:flex}.scientific-name{color:var(--text-dim);font-size:.75rem;font-style:italic}.detection-meta{align-items:center;gap:1rem;display:flex}.confidence{background:var(--border);border-radius:2px;flex:1;align-items:center;gap:.5rem;max-width:200px;height:4px;display:flex;position:relative}.confidence-bar{border-radius:2px;height:100%;transition:width .3s}.confidence-high .confidence-bar{background:var(--accent)}.confidence-mid .confidence-bar{background:var(--warn)}.confidence-low .confidence-bar{background:var(--danger)}.confidence-label{color:var(--text-dim);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:.7rem}.location{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:.7rem}.bird-id{color:var(--accent);font-variant-numeric:tabular-nums;margin-top:.25rem;font-size:.7rem}.bird-id.clickable:hover{text-decoration:underline}.play-btn{border:1px solid var(--border);color:var(--accent);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;margin-right:.25rem;padding:0;font-size:.7rem;transition:background .15s,border-color .15s;display:flex}.play-btn:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.play-btn.playing{opacity:.6;pointer-events:none;border-color:var(--accent)}.play-btn.error{border-color:var(--danger);color:var(--danger)}.share-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;width:1.5rem;height:1.5rem;font-size:.7rem;font-family:var(--font);background:0 0;border-radius:4px;justify-content:center;align-items:center;margin-right:.25rem;padding:0;transition:background .15s,border-color .15s,color .15s;display:flex}.share-btn:hover{background:var(--border);color:var(--text);border-color:var(--text-dim)}.detection-node{margin-top:.25rem}.node-tag{color:var(--text-dim);background:var(--border);letter-spacing:.03em;border-radius:3px;padding:.1rem .4rem;font-size:.65rem}.nodes-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.node-card{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:1rem;transition:border-color .15s}.node-card:hover{border-color:var(--accent-dim)}.node-header{align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.node-name{font-size:.9rem;font-weight:600}.node-stats{gap:1rem;margin-bottom:.75rem;display:flex}.node-stat{flex-direction:column;display:flex}.node-stat .stat-value{font-size:1.1rem}.node-meta{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.model-badge,.reticulum-badge{border:1px solid var(--border);color:var(--text-dim);background:#ffffff0d;border-radius:3px;padding:.15rem .4rem;font-size:.65rem}.reticulum-badge{border-color:var(--accent-dim);color:var(--accent)}.uptime{color:var(--text-dim);margin-left:auto;font-size:.7rem}.back-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;font-family:var(--font);background:0 0;border-radius:4px;margin-bottom:1.5rem;padding:.4rem .75rem;font-size:.75rem}.back-btn:hover{border-color:var(--text-dim);color:var(--text)}.detail-header{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.status-badge{color:var(--danger);background:#f871711a;border:1px solid #f8717133;border-radius:3px;padding:.2rem .5rem;font-size:.7rem}.status-badge.online{color:var(--accent);background:#4ade801a;border:1px solid #4ade8033}.health-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem;margin-bottom:2rem;display:grid}.health-card{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:.75rem 1rem}.health-card .stat-label{margin-bottom:.25rem}.health-card .stat-value{font-size:1.1rem}.empty-state{text-align:center;color:var(--text-dim);padding:3rem 1rem}.empty-state p{margin-bottom:.5rem}.hint{color:var(--text-dim);font-size:.75rem}h3{color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;font-size:.85rem;font-weight:600}.dashboard-toolbar{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.time-filters{gap:.25rem;display:flex}.filter-btn{font-family:var(--font);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;letter-spacing:.05em;background:0 0;border-radius:4px;padding:.3rem .6rem;font-size:.7rem;transition:all .15s}.filter-btn:hover{border-color:var(--text-dim);color:var(--text)}.filter-btn.active{border-color:var(--accent);color:var(--accent);background:#4ade801a}.search-box{flex:1;max-width:260px}.search-box input{width:100%;font-family:var(--font);border:1px solid var(--border);background:var(--bg-card);color:var(--text);border-radius:4px;outline:none;padding:.35rem .75rem;font-size:.8rem;transition:border-color .15s}.search-box input:focus{border-color:var(--accent-dim)}.search-box input::placeholder{color:var(--text-dim)}.loading-state{text-align:center;color:var(--text-dim);padding:3rem 1rem}.loading-spinner{border:2px solid var(--border);border-top:2px solid var(--accent);border-radius:50%;width:24px;height:24px;margin:0 auto 1rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-state{text-align:center;color:var(--danger);padding:3rem 1rem}.error-msg{margin-bottom:.5rem;font-weight:600}.error-state .hint{color:var(--text-dim);word-break:break-word;max-width:400px;margin:0 auto;font-size:.75rem}.activity-timeline{margin-bottom:2rem}.timeline-chart{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;align-items:flex-end;gap:3px;height:80px;padding:.75rem;display:flex}.timeline-bar-wrap{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:2px;height:100%;display:flex}.timeline-bar{background:var(--accent);border-radius:2px 2px 0 0;width:100%;min-height:2px;transition:height .3s}.timeline-bar.latest{background:var(--accent-light);box-shadow:0 0 6px #4ade804d}.timeline-count{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:.55rem}.export-btn{border:1px solid var(--border);color:var(--text-dim);font-family:var(--font);cursor:pointer;background:0 0;border-radius:4px;padding:.4rem 1rem;font-size:.75rem;transition:all .15s}.export-btn:hover{border-color:var(--accent);color:var(--accent)}.export-btn.exporting{opacity:.6;pointer-events:none;border-color:var(--accent);color:var(--accent)}.species-freq{margin-bottom:2rem}.freq-bars{flex-direction:column;gap:.4rem;display:flex}.freq-row{align-items:center;gap:.75rem;display:flex}.freq-label{text-align:right;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;width:180px;font-size:.8rem;overflow:hidden}.freq-track{background:var(--border);border-radius:3px;flex:1;height:6px;overflow:hidden}.freq-bar{background:var(--accent);border-radius:3px;min-width:3px;height:100%;transition:width .3s}.freq-count{width:2rem;color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:.75rem}.map-view{max-width:100%}.map-info{color:var(--text-dim);gap:2rem;margin-bottom:1rem;font-size:.75rem;display:flex}.map-container{border:1px solid var(--border);border-radius:6px;margin-bottom:2rem;overflow:hidden}.detection-map{width:100%;height:auto;display:block}.map-container-wrap{position:relative}.leaflet-map-container{border:1px solid var(--border);background:var(--bg-sidebar);border-radius:6px;width:100%;height:500px;margin-bottom:1rem;overflow:hidden}.map-empty-overlay{text-align:center;color:var(--text-muted);pointer-events:none;z-index:500;background:#0e0e16cc;border-radius:8px;padding:1.5rem 2rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.map-empty-overlay p{margin:0 0 .5rem}.map-empty-overlay .hint{opacity:.7;font-size:.85rem}@media (max-width:768px){.leaflet-map-container{height:350px}}.leaflet-popup-content-wrapper{background:var(--bg-card)!important;color:var(--text)!important;border:1px solid var(--border)!important;border-radius:6px!important}.leaflet-popup-tip{background:var(--bg-card)!important;border:1px solid var(--border)!important}.leaflet-popup-content{font-family:var(--font);font-size:.85rem}.chirp-node-icon{background:0 0!important;border:none!important}.map-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.map-dot{cursor:pointer;transition:opacity .15s}.map-dot:hover{opacity:1!important}.map-legend{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;flex-wrap:wrap;gap:.75rem;margin-top:1rem;padding:.75rem;display:flex}.legend-item{align-items:center;gap:.4rem;font-size:.75rem;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.legend-label{color:var(--text-dim);transition:color .15s}.legend-item:hover .legend-label{color:var(--text)}.clickable{cursor:pointer;border-radius:4px;margin:-.2rem -.4rem;padding:.2rem .4rem;transition:background .15s}.clickable:hover{background:#ffffff08}.clickable:hover .freq-label{color:var(--accent)}.species-detail .scientific-name{color:var(--text-dim);margin-bottom:1.5rem;font-size:.85rem;font-style:italic}.conf-histogram{align-items:flex-end;gap:.5rem;height:100px;margin-bottom:2rem;padding:0 1rem;display:flex}.conf-bucket{flex-direction:column;flex:1;align-items:center;gap:.25rem;display:flex}.conf-bucket-bar-wrap{align-items:flex-end;width:100%;height:80px;display:flex}.conf-bucket-bar{background:var(--accent);border-radius:3px 3px 0 0;width:100%;min-height:2px;transition:height .3s}.conf-bucket-label{color:var(--text-dim);white-space:nowrap;font-size:.6rem}.network-view{max-width:100%}.topology{border:1px solid var(--border);border-radius:6px;margin-bottom:2rem;overflow:hidden}.topology-svg{width:100%;height:auto;display:block}.mesh-node-list{flex-direction:column;gap:.5rem;display:flex}.mesh-node-row{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;align-items:center;gap:.75rem;padding:.6rem 1rem;display:flex}.mesh-node-info{flex-direction:column;flex:1;min-width:0;display:flex}.mesh-node-name{font-size:.85rem;font-weight:600}.mesh-node-desc{color:var(--text-dim);font-size:.7rem}.protocol-badge{border:1px solid var(--border);color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;background:#ffffff0d;border-radius:3px;padding:.15rem .5rem;font-size:.65rem}.protocol-badge.direct{border-color:var(--accent-dim);color:var(--accent)}.protocol-badge.websocket{color:var(--protocol-ws);border-color:#60a5fa4d}.protocol-badge.reticulum{color:var(--protocol-reticulum);border-color:#a855f74d}.protocol-badge.lora{color:var(--warn);border-color:#fbbf244d}.hop-count{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:.7rem}.settings-view{max-width:640px}.settings-section{border-bottom:1px solid var(--border);margin-bottom:2rem;padding-bottom:1.5rem}.settings-section:last-child{border-bottom:none}.settings-field{margin-bottom:1rem}.field-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem;font-size:.75rem;display:block}.field-row{align-items:center;gap:.75rem;display:flex}.settings-input{background:var(--bg-card);border:1px solid var(--border);color:var(--text);font-family:var(--font);border-radius:4px;outline:none;flex:1;padding:.5rem .75rem;font-size:.85rem;transition:border-color .15s}.settings-input:focus{border-color:var(--accent)}.field-hint{color:var(--text-dim);margin-top:.3rem;font-size:.7rem}.info-grid{flex-direction:column;gap:.4rem;display:flex}.info-row{justify-content:space-between;padding:.4rem 0;display:flex}.info-label{color:var(--text-dim);font-size:.8rem}.info-value{font-variant-numeric:tabular-nums;font-size:.8rem}.about-text{color:var(--text-dim);font-size:.8rem;line-height:1.6}.monospace{font-family:var(--font)}.clear-btn{border:1px solid var(--danger);color:var(--danger);font-family:var(--font);cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:0 0;border-radius:4px;padding:.3rem .75rem;font-size:.7rem;transition:all .15s}.clear-btn:hover{background:#f871711a}.clear-btn.danger{background:var(--danger);color:#fff;animation:.6s ease-in-out pulse-danger}.clear-btn.danger:hover{background:var(--danger-dark)}@keyframes pulse-danger{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.reticulum-info{background:var(--bg-card);border:1px solid #a855f733;border-radius:6px;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:.6rem 1rem;display:flex}.reticulum-id{color:var(--text-dim);font-size:.75rem;font-family:var(--font)}.reticulum-status{color:var(--protocol-reticulum);margin-left:auto;font-size:.7rem}.detection-card.clickable{cursor:pointer}.detection-card.clickable:hover .species-name{color:var(--accent)}.detection-card:first-child{animation:.6s ease-out pulse-in}@keyframes pulse-in{0%{border-color:var(--accent);box-shadow:0 0 12px #4ade8033}to{border-color:var(--border);box-shadow:none}}.hamburger{z-index:1001;background:var(--bg-sidebar);border:1px solid var(--border);cursor:pointer;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:36px;height:36px;padding:.5rem;display:none;position:fixed;top:.75rem;left:.75rem}.hamburger-line{background:var(--text-dim);border-radius:1px;width:18px;height:2px;transition:all .2s;display:block}.hamburger:hover .hamburger-line{background:var(--accent)}.sidebar-overlay{z-index:99;background:#0009;display:none;position:fixed;inset:0}@media (max-width:768px){.hamburger{display:flex}.sidebar-overlay{display:block}.sidebar{z-index:100;width:220px;padding-top:3.5rem;transition:left .25s;position:fixed;top:0;bottom:0;left:-240px}.sidebar.open{left:0}.content{padding:3.5rem 1rem 1rem}.page-title{font-size:.9rem}.stats-row{gap:.5rem}.stat-card{min-width:100px;padding:.75rem}.stat-value{font-size:1.2rem}.health-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem}.freq-label{width:120px;font-size:.7rem}.dashboard-toolbar{flex-direction:column;align-items:stretch;gap:.5rem}.search-box{max-width:none}.topology svg,.topology-svg,.settings-view{max-width:100%}.nodes-grid{grid-template-columns:1fr}.detection-header{flex-direction:column;align-items:flex-start;gap:.25rem}.map-toolbar{flex-direction:column;align-items:flex-start}.reticulum-info,.mesh-node-row{flex-wrap:wrap}}@media (max-width:480px){.content{padding:3.5rem .75rem .75rem}.stats-row{flex-direction:column}.stat-card{min-width:auto}.health-grid{grid-template-columns:repeat(2,1fr)}.conf-histogram{padding:0}.freq-label{width:90px;font-size:.65rem}.detection-meta{flex-direction:column;align-items:flex-start;gap:.5rem}.confidence{max-width:100%}.field-row{flex-direction:column;align-items:stretch}}.nav-badge{text-align:center;background:var(--accent);min-width:16px;height:16px;color:var(--bg);border-radius:8px;margin-left:auto;padding:0 4px;font-size:.6rem;font-weight:700;line-height:16px;animation:.3s ease-out badge-pop}@keyframes badge-pop{0%{transform:scale(0)}70%{transform:scale(1.2)}to{transform:scale(1)}}.status-dot.pulse-disconnect{animation:1.5s ease-in-out infinite pulse-red}@keyframes pulse-red{0%,to{opacity:1;box-shadow:0 0 #f8717166}50%{opacity:.5;box-shadow:0 0 8px 2px #f871714d}}.dashboard,.node-detail,.species-detail,.map-view,.network-view,.settings-view,.nodes-grid{animation:.2s ease-out view-enter}@keyframes view-enter{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.freq-trend{margin-left:.25rem;font-size:.65rem;font-weight:700}.freq-trend.hot{color:var(--accent)}.freq-trend.warm{color:var(--warn)}.stat-card{transition:border-color .15s}.stat-card:hover{border-color:var(--accent-dim)}.app:focus{outline:none}.consensus-card{border-left:3px solid var(--accent);background:linear-gradient(135deg,var(--bg-card)0%,#4ade8008 100%)}.consensus-card:hover{border-left-color:var(--accent-light)}.consensus-badge{color:var(--accent);cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:#4ade8026;border:1px solid #4ade8040;border-radius:3px;padding:.15rem .5rem;font-size:.65rem;font-weight:700;transition:all .15s}.consensus-badge:hover{border-color:var(--accent);background:#4ade8040}.consensus-contributors{border-top:1px solid var(--border);flex-direction:column;gap:.5rem;margin-top:.75rem;padding-top:.75rem;display:flex}.consensus-contributors .detection-card{background:#ffffff05;border-color:#ffffff0d;padding:.5rem .75rem;font-size:.85em}.export-row{flex-direction:column;align-items:flex-end;gap:.75rem;margin-bottom:1rem;display:flex}.export-dialog{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;width:100%;max-width:480px;padding:1rem 1.25rem;animation:.15s ease-out view-enter}.export-dialog h4{color:var(--text);letter-spacing:.05em;margin-bottom:.75rem;font-size:.8rem;font-weight:600}.export-formats{gap:.25rem;margin-bottom:1rem;display:flex}.export-actions{justify-content:flex-end;gap:.5rem;display:flex}.export-actions .export-btn{padding:.35rem .8rem;font-size:.7rem}@media (max-width:768px){.export-row{align-items:stretch}.export-dialog{max-width:none}.export-actions{flex-direction:column}.consensus-contributors .detection-card{padding:.4rem .5rem}.node-chip{min-height:44px;padding:.5rem .75rem}.live-species-tag{align-items:center;min-height:44px;padding:10px 14px;display:inline-flex}.freq-row.clickable{min-height:44px}.legend-item.clickable{min-height:44px;padding:.4rem 0}.nav-item{min-height:44px}}.call-badge{text-transform:uppercase;letter-spacing:.04em;background:var(--surface-2);color:var(--text-dim);white-space:nowrap;border-radius:3px;margin-left:.3rem;padding:.1rem .35rem;font-size:.6rem;font-weight:700;display:inline-block}.call-badge.song{color:var(--call-song);background:#4caf5033}.call-badge.alarm{color:var(--call-alarm);background:#f4433633}.call-badge.contact{color:var(--call-contact);background:#2196f333}.call-badge.flight{color:var(--call-flight);background:#9c27b033}.call-badge.begging{color:var(--call-begging);background:#ff980033}.call-badge.drumming{color:var(--call-drumming);background:#79554833}.source-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:10px;padding:2px 8px;font-size:.7em;font-weight:600;display:inline-block}.source-badge.visual{color:var(--source-visual-light);background:#9c27b033}.source-badge.fused{color:var(--source-fused-light);background:#e91e6333}.track-id{color:var(--text-dim);background:#ffffff0d;border-radius:4px;padding:1px 6px;font-family:monospace;font-size:.75em}.flight-speed{color:var(--accent);font-size:.75em}.evidence-badge{text-transform:uppercase;letter-spacing:.5px;cursor:help;border-radius:10px;padding:2px 8px;font-size:.65em;font-weight:600;display:inline-block}.grade-verified{color:var(--grade-verified);background:var(--grade-verified-bg)}.grade-research{color:var(--grade-research);background:var(--grade-research-bg)}.grade-confirmed{color:var(--grade-confirmed);background:var(--grade-confirmed-bg)}.grade-probable{color:var(--grade-probable);background:var(--grade-probable-bg)}.grade-needs-review{color:var(--grade-needs-review);background:var(--grade-needs-review-bg)}.grade-casual{color:var(--grade-casual);background:var(--grade-casual-bg)}.camera-view{padding:0 1rem}.camera-stats{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-bottom:1.5rem;display:grid}.camera-stats .stat-card{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:8px;padding:1rem}.camera-stats .stat-value{color:var(--text);font-size:1.8em;font-weight:700}.camera-stats .stat-label{color:var(--text-dim);margin-top:.25rem;font-size:.8em}.track-list{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:1rem;padding:1rem}.track-list h3{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin:0 0 .75rem;font-size:.9em}.track-row{border-bottom:1px solid var(--border);align-items:center;gap:.75rem;padding:.4rem 0;display:flex}.track-row:last-child{border-bottom:none}.track-id-label{color:var(--source-visual-light);min-width:2.5rem;font-family:monospace;font-weight:600}.track-species{color:var(--text);flex:1}.track-confidence{color:var(--text-dim);font-size:.85em}.flight-stats{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1rem}.flight-stats h3{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin:0 0 .75rem;font-size:.9em}.stat-row{justify-content:space-between;padding:.3rem 0;display:flex}.stat-key{color:var(--text-dim)}.stat-val{color:var(--text);font-weight:500}.fusion-view{padding:0 1rem 2rem}.fusion-stats{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-bottom:1.5rem;display:grid}.acoustic-stat .stat-value{color:var(--source-acoustic)}.visual-stat .stat-value{color:var(--source-visual)}.fused-stat .stat-value{color:var(--source-fused)}.source-distribution{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.source-bar{border-radius:6px;height:28px;margin-bottom:.5rem;display:flex;overflow:hidden}.source-segment{color:var(--bg);justify-content:center;align-items:center;font-size:.75rem;font-weight:600;transition:width .3s;display:flex}.source-segment.acoustic{background:var(--source-acoustic)}.source-segment.visual{background:var(--source-visual)}.source-segment.fused{background:var(--source-fused)}.source-legend{color:var(--text-dim);gap:1rem;font-size:.8rem;display:flex}.legend-item{align-items:center;gap:.3rem;display:flex}.legend-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.legend-dot.acoustic{background:var(--source-acoustic)}.legend-dot.visual{background:var(--source-visual)}.legend-dot.fused{background:var(--source-fused)}.call-type-analysis{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.call-type-bars{flex-direction:column;gap:.4rem;display:flex}.call-type-row{align-items:center;gap:.5rem;display:flex}.call-type-badge{text-transform:uppercase;text-align:center;border-radius:4px;min-width:70px;padding:.15rem .5rem;font-size:.7rem;font-weight:600}.call-type-badge.ct-song{background:var(--ct-song-bg);color:var(--ct-song)}.call-type-badge.ct-alarm{background:var(--ct-alarm-bg);color:var(--ct-alarm)}.call-type-badge.ct-contact{background:var(--ct-contact-bg);color:var(--ct-contact)}.call-type-badge.ct-call{background:var(--ct-call-bg);color:var(--ct-call)}.call-type-badge.ct-flight{background:var(--ct-flight-bg);color:var(--ct-flight)}.call-type-badge.ct-begging{background:var(--ct-begging-bg);color:var(--ct-begging)}.call-type-badge.ct-drumming{background:var(--ct-drumming-bg);color:var(--ct-drumming)}.call-type-badge.ct-other{background:var(--ct-other-bg);color:var(--ct-other)}.call-type-track{background:var(--bg);border-radius:3px;flex:1;height:14px;overflow:hidden}.call-type-bar{border-radius:3px;height:100%;transition:width .3s}.call-type-bar.ct-song{background:var(--ct-song)}.call-type-bar.ct-alarm{background:var(--ct-alarm)}.call-type-bar.ct-contact{background:var(--ct-contact)}.call-type-bar.ct-call{background:var(--ct-call)}.call-type-bar.ct-flight{background:var(--ct-flight)}.call-type-bar.ct-begging{background:var(--ct-begging)}.call-type-bar.ct-drumming{background:var(--ct-drumming)}.call-type-bar.ct-other{background:var(--ct-other)}.call-type-count{color:var(--text-dim);text-align:right;min-width:30px;font-size:.8rem}.species-call-matrix{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.matrix-row{border-bottom:1px solid var(--border);align-items:center;padding:.4rem 0;display:flex}.matrix-row:last-child{border-bottom:none}.matrix-species{min-width:150px;color:var(--text);font-size:.85rem;font-weight:500}.matrix-calls{flex-wrap:wrap;gap:.3rem;display:flex}.matrix-pill{border-radius:3px;padding:.1rem .4rem;font-size:.65rem;font-weight:500}.matrix-pill.ct-song{background:var(--ct-song-bg);color:var(--ct-song)}.matrix-pill.ct-alarm{background:var(--ct-alarm-bg);color:var(--ct-alarm)}.matrix-pill.ct-contact{background:var(--ct-contact-bg);color:var(--ct-contact)}.matrix-pill.ct-call{background:var(--ct-call-bg);color:var(--ct-call)}.matrix-pill.ct-flight{background:var(--ct-flight-bg);color:var(--ct-flight)}.matrix-pill.ct-begging{background:var(--ct-begging-bg);color:var(--ct-begging)}.matrix-pill.ct-drumming{background:var(--ct-drumming-bg);color:var(--ct-drumming)}.matrix-pill.ct-other{background:var(--ct-other-bg);color:var(--ct-other)}.feature-panels{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.feature-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1rem}.feature-grid{text-align:center;grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.feature-item{flex-direction:column;align-items:center;display:flex}.feature-value{color:var(--accent);font-size:1.4rem;font-weight:700}.feature-unit{color:var(--text-dim);text-transform:uppercase;font-size:.7rem}.feature-label{color:var(--text-dim);margin-top:.2rem;font-size:.7rem}.volume-view{padding:0 1rem 2rem}.heatmap-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:1.5rem;padding:1rem;overflow-x:auto}.heatmap-grid{grid-template-columns:60px repeat(7,1fr);gap:2px;display:grid}.heatmap-label{color:var(--text-dim);justify-content:flex-end;align-items:center;padding-right:.3rem;font-size:.7rem;display:flex}.heatmap-header{color:var(--text-dim);text-align:center;padding-bottom:.3rem;font-size:.7rem;font-weight:600}.heatmap-cell{background:var(--accent);min-height:16px;color:var(--bg);cursor:default;border-radius:2px;justify-content:center;align-items:center;font-size:.6rem;font-weight:600;display:flex}.diversity-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.diversity-chart{align-items:flex-end;gap:3px;height:120px;padding-top:.5rem;display:flex}.diversity-bar-wrap{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.diversity-bar{background:var(--accent);border-radius:2px 2px 0 0;width:100%;min-width:8px;transition:height .3s}.diversity-week{color:var(--text-dim);writing-mode:vertical-rl;margin-top:.2rem;font-size:.55rem}.migration-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.migration-grid{flex-direction:column;gap:.3rem;display:flex}.migration-row{align-items:center;gap:.5rem;height:20px;display:flex}.migration-species{min-width:140px;color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:500;overflow:hidden}.migration-track{background:var(--bg);border-radius:3px;flex:1;height:12px;position:relative}.migration-dot{background:var(--accent);cursor:default;border-radius:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.migration-total{min-width:35px;color:var(--text-dim);text-align:right;font-size:.75rem}.camera-viewport-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:1.5rem;overflow:hidden}.camera-viewport-svg{width:100%;height:auto;display:block}.sonogram-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:1.5rem;padding:1rem;overflow-x:auto}.sonogram-panel h3{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin:0 0 .75rem;font-size:.85em}.sonogram-svg{width:100%;height:auto;min-height:180px;display:block}.sonogram-legend{flex-wrap:wrap;gap:1rem;margin-top:.75rem;display:flex}.welcome-view{max-width:720px;margin:0 auto;padding:2rem 1.5rem 3rem}.welcome-hero{text-align:center;margin-bottom:2.5rem;padding:2rem 0 1.5rem}.welcome-logo{letter-spacing:6px;color:var(--accent);font-size:2.4rem;font-weight:700}.welcome-tagline{color:var(--text-dim);letter-spacing:2px;text-transform:lowercase;margin-top:.5rem;font-size:.8rem}.welcome-intro{margin-bottom:2rem}.welcome-intro h2{color:var(--text);margin-bottom:.5rem;font-size:1.1rem}.welcome-intro p{color:var(--text-dim);line-height:1.7}.welcome-cards{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.welcome-card{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:1.25rem;transition:border-color .2s,transform .15s}.welcome-card:hover{border-color:var(--accent);transform:translateY(-2px)}.welcome-card-icon{color:var(--accent);opacity:.7;margin-bottom:.75rem;font-size:1.4rem}.welcome-card h3{color:var(--text);margin-bottom:.5rem;font-size:.9rem}.welcome-card p{color:var(--text-dim);margin-bottom:.75rem;font-size:.75rem;line-height:1.6}.welcome-card-action{color:var(--accent);opacity:0;font-size:.75rem;transition:opacity .2s}.welcome-card:hover .welcome-card-action{opacity:1}.welcome-footer{text-align:center}.welcome-footer .hint{color:var(--text-dim);font-size:.72rem}.node-offline{opacity:.7;border-color:var(--danger)!important}.offline-badge{color:var(--danger);border:1px solid var(--danger);letter-spacing:1px;border-radius:3px;margin-left:auto;padding:0 4px;font-size:.65rem;font-weight:600}.temp-badge{color:var(--text-dim);background:var(--bg);border:1px solid var(--border);border-radius:3px;padding:0 4px;font-size:.7rem}.temp-badge.temp-hot{color:var(--danger);border-color:var(--danger)}.listen-view{max-width:600px;padding:24px}.listen-description{color:var(--text-dim);margin-bottom:24px;line-height:1.6}.listen-status{color:var(--text);align-items:center;gap:10px;margin-bottom:20px;font-size:.95rem;display:flex}.status-dot.pulse-listen{background:var(--accent);animation:1.5s ease-in-out infinite pulse}.status-dot.pulse-analyze{background:var(--amber);animation:.6s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.listen-meter{background:var(--bg-card);border:1px solid var(--border);border-radius:4px;width:100%;height:8px;margin-bottom:24px;overflow:hidden}.listen-meter-bar{background:linear-gradient(90deg,var(--accent),var(--cyan));border-radius:4px;height:100%;transition:width .1s linear}.listen-controls{gap:12px;margin-bottom:24px;display:flex}.listen-btn{border:1px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;border-radius:6px;padding:14px 28px;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s}.listen-btn:hover{border-color:var(--accent)}.listen-start{border-color:var(--accent);color:var(--accent)}.listen-start:hover{background:#4ade801a}.listen-stop{border-color:var(--danger);color:var(--danger)}.listen-stop:hover{background:#ef44441a}.listen-stats{gap:20px;margin-bottom:20px;display:flex}.listen-stat{flex-direction:column;align-items:center;gap:4px;display:flex}.listen-result{background:var(--bg-card);border:1px solid var(--accent);color:var(--accent);border-radius:6px;margin-bottom:24px;padding:14px 18px;font-weight:500;animation:.3s ease-in fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.listen-tips{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;margin-top:20px;padding:18px}.listen-tips h3{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px;font-size:.9rem}.listen-tips ul{margin:0;padding:0;list-style:none}.listen-tips li{color:var(--text-dim);padding:6px 0 6px 16px;font-size:.88rem;line-height:1.5;position:relative}.listen-tips li:before{content:">";color:var(--accent);position:absolute;left:0}.toast-container{z-index:1000;flex-direction:column;gap:8px;max-width:350px;display:flex;position:fixed;top:16px;right:16px}.toast{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--accent);color:var(--text);border-radius:6px;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;font-size:.88rem;animation:.3s ease-out toastSlide;display:flex;box-shadow:0 4px 12px #0006}.toast-dismiss{color:var(--text-dim);cursor:pointer;opacity:.6;background:0 0;border:none;flex-shrink:0;padding:0 4px;font-size:1.1rem;line-height:1;transition:opacity .15s}.toast-dismiss:hover{opacity:1;color:var(--text)}@keyframes toastSlide{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.live-now{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:20px;padding:14px 18px}.live-now h3{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:8px;margin:0 0 10px;font-size:.85rem;display:flex}.live-now h3 .status-dot{animation:1s ease-in-out infinite pulse}.live-species-list{flex-wrap:wrap;gap:8px;display:flex}.live-species-tag{cursor:pointer;border:1px solid;border-radius:12px;padding:4px 10px;font-size:.82rem;font-weight:500;animation:.3s ease-in fadeIn}.live-species-tag:hover{opacity:.8}.phone-camera-section{margin-bottom:16px}.phone-camera-wrap{margin-bottom:20px}.phone-camera-wrap .hint{color:var(--text-dim);margin-top:8px;font-size:.85rem}.loading-overlay{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 1rem;display:flex}.loading-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.loading-text{color:var(--text-dim);font-size:.9rem}.connection-banner{color:var(--warn);background:#f59e0b1a;border:1px solid #f59e0b4d;border-radius:6px;align-items:center;gap:.5rem;margin:0 1rem .75rem;padding:.5rem 1rem;font-size:.82rem;display:flex}.banner-btn{color:var(--warn);font-family:var(--font);cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:#f59e0b33;border:1px solid #f59e0b66;border-radius:4px;padding:.2rem .6rem;font-size:.75rem;transition:background .15s}.banner-btn:hover{background:#f59e0b59}.banner-link{color:var(--accent);cursor:pointer;text-decoration:underline}.banner-link:hover{opacity:.8}button:focus-visible,input:focus-visible,select:focus-visible,.nav-item:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.nav-item{cursor:pointer}.settings-input.invalid{border-color:var(--danger)}.field-error{color:var(--danger);margin-top:2px;font-size:.75rem}.export-success{color:var(--accent);margin-top:2px;font-size:.75rem}.bird-detail{padding:20px;animation:.3s fadeIn}.export-filters{flex-wrap:wrap;gap:12px;margin:12px 0;display:flex}.export-field{flex-direction:column;gap:4px;min-width:140px;display:flex}.export-field label{color:var(--text-dim);font-size:.75rem}.load-more-row{text-align:center;color:var(--accent);cursor:pointer;border-top:1px solid var(--border);justify-content:center;align-items:center;min-height:44px;padding:12px 16px;font-size:.85rem;transition:background .2s;display:flex}.load-more-row:hover{background:#4ade800d}.map-count{color:var(--text-dim);margin-left:8px;font-size:.75rem}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}button:disabled,input:disabled,select:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}