:root{--background:#f7f8f7;--surface:#fff;--surface-muted:#f1f4f2;--surface-strong:#e7eee9;--border:#d9dfdc;--border-strong:#b9c4bf;--text:#17201c;--muted:#66736e;--muted-strong:#43504b;--accent:#158074;--accent-strong:#0f5f57;--positive:#168a4a;--negative:#c9463a;--warning:#a96d10;--shadow:0 14px 38px #17201c14;--radius:8px}*{box-sizing:border-box}html,body{min-height:100%}body{background:var(--background);color:var(--text);letter-spacing:0;margin:0;font-family:Arial,Helvetica,sans-serif}button,input{font:inherit}a{color:inherit;text-decoration:none}.app-shell{grid-template-columns:286px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--border);background:var(--surface);flex-direction:column;gap:18px;height:100vh;padding:22px 18px;display:flex;position:sticky;top:0}.brand-row{align-items:center;gap:12px;display:flex}.brand-mark{border:1px solid var(--border-strong);border-radius:var(--radius);block-size:38px;inline-size:38px;color:var(--accent-strong);background:#e8f3ef;place-items:center;font-weight:800;display:grid}.brand-row strong,.brand-row span{display:block}.brand-row strong{font-size:17px}.brand-row span{color:var(--muted);font-size:12px}.sidebar-search{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-muted);align-items:center;gap:9px;min-height:38px;padding:0 11px;display:flex}.sidebar-search svg{inline-size:16px;color:var(--muted)}.sidebar-search input{width:100%;color:var(--text);background:0 0;border:0;outline:0;font-size:13px}.add-ticker{grid-template-columns:minmax(0,1fr) 38px;gap:8px;display:grid}.add-ticker input{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-muted);min-width:0;min-height:38px;color:var(--text);outline:0;padding:0 10px;font-size:13px}.add-ticker button{border:1px solid var(--border);border-radius:var(--radius);background:var(--accent);color:#fff;cursor:pointer;place-items:center;min-height:38px;display:grid}.add-ticker button:disabled{cursor:progress;opacity:.6}.add-ticker svg{inline-size:17px}.watchlist-header,.sidebar-footer{color:var(--muted-strong);text-transform:uppercase;justify-content:space-between;align-items:center;font-size:12px;font-weight:700;display:flex}.watchlist{flex-direction:column;flex:1;gap:2px;display:flex;overflow:auto}.watchlist-group{flex-direction:column;gap:6px;display:flex}.watchlist-group+.watchlist-group{margin-top:14px}.watchlist-group-header{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:6px;padding:0 4px;font-size:11px;font-weight:700;display:flex}.watchlist-group-header:after{content:"";background:var(--border);flex:1;height:1px}.watch-row{border-radius:var(--radius);border:1px solid #0000;grid-template-columns:minmax(0,1fr) 28px;gap:0;display:grid}.watch-row:hover,.watch-row.selected{border-color:var(--border-strong);background:var(--surface-muted)}.watch-row-main{border-radius:var(--radius);width:100%;min-height:62px;color:var(--text);cursor:pointer;text-align:left;font:inherit;background:0 0;border:0;grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:10px 8px 10px 12px;display:grid}.watch-row.selected .watch-row-main{font-weight:600}.watch-row-main strong,.watch-row-main small,.watch-row-main em{display:block}.watch-row-main small{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;line-height:1.35;overflow:hidden}.watch-remove{border-radius:0 var(--radius) var(--radius) 0;width:28px;min-height:62px;color:var(--muted);cursor:pointer;opacity:0;font:inherit;background:0 0;border:0;place-items:center;padding:0;display:grid}.watch-row:hover .watch-remove,.watch-row.selected .watch-remove{opacity:1}.watch-remove:hover{color:var(--negative);background:color-mix(in srgb, var(--negative) 10%, transparent)}.watch-remove svg{inline-size:14px}.watch-price{flex-direction:column;align-items:flex-end;gap:6px;font-size:12px;font-weight:700;display:flex}.watch-price em{align-items:center;gap:2px;font-size:12px;font-style:normal;display:flex}.watch-price svg{inline-size:14px}.watch-empty{border:1px dashed var(--border);border-radius:var(--radius);min-height:96px;color:var(--muted);place-items:center;font-size:13px;display:grid}.sidebar-footer{text-transform:none;justify-content:flex-start;gap:8px}.sidebar-footer svg{inline-size:16px}.workspace{flex-direction:column;gap:18px;padding:22px;display:flex}.topbar{justify-content:space-between;align-items:center;gap:16px;min-height:58px;display:flex}.topbar h1{margin:0;font-size:30px;line-height:1}.topbar span{color:var(--muted);font-size:13px}.topbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.model-chip,.cost-chip{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);min-height:34px;color:var(--muted-strong);align-items:center;gap:7px;padding:0 10px;font-size:12px;font-weight:700;display:inline-flex}.model-chip svg,.cost-chip svg{inline-size:16px;color:var(--accent)}.profile-selector{border:1px solid var(--border);border-radius:var(--radius);display:inline-flex;overflow:hidden}.profile-selector button{min-height:34px;color:var(--muted);cursor:pointer;font-size:12px;font-weight:600;font:inherit;background:0 0;border:0;place-items:center;padding:0 10px;transition:background .15s,color .15s;display:grid}.profile-selector button.active{background:var(--accent);color:#fff}.profile-selector button:not(.active):hover{background:var(--surface-muted);color:var(--text)}.hero-grid,.main-grid,.lower-grid{gap:18px;display:grid}.hero-grid{grid-template-columns:minmax(0,1.4fr) minmax(320px,.8fr)}.main-grid{grid-template-columns:minmax(0,1.45fr) minmax(360px,.8fr)}.lower-grid{grid-template-columns:.85fr .9fr 1.2fr;align-items:start}.panel{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);min-width:0;box-shadow:var(--shadow)}.panel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;min-height:52px;padding:15px 16px;display:flex}.panel-header h2{margin:0;font-size:15px}.panel-kicker{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:700;display:block}.settings-panel{padding:12px}.settings-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.snapshot-panel{padding:18px}.snapshot-head{justify-content:space-between;gap:14px;display:flex}.snapshot-head h2{margin:6px 0 0;font-size:34px}.snapshot-panel p,.analysis-summary{color:var(--muted-strong);margin:14px 0 0;font-size:14px;line-height:1.55}.analysis-summary p{margin:0 0 10px}.analysis-summary p:last-child{margin-bottom:0}.analysis-summary strong{color:var(--text);font-weight:700}.analysis-summary ul,.analysis-summary ol{margin:6px 0 10px;padding-left:20px}.analysis-summary li{margin-bottom:4px}.analysis-summary h1,.analysis-summary h2,.analysis-summary h3{color:var(--text);margin:14px 0 6px;font-weight:700}.analysis-summary h1{font-size:16px}.analysis-summary h2{font-size:15px}.analysis-summary h3{font-size:14px}.metric-strip{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:17px;display:grid}.zones{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-top:17px;display:grid}.metric{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-muted);flex-direction:column;gap:4px;min-width:0;padding:10px;display:flex}.metric span{color:var(--muted);font-size:11px;font-weight:700}.metric strong{overflow-wrap:break-word;word-break:normal;font-size:13px}.signal-panel{flex-direction:column;display:flex}.signal-body{gap:12px;padding:16px;display:flex}.signal-body svg{inline-size:22px;color:var(--accent);flex:none}.signal-body h3{margin:0 0 7px;font-size:16px}.signal-body p,.risk-row p,.trend-row p{color:var(--muted-strong);margin:0;font-size:13px;line-height:1.45}.zones{margin:auto 16px 16px}.chart-panel{padding-bottom:16px}.chart-wrap{padding:10px 16px 0;position:relative}.chart-wrap svg{border:1px solid var(--border);border-radius:var(--radius);background:linear-gradient(#fbfcfb 0%,#f4f7f5 100%);width:100%;height:auto;display:block}.chart-empty{border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface-muted);min-height:260px;color:var(--muted);text-align:center;place-items:center;margin:10px 16px 0;font-size:13px;display:grid}.chart-grid{stroke:#e4e9e6;stroke-width:1px}.chart-line{stroke:var(--accent);stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.chart-hover-line{stroke:var(--muted);stroke-width:1px;stroke-dasharray:4 3}.chart-hover-dot{fill:var(--accent);stroke:#fff;stroke-width:2px}.chart-tooltip{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);pointer-events:none;z-index:10;flex-direction:column;gap:3px;min-width:90px;padding:8px 11px;font-size:12px;display:flex;position:absolute;top:10px;transform:translate(-50%);box-shadow:0 2px 8px #00000014}.chart-tooltip-date{color:var(--muted);margin-bottom:2px;font-size:11px;font-weight:600}.chart-tooltip-row{justify-content:space-between;gap:14px;display:flex}.chart-tooltip-row span{color:var(--muted);font-weight:600}.chart-tooltip-row strong{color:var(--text);font-weight:700}.chart-tooltip-vol{border-top:1px solid var(--border);margin-top:2px;padding-top:3px}.chart-meta{color:var(--muted);justify-content:space-between;margin-top:9px;font-size:12px;display:flex}.analysis-summary{padding:0 16px}.analysis-header{align-items:center;gap:8px;padding:8px 16px 0;display:flex}.analysis-date{color:var(--muted);font-size:11px;font-weight:600}.analysis-model{background:var(--surface-muted);color:var(--muted);border-radius:4px;padding:1px 6px;font-size:10px;font-weight:600}.analysis-badge{text-transform:uppercase;border-radius:4px;padding:1px 6px;font-size:10px;font-weight:700}.analysis-badge.history{color:#856404;background:#fff3cd}.trend-list,.fundamentals,.risk-list,.feed-list{flex-direction:column;display:flex}.trend-row{border-bottom:1px solid var(--border);grid-template-columns:58px minmax(0,1fr);gap:13px;padding:16px;display:grid}.trend-row:last-child,.fund-row:last-child,.risk-row:last-child{border-bottom:0}.trend-row strong,.trend-row em{display:inline-block}.trend-row em{color:var(--accent-strong);margin-left:8px;font-size:12px;font-style:normal;font-weight:700}.score-ring{background:conic-gradient(var(--accent) var(--score), var(--surface-strong) 0);border-radius:999px;place-items:center;block-size:48px;inline-size:48px;display:grid}.score-ring span{background:var(--surface);border-radius:999px;place-items:center;block-size:36px;inline-size:36px;font-size:12px;font-weight:800;display:grid}.driver-list{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.fund-row{border-bottom:1px solid var(--border);grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:12px;min-height:48px;padding:0 16px;font-size:13px;display:grid}.fund-row span{color:var(--muted-strong)}.fund-row em{font-style:normal;font-weight:800}.risk-row,.feed-row{border-bottom:1px solid var(--border);gap:11px;padding:14px 16px;display:flex}.risk-row svg,.feed-row svg,.panel-icon{inline-size:18px;color:var(--warning);flex:none}.risk-row strong,.risk-row span,.feed-row strong,.feed-row small,.feed-row em{display:block}.risk-row span,.feed-row small{color:var(--muted);margin-top:3px;font-size:12px}.risk-row p,.feed-row em{color:var(--muted-strong);margin-top:7px;font-size:13px;font-style:normal;line-height:1.42}.feed-row:hover{background:var(--surface-muted)}.segmented{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-muted);padding:3px;display:inline-flex}.segmented button{min-height:26px;color:var(--muted-strong);cursor:pointer;background:0 0;border:0;border-radius:6px;padding:0 9px;font-size:12px;font-weight:800}.segmented .active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px #17201c1a}.badge{border:1px solid var(--border);white-space:nowrap;border-radius:999px;align-items:center;min-height:24px;padding:0 8px;font-size:12px;font-weight:800;display:inline-flex}.badge-neutral{background:var(--surface-muted);color:var(--muted-strong)}.badge-positive{color:var(--positive);background:#168a4a14;border-color:#168a4a3d}.badge-negative{color:var(--negative);background:#c9463a14;border-color:#c9463a3d}.badge-warning{color:var(--warning);background:#a96d101a;border-color:#a96d103d}.badge-accent{color:var(--accent-strong);background:#1580741a;border-color:#1580743d}.button{border-radius:var(--radius);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:7px;min-height:34px;padding:0 12px;font-size:13px;font-weight:800;display:inline-flex}.button svg{inline-size:15px}.button-primary{background:var(--accent);color:#fff}.button-secondary{border-color:var(--border);background:var(--surface);color:var(--text)}.button-ghost{color:var(--muted-strong);background:0 0}.positive{color:var(--positive)}.negative{color:var(--negative)}.empty-workspace{text-align:center;place-items:center;gap:18px;min-height:380px;padding:40px;display:grid}.empty-workspace h1{margin:10px 0 6px;font-size:22px}.empty-workspace p{color:var(--muted-strong);max-width:420px;margin:0;font-size:14px;line-height:1.5}.empty-workspace-meta{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:8px;display:flex}@media (max-width:1180px){.app-shell{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid var(--border);height:auto;position:relative}.watchlist{flex-direction:column;gap:2px;display:flex}.hero-grid,.main-grid,.lower-grid{grid-template-columns:1fr}}@media (max-width:760px){.workspace,.sidebar{padding:14px}.topbar{flex-direction:column;align-items:flex-start}.topbar-actions{grid-template-columns:repeat(2,minmax(0,1fr));justify-content:stretch;width:100%;display:grid}.topbar-actions>*,.topbar-actions>.button{width:100%}.topbar-actions>.cost-chip,.topbar-actions .profile-selector,.topbar-actions>.button:last-child{grid-column:1/-1}.topbar-actions .profile-selector{grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.watchlist,.metric-strip,.zones,.settings-grid{grid-template-columns:1fr}.snapshot-head{flex-direction:column;align-items:flex-start}.snapshot-head h2{font-size:28px}.fund-row{grid-template-columns:1fr;gap:4px;padding-block:10px}}.history-panel{flex-direction:column;max-height:400px;display:flex;overflow:hidden}.history-header{color:var(--muted-strong);text-transform:uppercase;justify-content:space-between;align-items:center;padding:0 0 10px;font-size:12px;font-weight:700;display:flex}.history-clear{color:var(--accent);cursor:pointer;text-transform:none;font-size:12px;font-weight:600;font:inherit;background:0 0;border:0}.history-clear:hover{text-decoration:underline}.history-empty{min-height:80px;color:var(--muted);place-items:center;font-size:13px;display:grid}.history-list{flex-direction:column;gap:6px;display:flex;overflow:auto}.history-row{border-radius:var(--radius);width:100%;color:var(--text);cursor:pointer;text-align:left;font:inherit;background:0 0;border:1px solid #0000;flex-direction:column;gap:3px;padding:10px 12px;display:flex}.history-row:hover,.history-row.selected{border-color:var(--border-strong);background:var(--surface-muted)}.history-row-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.history-date{font-size:12px;font-weight:600}.history-profile{background:var(--surface);color:var(--muted-strong);text-transform:uppercase;border-radius:4px;padding:1px 6px;font-size:11px;font-weight:600}.history-model{color:var(--muted);font-size:11px}.history-preview{color:var(--muted);font-size:12px;line-height:1.4}
