:root{--bg-color: #f3f4f6;--surface-color: #ffffff;--surface-hover: #f9fafb;--border-color: #e5e7eb;--border-light: #f3f4f6;--text-main: #111827;--text-muted: #4b5563;--text-light: #9ca3af;--primary: #2563eb;--primary-hover: #1d4ed8;--success: #059669;--danger: #dc2626;--warning: #d97706;--radius: 8px;--radius-sm: 6px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--transition: all .2s ease-in-out}*{box-sizing:border-box}body{margin:0;padding:0;background-color:var(--bg-color);color:var(--text-main);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6,p,dl,dd,dt{margin:0;padding:0}button{font-family:inherit;border:none;cursor:pointer;background:none;outline:none}.app-shell{max-width:1440px;margin:0 auto;padding:0 24px 32px}.hero-banner{position:relative;display:flex;min-height:340px;overflow:hidden;align-items:center;margin:0 calc(50% - 50vw) 0;padding:52px max(24px,calc((100vw - 1392px)/2 + 24px)) 104px;background-position:center top;background-size:cover;background-repeat:no-repeat}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#f3f4f6,#f3f4f6eb 30%,#f3f4f66b 68%,#f3f4f614),linear-gradient(180deg,rgba(243,244,246,0) 0%,rgba(243,244,246,.72) 72%,var(--bg-color) 100%);pointer-events:none}.hero-content{position:relative;z-index:1;display:flex;flex-direction:column;gap:8px;max-width:620px}.eyebrow{font-size:13px;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.05em}.hero-banner h1{font-size:40px;font-weight:700;color:var(--text-main);line-height:1.2}.subtitle{font-size:15px;color:var(--text-muted);line-height:1.7}.hero-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.hero-meta span{display:inline-flex;align-items:center;min-height:26px;border:1px solid rgba(203,213,225,.82);border-radius:999px;background:#ffffffad;padding:3px 10px;color:#334155;font-size:12px;font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;font-size:14px;font-weight:500;border-radius:var(--radius-sm);transition:var(--transition);border:1px solid var(--border-color);background-color:var(--surface-color);color:var(--text-main);box-shadow:var(--shadow-sm)}.btn:hover:not(:disabled){background-color:var(--surface-hover);border-color:#d1d5db}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);border-color:var(--primary-hover)}.notice{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius);margin-bottom:24px;font-size:14px;font-weight:500}.notice-danger{background-color:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.notice-warn{background-color:#fffbeb;border:1px solid #fde68a;color:#b45309}.grid-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;position:relative;z-index:2;margin-top:-54px;margin-bottom:24px}.grid-charts-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:24px}.grid-charts-wide{display:grid;grid-template-columns:2fr 1fr;gap:24px;margin-bottom:24px}.card{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);transition:var(--transition);display:flex;flex-direction:column}.card:hover{box-shadow:var(--shadow-md);border-color:#d1d5db}.app-shell>.card{margin-bottom:24px}.fund-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.fund-tags{display:flex;gap:8px;flex-wrap:wrap}.tag{font-size:11px;font-weight:600;padding:2px 8px;border-radius:99px;background-color:#f3f4f6;color:var(--text-muted)}.tag-type{background-color:#e0e7ff;color:#4338ca}.fund-source{font-size:11px;color:var(--text-light)}.fund-title-group{margin-bottom:20px}.fund-name{font-size:18px;font-weight:700;color:var(--text-main);margin-bottom:4px;line-height:1.3}.fund-code{font-size:13px;color:var(--text-muted);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.fund-metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}.metric-item{display:flex;flex-direction:column;gap:4px;padding:10px;background-color:#f9fafb;border-radius:var(--radius-sm);border:1px solid var(--border-light)}.metric-label{font-size:12px;color:var(--text-muted);font-weight:500}.metric-value{font-size:16px;font-weight:700;color:var(--text-main)}.metric-value.positive{color:var(--danger)}.metric-value.negative{color:var(--success)}.kv-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;border-top:1px solid var(--border-light);padding-top:16px}.kv-item{display:flex;justify-content:space-between;font-size:13px}.kv-key{color:var(--text-muted)}.kv-val{font-weight:500;color:var(--text-main);text-align:right;max-width:60%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fund-desc{font-size:13px;color:var(--text-muted);line-height:1.6;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.fund-changes{margin-top:auto;border-top:1px solid var(--border-light);padding-top:12px}.changes-title{font-size:12px;font-weight:600;color:var(--text-main);margin-bottom:8px}.change-item{font-size:12px;color:var(--text-muted);line-height:1.5;margin-bottom:4px}.panel-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.panel-title{font-size:16px;font-weight:600;color:var(--text-main)}.panel-subtitle{font-size:13px;color:var(--text-muted);margin-top:4px}.year-range-selector{display:flex;flex:0 1 auto;max-width:min(520px,52vw);flex-wrap:wrap;justify-content:flex-end;gap:6px}.year-range-selector button{min-height:28px;border:1px solid #dbe3ee;border-radius:999px;background:#f8fafc;color:#475569;padding:4px 10px;font-size:12px;font-weight:650;line-height:1;box-shadow:inset 0 1px #ffffffd1;transition:var(--transition)}.year-range-selector button:hover{border-color:#bfdbfe;background:#eff6ff;color:#1d4ed8}.year-range-selector button.active{border-color:#2563eb;background:#2563eb;color:#fff;box-shadow:0 6px 14px #2563eb2e}.table-container{overflow-x:auto;border:1px solid var(--border-light);border-radius:var(--radius-sm)}.data-table{width:100%;min-width:800px;border-collapse:collapse;font-size:13px;text-align:right}.data-table th,.data-table td{padding:12px 16px;border-bottom:1px solid var(--border-light)}.data-table th{background-color:#f9fafb;font-weight:600;color:var(--text-muted)}.data-table th:first-child,.data-table td:first-child{text-align:left}.data-table th:nth-child(2),.data-table td:nth-child(2){text-align:left;min-width:210px}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background-color:#f9fafb}.cell-winner{color:var(--danger);font-weight:600;background-color:#fef2f2}.market-tag-list{display:flex;flex-wrap:wrap;gap:6px;max-width:280px}.market-tag{display:inline-flex;align-items:center;min-height:22px;border:1px solid #dbeafe;border-radius:999px;background-color:#eff6ff;color:#1e40af;padding:2px 8px;font-size:12px;font-weight:600;white-space:nowrap}.market-empty{color:var(--text-light);font-size:12px}.ranking-container{display:flex;flex-direction:column;gap:14px}.ranking-panel-embedded{margin-top:6px;padding-top:18px;border-top:1px solid var(--border-light)}.ranking-panel-embedded .ranking-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}.ranking-chart-group{background-color:#f9fafb;border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:12px}.ranking-chart-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.ranking-metric-name{font-size:13px;font-weight:600;color:var(--text-main)}.ranking-direction{flex:0 0 auto;color:var(--text-light);font-size:11px;font-weight:600}.ranking-bars{display:grid;gap:8px}.ranking-bar-row{display:grid;grid-template-columns:minmax(120px,1fr) minmax(96px,1.2fr) auto;align-items:center;gap:10px}.ranking-bar-meta{display:flex;min-width:0;align-items:center;gap:8px;font-size:12px}.ranking-rank{display:inline-flex;flex:0 0 auto;width:28px;height:22px;align-items:center;justify-content:center;border-radius:999px;background-color:#eef2ff;font-weight:700;color:#3730a3}.ranking-name{color:var(--text-main);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ranking-bar-track{position:relative;height:8px;overflow:hidden;border-radius:999px;background-color:#e5e7eb}.ranking-bar-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#457b9d,#2a9d8f)}.ranking-value{justify-self:end;color:var(--text-main);font-size:12px;font-weight:600;font-variant-numeric:tabular-nums}.fund-color-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 18px;margin-top:18px;padding:12px 16px;border:1px solid #e2e8f0;border-radius:var(--radius-sm);background:#f8fafceb}.fund-color-legend-item{display:inline-flex;align-items:center;gap:8px;color:#334155;font-size:13px;font-weight:500}.fund-color-legend-item i{display:inline-block;width:34px;height:14px;border-radius:4px}.ai-summary-card{margin-bottom:24px}.ai-content{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:var(--radius-sm);padding:20px;font-size:14px;line-height:1.7;color:var(--text-main)}.ai-content pre{font-family:inherit;white-space:pre-wrap;margin:0}.ai-meta{margin-top:16px;padding-top:16px;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;background-color:#f9fafb;border:1px dashed var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);font-size:14px;text-align:center}.app-footer{display:flex;flex-wrap:wrap;gap:10px 18px;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-light);padding-top:16px;border-top:1px solid var(--border-color)}.footer-links{display:inline-flex;flex-wrap:wrap;gap:10px 14px;align-items:center;justify-content:flex-end}.footer-links a{color:var(--text-muted);text-decoration:none}.footer-links a:hover{color:var(--primary)}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.floating-refresh-btn{position:fixed;bottom:22px;right:22px;width:38px;height:38px;border-radius:50%;background-color:#ffffffc7;border:1px solid rgba(203,213,225,.85);box-shadow:0 8px 20px #0f172a14;color:var(--text-muted);display:flex;align-items:center;justify-content:center;z-index:100;transition:var(--transition);opacity:.72;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.floating-refresh-btn:hover:not(:disabled){opacity:1;box-shadow:0 10px 26px #0f172a1f;color:var(--primary);border-color:#bfdbfe;transform:translateY(-1px)}.floating-refresh-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 1024px){.grid-charts-2,.grid-charts-wide{grid-template-columns:1fr}}@media (max-width: 768px){.hero-banner{min-height:320px;padding:28px 24px 76px;background-position:62% center}.hero-overlay{background:linear-gradient(90deg,#f3f4f6,#f3f4f6e0,#f3f4f64d),linear-gradient(0deg,#f3f4f6,#f3f4f6cc,#f3f4f600 30%)}.hero-banner h1{font-size:28px}.grid-cards{margin-top:-38px}.panel-header{flex-direction:column;align-items:stretch}.year-range-selector{max-width:100%;justify-content:flex-start}.floating-refresh-btn{bottom:24px;right:24px}}
