:root{color:#edf4ed;font-synthesis:none;text-rendering:optimizelegibility;background:#101312;font-family:Inter,PingFang SC,Microsoft YaHei,Arial,sans-serif}*{box-sizing:border-box}body{background-color:#0000;background-image:linear-gradient(#1013124d,#101312 680px),url("data:image/svg+xml,%3Csvg width='1600' height='900' viewBox='0 0 1600 900' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='1600' height='900' fill='%23101312'/%3E%3Cpath d='M0 620 C260 420 420 460 620 300 C820 140 1040 180 1600 40 L1600 900 L0 900 Z' fill='%2322342d'/%3E%3Cpath d='M0 760 C220 620 380 660 570 520 C840 320 1110 410 1600 250 L1600 900 L0 900 Z' fill='%23294d47' fill-opacity='.72'/%3E%3Cpath d='M210 0 C180 160 280 280 250 430 C220 600 330 760 260 900' stroke='%23a6c389' stroke-width='10' fill='none' opacity='.5'/%3E%3Cpath d='M720 0 C650 150 730 270 690 420 C650 590 750 720 720 900' stroke='%237db9b4' stroke-width='8' fill='none' opacity='.48'/%3E%3Cpath d='M1190 0 C1080 190 1180 320 1130 500 C1090 650 1190 760 1150 900' stroke='%23dfb866' stroke-width='8' fill='none' opacity='.5'/%3E%3C/svg%3E");background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:cover;background-attachment:fixed;background-origin:padding-box,padding-box;background-clip:border-box,border-box;min-width:320px;margin:0}button,input{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;padding:22px}.topbar{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#0d1210c7;border:1px solid #d2e8d224;justify-content:space-between;align-items:center;gap:18px;padding:18px 22px;display:flex}.brand-block{cursor:pointer}.topbar h1{letter-spacing:0;margin:4px 0 0;font-size:24px;font-weight:650;line-height:1.35}.eyebrow{color:#a9c59a;text-transform:uppercase;letter-spacing:0;margin:0;font-size:12px}.top-actions,.catalog-toolbar,.panel-head,.search-wrap,.pager,.detail-tags,.tags{align-items:center;display:flex}.top-actions{flex-shrink:0;gap:10px}.icon-btn,.primary-btn,.pager button,.search-wrap button{color:#eef8ed;background:#ffffff0f;border:1px solid #cde6c82e;height:40px}.icon-btn{place-items:center;width:40px;display:grid}.primary-btn{color:#15140e;background:#d4a84f;border-color:#d4a84f;align-items:center;gap:8px;padding:0 14px;font-weight:650;display:inline-flex}.dashboard{gap:16px;margin-top:16px;display:grid}.hero-panel,.workbench>*,.topic-card,.detail-drawer,.taxonomy-panel,.map-panel,.catalog-panel,.analytics-panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#101815d1;border:1px solid #d2e8d224;box-shadow:0 20px 70px #00000040}.hero-panel{grid-template-columns:minmax(280px,1.1fr) minmax(420px,1.5fr);gap:20px;min-height:210px;padding:24px;display:grid}.hero-copy h2{letter-spacing:0;max-width:720px;margin:10px 0;font-size:36px;line-height:1.15}.hero-copy p:last-child{color:#c8d7ca;max-width:780px;line-height:1.8}.metric-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.metric-card{background:#ffffff0e;border:1px solid #ffffff1a;min-height:84px;padding:14px}.metric-card strong{color:#f0c86d;font-size:30px;display:block}.metric-card span,.metric-card small{color:#c8d7ca;display:block}.topic-strip{grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;display:grid}.topic-card{color:#edf4ed;text-align:left;justify-content:space-between;align-items:center;min-height:78px;padding:18px 14px 12px;display:flex;position:relative}.topic-card.active,.topic-card:hover{background:#d4a84f2e;border-color:#f0c86db3}.topic-card strong{color:#f0c86d;font-size:26px}.topic-badge{color:#f2dda4;background:#f0c86d2e;border:1px solid #f0c86d6b;padding:3px 6px;font-size:11px;line-height:1;position:absolute;top:7px;right:7px}.topic-badge:hover{color:#14150f;background:#f0c86d}.workbench,.lower-grid{grid-template-columns:minmax(360px,.9fr) minmax(620px,1.6fr);align-items:start;gap:16px;display:grid}.taxonomy-panel,.map-panel,.catalog-panel{min-height:620px;padding:18px}.taxonomy-wide{min-height:auto}.taxonomy-filterbar{color:#f2dda4;background:linear-gradient(90deg,#f0c86d1f,#7db9b414),#070c0a61;border:1px solid #f0c86d33;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding:10px 12px;font-size:13px;display:flex}.taxonomy-filterbar button{color:#edf4ed;background:#0003;border:1px solid #f0c86d57;min-height:30px;padding:0 10px}.taxonomy-matrix{grid-template-columns:repeat(7,minmax(148px,1fr));gap:8px;padding-bottom:4px;display:grid;overflow-x:auto}.rank-column{background:linear-gradient(#ffffff0e,#ffffff06),#070c0a6b;border:1px solid #ffffff1a;min-width:148px;max-height:470px;overflow:auto}.rank-title{z-index:2;color:#f0c86d;background:#121916f5;border-bottom:1px solid #f0c86d33;padding:10px;font-size:13px;font-weight:750;position:sticky;top:0}.rank-node{color:#edf4ed;text-align:left;background:0 0;border:0;border-bottom:1px solid #ffffff12;grid-template-columns:minmax(0,1fr) auto;gap:3px 8px;width:100%;min-height:64px;padding:10px;display:grid}.rank-node:hover,.rank-node.active{background:linear-gradient(90deg,#f0c86d2e,#7db9b414)}.rank-node.active{box-shadow:inset 3px 0 #f0c86d}.rank-node span{overflow-wrap:anywhere;min-width:0;font-weight:650}.rank-node small{color:#f0c86d;white-space:nowrap}.rank-node em{color:#9fb1a4;overflow-wrap:anywhere;grid-column:1/-1;font-size:12px}.taxonomy-explorer{grid-template-columns:minmax(220px,.8fr) minmax(220px,.8fr) minmax(360px,1.25fr);gap:12px;display:grid}.higher-taxonomy{background:#f0c86d12;border:1px solid #f0c86d2e;margin:0 0 12px}.higher-taxonomy summary{cursor:pointer;color:#f2dda4;justify-content:space-between;align-items:center;gap:16px;min-height:42px;padding:0 12px;display:flex}.higher-taxonomy summary b{color:#edf4ed;font-weight:650}.higher-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;padding:0 12px 12px;display:grid}.higher-node{color:#edf4ed;text-align:left;cursor:pointer;background:#0a0f0d6b;border:1px solid #ffffff1a;min-height:74px;padding:10px}.higher-node:hover,.higher-node.active{background:#f0c86d24;border-color:#f0c86da6}.higher-node small,.higher-node em{color:#9fb1a4;overflow-wrap:anywhere;font-size:12px;display:block}.higher-node strong{color:#edf4ed;margin:4px 0;display:block}.family-focus{background:#f0c86d1a;border-color:#f0c86d73}.higher-filterbar{color:#f2dda4;background:#f0c86d14;border:1px solid #f0c86d3d;justify-content:space-between;align-items:center;gap:12px;margin:0 12px 12px;padding:8px 10px;display:flex}.higher-filterbar button{color:#edf4ed;background:#0000002e;border:1px solid #f0c86d57;min-height:30px;padding:0 10px}.tax-column{background:#ffffff0a;border:1px solid #ffffff1a;min-height:420px;max-height:560px;overflow:auto}.tax-column-title{z-index:1;color:#f0c86d;background:#121916f2;border-bottom:1px solid #ffffff1a;padding:10px 12px;font-size:13px;font-weight:700;position:sticky;top:0}.tax-row,.tax-species{color:#edf4ed;text-align:left;background:0 0;border:0;border-bottom:1px solid #ffffff14;width:100%;min-height:56px;padding:10px 12px;display:grid}.tax-row{grid-template-columns:1fr auto;column-gap:8px}.tax-row:hover,.tax-row.active,.tax-species:hover{background:#f0c86d1f}.tax-row.active{border-left:3px solid #f0c86d}.tax-row span,.tax-species span{font-weight:650}.tax-row small{color:#f0c86d}.tax-row em,.tax-species em{color:#9fb1a4;overflow-wrap:anywhere;grid-column:1/-1;margin-top:4px;font-size:12px}.species-column .tax-species{min-height:48px}.panel-head{justify-content:space-between;margin-bottom:14px}.taxonomy-actions{align-items:center;gap:12px;display:flex}.view-switch{background:#070c0a85;border:1px solid #d2e8d229;padding:3px;display:inline-flex}.view-switch button{color:#c8d7ca;background:0 0;border:0;min-height:32px;padding:0 12px}.view-switch button.active{color:#15140e;background:#f0c86d;font-weight:700}.classic-taxonomy{gap:12px;display:grid}.panel-head h3,.catalog-toolbar h3{margin:3px 0 0;font-size:22px}.search-input,.search-wrap input{color:#edf4ed;background:#080c0a94;border:1px solid #d2e8d224;outline:none;width:100%}.search-input{height:40px;margin-bottom:12px;padding:0 12px}.tree-list{max-height:540px;padding-right:4px;overflow:auto}.tree-family,.tree-genus{border-bottom:1px solid #ffffff12}.tree-family summary,.tree-genus summary{cursor:pointer;justify-content:space-between;gap:12px;padding:10px 0;display:flex}.tree-family summary b{color:#f0c86d}.tree-genus{color:#cfe0d0;margin-left:12px}.tree-species{color:#edf4ed;text-align:left;background:0 0;border:0;border-left:2px solid #f0c86d4d;width:100%;min-height:34px;padding:7px 8px;display:block}.tree-species:hover{background:#ffffff0f}.tree-species em{color:#9fb1a4;font-size:12px;display:block}.basin-map{grid-template-rows:1fr auto;gap:12px;min-height:542px;display:grid}.basin-map svg{background:linear-gradient(150deg,#1d2f2ae6,#0b100fd6);border:1px solid #ffffff1a;width:100%;min-height:410px}.terrain{fill:#3c594abf;stroke:#e2efd829}.ridge{stroke:#e9e3ba33;fill:none;stroke-width:1.2px}.river-node{cursor:pointer}.river-node circle{stroke:#ffffffe6;stroke-width:.8px}.river-node text{fill:#edf4ed;paint-order:stroke;stroke:#0000008c;stroke-width:.8px;font-size:4px}.river-detail{background:#ffffff0e;border:1px solid #ffffff1a;padding:14px}.river-detail h4{margin:3px 0 8px;font-size:24px}.river-detail p:last-child{color:#c8d7ca;margin:0;line-height:1.6}.catalog-panel{min-width:0}.catalog-toolbar{justify-content:space-between;gap:16px;margin-bottom:14px}.search-wrap{background:#080c0a8c;border:1px solid #d2e8d224;flex:1;gap:8px;max-width:620px;padding:0 8px 0 12px}.search-wrap input{background:0 0;border:0;height:40px}.search-wrap button{padding:0 14px}.species-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.species-card{cursor:pointer;background:#ffffff0e;border:1px solid #ffffff1a;min-width:0;transition:transform .18s,border-color .18s;overflow:hidden}.species-card:hover{border-color:#f0c86d99;transform:translateY(-2px)}.plant-photo,.detail-photo{position:relative;background-position:50%!important;background-size:cover!important}.plant-photo{height:132px}.plant-photo:after,.detail-photo:after{content:"";background:linear-gradient(115deg,#0000 44%,#ffffff26 45%,#0000 47%),radial-gradient(circle at 30% 72%,#ffffff29,#0000 22%);position:absolute;inset:0}.plant-photo span,.detail-photo span{z-index:1;color:#f3f7f0;background:#00000061;padding:5px 8px;font-size:12px;position:absolute;bottom:10px;left:10px}.species-body{padding:12px}.species-title h4{margin:0 0 4px;font-size:18px}.species-title em,.detail-drawer em{color:#aebfb1;overflow-wrap:anywhere;font-size:13px}.species-body p{color:#c8d7ca;min-height:20px;margin:10px 0}.tags,.detail-tags{flex-wrap:wrap;gap:6px}.tags span,.detail-tags span{color:#f2dda4;background:#f0c86d21;border:1px solid #f0c86d3d;padding:4px 7px;font-size:12px}.pager{color:#c8d7ca;justify-content:center;gap:14px;margin-top:16px}.pager button{padding:0 14px}.pager button:disabled{opacity:.45;cursor:not-allowed}.analytics-panel{padding:18px}.field-dashboard{grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;display:grid}.value-card,.chart-card{background:linear-gradient(#ffffff0f,#ffffff06),#070c0a6b;border:1px solid #ffffff1a}.value-card{min-height:86px;padding:13px}.value-card span{color:#aebfb1;font-size:12px;display:block}.value-card strong{color:#f0c86d;margin-top:6px;font-size:30px;display:block}.chart-card{min-height:190px;padding:14px}.chart-card.wide{grid-column:span 3}.chart-card h4{color:#edf4ed;margin:0 0 12px;font-size:15px}.bar-row{color:#c8d7ca;grid-template-columns:74px minmax(0,1fr) 44px;align-items:center;gap:8px;min-height:26px;font-size:12px;display:grid}.bar-row>div{background:#ffffff17;height:8px;overflow:hidden}.bar-row i{background:linear-gradient(90deg,#7db9b4,#f0c86d);height:100%;display:block}.bar-row b,.mini-row b{color:#f0c86d;text-align:right;font-weight:700}.mini-row{color:#c8d7ca;border-bottom:1px solid #ffffff12;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:7px 0;font-size:13px;display:grid}.mini-row span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.detail-photo{border:1px solid #ffffff1f;height:280px;margin:0 0 18px}.species-page{margin-top:16px}.loading-panel,.species-hero,.species-detail-grid>*{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#101815db;border:1px solid #d2e8d224}.loading-panel{padding:26px}.species-hero{grid-template-columns:minmax(320px,.85fr) minmax(520px,1.15fr);gap:22px;padding:22px;display:grid}.page-photo{height:440px;margin:0}.species-hero-copy{align-self:center}.species-hero-copy h2{margin:10px 0 4px;font-size:44px;line-height:1.1}.species-hero-copy>p{color:#d6e2d8;max-height:300px;line-height:1.8;overflow:auto}.species-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px;display:grid}.detail-drawer h2{margin:8px 0 4px;font-size:32px}.detail-tags{margin:16px 0}.info-block{background:#ffffff0b;border:1px solid #ffffff1a;margin:16px 0;padding:14px}.info-block h4,.source-list h4{color:#f0c86d;margin:0 0 8px}.info-block p{color:#d6e2d8;overflow-wrap:anywhere;margin:0;line-height:1.75}.source-list{flex-wrap:wrap;gap:8px;margin-bottom:28px;display:flex}.source-list h4{flex:0 0 100%}.source-list a{color:#dff3de;background:#ffffff0f;border:1px solid #d2e8d22e;padding:7px 10px;text-decoration:none}.topic-page{gap:16px;margin-top:16px;display:grid}.topic-hero,.topic-story-card,.topic-species-panel,.topic-source-panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#101815db;border:1px solid #d2e8d224;box-shadow:0 20px 70px #00000040}.topic-hero{background:linear-gradient(120deg,#f0c86d1f,#0000 42%),linear-gradient(270deg,#7db9b429,#0000 48%),#101815e0;grid-template-columns:minmax(360px,1.05fr) minmax(520px,1.35fr);gap:20px;min-height:260px;padding:24px;display:grid}.topic-hero-copy h2{margin:10px 0;font-size:42px;line-height:1.1}.topic-hero-copy p{color:#d6e2d8;max-width:740px;line-height:1.8}.topic-focus-list,.source-chip-row{flex-wrap:wrap;gap:8px;display:flex}.topic-focus-list span,.source-chip-row span{color:#f2dda4;background:#f0c86d1a;border:1px solid #f0c86d3d;padding:7px 10px;font-size:12px}.topic-metric-board{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.topic-metric-card{background:linear-gradient(#ffffff12,#ffffff06),#070c0a6b;border:1px solid #ffffff1a;min-height:96px;padding:14px}.topic-metric-card strong{color:#f0c86d;font-size:32px;display:block}.topic-metric-card span,.topic-metric-card small{color:#c8d7ca;display:block}.topic-story-grid{grid-template-columns:minmax(420px,1.1fr) minmax(420px,.9fr);gap:16px;display:grid}.topic-story-card{padding:18px}.topic-story-card h3{margin:6px 0 10px;font-size:24px}.topic-story-card p:last-child{color:#d6e2d8;margin:0;line-height:1.8}.primary-story{border-color:#f0c86d42}.topic-bar{grid-template-columns:86px minmax(0,1fr) 46px}.topic-visual-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;display:grid}.topic-visual-grid .chart-card{grid-column:span 2}.topic-species-panel,.topic-source-panel{padding:18px}.topic-species-grid{grid-template-columns:repeat(6,minmax(0,1fr))}.topic-source-panel{min-height:120px}.assessment-lab{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:linear-gradient(135deg,#f0c86d1a,#0000 32%),linear-gradient(315deg,#5ca3a81f,#0000 36%),#101815e0;border:1px solid #d2e8d224;padding:18px;box-shadow:0 20px 70px #00000040}.assessment-formula{background:#070c0a6b;border:1px solid #f0c86d38;grid-template-columns:minmax(360px,.95fr) minmax(420px,1.05fr);gap:14px;margin-bottom:14px;padding:16px;display:grid}.assessment-formula span{color:#aebfb1;font-size:12px;display:block}.assessment-formula strong{color:#f0c86d;overflow-wrap:anywhere;margin-top:6px;font-size:20px;line-height:1.45;display:block}.assessment-formula p{color:#d6e2d8;margin:0;line-height:1.75}.assessment-flow{grid-template-columns:repeat(7,minmax(130px,1fr));gap:8px;padding-bottom:6px;display:grid;overflow-x:auto}.flow-node{background:linear-gradient(#ffffff12,#ffffff06),#070c0a75;border:1px solid #ffffff1a;min-width:130px;min-height:150px;padding:12px}.flow-node b{color:#15140e;background:#f0c86d;place-items:center;width:34px;height:34px;margin-bottom:8px;display:grid}.flow-node span{color:#edf4ed;font-weight:700;display:block}.flow-node strong{color:#7db9b4;margin:5px 0;font-size:20px;display:block}.flow-node p{color:#aebfb1;margin:0;font-size:12px;line-height:1.55}.assessment-grid{grid-template-columns:minmax(280px,.75fr) minmax(420px,1.3fr) minmax(300px,.95fr);gap:10px;margin-top:10px;display:grid}.assessment-card{background:#070c0a6b;border:1px solid #ffffff1a;min-height:240px;padding:14px}.assessment-card h4{color:#edf4ed;margin:0 0 12px}.threshold-row{border-bottom:1px solid #ffffff12;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:8px;min-height:38px;display:grid}.threshold-row span{color:#d6e2d8;overflow-wrap:anywhere}.threshold-row em{color:#9fb1a4;font-size:12px}.threshold-row b,.score-rank-row b{color:#f0c86d}.contribution-row{grid-template-columns:120px minmax(0,1fr) 74px}.score-rank-row{color:#edf4ed;text-align:left;background:0 0;border:0;border-bottom:1px solid #ffffff12;grid-template-columns:minmax(0,1fr) auto;gap:2px 10px;width:100%;min-height:44px;padding:7px 0;display:grid}.score-rank-row:hover{background:#f0c86d14}.score-rank-row span{font-weight:650}.score-rank-row em{color:#9fb1a4;overflow-wrap:anywhere;grid-column:1/2;font-size:12px}.score-rank-row b{grid-area:1/2/span 2;align-self:center}@media (width<=1320px){.workbench{grid-template-columns:320px 1fr}.catalog-panel{grid-column:1/-1}.lower-grid,.species-hero,.taxonomy-explorer,.topic-hero,.topic-story-grid,.assessment-formula,.assessment-grid{grid-template-columns:1fr}.topic-species-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.taxonomy-matrix{grid-template-columns:repeat(7,minmax(170px,170px))}.higher-grid{grid-template-columns:1fr 1fr}.tax-column{min-height:auto;max-height:360px}}@media (width<=860px){.app-shell{padding:12px}.topbar,.hero-panel,.catalog-toolbar{flex-direction:column;grid-template-columns:1fr;align-items:stretch}.hero-panel,.workbench{grid-template-columns:1fr;display:grid}.lower-grid,.species-detail-grid,.topic-visual-grid{grid-template-columns:1fr}.topic-strip,.metric-grid,.species-grid,.field-dashboard,.topic-metric-board{grid-template-columns:1fr 1fr}.topic-visual-grid .chart-card{grid-column:auto}.chart-card.wide{grid-column:1/-1}.hero-copy h2{font-size:28px}}@media (width<=560px){.topic-strip,.metric-grid,.species-grid,.field-dashboard,.topic-metric-board,.topic-species-grid{grid-template-columns:1fr}.taxonomy-filterbar{flex-direction:column;align-items:stretch}.topbar h1{font-size:19px}}
