*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text: #0f172a;--text-secondary: #64748b;--text-tertiary: #94a3b8;--border: #e2e8f0;--border-strong: #cbd5e1;--accent: #2563eb;--green: #16a34a;--green-bg: #dcfce7;--red: #dc2626;--red-bg: #fee2e2}[data-theme=dark]{--bg: #0b1220;--bg-secondary: #131a2b;--bg-tertiary: #1c2438;--text: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--border: #1f2a44;--border-strong: #334155;--accent: #60a5fa;--green: #22c55e;--green-bg: #052e1a;--red: #f87171;--red-bg: #2e0a0a}html,body,#root{height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;height:100vh}.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0}.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:15px}.brand-dot{width:8px;height:8px;border-radius:50%;background:var(--green)}.topbar-right{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--text-secondary)}.theme-btn{width:32px;height:32px;border-radius:6px;border:1px solid var(--border);background:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:background .15s}.theme-btn:hover{background:var(--bg-secondary)}.theme-btn svg{width:16px;height:16px}.main{display:flex;flex:1;overflow:hidden}.sidebar{width:200px;border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--bg-secondary);flex-shrink:0;transition:width .2s ease}.sidebar-collapsed{width:44px;overflow:hidden}.sidebar-toggle{width:100%;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text-tertiary);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s;margin-top:4px}.sidebar-toggle:hover{background:var(--bg-tertiary);color:var(--text)}.sidebar-collapsed .sidebar-nav{padding:8px 4px;align-items:center}.sidebar-collapsed .sidebar-nav-tab{width:32px;height:32px;padding:0;justify-content:center}.sidebar-collapsed .sidebar-nav-label{display:none}.sidebar-collapsed .sidebar-toggle{width:32px}.search-wrap{padding:12px;border-bottom:1px solid var(--border)}.search-input{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:13px;font-family:inherit}.search-input:focus{outline:none;border-color:var(--accent)}.sidebar-meta{padding:6px 14px;font-size:11px;color:var(--text-tertiary);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.stock-list{flex:1;overflow-y:auto}.stock-row{display:grid;grid-template-columns:60px 1fr auto;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;align-items:center;transition:background .1s}.stock-row:hover{background:var(--bg-tertiary)}.stock-row.active{background:var(--bg-tertiary);border-left:3px solid var(--accent);padding-left:11px}.stock-ticker{font-weight:700;font-size:13px}.stock-name{color:var(--text-secondary);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stock-price-mini{text-align:right;font-size:12px;font-weight:600}.stock-change-mini{font-size:11px;font-weight:600;text-align:right}.up{color:var(--green)}.down{color:var(--red)}.flat{color:var(--text-tertiary)}.pane{flex:1;display:flex;flex-direction:column;overflow:hidden}.pane-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:14px}.pane-header{padding:16px 24px;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between}.pane-title h1{font-size:22px;font-weight:800;letter-spacing:-.01em}.pane-title .sub{color:var(--text-secondary);font-size:13px;margin-top:2px}.price-block{text-align:right}.price-big{font-size:24px;font-weight:700;font-variant-numeric:tabular-nums}.price-change-row{display:flex;gap:8px;justify-content:flex-end;margin-top:2px;font-size:13px;font-weight:600;font-variant-numeric:tabular-nums}.toolbar{padding:10px 24px;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:16px;align-items:center;background:var(--bg)}.toolbar-group{display:flex;gap:4px;align-items:center}.toolbar-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-right:4px}.btn{padding:6px 10px;font-size:12px;font-weight:600;border:1px solid var(--border);background:var(--bg);color:var(--text-secondary);border-radius:5px;cursor:pointer;font-family:inherit;transition:all .15s}.btn:hover{background:var(--bg-secondary);color:var(--text)}.btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.btn.toggle.active{background:var(--bg-secondary);color:var(--text);border-color:var(--border-strong)}.chart-wrap{flex:1;position:relative;overflow:hidden;padding:8px 16px 16px}.chart-host{width:100%;height:100%}.chart-loading,.chart-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:13px;gap:12px;pointer-events:none}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.info-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1px;background:var(--border);border-top:1px solid var(--border)}.info-cell{background:var(--bg);padding:10px 16px}.info-label{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.info-value{font-size:13px;font-weight:600;margin-top:2px;font-variant-numeric:tabular-nums}.error-banner{background:var(--red-bg);color:var(--red);padding:10px 16px;font-size:13px;border-radius:6px;margin:12px 16px}.pane-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0}.pane-tab{padding:10px 20px;font-size:13px;font-weight:600;font-family:inherit;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);cursor:pointer;transition:color .15s,border-color .15s}.pane-tab:hover{color:var(--text)}.pane-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-secondary);text-align:center;padding:40px}.tab-empty-icon{font-size:40px;margin-bottom:8px}.tab-empty-title{font-size:16px;font-weight:700}.tab-empty-sub{font-size:13px;color:var(--text-tertiary)}.div-tab-wrap{flex:1;overflow-y:auto;background:var(--bg-secondary)}.div-root{padding:0 0 24px}.div-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:200px;color:var(--text-tertiary);font-size:13px}.div-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;height:240px;color:var(--text-secondary);font-size:14px;text-align:center;padding:24px}.div-empty-icon{font-size:40px;margin-bottom:8px}.div-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1px;background:var(--border);border-bottom:1px solid var(--border)}.div-metric{background:var(--bg);padding:14px 20px}.div-metric-label{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.div-metric-value{font-size:20px;font-weight:700;margin-top:4px;font-variant-numeric:tabular-nums}.div-metric-sub{font-size:11px;color:var(--text-tertiary);margin-top:2px}.div-section{padding:16px 24px 8px}.div-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:10px;display:flex;align-items:center;gap:12px}.div-legend{display:flex;align-items:center;gap:6px;font-size:11px;text-transform:none;letter-spacing:normal;font-weight:500;color:var(--text-tertiary)}.div-legend-dot{display:inline-block;width:8px;height:8px;border-radius:2px;margin-left:6px}.div-barchart-wrap{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:6px;overflow:hidden;padding:8px 0 4px}.div-table-wrap{background:var(--bg);border:1px solid var(--border);border-radius:6px;overflow:hidden}.div-table-scroll{max-height:260px;overflow-y:auto}.div-table{width:100%;border-collapse:collapse;font-size:13px;font-variant-numeric:tabular-nums}.div-table thead th{position:sticky;top:0;background:var(--bg-secondary);padding:8px 16px;font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);font-weight:600;border-bottom:1px solid var(--border);text-align:left}.div-table thead th.num{text-align:right}.div-table tbody td{padding:8px 16px;border-bottom:1px solid var(--border);color:var(--text)}.div-table tbody tr:last-child td{border-bottom:none}.div-table tbody tr:hover td{background:var(--bg-secondary)}.div-table td.num{text-align:right}.div-table td.bold{font-weight:700}.div-footer{padding:12px 24px 0;font-size:11px;color:var(--text-tertiary);border-top:1px solid var(--border);margin:16px 0 0}.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:8px 6px;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0}.sidebar-nav-tab{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;border:1px solid transparent;background:none;color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;transition:all .15s;white-space:nowrap;text-align:left;width:100%}.sidebar-nav-tab:hover{background:var(--bg-tertiary);color:var(--text)}.sidebar-nav-tab.active{background:var(--bg-tertiary);color:var(--accent);border-color:var(--border)}.sidebar-nav-icon{font-size:15px;flex-shrink:0}.sidebar-nav-label{font-size:12px}.sidebar-rank-hint{padding:20px 16px;font-size:13px;font-weight:600;color:var(--text-secondary);text-align:center}.rank-pane{overflow-y:auto}.rank-view{min-height:100%;display:flex;flex-direction:column}.rank-header{display:flex;flex-wrap:wrap;gap:20px;align-items:flex-start;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border);background:var(--bg)}.rank-title{font-size:20px;font-weight:800;letter-spacing:-.01em}.rank-subtitle{font-size:13px;color:var(--text-secondary);margin-top:4px;max-width:480px}.rank-meta-pills{display:flex;gap:12px;flex-wrap:wrap}.rank-pill{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:8px 14px;min-width:90px;text-align:center}.rank-pill-label{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);font-weight:600}.rank-pill-value{font-size:16px;font-weight:700;margin-top:2px;font-variant-numeric:tabular-nums}.rank-section{padding:16px 24px 8px}.rank-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:10px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.rank-table-wrap{background:var(--bg);border:1px solid var(--border);border-radius:6px;overflow:auto;max-height:560px}.rank-table{width:100%;border-collapse:collapse;font-size:12px;white-space:nowrap}.rank-th{position:sticky;top:0;background:var(--bg-secondary);padding:8px 12px;font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);font-weight:700;border-bottom:1px solid var(--border);text-align:right;z-index:1}.rank-th.left{text-align:left}.rank-th.num{text-align:right}.rank-row{cursor:pointer;border-bottom:1px solid var(--border)}.rank-row:hover td{background:var(--bg-secondary)}.rank-row-open td{background:var(--bg-tertiary)}.rank-row-detail td{background:var(--bg-secondary);border-bottom:1px solid var(--border)}.rank-td{padding:8px 12px;color:var(--text);text-align:right;font-variant-numeric:tabular-nums}.rank-td.num{text-align:right}.rank-td.bold{font-weight:700}.rank-td.muted{color:var(--text-tertiary)}.rank-td.accent{color:var(--accent)}.rank-td.name-cell{text-align:left;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary)}.up.strong{color:var(--green);font-weight:700}.co-score-bar-wrap{display:flex;align-items:center;gap:8px}.co-score-bar-track{flex:1;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden;min-width:60px}.co-score-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.co-score-num{font-size:12px;font-weight:700;width:28px;text-align:right;font-variant-numeric:tabular-nums}.co-detail-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);margin-bottom:10px;padding-top:8px}.co-score-detail{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:6px 24px}.co-score-detail-row{display:flex;align-items:center;gap:8px}.co-score-detail-label{font-size:11px;color:var(--text-secondary);width:130px;flex-shrink:0}.co-score-detail-bar-wrap{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.co-score-detail-bar{height:100%;border-radius:3px}.co-score-detail-num{font-size:11px;font-weight:600;color:var(--text-secondary);width:36px;text-align:right;flex-shrink:0}.co-legend-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:6px;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:12px 16px}.co-legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.co-legend-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}.rank-no-data{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:60px 40px;text-align:center}.rank-no-data-title{font-size:16px;font-weight:700}.rank-no-data-sub{font-size:13px;color:var(--text-tertiary);line-height:1.6}@media (max-width: 768px){.sidebar{width:100%;height:50%}.main{flex-direction:column}.pane-header{padding:12px 16px}.toolbar{padding:8px 12px;gap:8px}.price-big{font-size:20px}}.fin-root{padding:0 0 24px}.fin-top{display:flex;gap:24px;padding:16px 24px;border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:flex-start}.fin-score{display:flex;gap:16px;align-items:flex-start;flex-shrink:0}.fin-score-badge{border:2px solid;border-radius:10px;padding:10px 16px;text-align:center;min-width:80px}.fin-score-label{font-size:10px;text-transform:uppercase;letter-spacing:.06em;font-weight:600;color:var(--text-tertiary);margin-bottom:4px}.fin-score-value{font-size:18px;font-weight:800}.fin-score-reasons{display:flex;flex-direction:column;gap:4px;justify-content:center}.fin-score-reason{font-size:11px;font-weight:500}.fin-range-section{flex:1;min-width:200px}.fin-range-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:10px}.fin-range-wrap{display:flex;align-items:center;gap:10px}.fin-range-end{font-size:11px;color:var(--text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap}.fin-range-track{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;position:relative}.fin-range-fill{position:absolute;left:0;top:0;height:100%;background:var(--accent);border-radius:3px;opacity:.4}.fin-range-dot{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:var(--accent);border-radius:50%;border:2px solid var(--bg)}.fin-range-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--text-tertiary);margin-top:6px}.fin-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 1px;background:var(--border);margin:0}.fin-col{background:var(--bg-secondary);display:flex;flex-direction:column;gap:1px}.fin-table{width:100%;border-collapse:collapse;background:var(--bg)}.fin-section-header td{padding:8px 16px 6px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--text-tertiary);background:var(--bg-secondary);border-top:1px solid var(--border)}.fin-row:hover td{background:var(--bg-tertiary)}.fin-label{padding:7px 16px;font-size:13px;color:var(--text-secondary);border-bottom:1px solid var(--border);width:55%}.fin-value{padding:7px 16px;font-size:13px;font-weight:600;text-align:right;font-variant-numeric:tabular-nums;border-bottom:1px solid var(--border)}.fin-value-sub{font-size:10px;color:var(--text-tertiary);font-weight:400;margin-left:4px}@media (max-width: 900px){.fin-grid{grid-template-columns:1fr}.fin-top{flex-direction:column;gap:16px}}
