@import "https://fonts.googleapis.com/css2?family=Outfit:wght@500;600;700;800&family=Noto+Sans+SC:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--primary-50:#eff6ff;--primary-100:#dbeafe;--primary-200:#bfdbfe;--primary-300:#93c5fd;--primary-400:#60a5fa;--primary-500:#3b82f6;--primary-600:#2563eb;--primary-700:#1d4ed8;--primary-800:#1e40af;--primary-900:#1e3a8a;--success:#22c55e;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--risk-high:#ef4444;--risk-moderate:#f59e0b;--risk-low:#22c55e;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#64748b;--text-disabled:#94a3b8;--bg-body:#f6f8f5;--bg-surface:#fff;--bg-hover:#f1f5f9;--bg-active:#e2e8f0;--border:#e2e8f0;--border-light:#f1f5f9;--border-focus:#3b82f6;--sider-bg:#ffffffdb;--sider-text:#64748b;--sider-text-hover:#0f172a;--sider-active:#eff6ff;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000d;--shadow-lg:0 10px 15px #0000001a, 0 4px 6px #0000000d;--shadow-xl:0 20px 25px #0000001a, 0 10px 10px #0000000a;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--font-sans:"Noto Sans SC", "MiSans", "HarmonyOS Sans SC", "Alibaba PuHuiTi 3.0", "PingFang SC", "Microsoft YaHei", sans-serif;--font-headline:"Outfit", "Noto Sans SC", "MiSans", "HarmonyOS Sans SC", "PingFang SC", sans-serif;--font-brand:"Outfit", "MiSans", "HarmonyOS Sans SC", "PingFang SC", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--sider-width:256px;--header-height:64px;--content-max-width:1440px;--brand-blue:#2563eb;--brand-teal:#14b8a6;--brand-purple:#8b5cf6;--brand-coral:#f97316;--brand-gradient:linear-gradient(135deg, #2563eb 0%, #14b8a6 100%);--brand-gradient-soft:linear-gradient(135deg, #eff6ff 0%, #f0fdfa 100%);--dog-color:#f59e0b;--dog-light:#fffbeb;--cat-color:#8b5cf6;--cat-light:#f5f3ff;--risk-high-bg:#fef2f2;--risk-high-border:#fca5a5;--risk-high-text:#dc2626;--risk-moderate-bg:#fffbeb;--risk-moderate-border:#fcd34d;--risk-moderate-text:#d97706;--risk-low-bg:#f0fdf4;--risk-low-border:#86efac;--risk-low-text:#16a34a;--risk-modifier-bg:#f5f3ff;--risk-modifier-border:#c4b5fd;--risk-modifier-text:#7c3aed;--shadow-brand:0 4px 14px #2563eb47;--shadow-card-hover:0 0 0 1px #3b82f61f, 0 8px 20px #0000001a;--shadow-ambient:0px 20px 40px #191b230f;--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--ease-smooth:cubic-bezier(.16, 1, .3, 1);--ease-standard:cubic-bezier(.4, 0, .2, 1);--glass-bg:#ffffffb3;--glass-border:#ffffff80}*,:before,:after{box-sizing:border-box}html,body,#root{width:100%;min-height:100vh;margin:0;padding:0}body{font-family:var(--font-sans);color:var(--text-primary);background-color:var(--bg-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5}h1,h2,h3,h4,h5,h6{font-family:var(--font-headline);color:var(--text-primary);margin:0;font-weight:700;line-height:1.3}.ant-typography,.ant-btn,.ant-input,.ant-select,.ant-table,.ant-menu,.ant-tag,.ant-modal{font-family:var(--font-sans)}h1{font-size:28px}h2{font-size:22px}h3{font-size:18px}h4{font-size:15px}p{margin:0;line-height:1.6}a{color:var(--primary-600);text-decoration:none}a:hover{color:var(--primary-700)}.app-shell{min-height:100vh;display:flex}.main-layout{margin-left:var(--sider-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.content-wrapper{max-width:var(--content-max-width);width:100%;padding:0 var(--space-6);transition:max-width .36s var(--ease-smooth), padding .36s var(--ease-smooth);margin:0 auto}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base), transform var(--transition-base), border-color var(--transition-base), background-color var(--transition-base)}.card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.card-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.card-body{padding:var(--space-6)}.card-ambient{border-radius:var(--radius-xl);box-shadow:var(--shadow-ambient);background:#fff;border:1px solid #c2c6d633}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border)}.text-gradient{background:var(--brand-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.shimmer-bar{background:linear-gradient(90deg,#d8e2ff 0%,#0058be 50%,#d8e2ff 100%) 0 0/200% 100%;animation:2s linear infinite shimmer}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 #22c55e66}50%{opacity:.8;box-shadow:0 0 0 4px #22c55e00}}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:1s linear infinite spin}.animate-bounce-dot{animation:1.4s ease-in-out infinite bounce-dot}@keyframes bounce-dot{0%,80%,to{opacity:.5;transform:scale(0)}40%{opacity:1;transform:scale(1)}}.stat-card{padding:var(--space-5);justify-content:space-between;align-items:flex-start;display:flex}.stat-card-content{flex:1;min-width:0}.stat-card-label{color:var(--text-muted);margin-bottom:var(--space-2);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.stat-card-value{color:var(--text-primary);font-size:28px;font-weight:700;line-height:1.2}.stat-card-sub{color:var(--text-muted);margin-top:var(--space-1);font-size:12px}.stat-card-icon{border-radius:var(--radius-md);width:48px;height:48px;margin-left:var(--space-4);flex-shrink:0;justify-content:center;align-items:center;font-size:20px;display:flex}.grid-4{gap:var(--space-5);grid-template-columns:repeat(4,1fr);display:grid}.grid-3{gap:var(--space-5);grid-template-columns:repeat(3,1fr);display:grid}.grid-2{gap:var(--space-5);grid-template-columns:repeat(2,1fr);display:grid}@media (width<=1200px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}.ant-layout,.ant-layout-content{background:0 0!important}.ant-menu{background:0 0!important;border:none!important}.ant-card{border-radius:var(--radius-lg)!important;border-color:var(--border)!important;box-shadow:var(--shadow-sm)!important}.ant-card-head{border-bottom-color:var(--border)!important;padding:0 var(--space-5)!important;min-height:56px!important;font-weight:600!important}.ant-card-body{padding:var(--space-5)!important}.ant-btn{border-radius:var(--radius-md)!important;font-weight:500!important}.ant-btn-primary{background:var(--primary-600)!important;border-color:var(--primary-600)!important}.ant-btn-primary:hover{background:var(--primary-700)!important;border-color:var(--primary-700)!important}.ant-input,.ant-input-affix-wrapper,.ant-select-selector{border-radius:var(--radius-md)!important;border-color:var(--border)!important}.ant-input:focus,.ant-input-affix-wrapper:focus-within,.ant-select-focused .ant-select-selector{border-color:var(--primary-500)!important;box-shadow:0 0 0 3px #3b82f61a!important}.ant-table{background:0 0!important}.ant-table-thead>tr>th{background:var(--gray-50)!important;border-bottom:1px solid var(--border)!important;color:var(--text-secondary)!important;font-weight:600!important}.ant-table-tbody>tr>td{border-bottom:1px solid var(--border-light)!important}.ant-table-tbody>tr:hover>td{background:var(--gray-50)!important}.ant-tag{border-radius:var(--radius-full)!important;padding:2px 10px!important;font-size:12px!important;font-weight:500!important}.ant-badge-count{border-radius:var(--radius-full)!important;font-weight:600!important}.ant-tooltip-inner{border-radius:var(--radius-md)!important;font-size:13px!important}.ant-modal-content{border-radius:var(--radius-xl)!important}.ant-steps-item-icon,.ant-progress-bg{border-radius:var(--radius-full)!important}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-error{color:var(--error)}.bg-primary{background-color:var(--primary-500)}.bg-success{background-color:var(--success)}.bg-warning{background-color:var(--warning)}.bg-error{background-color:var(--error)}.bg-surface{background-color:var(--bg-surface)}.font-mono{font-family:var(--font-mono)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.text-sm{font-size:12px}.text-base{font-size:14px}.text-lg{font-size:16px}.text-xl{font-size:20px}.text-2xl{font-size:24px}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.3s fadeIn}.animate-fade-in-up{animation:.3s fadeInUp}@keyframes pageAccentSweep{0%{opacity:0;transform:translate(-110%)skew(-16deg)}28%{opacity:.46}to{opacity:0;transform:translate(110%)skew(-16deg)}}.page-transition-shell{transform-origin:50% 18%;min-height:100%;position:relative}.page-transition-shell:after{content:"";pointer-events:none;animation:pageAccentSweep .52s var(--ease-smooth);mix-blend-mode:multiply;background:linear-gradient(90deg,#0000,#14b8a61f,#0000);position:absolute;inset:0}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:1ms!important;animation-duration:1ms!important}}@media (width<=768px){.main-layout{margin-left:0}.content-wrapper{padding:0 var(--space-4)}}@media print{.no-print{display:none!important}body{background:#fff!important}.card{box-shadow:none!important;border:1px solid var(--border)!important}}.home-page{flex-direction:column;gap:24px;display:flex}.home-page-simple{gap:28px}.home-hero{background-position:100%;background-size:cover;border:1px solid #2563eb1a;border-radius:24px;align-items:center;min-height:min(620px,100vh - 150px);padding:64px;display:flex;position:relative;overflow:hidden;box-shadow:0 30px 80px #0f172a1a}.simple-hero{margin-bottom:2px}.home-hero-copy{z-index:2;flex-direction:column;justify-content:center;max-width:650px;display:flex;position:relative}.home-kicker{color:#0f766e;background:#f0fdfaeb;border:1px solid #14b8a63d;border-radius:999px;align-items:center;gap:8px;width:fit-content;padding:7px 12px;font-size:12px;font-weight:700;display:inline-flex}.home-hero h1{letter-spacing:0;max-width:620px;margin:18px 0 14px;font-size:58px;line-height:1.12}.home-hero p{max-width:560px;color:var(--text-secondary);font-size:17px;line-height:1.75}.home-hero-actions{flex-wrap:wrap;gap:12px;margin:28px 0 20px;display:flex}.home-hero-actions .ant-btn{align-items:center;gap:8px;min-height:44px;padding-inline:18px;display:inline-flex}.home-trust-row{flex-wrap:wrap;gap:10px;display:flex}.home-trust-row span{color:var(--text-secondary);background:#ffffffb8;border:1px solid #94a3b83d;border-radius:999px;align-items:center;gap:6px;padding:8px 10px;font-size:12px;font-weight:600;display:inline-flex}.home-hero-report{z-index:2;-webkit-backdrop-filter:blur(18px);background:#ffffffc2;border:1px solid #ffffffa6;border-radius:18px;width:min(360px,34vw);padding:18px;position:absolute;bottom:clamp(22px,4vw,46px);right:clamp(24px,4vw,58px);box-shadow:0 22px 55px #0f172a29}.home-hero-report>div{flex-direction:column;gap:2px;margin-bottom:12px;display:flex}.home-hero-report span,.home-section-heading span,.insight-panel-header span{color:var(--text-muted);font-size:12px;font-weight:700}.home-hero-report strong,.home-section-heading h2,.insight-panel-header h2{letter-spacing:0;margin:4px 0 0}.home-hero-report strong{color:var(--text-primary);font-family:var(--font-headline);font-size:20px}.home-hero-report p{color:var(--text-secondary);margin-top:12px;font-size:13px;line-height:1.55}.home-section-heading.centered{text-align:center;max-width:620px;margin:0 auto 24px}.service-section{padding:34px}.service-card-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;display:grid}.service-card{min-height:245px;color:var(--text-primary);text-align:left;cursor:pointer;background:#ffffffdb;border:1px solid #cbd5e1e0;border-radius:18px;flex-direction:column;align-items:flex-start;padding:24px;transition:transform .18s,box-shadow .18s,border-color .18s;display:flex;box-shadow:0 18px 45px #0f172a0d}.service-card:hover{border-color:#2563eb42;transform:translateY(-3px);box-shadow:0 24px 58px #0f172a1a}.service-icon{width:52px;height:52px;color:var(--brand-blue);background:linear-gradient(135deg,#2563eb1f,#14b8a624);border-radius:16px;justify-content:center;align-items:center;margin-bottom:18px;display:flex}.service-card h3{margin:0 0 10px;font-size:20px}.service-card p{color:var(--text-secondary);flex:1;font-size:14px;line-height:1.75}.service-card strong{color:var(--brand-blue);align-items:center;gap:6px;margin-top:18px;font-size:14px;display:inline-flex}.workflow-section{padding:32px 34px}.simple-workflow{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.simple-workflow-item{border:1px solid var(--border);background:#fff;border-radius:16px;padding:20px;position:relative}.workflow-step-num{color:#0f172a1a;font-family:var(--font-headline);font-size:36px;font-weight:800;line-height:1;position:absolute;top:16px;right:18px}.workflow-step-icon{color:#0f766e;background:#f0fdfa;border-radius:999px;justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:14px;display:flex}.simple-workflow-item h3{margin-bottom:8px;font-size:17px}.simple-workflow-item p{color:var(--text-secondary);font-size:13px;line-height:1.65}.report-outcome{background:linear-gradient(135deg,#eff6ffe6,#f0fdfad1),#fff;border:1px solid #2563eb1f;border-radius:22px;grid-template-columns:minmax(0,1fr) minmax(320px,420px);align-items:center;gap:22px;padding:34px;display:grid}.report-outcome-copy h2{letter-spacing:0;max-width:720px;margin:12px 0;font-size:30px}.report-outcome-copy p{max-width:760px;color:var(--text-secondary);font-size:15px;line-height:1.8}.report-highlight-list{flex-wrap:wrap;gap:10px;margin-top:18px;display:flex}.report-highlight-list span{color:#0f766e;background:#ffffffb8;border:1px solid #14b8a633;border-radius:999px;align-items:center;gap:6px;padding:8px 11px;font-size:12px;font-weight:700;display:inline-flex}.report-outcome-card{background:#ffffffd1;border:1px solid #ffffffb8;border-radius:20px;padding:24px;box-shadow:0 22px 55px #0f172a1a}.report-outcome-card span{color:var(--text-muted);font-size:12px;font-weight:700}.report-outcome-card h3{margin:8px 0 10px;font-size:21px}.report-outcome-card p{color:var(--text-secondary);margin-bottom:18px;font-size:13px;line-height:1.7}.home-evidence-band{grid-template-columns:repeat(3,minmax(0,1fr)) minmax(220px,.9fr);gap:14px;display:grid}.evidence-item,.evidence-rate,.journey-card,.insight-panel{border:1px solid var(--border);box-shadow:var(--shadow-xs);background:#fff;border-radius:14px}.evidence-item{padding:18px 20px}.evidence-item strong{color:var(--text-primary);font-size:26px;line-height:1;display:block}.evidence-item span{color:var(--text-primary);margin-top:8px;font-weight:700;display:block}.evidence-item small{color:var(--text-muted);margin-top:4px;display:block}.evidence-rate{color:#0f766e;background:#f0fdfa;justify-content:center;align-items:center;gap:8px;padding:18px;font-weight:700;display:flex}.home-section,.insight-panel{padding:24px}.home-section.compact{min-height:100%}.home-section-heading{margin-bottom:18px}.journey-grid,.audience-grid,.home-grid-split{gap:18px;display:grid}.journey-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.journey-card{min-height:220px;padding:22px;transition:transform .18s,box-shadow .18s,border-color .18s;position:relative;overflow:hidden}.journey-card:hover,.audience-card:hover,.insight-panel:hover{box-shadow:var(--shadow-card-hover);border-color:#2563eb38;transform:translateY(-2px)}.journey-index{color:#0f172a14;font-family:var(--font-headline);font-size:42px;font-weight:800;position:absolute;top:16px;right:18px}.journey-icon{color:#2563eb;background:#eff6ff;border-radius:12px;justify-content:center;align-items:center;width:46px;height:46px;margin-bottom:18px;display:flex}.journey-card h3{font-size:18px}.journey-card p{color:var(--text-secondary);margin:10px 0 14px;font-size:13px}.journey-card small{color:#0f766e;font-weight:700}.journey-arrow{color:var(--text-disabled);position:absolute;top:50%;right:-9px}.home-grid-split{grid-template-columns:minmax(0,.95fr) minmax(360px,1.05fr);align-items:stretch}.home-grid-split.bottom{grid-template-columns:.9fr 1.1fr}.audience-grid{grid-template-columns:1fr}.audience-card{border:1px solid var(--border);width:100%;color:var(--text-primary);text-align:left;cursor:pointer;background:#fff;border-radius:14px;grid-template-columns:42px minmax(0,1fr) auto;align-items:center;gap:8px 12px;padding:16px;transition:transform .18s,box-shadow .18s,border-color .18s;display:grid}.audience-card svg{border-radius:12px;grid-row:span 2;width:42px;height:42px;padding:10px}.audience-card span{font-weight:800}.audience-card strong{font-family:var(--font-headline);font-size:20px}.audience-card p{color:var(--text-muted);grid-column:2/4;font-size:13px}.audience-card.dog svg{color:#b45309;background:#fffbeb}.audience-card.cat svg{color:#7c3aed;background:#f5f3ff}.audience-card.ai svg{color:#2563eb;background:#eff6ff}.insight-panel{transition:transform .18s,box-shadow .18s,border-color .18s}.insight-panel-header{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px;display:flex}.home-chart-tooltip{border:1px solid var(--border);color:var(--text-secondary);box-shadow:var(--shadow-md);background:#fff;border-radius:10px;flex-direction:column;gap:3px;padding:10px 12px;font-size:12px;display:flex}.category-legend{flex-wrap:wrap;gap:9px;margin-top:-4px;display:flex}.category-legend span{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:inline-flex}.category-legend i{border-radius:999px;width:8px;height:8px}@media (width<=1180px){.home-hero,.home-grid-split,.home-grid-split.bottom{grid-template-columns:1fr}.home-evidence-band{grid-template-columns:repeat(2,1fr)}.service-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=820px){.home-hero{background-position:62%;align-items:flex-start;min-height:620px;padding:24px}.home-hero h1{font-size:34px}.journey-grid,.home-evidence-band,.service-card-grid,.simple-workflow,.report-outcome{grid-template-columns:1fr}.home-hero-report{width:auto;bottom:18px;left:18px;right:18px}}.upload-page-shell{grid-template-columns:minmax(0,1fr) minmax(280px,340px);align-items:start;gap:24px;display:grid}@media (width<=1080px){.upload-page-shell{grid-template-columns:1fr}.upload-page-shell aside{position:static!important}}.page{min-height:100vh;padding:24px}.page-hero{background:#fff;border:1px solid #e2e8f0;border-radius:14px;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding:20px 24px;display:flex;box-shadow:0 1px 3px #0000000a}.page-hero h1{color:#0f172a;align-items:center;gap:12px;margin:0 0 8px;font-size:24px;font-weight:700;display:flex}.page-hero p{color:#64748b;margin:0;font-size:14px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}@media (width<=768px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:16px;padding:16px 20px;transition:all .2s;display:flex}.stat-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000000f}.stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.stat-content{flex:1}.stat-label{color:#94a3b8;margin-bottom:4px;font-size:12px}.stat-value{font-size:26px;font-weight:700;line-height:1}.task-timeline{flex-direction:column;gap:12px;display:flex}.task-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:18px 22px;transition:all .22s;box-shadow:0 1px 3px #0000000a}.task-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #00000014}.task-card-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.task-card-pet{align-items:center;gap:12px;display:flex}.species-badge{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.pet-name{color:#0f172a;font-size:16px;font-weight:700;line-height:1.3;display:block}.pet-species{font-size:12px;font-weight:500;display:block}.task-card-status{border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:13px;font-weight:600;display:flex}.task-card-meta{align-items:center;gap:16px;margin-bottom:12px;padding-left:52px;display:flex}.task-id code{color:#3b82f6;background:#eff6ff;border-radius:4px;padding:3px 8px;font-family:SF Mono,Fira Code,monospace;font-size:11px}.task-time{color:#94a3b8;font-size:12px}.task-card-actions{align-items:center;gap:8px;padding-left:52px;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-dot-completed{background:#10b981}.status-dot-running{background:#3b82f6;animation:2s ease-in-out infinite pulse}.status-dot-error{background:#ef4444}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 #22c55e66}50%{opacity:.8;box-shadow:0 0 0 4px #22c55e00}}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:6px 12px;font-size:12px}.btn-primary{color:#fff;background:#3b82f6;border:1px solid #3b82f6}.btn-primary:hover:not(:disabled){background:#2563eb;border-color:#2563eb;box-shadow:0 2px 8px #3b82f64d}.btn-secondary{color:#475569;background:#fff;border:1px solid #e2e8f0}.btn-secondary:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.btn-ghost{color:#64748b;background:0 0;border:1px solid #0000}.btn-ghost:hover:not(:disabled){color:#3b82f6;background:#f8fafc}.loading-state{background:#fff;border:1px solid #e2e8f0;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 20px;display:flex}.loading-spinner{border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;width:32px;height:32px;animation:1s linear infinite spin}.empty-state-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.page-footer{text-align:center;margin-top:20px;padding:16px}@media (width<=768px){.task-card-header{flex-direction:column;align-items:flex-start;gap:8px}.task-card-meta,.task-card-actions{padding-left:0}}.gene-db-page{min-height:100%;color:var(--text-primary);padding:24px}.gene-db-header{border:1px solid var(--border);background:linear-gradient(90deg, #fffffffa 0%, #ffffffe6 58%, #ffffff47 100%), var(--gene-db-visual), #fff;background-position:100%;background-size:cover;border-radius:8px;grid-template-columns:minmax(0,1fr) minmax(320px,460px);align-items:end;gap:28px;margin-bottom:24px;padding:28px;display:grid;overflow:hidden}.gene-db-eyebrow{color:#2f80ed;letter-spacing:0;align-items:center;gap:8px;margin-bottom:10px;font-size:12px;font-weight:700;display:inline-flex}.gene-db-header h2{color:var(--text-primary);font-family:var(--font-headline);margin:0 0 8px}.gene-db-header .ant-typography{max-width:760px;color:var(--text-secondary)}.gene-db-searchbar{grid-template-columns:minmax(0,1fr) auto;gap:10px;display:grid}.gene-db-layout{grid-template-columns:280px minmax(0,1fr);align-items:start;gap:20px;display:grid}.gene-db-sidebar{top:calc(var(--header-height) + 18px);gap:14px;display:grid;position:sticky}.filter-panel,.species-summary,.gene-db-main,.gene-card{border:1px solid var(--border);background:#fff;border-radius:8px}.filter-panel{padding:16px}.panel-title{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:12px;font-weight:700;display:flex}.species-list{gap:8px;display:grid}.species-option{border:1px solid var(--border);width:100%;min-height:48px;color:var(--text-primary);text-align:left;cursor:pointer;background:#fff;border-radius:8px;grid-template-columns:28px minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 12px;transition:border-color .2s,background .2s,transform .2s;display:grid}.species-option:hover{border-color:#2f80ed59;transform:translateY(-1px)}.species-option.active{background:#2f80ed0f;border-color:#2f80eda6}.species-option strong{white-space:nowrap;text-overflow:ellipsis;font-size:14px;overflow:hidden}.species-option em{color:#0f766e;font-size:12px;font-style:normal;font-weight:700}.filter-panel label{color:var(--text-secondary);gap:6px;margin-top:12px;font-size:12px;font-weight:700;display:grid}.filter-panel .ant-select{width:100%}.gene-db-main{padding:18px}.species-summary{background:linear-gradient(135deg,#fff,#f7fbff);grid-template-columns:minmax(180px,240px) minmax(0,1fr);align-items:center;gap:18px;margin-bottom:16px;padding:18px;display:grid}.species-summary h4{margin:3px 0 0}.summary-stats{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.summary-stats>div{background:#ffffffb3;border:1px solid #94a3b82e;border-radius:8px;min-width:0;padding:10px 12px}.summary-stats span{color:#14b8a6;margin-right:7px;display:inline-flex}.summary-stats strong{color:var(--text-primary);font-size:18px}.summary-stats .ant-typography{color:var(--text-muted);margin-top:3px;font-size:11px;display:block}.gene-db-toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.gene-card-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;display:grid}.gene-card{text-align:left;cursor:pointer;flex-direction:column;min-height:260px;padding:16px;transition:border-color .2s,box-shadow .2s,transform .2s;display:flex}.gene-card:hover{border-color:#2f80ed73;transform:translateY(-2px);box-shadow:0 12px 32px #0f172a14}.gene-card-head{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:12px;display:flex}.gene-symbol{color:#17324d;font-family:var(--font-mono);letter-spacing:0;font-size:20px;font-weight:800}.gene-description{min-height:56px;color:var(--text-secondary);line-height:1.55}.gene-card-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:14px 0;display:grid}.gene-card-metrics span{color:var(--text-muted);background:#f8fafc;border-radius:8px;padding:8px;font-size:11px}.gene-card-metrics strong{color:var(--text-primary);font-size:15px;display:block}.gene-disease-preview{gap:7px;margin-bottom:14px;display:grid}.gene-disease-preview>div{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;display:grid}.gene-disease-preview .ant-typography{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.gene-card-action{color:#2f80ed;margin-top:auto;font-size:12px;font-weight:700}.gene-inherit{border-radius:6px;justify-content:center;align-items:center;min-width:48px;min-height:22px;padding:2px 7px;font-size:11px;font-weight:700;display:inline-flex}.inherit-ar{color:#2f80ed;background:#2f80ed17;border:1px solid #2f80ed47}.inherit-ad{color:#dc4444;background:#dc444414;border:1px solid #dc444447}.inherit-xr,.inherit-xd{color:#7c54b8;background:#7c54b814;border:1px solid #7c54b847}.inherit-mito{color:#b45309;background:#f59e0b1a;border:1px solid #f59e0b4d}.inherit-unknown{color:#64748b;background:#64748b14;border:1px solid #64748b33}.disease-name-cell{gap:4px;display:grid}.disease-name-cell .ant-typography-secondary,.gene-table-muted{color:var(--text-muted);font-size:12px;line-height:1.45}.gene-table-symbol{color:#17324d;font-family:var(--font-mono);font-weight:800}.breed-tags{flex-wrap:wrap;gap:4px;display:flex}.gene-disease-table .ant-table{border-radius:8px}.gene-detail-modal .ant-modal-content{border-radius:8px;padding:22px}.gene-modal-header{grid-template-columns:64px minmax(0,1fr);align-items:start;gap:16px;margin-bottom:18px;display:grid}.gene-symbol-mark{color:#fff;width:58px;height:58px;font-family:var(--font-mono);background:linear-gradient(135deg,#2f80ed,#14b8a6);border-radius:8px;place-items:center;font-size:18px;font-weight:800;display:grid}.gene-modal-kicker{color:#2f80ed;font-size:12px;font-weight:700}.gene-modal-header h3{margin:2px 0 5px}.gene-modal-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:18px;display:grid}.gene-modal-metrics>div{border:1px solid var(--border);background:#f8fafc;border-radius:8px;padding:12px}.gene-modal-metrics span{color:var(--text-primary);font-size:22px;font-weight:800;display:block}.gene-modal-disease{gap:4px;display:grid}.gene-modal-breeds{flex-wrap:wrap;gap:4px;display:flex}@media (width<=1120px){.gene-db-header,.gene-db-layout{grid-template-columns:1fr}.gene-db-sidebar{position:static}.species-list{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media (width<=760px){.gene-db-page{padding:14px}.gene-db-header,.gene-db-main,.species-summary{padding:16px}.gene-db-searchbar,.species-summary,.summary-stats{grid-template-columns:1fr}.gene-db-toolbar{flex-direction:column;align-items:flex-start}.gene-card-grid,.gene-modal-header,.gene-modal-metrics{grid-template-columns:1fr}}.assistant-page-layout{height:calc(100vh - var(--header-height) - 48px);border-radius:var(--radius-lg);border:1px solid #e2e8f0c7;grid-template-columns:280px minmax(0,1fr);gap:0;min-height:500px;display:grid;overflow:hidden;box-shadow:0 18px 44px #0f172a0f}.assistant-page-sidebar,.assistant-page-main{min-width:0}@media (width<=900px){.assistant-page-layout{height:calc(100vh - var(--header-height) - 32px);grid-template-columns:minmax(0,1fr);min-height:560px}.assistant-page-sidebar{display:none!important}.assistant-page-main{min-height:0}}@media (width<=520px){.assistant-page-layout{height:calc(100vh - var(--header-height) - 24px);border-radius:var(--radius-md);min-height:520px}}.chat-fab{z-index:1000;cursor:pointer;color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#8b5cf6 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:24px;transition:all .22s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 14px #3b82f659}.chat-fab:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f673}.chat-fab:active{transform:scale(.95)}.chat-fab .fab-badge{opacity:0;background:#ef4444;border:2px solid #fff;border-radius:50%;width:12px;height:12px;transition:all .2s;position:absolute;top:0;right:0;transform:scale(0)}.chat-fab .fab-badge.visible{opacity:1;transform:scale(1)}.chat-window{z-index:1000;opacity:0;pointer-events:none;background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;width:420px;height:580px;transition:all .25s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;bottom:96px;right:28px;overflow:hidden;transform:translateY(16px)scale(.97);box-shadow:0 8px 32px #0000001f,0 2px 8px #0000000f}.chat-window.open{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.chat-header{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#8b5cf6 100%);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.chat-header-left{align-items:center;gap:10px;display:flex}.chat-header-left .chat-avatar{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.chat-header-left .chat-title-group{flex-direction:column;display:flex}.chat-header-left .chat-title{letter-spacing:0;color:#fff;font-size:15px;font-weight:700;line-height:1.3}.chat-header-left .chat-subtitle{opacity:.85;color:#ffffffe6;align-items:center;gap:5px;font-size:11.5px;display:flex}.chat-header-left .chat-subtitle .status-dot{background:#4ade80;border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse}.chat-header-actions{gap:4px;display:flex}.chat-header-actions button{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;transition:background .2s;display:flex}.chat-header-actions button:hover{background:#ffffff40}.chat-messages{background:#f8fafc;flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.chat-msg{gap:8px;max-width:88%;animation:.25s chatMsgIn;display:flex}@keyframes chatMsgIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.chat-msg.user{flex-direction:row-reverse;align-self:flex-end}.chat-msg-avatar{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;display:flex}.chat-msg.assistant .chat-msg-avatar{color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#f5f3ff);border:1px solid #e2e8f0}.chat-msg.user .chat-msg-avatar{color:#fff;background:linear-gradient(135deg,#3b82f6,#8b5cf6);font-size:12px;font-weight:700}.chat-msg-bubble{word-break:break-word;border-radius:12px;padding:10px 14px;font-size:13.5px;line-height:1.7}.chat-msg.assistant .chat-msg-bubble{color:#1e293b;background:#fff;border:1px solid #e2e8f0;border-left:3px solid #3b82f6;border-top-left-radius:4px;box-shadow:0 1px 3px #0000000a}.chat-msg.user .chat-msg-bubble{color:#fff;background:linear-gradient(135deg,#3b82f6,#6366f1);border-top-right-radius:4px;font-weight:500;box-shadow:0 2px 8px #3b82f640}.chat-typing{align-items:center;gap:5px;padding:6px 0;display:flex}.chat-typing .dot{background:#3b82f6;border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite typingBounce}.chat-typing .dot:nth-child(2){animation-delay:.16s}.chat-typing .dot:nth-child(3){animation-delay:.32s}@keyframes typingBounce{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-5px)}}.chat-welcome{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:28px 20px 16px;display:flex}.chat-welcome .welcome-icon{color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#f5f3ff);border:1px solid #e2e8f0;border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:12px;font-size:24px;display:flex}.chat-welcome .welcome-title{color:#1e293b;margin-bottom:4px;font-size:16px;font-weight:700}.chat-welcome .welcome-desc{color:#64748b;max-width:280px;font-size:12.5px;line-height:1.6}.chat-welcome .welcome-suggestions{flex-wrap:wrap;justify-content:center;gap:6px;margin-top:14px;display:flex}.chat-welcome .welcome-suggestions button{color:#3b82f6;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:5px 12px;font-size:12px;transition:all .2s}.chat-welcome .welcome-suggestions button:hover{background:#eff6ff;border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61f}.chat-input-area{background:#fff;border-top:1px solid #f1f5f9;flex-shrink:0;padding:12px 16px}.chat-input-row{box-sizing:border-box;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;align-items:center;gap:10px;min-height:50px;padding:5px 6px 5px 16px;transition:all .2s;display:flex}.chat-input-row:focus-within{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.chat-input-row textarea{resize:none;color:#1e293b;box-sizing:border-box;background:0 0;border:none;outline:none;flex:1;min-width:0;min-height:24px;max-height:96px;padding:7px 0;font-family:inherit;font-size:13.5px;line-height:1.55}.chat-input-row textarea::placeholder{color:#94a3b8}.chat-send-btn{color:#fff;cursor:pointer;opacity:.5;background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:38px;min-width:38px;height:38px;font-size:16px;transition:all .2s;display:flex}.chat-send-btn .anticon{justify-content:center;align-items:center;line-height:1;display:flex}.chat-send-btn.enabled{opacity:1;box-shadow:0 2px 8px #3b82f64d}.chat-send-btn.enabled:hover{transform:scale(1.06);box-shadow:0 4px 12px #3b82f666}.chat-send-btn:disabled{cursor:not-allowed}.chat-send-btn.abort{opacity:1;background:#ef4444}.chat-send-btn.abort:hover{transform:scale(1.06);box-shadow:0 4px 12px #ef444466}.abort-icon{font-size:12px;font-weight:700}.chat-msg.streaming .chat-msg-bubble{border-left:3px solid #8b5cf6}.streaming-indicator{color:#3b82f6;font-size:10px;animation:1s ease-in-out infinite pulse}.chat-header-actions button.active{background:#ffffff4d}.chat-quick-actions{gap:6px;margin-top:8px;padding-bottom:2px;display:flex;overflow-x:auto}.chat-quick-actions button{color:#64748b;cursor:pointer;white-space:nowrap;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;flex-shrink:0;padding:4px 10px;font-size:11.5px;transition:all .2s}.chat-quick-actions button:hover{color:#3b82f6;background:#eff6ff;border-color:#3b82f6}.chat-error{text-align:center;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:8px;font-size:12px}.ai-markdown{color:#1e293b;font-size:13.5px;line-height:1.7}.ai-markdown p{margin:0 0 8px}.ai-markdown p:last-child{margin-bottom:0}.ai-markdown strong{color:#0f172a;font-weight:600}.ai-markdown code{color:#7c3aed;background:#f1f5f9;border-radius:4px;padding:1px 5px;font-size:12.5px}.ai-markdown pre{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin:8px 0;padding:10px 12px;overflow-x:auto}.ai-markdown pre code{color:#1e293b;background:0 0;padding:0}.ai-markdown ul,.ai-markdown ol{margin:4px 0;padding-left:20px}.ai-markdown li{margin:2px 0}.ai-markdown h1,.ai-markdown h2,.ai-markdown h3,.ai-markdown h4{color:#0f172a;margin:10px 0 4px;font-weight:600}.ai-markdown h1{font-size:16px}.ai-markdown h2{font-size:15px}.ai-markdown h3{font-size:14px}.ai-markdown blockquote{color:#475569;background:#eff6ff;border-left:3px solid #3b82f6;border-radius:0 6px 6px 0;margin:6px 0;padding:4px 12px}.ai-markdown a{color:#3b82f6;text-decoration:none}.ai-markdown a:hover{text-decoration:underline}.ai-markdown table{border-collapse:collapse;width:100%;margin:8px 0;font-size:12.5px}.ai-markdown th,.ai-markdown td{text-align:left;border:1px solid #e2e8f0;padding:4px 8px}.ai-markdown th{background:#f8fafc;font-weight:600}@media (width<=520px){.chat-window{border-radius:0;width:100%;height:100%;bottom:0;right:0}.chat-fab{width:48px;height:48px;font-size:20px;bottom:16px;right:16px}}.app-shell{background:radial-gradient(circle at 15% 0%, #14b8a61f, transparent 28%), radial-gradient(circle at 90% 10%, #f973161a, transparent 26%), var(--bg-body);min-height:100vh}.app-sider{-webkit-backdrop-filter:blur(22px);z-index:100;height:100vh;transition:width .36s var(--ease-smooth), transform .36s var(--ease-smooth), box-shadow .36s var(--ease-smooth);border-right:1px solid #cbd5e194;flex-direction:column;display:flex;top:0;bottom:0;left:0;overflow:hidden;box-shadow:18px 0 55px #0f172a0d;width:var(--sider-width)!important;background:var(--sider-bg)!important;position:fixed!important}.sidebar-header{align-items:center;gap:var(--space-3);border-bottom:1px solid #e2e8f0c2;flex-shrink:0;padding:22px 20px;display:flex}.brand-icon{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--brand-blue), var(--brand-teal));color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.brand-logo{font-size:20px}.sidebar-cta{padding:12px 16px 4px}.sidebar-primary-action{background:linear-gradient(135deg, var(--brand-blue), var(--brand-teal));color:#fff;width:100%;min-height:40px;font-family:var(--font-headline);cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast), filter var(--transition-fast);border:0;border-radius:999px;justify-content:center;align-items:center;gap:8px;font-size:13px;font-weight:700;display:flex;box-shadow:0 8px 20px #14b8a62e}.sidebar-primary-action:hover{filter:saturate(1.08);transform:translateY(-1px);box-shadow:0 10px 24px #2563eb38}.brand-text{flex-direction:column;gap:2px;min-width:0;display:flex}.brand-name{color:var(--text-primary);font-size:16px;font-weight:700;font-family:var(--font-brand);letter-spacing:0;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.brand-tagline{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-nav{padding:var(--space-3);flex:1;overflow:hidden auto}.nav-section-label{text-transform:uppercase;letter-spacing:0;color:var(--sider-text);padding:var(--space-3) var(--space-3) var(--space-2);font-size:11px;font-weight:600}.nav-link{width:100%;font-size:14px;font-weight:500;display:block;color:inherit!important;text-decoration:none!important}.app-sider .ant-menu{background:0 0!important;border:none!important}.app-sider .ant-menu-item{border-radius:var(--radius-md)!important;margin-bottom:var(--space-1)!important;height:44px!important;color:var(--sider-text)!important;padding-left:var(--space-3)!important;padding-right:var(--space-3)!important;transition:all var(--transition-base)!important;margin-left:0!important;margin-right:0!important;line-height:44px!important}.app-sider .ant-menu-item:hover{color:var(--sider-text-hover)!important;background:#2563eb12!important}.app-sider .ant-menu-item-selected{color:var(--brand-blue)!important;border-right:4px solid var(--brand-teal)!important;border-radius:var(--radius-md) 0 0 var(--radius-md)!important;padding-right:calc(var(--space-3) - 4px)!important;background:linear-gradient(90deg,#2563eb1f,#14b8a614)!important;margin-right:0!important;font-weight:600!important}.app-sider .ant-menu-item .anticon{margin-right:var(--space-3)!important;font-size:16px!important}.app-sider .nav-icon{vertical-align:-3px;justify-content:center;align-items:center;margin-right:10px;display:inline-flex}.resource-links{padding:0 var(--space-1);flex-direction:column;gap:2px;display:flex}.resource-link{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:all var(--transition-fast);font-size:13px;display:flex;color:var(--sider-text)!important;text-decoration:none!important}.resource-link:hover{background:#2563eb12;color:var(--sider-text-hover)!important}.sidebar-footer{padding:var(--space-4) var(--space-5);border-top:1px solid #e2e8f0c2;flex-shrink:0}.sidebar-status{align-items:center;gap:var(--space-3);margin-bottom:var(--space-2);display:flex}.status-dot{background:var(--success);border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-dot.pulse{animation:2s infinite pulse}.status-info{flex-direction:column;gap:1px;min-width:0;display:flex}.status-label{text-transform:uppercase;letter-spacing:0;color:var(--sider-text);font-size:10px}.status-value{color:var(--success);font-size:12px;font-weight:600}.sidebar-meta{align-items:center;gap:var(--space-2);color:var(--sider-text);font-size:11px;display:flex}.sidebar-meta .separator{opacity:.5}.sidebar-version{color:var(--sider-text);opacity:.65;margin-left:auto;font-size:10px}.main-layout{min-height:100vh;margin-left:var(--sider-width);transition:margin-left .36s var(--ease-smooth);background:0 0}.app-header{height:var(--header-height);z-index:50;transition:background-color .26s var(--ease-smooth), backdrop-filter .26s var(--ease-smooth), padding .36s var(--ease-smooth), border-color .26s var(--ease-smooth);top:0;-webkit-backdrop-filter:blur(18px)!important;padding:0 var(--space-6)!important;background:#f6f8f5c2!important;border-bottom:1px solid #e2e8f09e!important;justify-content:space-between!important;align-items:center!important;display:flex!important;position:sticky!important}.header-left{flex-direction:column;flex:auto;gap:2px;min-width:0;display:flex}.breadcrumb{align-items:center;gap:var(--space-2);display:flex}.breadcrumb-root{font-size:13px;font-weight:500;color:var(--text-muted)!important}.breadcrumb-sep{color:var(--gray-400);font-size:13px}.breadcrumb-current{font-size:14px;font-weight:600;font-family:var(--font-brand);color:var(--text-primary)!important}.breadcrumb-sub{font-size:12px;font-family:var(--font-mono);color:var(--text-muted)!important}.header-right{align-items:center;gap:var(--space-3);flex:none;display:flex}.mobile-nav-toggle,.mobile-sider-backdrop{display:none}.mobile-nav-toggle{width:38px;height:38px;color:var(--text-primary);cursor:pointer;transition:transform var(--transition-fast), border-color var(--transition-fast), background-color var(--transition-fast);background:#ffffffdb;border:1px solid #cbd5e1c7;border-radius:999px;flex:0 0 38px;justify-content:center;align-items:center;box-shadow:0 8px 22px #0f172a0f}.mobile-nav-toggle:hover{background:#fff;border-color:#2563eb47;transform:translateY(-1px)}.mobile-sider-backdrop{z-index:190;-webkit-backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .22s var(--ease-smooth);background:#0f172a47;border:0;position:fixed;inset:0}.header-cta-btn{background:linear-gradient(135deg, var(--brand-blue), var(--brand-teal));color:#fff;font-size:13px;font-weight:600;font-family:var(--font-brand);cursor:pointer;border:none;border-radius:999px;align-items:center;gap:6px;padding:7px 16px;transition:all .15s;display:flex;box-shadow:0 4px 14px #3b82f64d}.header-cta-btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px #3b82f666}.header-icon-btn{border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#ffffffc7;border-radius:999px;justify-content:center;align-items:center;font-size:16px;display:flex}.header-icon-btn:hover{background:var(--gray-100);border-color:var(--gray-300);color:var(--text-primary)}.header-lang-btn{min-width:72px;height:36px;color:var(--brand-blue);font-family:var(--font-brand);cursor:pointer;transition:background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);background:#ffffffd1;border:1px solid #2563eb2e;border-radius:999px;justify-content:center;align-items:center;gap:7px;padding:0 12px;font-size:12px;font-weight:700;display:inline-flex;box-shadow:0 8px 22px #0f172a0a}.header-lang-btn:hover{color:#0f766e;background:#fff;border-color:#14b8a657;transform:translateY(-1px);box-shadow:0 12px 28px #0f172a14}.user-avatar{border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#ffffffc7;border-radius:999px;justify-content:center;align-items:center;display:flex}.user-avatar:hover{background:var(--primary-50);border-color:var(--primary-200);color:var(--primary-700)}.app-content{min-height:calc(100vh - var(--header-height));transition:padding .36s var(--ease-smooth);padding:var(--space-6)!important}.page-header{margin-bottom:var(--space-6)}.page-header-top{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.page-title{margin-bottom:var(--space-2);color:var(--text-primary);font-size:24px;font-weight:700}.page-description{color:var(--text-muted);max-width:600px;font-size:14px;line-height:1.6}.page-tags{gap:var(--space-2);flex-wrap:wrap;display:flex}.stats-grid{gap:var(--space-5);margin-bottom:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.stats-grid{grid-template-columns:1fr}}.quick-actions{margin-bottom:var(--space-6)}.quick-actions-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.quick-action-card{padding:var(--space-5);text-align:center;cursor:pointer;transition:all var(--transition-base);border:1px solid #0000}.quick-action-card:hover{border-color:var(--primary-200);transform:translateY(-2px)}.quick-action-icon{border-radius:var(--radius-lg);width:56px;height:56px;margin:0 auto var(--space-4);justify-content:center;align-items:center;font-size:24px;display:flex}.quick-action-title{margin-bottom:var(--space-2);color:var(--text-primary);font-size:15px;font-weight:600}.quick-action-desc{color:var(--text-muted);margin-bottom:var(--space-3);font-size:13px;line-height:1.5}.quick-action-link{justify-content:center;align-items:center;gap:var(--space-1);font-size:12px;font-weight:500;display:flex}.charts-grid{gap:var(--space-5);margin-bottom:var(--space-5);grid-template-columns:1.5fr 1fr;display:grid}@media (width<=1024px){.charts-grid{grid-template-columns:1fr}}.chart-card{padding:var(--space-5)}.chart-card-header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.chart-card-title{color:var(--text-primary);font-size:15px;font-weight:600}.bottom-grid{gap:var(--space-5);grid-template-columns:1fr 1fr;display:grid}@media (width<=1024px){.bottom-grid{grid-template-columns:1fr}}.species-list{gap:var(--space-3);flex-direction:column;display:flex}.species-item{align-items:center;gap:var(--space-3);display:flex}.species-icon{flex-shrink:0}.species-info{flex:1;min-width:0}.species-header{margin-bottom:var(--space-1);justify-content:space-between;align-items:center;display:flex}.species-name{color:var(--text-secondary);font-size:13px}.species-count{color:var(--text-muted);font-size:12px}.species-progress{background:var(--gray-100);border-radius:3px;height:6px;overflow:hidden}.species-progress-bar{border-radius:3px;height:100%;transition:width .3s}.section-title{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.section-title-left{align-items:center;gap:var(--space-3);display:flex}.section-title-icon{color:var(--primary-500);font-size:18px}.section-title-text{color:var(--text-primary);font-size:16px;font-weight:600}@media (width<=768px){.mobile-nav-toggle{display:inline-flex}.mobile-sider-backdrop{display:block}.mobile-sider-backdrop.active{opacity:1;pointer-events:auto}.app-sider{z-index:200;transition:transform var(--transition-base);transform:translate(-100%);position:fixed!important}.app-sider.open{transform:translate(0)}.main-layout{margin-left:0}.app-content{padding:var(--space-4)!important}.content-wrapper{min-width:0}.page-header-top{flex-direction:column}.app-header{gap:var(--space-3);padding:0 var(--space-4)!important}.header-left{flex:auto;overflow:hidden}.breadcrumb{min-width:0}.breadcrumb-current,.breadcrumb-sub{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.breadcrumb-sub{display:none}.header-right{gap:var(--space-2)}.header-cta-btn{display:none}.header-lang-btn{width:38px;min-width:38px;padding:0}.header-lang-btn span{display:none}}@media (width<=460px){.breadcrumb-root,.breadcrumb-sep{display:none}.app-content{padding:var(--space-3)!important}}@media print{.app-sider,.app-header{display:none!important}.main-layout{margin-left:0!important}body{color:#000!important;background:#fff!important}.app-content{padding:0!important}.card{break-inside:avoid;box-shadow:none!important;border:1px solid var(--border)!important}}
