@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Spectral:wght@500;600&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,400;0,500;0,600;0,700&display=swap";@import"https://fonts.googleapis.com/css2?family=Source+Sans+3:wght@400;500;600;700&display=swap";:root{color-scheme:var(--color-scheme, dark);--font-sans: "Space Grotesk", system-ui, sans-serif;--bg: #0b1b1f;--bg-soft: #12252b;--panel: #13272d;--panel-strong: #16333b;--text: #e8f3f2;--muted: #a5c0bd;--accent: #44e5b1;--accent-2: #ffd36a;--danger: #ff6b6b;--shadow: 0 20px 50px rgba(6, 18, 20, .45);--body-bg: radial-gradient(circle at top, #1d3b3f 0%, #0b1b1f 55%, #081215 100%);--overlay: rgba(8, 18, 21, .6);--overlay-strong: rgba(8, 18, 21, .8);--overlay-card: rgba(8, 18, 21, .7);--overlay-tile: rgba(11, 27, 31, .5);--border: rgba(255, 255, 255, .06);--border-strong: rgba(255, 255, 255, .12);--border-subtle: rgba(255, 255, 255, .04);--border-focus: rgba(255, 255, 255, .08);--border-pill: rgba(255, 255, 255, .4);--accent-bg: rgba(68, 229, 177, .12);--accent-bg-strong: rgba(68, 229, 177, .2);--accent-bg-soft: rgba(68, 229, 177, .08);--accent-border: rgba(68, 229, 177, .5);--accent-border-strong: rgba(68, 229, 177, .6);--accent-glow: rgba(68, 229, 177, .25);--accent-glow-strong: rgba(68, 229, 177, .45);--on-accent: #071517;--gradient-end: #2c8bdc;--gradient-mid: #3edbd8;--brand-end: #35a8ff;--accent-2-end: #f0a040;--accent-2-border: rgba(255, 211, 106, .5);--sidebar-from: rgba(19, 39, 45, .95);--sidebar-to: rgba(10, 20, 24, .95);--app-tint: rgba(68, 229, 177, .08);--sidebar-card-bg: linear-gradient(160deg, rgba(255, 211, 106, .2), rgba(19, 39, 45, .8));--sidebar-download-bg: linear-gradient(160deg, rgba(68, 229, 177, .15), rgba(19, 39, 45, .8));--surface: rgba(255, 255, 255, .06);--surface-hover: rgba(255, 255, 255, .08);--surface-strong: rgba(255, 255, 255, .1);--surface-muted: rgba(255, 255, 255, .45);--chart-bg: linear-gradient(180deg, rgba(68, 229, 177, .05), transparent);--color-scheme: dark}*{box-sizing:border-box}html,body{min-height:100%;background:var(--body-bg);background-attachment:fixed}body{margin:0;font-family:var(--font-sans);min-height:100vh;color:var(--text)}.selector-page{min-height:100vh;display:grid;place-items:center;padding:32px 18px;background:var(--body-bg)}.selector-card{width:min(980px,100%);background:var(--overlay-card);border-radius:26px;padding:36px;border:1px solid var(--border);box-shadow:var(--shadow)}.selector-card h1{margin:0 0 6px;font-size:32px;font-weight:800;letter-spacing:-.5px}.selector-sub{font-size:14px;color:var(--muted);margin:0 0 28px}.selector-card.simple{padding:36px 40px 40px;border-top:4px solid var(--accent)}.selector-card.simple .brand-logo{max-width:220px;margin-bottom:28px}.selector-divider{height:1px;background:var(--border);margin:0 0 24px}.selector-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.selector-tile{text-align:left;padding:20px;border-radius:16px;background:var(--bg-soft);border:1px solid var(--border);color:var(--text);cursor:pointer;display:flex;flex-direction:column;gap:6px;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.selector-tile:hover{transform:translateY(-4px);border-color:var(--accent-border-strong);box-shadow:0 8px 24px var(--accent-glow)}.selector-year{font-size:22px;font-weight:800;color:var(--text);letter-spacing:-.5px}.selector-meta{font-size:12px;color:var(--muted);font-weight:500}.app{min-height:100vh;display:grid;grid-template-columns:260px 1fr;background-image:linear-gradient(135deg,var(--app-tint),transparent 60%)}.sidebar{padding:28px 20px;background:linear-gradient(180deg,var(--sidebar-from),var(--sidebar-to));border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:24px}.brand{display:flex;gap:12px;align-items:center;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1)}.brand-logo{max-width:180px;height:auto;display:block}.brand-icon{max-width:160px;height:auto;display:block}[data-color-schema=minimal] .brand-logo{filter:invert(1)}.brand-mark{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--brand-end));color:var(--on-accent);font-weight:700}.brand-title{font-weight:700;letter-spacing:.4px}.brand-sub{font-size:12px;color:var(--muted)}.nav{display:grid;gap:10px}.nav-item{background:transparent;border:1px solid transparent;color:var(--muted);text-align:left;padding:10px 14px;border-radius:12px;font-weight:600;cursor:pointer;transition:all .25s ease}.nav-item:hover{border-color:var(--border-focus);color:var(--text)}.nav-item.active:hover{border-color:var(--accent-border-strong)}.nav-item.active{background:var(--accent-bg);color:var(--text);border-color:var(--accent-border);border-left-color:var(--accent);border-left-width:3px;padding-left:11px}.sidebar-card{padding:18px;border-radius:16px;background:var(--sidebar-card-bg);border:1px solid var(--border);display:block;cursor:pointer;text-align:left;color:inherit}.sidebar-card h4{margin:0 0 6px;font-size:14px}.sidebar-card p{margin:0 0 14px;color:var(--muted);font-size:13px}.sidebar-download{background:var(--sidebar-download-bg);text-decoration:none;color:var(--text);cursor:pointer;transition:border-color .2s ease}.sidebar-download:hover{border-color:var(--accent-border)}.sidebar-card:not(.sidebar-download):hover{border-color:var(--accent-2-border)}.year-window{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.year-pill{border:1px solid var(--border-strong);background:var(--overlay);color:var(--muted);padding:6px 10px;border-radius:999px;font-size:12px;display:inline-flex;align-items:center;gap:6px;cursor:pointer}.year-pill .check{width:10px;height:10px;border-radius:50%;border:1px solid var(--border-pill);display:inline-block}.year-pill.active{color:var(--text);border-color:var(--accent-border-strong);background:var(--accent-bg)}.year-pill.active .check{background:var(--accent);border-color:var(--accent)}.year-pill:hover{border-color:var(--border-focus)}.year-pill.active:hover{border-color:var(--accent-border-strong)}.year-select{display:grid;gap:6px;font-size:12px;color:var(--muted);margin-bottom:12px}.year-select select{background:var(--overlay);color:var(--text);border:1px solid var(--border-strong);border-radius:10px;padding:8px 10px}.ghost{background:transparent;border:1px solid var(--border-strong);color:var(--text);padding:8px 12px;border-radius:10px;font-size:12px;cursor:pointer}.sidebar-card:not(.sidebar-download) .ghost:hover{border-color:var(--accent-2-border)}.sidebar-download .ghost:hover{border-color:var(--accent-border)}.main{padding:32px 36px 48px;min-width:0;overflow-x:auto}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding-bottom:24px;border-bottom:1px solid var(--border);margin-bottom:8px}.topbar h1{margin:0 0 6px;font-size:28px;font-weight:800;letter-spacing:-.5px}.topbar p{margin:0;color:var(--muted);max-width:420px;font-size:13px}.topbar-actions{display:flex;align-items:center;gap:12px}.pill{padding:8px 12px;border-radius:999px;background:var(--accent-bg-strong);border:1px solid var(--accent-border);font-size:12px}.pill:hover{border-color:var(--accent-border-strong)}.pill.soft{background:var(--surface);border-color:var(--border-strong);color:var(--text)}.pill.soft:hover{border-color:var(--border-focus)}.overview-grid{margin-top:20px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}[data-color-schema=afdf] .sidebar{box-shadow:4px 0 24px #0e24442e;border-right:none}[data-color-schema=afdf] .brand-icon{background:#fffffff5;padding:7px 11px;border-radius:10px;max-width:140px}[data-color-schema=afdf] .nav-item{color:#b4cde4bf}[data-color-schema=afdf] .nav-item:hover{color:#fff;background:#ffffff12;border-color:#ffffff1f}[data-color-schema=afdf] .nav-item.active{color:#fff;background:#3b8fd438;border-color:#3b8fd473;border-left-color:#3b8fd4}[data-color-schema=afdf] .nav-item.active:hover{border-color:#3b8fd4a6;border-left-color:#3b8fd4}[data-color-schema=afdf] .sidebar-card{background:#ffffff0f;border-color:#ffffff1a;color:#e4eef7}[data-color-schema=afdf] .sidebar-card h4{color:#fff}[data-color-schema=afdf] .sidebar-card p{color:#8ca3b8e6}[data-color-schema=afdf] .sidebar-download{background:#3b8fd41f;border-color:#3b8fd438}[data-color-schema=afdf] .sidebar-card:not(.sidebar-download):hover{border-color:#ffffff38}[data-color-schema=afdf] .sidebar-download:hover{border-color:#3b8fd480}[data-color-schema=afdf] .ghost{border-color:#ffffff2e;color:#e4eef7}[data-color-schema=afdf] .sidebar-card:not(.sidebar-download) .ghost:hover{border-color:#ffffff59;background:#ffffff0d}[data-color-schema=afdf] .sidebar-download .ghost:hover{border-color:#3b8fd499;background:#3b8fd41a}.overview-panel{display:grid;gap:18px}.overview-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.overview-item{background:var(--overlay);border:1px solid var(--border);border-radius:14px;padding:12px 14px;display:grid;gap:6px}.overview-item .label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.overview-item .value{font-size:20px;font-weight:700}.overview-block h4{margin:0 0 8px;font-size:14px}.pill-list{display:flex;flex-wrap:wrap;gap:8px;font-size:12px}.link-list{display:grid;gap:8px;font-size:13px}.map-page{min-height:100vh;padding:32px 36px 48px;color:var(--text)}.map-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px}.map-header h1{margin:0 0 8px;font-size:28px}.map-header p{margin:0;color:var(--muted)}.map-layout{display:grid;grid-template-columns:280px 1fr;gap:18px}.map-list{background:var(--overlay);border:1px solid var(--border);border-radius:18px;padding:16px;display:grid;gap:10px}.map-list h3{margin:0 0 4px;font-size:14px}.map-item{text-align:left;padding:10px 12px;border-radius:12px;border:1px solid var(--border-focus);background:var(--overlay-tile);color:var(--text);cursor:pointer;transition:border-color .2s ease}.map-item.active{border-color:var(--accent-border-strong)}.map-frame{border-radius:18px;overflow:hidden;border:1px solid var(--border);background:var(--overlay);min-height:480px}.map-frame iframe{width:100%;height:100%;border:0}.map-empty{padding:24px;color:var(--muted)}@media(max-width:900px){.map-layout,.overview-grid{grid-template-columns:1fr}}.range-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}.tests-scroll{display:flex;gap:14px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch}.test-card{min-width:180px;background:var(--overlay);border:1px solid var(--border);border-radius:16px;padding:14px;display:grid;gap:6px}.test-title{font-weight:700;font-size:14px}.test-value{font-size:20px;font-weight:700}.test-meta{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.range-card{background:var(--overlay);border:1px solid var(--border);border-radius:16px;padding:14px;display:grid;gap:10px}.range-card-button{transition:all .2s ease;width:100%;font-family:inherit;font-size:inherit;color:inherit}.range-card-button:hover{background:var(--overlay-strong);border-color:var(--border-strong);transform:translateY(-2px)}.range-card-active .range-card-button:hover{border-color:var(--accent-border-strong)}.range-card-active{background:var(--accent-bg-soft);border-color:var(--accent)!important}.category-analyses-list{border-top:1px solid var(--border);padding-top:20px}.range-title{font-weight:700;font-size:14px}.range-row{display:grid;gap:4px;font-size:12px}.range-row.range-row-split{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.range-half{display:flex;flex-direction:column;padding:6px 8px;border-radius:10px;background:var(--overlay-card);border:1px solid var(--border-subtle)}.range-half-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}.range-half-value{font-size:16px;font-weight:600}.range-row .unit{color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-size:11px}.range-row .value{font-weight:600}.range-empty{font-size:12px;color:var(--muted)}.inline-link{color:var(--accent);text-decoration:none;font-weight:600}.inline-link:hover{text-decoration:underline}.solid{padding:10px 16px;border-radius:12px;border:2px solid transparent;background:var(--accent);color:var(--on-accent);font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center}.solid:hover{border-color:var(--accent-border-strong)}.overview-stats{margin-top:26px;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:14px}.overview-stat-card{background:var(--panel);padding:18px 20px;border-radius:16px;border:1px solid var(--border);border-top:3px solid var(--accent);box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px}.overview-row2{margin-top:18px;display:grid;grid-template-columns:2fr 1fr;gap:16px}.timeline-chart{display:flex;align-items:flex-end;gap:6px;height:180px;padding-top:8px}.timeline-col{flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;height:100%;gap:4px}.timeline-count{flex:0 0 auto;font-size:10px;color:var(--muted);opacity:0;transition:opacity .2s ease}.timeline-col:hover .timeline-count{opacity:1}.timeline-bar-area{flex:1 1 0;min-height:0;width:100%;display:flex;align-items:flex-end;justify-content:center}.timeline-bar{width:100%;max-width:32px;min-height:4px;border-radius:6px 6px 3px 3px;background:linear-gradient(180deg,var(--accent),var(--gradient-end));box-shadow:0 4px 12px var(--accent-glow);transition:height .3s ease}.timeline-col:hover .timeline-bar{box-shadow:0 4px 16px var(--accent-glow-strong)}.timeline-label{font-size:10px;color:var(--muted);white-space:nowrap;writing-mode:vertical-lr;transform:rotate(180deg);height:48px;overflow:hidden}.origin-breakdown{display:flex;flex-direction:column;gap:20px;padding:8px 0}.origin-row{display:flex;flex-direction:column;gap:8px}.origin-row-header{display:flex;justify-content:space-between;align-items:baseline}.origin-row-label{font-weight:700;font-size:14px}.origin-row-value{font-size:22px;font-weight:700}.origin-bar-track{height:10px;background:var(--surface);border-radius:999px;overflow:hidden}.origin-bar-fill{height:100%;border-radius:999px;transition:width .5s ease}.origin-bar-fill.farmed{background:linear-gradient(90deg,var(--accent),var(--gradient-mid))}.origin-bar-fill.wild{background:linear-gradient(90deg,var(--accent-2),var(--accent-2-end))}.overview-lists{margin-top:18px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.overview-lists .kpi-detail-list{height:240px}.overview-ranges{margin-top:18px}.overview-ranges-top{margin-top:26px}.range-card-lg{padding:20px}.range-card-lg .range-title{font-size:18px;margin-bottom:6px}.range-card-lg .range-row .value{font-size:22px;font-weight:700}.range-card-lg .range-row .value .unit{font-size:12px;font-weight:500;margin-left:6px;vertical-align:baseline}.overview-chart-center{display:flex;justify-content:center;flex:0 0 auto}.overview-donut{width:150px;height:150px;display:block}.overview-donut-lg{width:240px;height:240px}.overview-donut path{transition:opacity .2s,transform .15s;transform-origin:center}.overview-donut path:hover{filter:brightness(1.2);transform:scale(1.03);transform-origin:center}.species-side-layout{display:grid;grid-template-columns:minmax(240px,auto) 1fr;gap:20px;max-width:640px;margin:0 auto;align-items:start}.species-side-layout .overview-chart-center{grid-row:1 / -1;align-self:center;width:240px;min-width:240px;min-height:240px;flex-shrink:0;flex-direction:column;align-items:center;gap:8px}.species-side-layout .overview-chart-center .species-filter-hint{display:block;font-size:12px;line-height:1.4;text-align:center;color:var(--muted);margin:0;padding:0 4px;white-space:normal}.samples-grid .panel-species-distribution .overview-donut-lg{width:240px;height:240px;min-width:240px;min-height:240px}.samples-grid .panel-species-distribution .overview-chart-center{width:240px;min-width:240px;min-height:240px}.species-side-layout .species-side-list{grid-column:2;min-width:0}.species-side-layout>button.meta{grid-column:2}.species-side-list{height:auto;min-height:0}.species-side-list .kpi-detail-row{font-size:15px;cursor:pointer;border-radius:6px;padding:6px 8px;margin:-2px -8px;transition:background .15s,opacity .2s}.species-side-list .kpi-detail-row:hover{background:var(--surface-hover)}.species-side-list .kpi-row-detail{font-size:13px;color:var(--surface-muted);font-weight:500}.species-side-list .kpi-row-detail.species-cell{background:none;padding:0;font-style:italic}.species-side-list .species-dot{margin-top:3px}.hbar-chart{display:flex;flex-direction:column;gap:12px;padding:4px 0}.hbar-row{display:grid;grid-template-columns:100px 1fr auto;gap:10px;align-items:center;font-size:13px}.hbar-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600;font-size:12px}.hbar-track{height:18px;background:var(--surface);border-radius:6px;overflow:hidden}.hbar-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--accent),var(--gradient-end));box-shadow:0 2px 8px var(--accent-glow);transition:width .5s ease;min-width:4px}.hbar-value{font-size:12px;color:var(--muted);white-space:nowrap;min-width:50px;text-align:right}.lab-stacked-bar{display:flex;height:28px;border-radius:10px;overflow:hidden;margin-bottom:18px;box-shadow:var(--shadow)}.lab-stacked-seg{height:100%;transition:width .5s ease;min-width:4px}.lab-stacked-seg:first-child{border-radius:10px 0 0 10px}.lab-stacked-seg:last-child{border-radius:0 10px 10px 0}.lab-legend{display:flex;flex-direction:column;gap:14px}.lab-legend-item{display:flex;align-items:flex-start;gap:10px}.lab-legend-dot{width:12px;height:12px;border-radius:4px;flex:0 0 auto;margin-top:2px}.lab-legend-text{display:flex;flex-direction:column;gap:2px}.lab-legend-name{font-weight:600;font-size:13px}.lab-capabilities{margin-bottom:16px}.lab-capability-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);padding:6px 0;border-bottom:1px solid var(--border-subtle)}.lab-capability-item:last-child{border-bottom:none}.lab-capability-dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto}.lab-card-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}.range-viz{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.range-scale{position:relative;height:10px;background:var(--surface);border-radius:999px;overflow:hidden}.range-span{position:absolute;top:0;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--gradient-mid));box-shadow:0 2px 8px var(--accent-glow);min-width:6px}.range-labels{display:flex;justify-content:space-between;font-size:12px;font-weight:600}.range-row{display:flex;justify-content:space-between;gap:4px;font-size:12px}.kpi-grid{margin-top:26px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.kpi-card{background:var(--panel);padding:18px 20px;border-radius:18px;border:1px solid var(--border);box-shadow:var(--shadow);transition:transform .25s ease;text-align:left;cursor:pointer;width:100%;appearance:none;color:var(--text)}.kpi-card:hover{transform:translateY(-4px);border-color:var(--border-strong)}.kpi-card.active:hover{border-color:var(--accent-border-strong)}.kpi-card:focus-visible{outline:2px solid var(--accent-border-strong);outline-offset:2px}.kpi-card.active{border-color:var(--accent-border-strong);box-shadow:0 18px 40px var(--accent-glow)}.kpi-label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:1px}.kpi-value{font-size:26px;font-weight:700;margin:8px 0 6px}.kpi-meta{font-size:12px;color:var(--accent);font-weight:600}.kpi-detail{margin-top:18px}.kpi-detail-body{display:grid;grid-template-columns:1fr 1fr 2fr;gap:14px;align-items:stretch}.kpi-stat{background:var(--overlay);border:1px solid var(--border);border-radius:14px;padding:16px;display:flex;flex-direction:column;justify-content:center;gap:8px}.kpi-stat-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.kpi-stat-value{font-size:20px;font-weight:700}.kpi-detail-title{font-size:13px;font-weight:700;margin-bottom:8px}.kpi-detail-list{background:var(--overlay);border:1px solid var(--border);border-radius:16px;padding:14px;display:flex;flex-direction:column;gap:8px;height:260px;overflow-y:auto}.kpi-detail-row{display:flex;align-items:baseline;gap:12px;font-size:13px}.kpi-row-name{flex:1 1 0;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kpi-row-detail{flex:0 0 auto;font-size:11px;color:var(--surface-muted);background:var(--surface);padding:1px 8px;border-radius:8px;white-space:nowrap}.kpi-row-records{flex:0 0 auto;text-align:right;white-space:nowrap}.species-name{font-weight:600}.species-common{font-size:12px;color:var(--muted)}.species-layout{display:grid;grid-template-columns:1fr;gap:16px;align-items:start}.species-chart{display:grid;justify-items:center;gap:10px}.pie-chart{width:200px;height:200px;border-radius:50%;border:1px solid var(--border-focus);box-shadow:var(--shadow);display:block}.species-list{height:220px}.species-label{display:flex;align-items:flex-start;gap:10px}.species-dot{width:10px;height:10px;border-radius:50%;margin-top:4px;flex:0 0 auto}.kpi-delta{font-size:12px;color:var(--accent)}.kpi-delta.down{color:var(--accent-2)}.grid{margin-top:20px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.panel{background:var(--panel);padding:22px;border-radius:18px;border:1px solid var(--border);box-shadow:var(--shadow)}.panel-wide{grid-column:span 2}.samples-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.labs-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.samples-grid .panel-wide{grid-column:span 3}.samples-grid .panel-species-distribution{grid-column:1 / -1;min-width:0;justify-self:center}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.panel-controls{display:flex;align-items:center;gap:12px}.unit-select{display:grid;gap:4px;font-size:11px;color:var(--muted)}.unit-select select{background:var(--overlay);color:var(--text);border:1px solid var(--border-strong);border-radius:10px;padding:6px 10px}.panel-header h3{margin:0;font-size:18px}.meta{color:var(--muted);font-size:12px}.chart{height:220px;display:flex;align-items:flex-end;background:var(--chart-bg);border-radius:16px;padding:16px 10px 10px;overflow-x:auto}.chart-line{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(28px,1fr);gap:10px;width:100%;align-items:end}.line-point{display:grid;gap:8px;align-items:end;justify-items:center;font-size:11px;color:var(--muted)}.line-point .dot{width:20px;border-radius:12px 12px 6px 6px;background:linear-gradient(180deg,var(--accent),var(--gradient-end));box-shadow:0 10px 20px var(--accent-glow-strong);transition:height .3s ease}.date-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.date-item{border:1px solid var(--border-focus);background:var(--overlay);color:var(--text);padding:12px 14px;border-radius:14px;display:grid;gap:6px;cursor:pointer;transition:transform .2s ease,border-color .2s ease}.date-item:hover{transform:translateY(-2px);border-color:var(--border-strong)}.date-item.active:hover{border-color:var(--accent-border-strong)}.date-item.active{border-color:var(--accent-border-strong);box-shadow:0 12px 30px var(--accent-glow)}.donut{position:relative;width:180px;height:180px;margin:0 auto 16px}.donut-ring{width:100%;height:100%;border-radius:50%;background:conic-gradient(var(--accent) 0 338deg,var(--accent-2) 338deg 355deg,var(--panel-strong) 355deg 360deg);-webkit-mask:radial-gradient(circle,transparent 55%,black 56%);mask:radial-gradient(circle,transparent 55%,black 56%)}.donut-center{position:absolute;inset:0;display:grid;place-items:center;text-align:center}.donut-value{font-size:28px;font-weight:700}.donut-label{font-size:12px;color:var(--muted)}.legend{display:grid;gap:8px;font-size:12px;color:var(--muted)}.legend-item{display:flex;align-items:center;gap:8px}.legend-item .dot{width:8px;height:8px;border-radius:50%;display:inline-block}.legend-item .a{background:var(--accent)}.legend-item .b{background:var(--accent-2)}.legend-item .c{background:var(--panel-strong)}.legend-item:nth-child(1) .dot{background:var(--accent)}.legend-item:nth-child(2) .dot{background:var(--accent-2)}.legend-item:nth-child(3) .dot{background:var(--gradient-mid)}.legend-item:nth-child(4) .dot{background:var(--gradient-end)}.legend-item:nth-child(5) .dot{background:var(--danger)}.legend-item:nth-child(6) .dot{background:var(--gradient-end)}.stack{display:grid;gap:14px}.stack-row{display:grid;gap:8px;font-size:12px}.stack-row strong{display:block;font-size:13px}.stack-row span{color:var(--muted)}.stack-bar{height:8px;background:var(--surface-hover);border-radius:999px;overflow:hidden}.stack-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--gradient-mid))}.alerts{display:grid;gap:12px}.alert{padding:12px;border-radius:12px;display:flex;justify-content:space-between;gap:10px;background:var(--surface);border:1px solid var(--border-subtle);font-size:12px}.alert p{margin:6px 0 0;color:var(--muted)}.alert.warning{border-color:var(--accent-2)}.alert.attention{border-color:var(--danger)}.alert.info{border-color:var(--accent-border)}.prep-description{margin:0 0 12px;color:var(--muted);line-height:1.7;font-size:14px}.prep-mission{margin:0 0 16px;color:var(--text);font-size:13px;line-height:1.6;padding:12px 14px;background:var(--accent-bg-soft);border-left:3px solid var(--accent);border-radius:0 10px 10px 0}.prep-steps{display:grid;gap:10px;margin-bottom:16px}.prep-step{display:grid;grid-template-columns:130px 1fr;gap:12px;padding:10px 14px;background:var(--overlay-tile);border:1px solid var(--border);border-radius:12px;font-size:13px}.prep-step-label{font-weight:700;color:var(--accent);font-size:12px;text-transform:uppercase;letter-spacing:.5px;padding-top:1px}.prep-step-detail{color:var(--muted);line-height:1.5}.prep-download{display:inline-flex;margin-top:4px}@media(max-width:480px){.prep-step{grid-template-columns:1fr;gap:4px}}.prep-contacts{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.prep-contact-card{background:var(--overlay);border:1px solid var(--border);border-radius:14px;padding:14px 16px;display:grid;gap:4px}.prep-contact-name{font-weight:700;font-size:14px}.prep-contact-role{font-size:12px;color:var(--muted)}.prep-contact-info{display:flex;gap:12px;font-size:12px;color:var(--muted);margin-top:6px;flex-wrap:wrap}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{text-align:left;color:var(--muted);font-weight:500;padding-bottom:10px}.table td{padding:12px 0;border-top:1px solid var(--border)}.sample-table-wrap{max-height:320px;overflow:auto;-webkit-overflow-scrolling:touch}.sample-table th,.sample-table td{white-space:nowrap;padding-right:16px}.sample-table .sample-th-sort{cursor:pointer;-webkit-user-select:none;user-select:none}.sample-table .sample-th-sort:hover{color:var(--accent)}.sample-table .species-cell{font-style:italic}.sample-table tr.sample-row-selected{background:var(--accent-bg-strong);outline:2px solid var(--accent);outline-offset:-2px}.sample-table tr.sample-row-selected:hover{background:var(--accent-bg-strong)}.sample-table tbody tr:hover{background:var(--surface)}.sample-table tbody tr.sample-row-selected:hover{background:var(--accent-bg-strong)}.origin-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:11px;line-height:1;border:1px solid transparent}.origin-pill.farmed{color:var(--accent);border-color:var(--accent-border);background:var(--accent-bg)}.origin-pill.wild{color:var(--accent-2);border-color:var(--accent-border);background:var(--accent-bg)}.origin-pill.unknown{color:var(--muted);border-color:var(--border-strong);background:var(--surface)}.quality{display:flex;align-items:center;gap:10px}.bar{width:120px;height:6px;background:var(--surface-strong);border-radius:999px;overflow:hidden}.bar span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--gradient-mid))}.risk{padding:4px 10px;border-radius:999px;font-size:11px;border:1px solid transparent}.risk.low{color:var(--accent);border-color:var(--accent-border)}.risk.medium{color:var(--accent-2);border-color:var(--accent-border)}.risk.high{color:var(--danger);border-color:var(--danger)}.nav-year-mobile{display:none}@media(max-width:1100px){.app{grid-template-columns:1fr}.sidebar{flex-direction:column;align-items:stretch;padding:14px 16px;gap:10px;border-right:none;border-bottom:1px solid var(--border-subtle)}.brand{justify-content:space-between}.sidebar-card{display:none}.nav-year-mobile{display:inline-flex;margin-left:auto;background:var(--accent-bg);border-color:var(--accent-border);color:var(--text)}.nav{display:flex;flex-wrap:nowrap;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.nav-item{flex:0 0 auto}.overview-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.overview-row2,.overview-lists{grid-template-columns:1fr}.overview-lists .kpi-detail-list{height:auto;max-height:220px}.species-side-layout{grid-template-columns:1fr;justify-items:center}.species-side-layout .overview-chart-center{grid-row:auto;align-self:auto}.species-side-layout .species-side-list,.species-side-layout>button.meta{grid-column:auto}.species-side-list{height:auto}.hbar-row{grid-template-columns:80px 1fr auto}.timeline-label{font-size:9px;height:40px}.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.kpi-detail-body{grid-template-columns:1fr 1fr}.kpi-detail-body .kpi-detail-list{grid-column:span 2}.grid{grid-template-columns:1fr}.panel-wide{grid-column:span 1}.samples-grid{grid-template-columns:1fr}.samples-grid .panel-wide,.samples-grid .panel-species-distribution{grid-column:span 1}.species-chart{justify-items:center}.species-list{height:auto;max-height:260px}.kpi-detail-body .kpi-stat{min-height:80px}.kpi-detail-list{height:auto;max-height:260px}}@media(max-width:720px){.main{padding:20px 14px 32px}.topbar{flex-direction:column;align-items:flex-start}.topbar h1{font-size:22px}.topbar p{max-width:100%;font-size:13px}.topbar-actions{flex-wrap:wrap;width:100%}.overview-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.overview-stat-card{padding:14px 16px}.timeline-chart{height:140px}.timeline-label{display:none}.overview-donut-lg{width:160px;height:160px}.kpi-grid{grid-template-columns:1fr}.kpi-stat-value{font-size:16px}.panel{padding:16px;border-radius:14px}.panel-header{flex-direction:column;align-items:flex-start;gap:4px}.panel-controls{flex-direction:column;align-items:flex-start;gap:8px;width:100%}.sample-table-wrap{max-height:280px}.sample-table th,.sample-table td{font-size:12px;padding-right:10px}.map-layout{grid-template-columns:1fr}.map-frame{min-height:300px}.selector-card{padding:20px;border-radius:18px}.selector-card h1{font-size:22px}.pie-chart{width:160px;height:160px}.range-grid{grid-template-columns:1fr}}@media(max-width:480px){.main{padding:16px 10px 24px}.sidebar{padding:10px 12px;gap:8px}.brand-icon{width:28px;height:28px}.brand-title{font-size:13px}.brand-sub{display:none}.topbar h1{font-size:18px;line-height:1.3}.topbar p{font-size:12px}.pill{font-size:11px;padding:6px 10px}.solid{font-size:12px;padding:8px 14px}.nav{gap:4px}.nav-item{padding:6px 10px;font-size:12px;border-radius:8px}.overview-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.overview-stat-card{padding:12px 14px;border-radius:12px}.overview-row2,.overview-lists{gap:12px}.timeline-chart{height:120px;gap:3px}.grid,.samples-grid{gap:12px}.panel{padding:14px;border-radius:12px}.kpi-stat{padding:10px 12px;border-radius:10px}.kpi-stat-value{font-size:15px}.kpi-stat-label{font-size:10px}.selector-card{padding:16px;border-radius:14px}.selector-card h1{font-size:18px}.selector-tile{padding:14px;border-radius:14px}.selector-grid{grid-template-columns:1fr}}
