:root{--bg:#0a0f18;--panel:#0f1724;--panel-2:#121d2d;--line:#314055;--line-soft:#253244;--ink:#f5f8fc;--muted:#b4bfce;--accent:#38bdf8;--accent-soft:#16344b;--green:#22c55e;--red:#ef4444}*{box-sizing:border-box}body{color:var(--ink);background:radial-gradient(900px 520px at 52% -18%,#38bdf81a,#0000 62%),linear-gradient(#0c111b 0%,#080c14 100%);margin:0;font-family:IBM Plex Sans,Segoe UI,Avenir Next,sans-serif}button{font:inherit}.page{min-height:100vh;padding:14px 20px 24px}.app-header,.panel{border:1px solid var(--line);background:linear-gradient(145deg,#131d2bf5,#0d1421fa);box-shadow:0 10px 28px #00000038,inset 0 1px #ffffff0d}.app-header{border-radius:10px;align-items:center;gap:16px;width:min(1480px,100%);height:64px;margin:0 auto 22px;padding:0 18px;display:flex}.brand-mark{width:38px;height:38px;color:var(--accent);background:#111827;border:1px solid #2f4158;border-radius:50%;place-items:center;font-size:24px;font-weight:800;display:grid}.app-header h1{letter-spacing:0;margin:0;font-size:24px;font-weight:620}.dashboard{grid-template-columns:minmax(0,1fr) minmax(360px,.42fr);gap:16px;width:min(1480px,100%);margin:0 auto;display:grid}.panel{border-radius:10px;padding:18px}.muted{color:var(--muted)}h2{letter-spacing:0;margin:0;font-size:22px;font-weight:600}.chart-card{grid-column:1/-1;min-height:min(72vh,720px)}.section-head{justify-content:space-between;align-items:center;gap:16px;display:flex}.timeframe{border:1px solid var(--line-soft);background:#080c14bd;border-radius:7px;padding:1px;display:flex}.timeframe button{border:0;border-left:1px solid var(--line-soft);color:#c5d0df;background:0 0;min-width:36px;padding:5px 8px;font-size:13px;line-height:1.1}.timeframe button:first-child{border-left:0}.timeframe .active{color:#fff;background:var(--accent-soft);border-radius:5px;box-shadow:inset 0 0 0 1px #38bdf857}.chart-subtitle{margin:5px 0 0;font-size:14px}.chart-meta{color:#c4d0df;justify-content:space-between;gap:14px;margin:14px 0 8px;font-size:14px;display:flex}.chart-host{width:100%;height:min(72vh,720px);min-height:560px}.chart-wrap{position:relative}.tv-legend{z-index:3;pointer-events:none;color:#d6dfeb;flex-wrap:wrap;align-items:center;gap:8px 12px;min-height:28px;font-family:IBM Plex Mono,SF Mono,Consolas,monospace;font-size:13px;display:flex;position:absolute;top:8px;left:10px;right:10px}.tv-symbol{color:#f3f7fd;font-family:IBM Plex Sans,Segoe UI,sans-serif;font-size:17px;font-weight:560}.tv-time{color:#8ea1b9}.tv-ohlc{color:#9fb2c9}.tv-ohlc b{color:#e9f2ff;font-weight:620}.loading{width:min(1480px,100%);color:var(--muted);margin:7rem auto}@media (width<=1100px){.dashboard{grid-template-columns:1fr}}@media (width<=680px){.page{padding:10px}.app-header{height:58px}.panel{padding:14px}.section-head,.chart-meta{flex-direction:column;align-items:flex-start}.timeframe{width:100%;overflow-x:auto}}html,body,#root{min-height:100%;margin:0}
