:root{color-scheme:light;font-family:Microsoft YaHei,PingFang SC,Noto Sans CJK SC,Source Han Sans SC,Arial,sans-serif;background:#f6f8f7;color:#15201f;--bg: #f6f8f7;--panel: #ffffff;--panel-soft: #f9fbfa;--text: #15201f;--muted: #64706c;--subtle: #87908c;--border: #d9e2de;--border-strong: #c0cfca;--teal: #0f766e;--teal-soft: #e7f4f1;--amber: #b98413;--amber-soft: #fff5db;--red: #c2413a;--red-soft: #fff0ee;--green: #168252;--green-soft: #e9f7ef;--shadow: 0 18px 45px rgba(29, 47, 43, .08)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#0f766e0d,#f6f8f700 360px),var(--bg)}button,table{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:248px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:22px;padding:22px 16px;border-right:1px solid var(--border);background:#ffffffd1;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand{display:flex;align-items:center;gap:12px;padding:8px 8px 18px;border-bottom:1px solid var(--border)}.brand-mark{display:grid;width:42px;height:42px;place-items:center;border-radius:8px;background:#102b2a;color:#d7f4ec;font-size:20px;font-weight:800;box-shadow:inset 0 -10px 18px #10766e73}.brand strong{display:block;font-size:17px;line-height:1.2}.brand small{display:block;margin-top:4px;color:var(--muted);font-size:12px}.nav-list{display:grid;gap:5px}.nav-item{display:flex;align-items:center;gap:10px;min-height:40px;padding:0 11px;border-radius:8px;color:#3d4a47;text-decoration:none;font-size:14px}.nav-item:hover,.nav-item.active{background:var(--teal-soft);color:#0a5f58}.sidebar-note{margin-top:auto;display:flex;align-items:flex-start;gap:9px;padding:12px;border:1px solid var(--border);border-radius:8px;color:var(--muted);background:var(--panel-soft);font-size:12px;line-height:1.55}.workspace{min-width:0;padding:22px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px}.topbar h1{margin:0;font-size:28px;line-height:1.15;letter-spacing:0}.topbar p{margin:7px 0 0;color:var(--muted);font-size:14px}.topbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.status-dot{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 5px var(--green-soft)}.status-dot.warning{background:var(--amber);box-shadow:0 0 0 5px var(--amber-soft)}.timestamp{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 11px;border:1px solid var(--border);border-radius:8px;color:var(--muted);background:var(--panel);font-size:13px;white-space:nowrap}.icon-button,.refresh-button,.account-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:36px;border:1px solid var(--border);border-radius:8px;color:var(--text);background:var(--panel)}.icon-button{width:36px;padding:0}.refresh-button,.account-button{min-width:82px;padding:0 12px;font-size:14px}.refresh-button{border-color:#9bd2ca;color:#075f57;background:var(--teal-soft)}.account-menu-wrap{position:relative}.account-button.signed-in{border-color:#9bd2ca;color:#075f57;background:#fff}.account-panel{position:absolute;top:44px;right:0;z-index:30;width:min(360px,calc(100vw - 28px));padding:14px;border:1px solid var(--border);border-radius:8px;background:#fffffffa;box-shadow:0 24px 70px #1d2f2b2e}.account-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.account-panel-header strong,.current-account strong{display:block;color:var(--text);font-size:15px}.account-panel-header span,.current-account span,.section-label{display:block;margin-top:3px;color:var(--muted);font-size:12px}.panel-close{display:grid;width:28px;height:28px;place-items:center;border:1px solid var(--border);border-radius:8px;color:var(--muted);background:var(--panel-soft);font-size:18px;line-height:1}.current-account,.remembered-user,.secondary-action,.login-submit,.text-action,.switch-user-button{display:inline-flex;align-items:center}.current-account{width:100%;gap:10px;padding:10px;margin-bottom:12px;border:1px solid var(--border);border-radius:8px;background:var(--panel-soft)}.user-avatar{display:grid;width:44px;height:44px;place-items:center;flex:0 0 auto;border-radius:8px;color:#e7f4f1;background:#102b2a;font-weight:800}.user-avatar.small{width:34px;height:34px;font-size:14px}.user-avatar.mini{width:26px;height:26px;font-size:12px}.remembered-users{display:grid;gap:7px;margin-bottom:12px}.remembered-user{width:100%;min-height:38px;gap:9px;padding:6px 9px;border:1px solid var(--border);border-radius:8px;color:var(--text);background:#fff;text-align:left}.remembered-user span:nth-child(2){min-width:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.remembered-user.selected{border-color:#9bd2ca;color:#075f57;background:var(--teal-soft);cursor:default}.login-form{display:grid;gap:10px}.auth-tabs{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;padding:4px;border:1px solid var(--border);border-radius:8px;background:#f4f7f6}.auth-tabs button{min-height:32px;border:0;border-radius:6px;color:var(--muted);background:transparent;font-size:13px;font-weight:800}.auth-tabs button.selected{color:#0a625b;background:#fff;box-shadow:0 4px 12px #0f766e1f}.login-form label{display:grid;gap:6px;color:var(--muted);font-size:12px}.login-form input[type=text],.login-form input[type=password],.login-form input:not([type]){width:100%;min-height:38px;padding:0 10px;border:1px solid var(--border);border-radius:8px;color:var(--text);background:#fff;outline:none}.login-form input:focus{border-color:#78bdb4;box-shadow:0 0 0 3px #0f766e1f}.remember-toggle{display:flex!important;grid-template-columns:none;align-items:center;gap:8px!important;color:var(--text)!important}.remember-toggle input{width:16px;height:16px;accent-color:var(--teal)}.form-message{padding:9px 10px;border:1px solid #f0cf92;border-radius:8px;color:#72500a;background:#fff8e7;font-size:12px}.login-submit,.secondary-action,.switch-user-button{justify-content:center;gap:7px;min-height:38px;border:1px solid #9bd2ca;border-radius:8px;color:#075f57;background:var(--teal-soft);font-weight:800}.login-submit:disabled{cursor:wait;opacity:.72}.secondary-action{width:100%;margin-bottom:10px;color:var(--text);border-color:var(--border);background:var(--panel-soft)}.account-panel-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}.text-action{gap:5px;padding:0;border:0;color:var(--muted);background:transparent;font-size:12px}.text-action.danger{color:var(--red)}.refresh-button:disabled{cursor:wait;opacity:.75}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.alert{margin-bottom:14px;padding:12px 14px;border:1px solid #f0cf92;border-radius:8px;color:#72500a;background:#fff8e7;font-size:14px}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(340px,.75fr);gap:14px;align-items:start}.metric-strip{grid-column:1 / -1;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.user-home{grid-column:1 / -1;display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:14px;min-height:96px;padding:16px;border:1px solid var(--border);border-radius:8px;background:linear-gradient(90deg,#0f766e1a,#fff5db8c),#fff;box-shadow:var(--shadow)}.user-home-main{display:flex;align-items:center;min-width:0;gap:12px}.user-home h2{margin:0;font-size:20px;line-height:1.2;letter-spacing:0}.user-home p{margin:6px 0 0;color:var(--muted);font-size:13px}.user-home-stats{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.user-home-stats span{display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:0 9px;border:1px solid var(--border);border-radius:8px;color:#40504c;background:#ffffffb8;font-size:12px;white-space:nowrap}.switch-user-button{padding:0 12px;white-space:nowrap}.metric-card,.panel{border:1px solid var(--border);border-radius:8px;background:#ffffffeb;box-shadow:var(--shadow)}.metric-card{min-height:108px;padding:16px;display:grid;align-content:space-between}.metric-card span{color:var(--muted);font-size:13px}.metric-card strong{margin-top:8px;font-size:24px;line-height:1.15;letter-spacing:0}.metric-card em{margin-top:8px;font-style:normal;font-size:13px;font-weight:700}.up{color:var(--red)}.down{color:var(--green)}.panel{min-width:0;padding:16px}.panel-wide,.panel-source{grid-column:1 / -1}.panel-tall{min-height:450px}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.panel-title{display:flex;align-items:flex-start;gap:10px}.panel-icon{display:grid;width:34px;height:34px;place-items:center;flex:0 0 auto;border-radius:8px;color:#0a625b;background:var(--teal-soft)}.panel h2{margin:0;font-size:17px;line-height:1.25;letter-spacing:0}.panel p{margin:4px 0 0;color:var(--muted);font-size:12px;line-height:1.55}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:8px}.data-table{width:100%;min-width:980px;border-collapse:collapse;table-layout:fixed;font-size:13px}.data-table th,.data-table td{padding:11px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}.data-table th{color:var(--muted);background:#f3f7f5;font-weight:700;white-space:nowrap}.data-table th:first-child,.data-table td:first-child{width:58px}.data-table th:nth-child(2),.data-table td:nth-child(2){width:120px}.data-table th:nth-child(3),.data-table td:nth-child(3){width:110px}.data-table th:nth-child(4),.data-table td:nth-child(4){width:160px}.data-table th:nth-child(5),.data-table td:nth-child(5){width:120px}.data-table tr:last-child td{border-bottom:0}.rank-pill{display:grid;width:28px;height:28px;place-items:center;border-radius:8px;color:#0d5e57;background:var(--teal-soft);font-weight:800}.company-name{font-weight:800}.reason-cell{color:#40504c;line-height:1.55}.segmented{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:4px;margin-bottom:12px;border:1px solid var(--border);border-radius:8px;background:#f4f7f6}.segmented button{height:32px;border:0;border-radius:6px;color:var(--muted);background:transparent;font-size:13px;font-weight:700}.segmented button.selected{color:#0a625b;background:#fff;box-shadow:0 4px 12px #0f766e1f}.rank-list,.theme-list{display:grid;gap:10px}.rank-row{display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;padding:11px;border:1px solid var(--border);border-radius:8px;background:var(--panel-soft)}.rank-number{display:grid;width:30px;height:30px;place-items:center;border-radius:8px;color:#805b05;background:var(--amber-soft);font-weight:800}.rank-line,.spot-topline{display:flex;align-items:center;justify-content:space-between;gap:10px}.rank-line strong,.spot-topline strong,.theme-row strong{font-size:15px}.rank-row small,.spot-item small{display:block;margin-top:7px;color:#44534f;font-size:12px;line-height:1.55}.delta{flex:0 0 auto;font-size:13px;font-weight:800}.theme-row{display:flex;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--panel-soft)}.theme-row p{margin-top:8px;color:#40504c}.type-chip{display:inline-flex;align-items:center;height:22px;margin-right:8px;padding:0 8px;border-radius:7px;color:#0a625b;background:var(--teal-soft);font-size:12px;font-weight:800}.gold-badge{display:inline-flex;align-items:center;gap:8px;min-height:34px;padding:0 10px;border-radius:8px;color:#7d5a08;background:var(--amber-soft);font-size:13px;font-weight:800;white-space:nowrap}.gold-badge em{font-style:normal}.gold-chart{width:100%;height:360px;border:1px solid var(--border);border-radius:8px;background:linear-gradient(180deg,#fff,#fbfcfb);overflow:hidden}.gold-chart svg{display:block;width:100%;height:100%}.grid-line{stroke:#e6ece9;stroke-width:1}.close-area{fill:url(#chartFill)}.close-line{fill:none;stroke:#9a6d0d;stroke-width:1.8}.wick{stroke-width:1.5}.candle.up,.wick.up{fill:var(--red);stroke:var(--red)}.candle.down,.wick.down{fill:var(--green);stroke:var(--green)}.axis-label,.date-label{fill:var(--subtle);font-size:11px}.spot-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.spot-column{display:grid;gap:10px}.spot-column h3{margin:0;color:#253431;font-size:14px}.spot-item{padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--panel-soft)}.source-list{display:grid;gap:8px;margin:0;padding-left:18px;color:#3d4b48;font-size:13px;line-height:1.7}.warning-box{margin-top:12px;padding:12px;border:1px solid #f0cf92;border-radius:8px;background:#fff8e7}.warning-box p{margin:0 0 6px;color:#74540e}.warning-box p:last-child{margin-bottom:0}.loading-state,.empty-chart{min-height:380px;display:grid;place-items:center;align-content:center;gap:12px;border:1px dashed var(--border-strong);border-radius:8px;color:var(--muted);background:#ffffffb3}.loading-state strong{color:var(--text);font-size:18px}.loading-state span{font-size:13px}@media(max-width:1180px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;padding:14px}.nav-list{grid-template-columns:repeat(4,minmax(0,1fr))}.sidebar-note{display:none}.dashboard-grid{grid-template-columns:1fr}.user-home{grid-template-columns:minmax(0,1fr)}.user-home-stats{justify-content:flex-start}}@media(max-width:760px){.workspace{padding:14px}.topbar{align-items:flex-start;flex-direction:column}.topbar-actions{width:100%;justify-content:flex-start}.metric-strip,.spot-grid,.nav-list{grid-template-columns:1fr}.metric-card strong{font-size:21px}.panel{padding:13px}.gold-chart{height:280px}.theme-row,.rank-line,.spot-topline{align-items:flex-start;flex-direction:column}.timestamp,.refresh-button,.account-button,.account-menu-wrap{min-width:0}.account-panel{position:fixed;top:86px;left:14px;right:14px;width:auto;max-height:calc(100vh - 104px);overflow:auto}.account-panel-footer{align-items:flex-start;flex-direction:column}.user-home{align-items:stretch;min-height:0}.user-home-main{align-items:flex-start}.user-home-stats{align-items:flex-start;flex-direction:column}.switch-user-button{width:100%}}
