@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700&family=Noto+Sans+SC:wght@300;400;500;700&display=swap";:root{--bg-main:#0b0f19;--bg-card:#161c2d99;--bg-card-hover:#1e293bd9;--bg-input:#0f172a99;--border-color:#ffffff14;--border-glow:#ef444426;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--stock-red:#f43f5e;--stock-red-light:#f43f5e26;--stock-red-glow:#f43f5e66;--stock-green:#10b981;--stock-green-light:#10b9811f;--accent-gold:#f59e0b;--accent-gold-light:#f59e0b1a;--accent-blue:#3b82f6;--accent-blue-light:#3b82f61a;--font-sans:"Inter", "Noto Sans SC", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-outfit:"Outfit", sans-serif;--shadow-sm:0 2px 8px -1px #0000004d;--shadow-md:0 10px 25px -5px #0006;--shadow-lg:0 20px 40px -10px #00000080;--glass-blur:blur(16px);--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-full:9999px;--transition-fast:all .2s cubic-bezier(.4, 0, .2, 1);--transition-normal:all .35s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-main);color:var(--text-primary);font-family:var(--font-sans);background-image:radial-gradient(circle at 10% 20%,#f43f5e0d 0%,#0000 40%),radial-gradient(circle at 90% 80%,#3b82f60f 0%,#0000 40%);background-attachment:fixed;min-height:100vh;line-height:1.5;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-main)}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#ffffff1a}::-webkit-scrollbar-thumb:hover{background:#ffffff40}.app-container{flex-direction:column;gap:20px;max-width:1600px;margin:0 auto;padding:24px;display:flex}header{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:10px 20px;display:flex}.header-left{align-items:center;gap:16px;display:flex}.sentiment-divider,.controls-divider{background:#ffffff14;width:1px;height:24px}.sentiment-status-mini{align-items:center;gap:10px;display:flex}.sentiment-score-ring-mini{border-radius:var(--radius-full);background:conic-gradient(var(--stock-red) calc(var(--score) * 1%), #ffffff0d 0deg);justify-content:center;align-items:center;width:38px;height:38px;display:flex;position:relative;box-shadow:0 0 10px #f43f5e26}.sentiment-score-ring-mini:after{content:attr(data-score);background:var(--bg-main);border-radius:var(--radius-full);width:30px;height:30px;font-family:var(--font-outfit);color:var(--text-primary);justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex;position:absolute}.sentiment-value-mini{color:var(--stock-red);font-size:14px;font-weight:700}.sentiment-stats-horizontal{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.sentiment-stat-item-mini{border-radius:var(--radius-full);background:#ffffff05;border:1px solid #ffffff0a;align-items:center;gap:6px;padding:4px 10px;display:flex;box-shadow:inset 0 1px 1px #ffffff03}.sentiment-stat-item-mini .sentiment-stat-label{color:var(--text-muted);font-size:11px}.sentiment-stat-item-mini .sentiment-stat-val{font-size:12px;font-weight:600;font-family:var(--font-outfit)}.header-right{align-items:center;gap:16px;display:flex}.logo-section{align-items:center;gap:12px;display:flex}.logo-icon{background:linear-gradient(135deg, var(--stock-red), var(--accent-gold));border-radius:var(--radius-sm);width:36px;height:36px;font-family:var(--font-outfit);color:#fff;justify-content:center;align-items:center;font-size:20px;font-weight:700;display:flex;box-shadow:0 4px 12px #f43f5e4d}.logo-section h1{letter-spacing:.5px;background:linear-gradient(to right, var(--text-primary), var(--text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:20px;font-weight:700}.logo-section span{color:var(--text-muted);border-radius:var(--radius-full);border:1px solid #ffffff1a;margin-left:8px;padding:2px 8px;font-size:12px}.date-navigator{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-full);align-items:center;padding:4px 6px;display:flex}.date-btn{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-full);transition:var(--transition-fast);background:0 0;border:none;align-items:center;gap:4px;padding:6px 14px;font-size:14px;display:flex}.date-btn:hover:not(:disabled){color:var(--text-primary);background:#ffffff0d}.date-btn:disabled{color:var(--text-muted);cursor:not-allowed;opacity:.5}.current-date{font-weight:600;font-family:var(--font-outfit);color:var(--stock-red);letter-spacing:.5px;padding:0 16px;font-size:15px}.market-indices{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.index-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:var(--transition-fast);flex-direction:column;gap:4px;padding:12px 16px;display:flex}.index-card:hover{border-color:#ffffff26;transform:translateY(-2px)}.index-name{color:var(--text-secondary);font-size:13px}.index-values{justify-content:space-between;align-items:baseline;display:flex}.index-val{font-size:18px;font-weight:700;font-family:var(--font-outfit)}.index-pct{font-size:13px;font-weight:600;font-family:var(--font-outfit)}.trend-up{color:var(--stock-red)!important}.trend-down{color:var(--stock-green)!important}.trend-up-bg{background:var(--stock-red-light);border-color:#f43f5e33}.trend-down-bg{background:var(--stock-green-light);border-color:#10b98126}.tabs-container{border-bottom:1px solid var(--border-color);gap:24px;margin-top:10px;display:flex;position:relative}.primary-tab{color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;padding:12px 4px;font-size:16px;font-weight:500;position:relative}.primary-tab:hover{color:var(--text-primary)}.primary-tab.active{color:var(--stock-red);font-weight:700}.primary-tab.active:after{content:"";background:var(--stock-red);border-radius:var(--radius-full) var(--radius-full) 0 0;width:100%;height:3px;box-shadow:0 -2px 10px var(--stock-red-glow);position:absolute;bottom:-1px;left:0}.filter-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:5px;display:flex}.subtabs{background:var(--bg-input);border-radius:var(--radius-md);border:1px solid var(--border-color);gap:8px;padding:4px;display:flex}.sub-tab{color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;border-radius:8px;padding:6px 14px;font-size:13px}.sub-tab:hover{color:var(--text-primary)}.sub-tab.active{color:var(--text-primary);background:#ffffff14;font-weight:600}.search-wrapper{min-width:260px;position:relative}.search-input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:var(--transition-fast);outline:none;padding:8px 16px 8px 36px;font-size:13px}.search-input:focus{border-color:#f43f5e80;box-shadow:0 0 0 3px #f43f5e1a}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.sentiment-banner{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;padding:16px 24px;display:flex}.sentiment-status{align-items:center;gap:16px;display:flex}.sentiment-score-ring{border-radius:var(--radius-full);background:conic-gradient(var(--stock-red) calc(var(--score) * 1%), #ffffff0d 0deg);justify-content:center;align-items:center;width:50px;height:50px;display:flex;position:relative;box-shadow:0 0 15px #f43f5e26}.sentiment-score-ring:after{content:attr(data-score);background:var(--bg-main);border-radius:var(--radius-full);width:42px;height:42px;font-family:var(--font-outfit);justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex;position:absolute}.sentiment-label-group{flex-direction:column;display:flex}.sentiment-title{color:var(--text-secondary);font-size:12px}.sentiment-value{color:var(--stock-red);font-size:18px;font-weight:700}.sentiment-stats-grid{flex-wrap:wrap;gap:32px;display:flex}.sentiment-stat-item{flex-direction:column;display:flex}.sentiment-stat-label{color:var(--text-muted);font-size:12px}.sentiment-stat-val{font-size:16px;font-weight:600;font-family:var(--font-outfit)}.dashboard-grid{grid-template-columns:3fr 2fr;align-items:start;gap:20px;display:grid}.panel{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);flex-direction:column;gap:16px;padding:20px;display:flex}.panel-header{border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding-bottom:12px;display:flex}.panel-title{align-items:center;gap:8px;font-size:16px;font-weight:700;display:flex}.panel-title:before{content:"";background:var(--stock-red);border-radius:var(--radius-full);width:4px;height:16px}.panel-action{color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);font-size:12px}.panel-action:hover{color:var(--text-primary)}.ladder-container{flex-direction:column;gap:12px;display:flex}.ladder-row{border-bottom:1px dashed #ffffff0a;grid-template-columns:80px 1fr;align-items:start;gap:16px;padding:10px 0;display:grid}.ladder-row:last-child{border-bottom:none}.ladder-badge{border-radius:var(--radius-sm);font-size:13px;font-weight:700;font-family:var(--font-outfit);text-align:center;justify-content:space-between;align-items:center;min-width:72px;padding:6px 12px;display:flex}.ladder-badge-high{color:var(--accent-gold);background:linear-gradient(135deg,#ef444426 0%,#f59e0b26 100%);border:1px solid #f59e0b4d;box-shadow:0 0 10px #f59e0b0d}.ladder-badge-mid{color:var(--stock-red);background:#ef44441f;border:1px solid #ef444440}.ladder-badge-low{color:var(--accent-blue);background:#3b82f61f;border:1px solid #3b82f640}.ladder-stock-list{flex-direction:column;gap:12px;width:100%;display:flex}.ladder-stock-band{flex-direction:row;align-items:center;gap:15px;width:100%;display:flex}.chain-connector{color:var(--text-muted);opacity:.6;flex-shrink:0;font-size:16px;font-weight:700}.concept-synergy-chain{border-radius:var(--radius-sm);white-space:normal;background:#0f172a4d;border:1px dashed #f43f5e26;flex-flow:wrap;flex-grow:1;flex-shrink:1;align-items:center;gap:8px 6px;min-width:0;padding:8px 14px;font-size:12px;display:flex}.chain-title{color:var(--accent-gold);flex-shrink:0;margin-right:4px;font-weight:600}.chain-node{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:#1e293b4d;border:1px solid #ffffff0d;align-items:center;gap:6px;padding:4px 10px;transition:all .2s ease-in-out;display:inline-flex}.chain-node:hover{background:#f43f5e0d;border-color:#f43f5e66;transform:scale(1.02)}.chain-node.active{color:var(--stock-red);background:#ef44441f;border-color:#ef444466;font-weight:700;box-shadow:0 0 10px #ef44441a}.chain-node .node-name{font-weight:500}.chain-node .node-badge{border-radius:var(--radius-sm);color:var(--text-muted);background:#ffffff14;padding:1px 4px;font-size:10px}.chain-node.active .node-badge{color:var(--stock-red);background:#ef444433}.chain-arrow{color:#ffffff26;flex-shrink:0;font-weight:700}.ladder-stock-grid-row{border-top:1px solid #ffffff08;flex-direction:column;gap:8px;width:100%;margin-top:4px;padding-top:12px;display:flex}.grid-row-header{color:var(--text-muted);letter-spacing:.5px;margin-bottom:4px;font-size:11px;font-weight:600}.grid-row-cards{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;width:100%;display:grid}.time-type-toggle{border-radius:var(--radius-sm);background:#0f172a66;border:1px solid #ffffff0d;align-items:center;gap:4px;margin:0 10px;padding:3px 5px;display:flex}.toggle-label{color:var(--text-muted);margin-right:2px;font-size:11px;font-weight:500}.toggle-btn{color:var(--text-secondary);border-radius:var(--radius-xs);cursor:pointer;background:0 0;border:none;padding:3px 8px;font-size:11px;font-weight:500;transition:all .2s}.toggle-btn:hover{color:var(--text-primary)}.toggle-btn.active{color:var(--stock-red);background:#f43f5e26;border:1px solid #f43f5e40;font-weight:600}.time-re-sealed{text-shadow:0 0 5px #f59e0b33;font-weight:600;color:var(--accent-gold)!important}.time-diff-badge{color:var(--accent-gold);vertical-align:middle;background:#f59e0b26;border:1px solid #f59e0b59;border-radius:3px;margin-left:5px;padding:1px 4px;font-size:9px;font-weight:700;line-height:1.1;display:inline-block}.stock-card{border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;min-width:140px;transition:var(--transition-normal);background:#0f172a66;flex-direction:column;gap:4px;padding:8px 12px;display:flex;position:relative}.stock-card:hover{background:var(--bg-card-hover);border-color:#f43f5e59;transform:translateY(-2px);box-shadow:0 4px 15px #f43f5e14}.stock-card.active{border-color:var(--stock-red);background:#f43f5e0d;box-shadow:0 0 12px #f43f5e1f}.stock-card-header{justify-content:space-between;align-items:center;display:flex}.stock-name{color:var(--text-primary);font-size:14px;font-weight:600}.stock-code{color:var(--text-muted);font-size:11px;font-family:var(--font-outfit)}.stock-card-body{justify-content:space-between;align-items:center;font-size:12px;display:flex}.stock-time{color:var(--text-muted);font-family:var(--font-outfit)}.stock-status-badge{border-radius:3px;padding:1px 4px;font-size:9px;font-weight:500}.stock-status-up{color:var(--stock-red);background:#f43f5e1f}.stock-concepts-tag-list{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.stock-concept-tag{color:var(--text-secondary);background:#ffffff0d;border:1px solid #ffffff14;border-radius:4px;padding:1px 4px;font-size:9px}.stock-card:hover .stock-concept-tag{color:var(--stock-red);background:#f43f5e14;border-color:#f43f5e26}.concepts-container{flex-direction:column;gap:12px;display:flex}.concept-item-card{border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-normal);background:#0f172a66;flex-direction:column;gap:10px;padding:14px 16px;display:flex}.concept-item-card:hover{background:var(--bg-card-hover);border-color:#3b82f64d;transform:translate(4px);box-shadow:0 4px 15px #3b82f60d}.concept-item-card.collapsed{gap:0;transition:all .25s cubic-bezier(.25,.8,.25,1)}.concept-item-card.collapsed:hover{background:var(--bg-card-hover);border-color:#f43f5e59;transform:translateY(-2px)scale(1.01);box-shadow:0 4px 15px #f43f5e14}.concept-item-card.expanded{background:#0f172a80;border-color:#3b82f633;box-shadow:0 10px 25px #00000059}.concept-detail-link-btn{transition:all .2s cubic-bezier(.25,.8,.25,1)}.concept-detail-link-btn:hover{transform:scale(1.05);box-shadow:0 0 10px #f43f5e4d;background:#f43f5e40!important;border-color:#f43f5e8c!important}.concept-item-header{justify-content:space-between;align-items:center;display:flex}.concept-name{color:var(--text-primary);font-size:15px;font-weight:700}.concept-meta{align-items:center;gap:8px;display:flex}.concept-count-badge{color:var(--stock-red);border-radius:var(--radius-full);background:#f43f5e1f;border:1px solid #f43f5e40;padding:2px 8px;font-size:11px;font-weight:600}.concept-strength{color:var(--accent-gold);font-size:11px}.concept-ladder-chain{border-radius:var(--radius-sm);background:#00000026;flex-wrap:wrap;align-items:center;gap:6px;padding:6px 10px;font-size:12px;display:flex}.chain-node{align-items:center;gap:4px;display:flex}.chain-board{font-weight:700;font-family:var(--font-outfit);color:var(--text-muted)}.chain-board-active{color:var(--stock-red)}.chain-stock{color:var(--text-secondary);background:#ffffff08;border:1px solid #ffffff0d;border-radius:4px;padding:2px 6px}.chain-stock-leader{color:var(--accent-gold);background:#f59e0b14;border-color:#f59e0b40;font-weight:600}.chain-board-first{color:var(--stock-red);font-size:12px}.chain-node-first-board{flex-wrap:wrap}.chain-stock-first{color:var(--text-secondary);background:#ffffff0f;border:1px solid #ffffff14;border-radius:4px;padding:1px 5px;font-size:12px}.chain-arrow{color:var(--text-muted);font-size:10px}.concept-metrics{border-top:1px solid #ffffff0d;grid-template-columns:repeat(5,1fr);gap:8px;padding-top:8px;display:grid}.concept-metric-item{background:#0003;border-radius:4px;flex-direction:column;gap:2px;padding:4px 6px;display:flex}.metric-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;font-size:10px}.metric-value{color:var(--text-primary);font-size:12px;font-weight:600;font-family:var(--font-outfit)}.concept-sort-controls{align-items:center;gap:6px;display:flex}.concept-sort-btn{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff08;border:1px solid #ffffff14;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:500;transition:all .2s;display:flex}.concept-sort-btn:hover{color:var(--stock-red);background:#f43f5e1a;border-color:#f43f5e4d}.concept-sort-btn .sort-arrow:after{content:"⇅";opacity:.3;font-size:10px}.concept-sort-btn.sort-active-desc{border-color:var(--stock-red);color:var(--stock-red);background:#f43f5e26}.concept-sort-btn.sort-active-desc .sort-arrow:after{content:"↓";opacity:1}.concept-sort-btn.sort-active-asc{color:#3b82f6;background:#3b82f626;border-color:#3b82f680}.concept-sort-btn.sort-active-asc .sort-arrow:after{content:"↑";opacity:1}.detail-drawer{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);flex-direction:column;gap:12px;padding:20px;display:none}.detail-drawer.show{animation:.3s ease-out fadeIn;display:flex}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;display:grid}.detail-item{border-radius:var(--radius-sm);background:#00000026;flex-direction:column;gap:2px;padding:8px 12px;display:flex}.detail-label{color:var(--text-muted);font-size:11px}.detail-value{font-size:14px;font-weight:600}.level2-view{flex-direction:column;gap:20px;width:100%;display:none}.level2-view.active{animation:.4s cubic-bezier(.16,1,.3,1) slideInRight;display:flex}.level1-view{flex-direction:column;gap:20px;display:flex}.level1-view.hidden{display:none}.level2-header{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.back-btn{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-full);cursor:pointer;transition:var(--transition-fast);align-items:center;gap:8px;padding:8px 16px;font-size:13px;display:flex}.back-btn:hover{color:var(--text-primary);background:#ffffff14}.level2-title-section{flex-direction:column;align-items:center;gap:4px;display:flex}.level2-title{color:var(--text-primary);align-items:center;gap:10px;font-size:20px;font-weight:700;display:flex}.level2-subtitle{color:var(--text-muted);font-size:12px}.table-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow-x:auto}.premium-table{border-collapse:collapse;text-align:left;width:100%;color:var(--text-secondary);min-width:1200px;font-size:13px}.premium-table th,.premium-table td{white-space:nowrap;border-bottom:1px solid #ffffff0a;padding:12px 14px}.premium-table th{color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;z-index:10;border-bottom:2px solid var(--border-glow);background:#0f172af2;font-size:12px;font-weight:600;position:sticky;top:0}.premium-table tr{transition:var(--transition-fast)}.premium-table tbody tr:hover{cursor:pointer;background:#f43f5e0d}.premium-table tr:last-child td{border-bottom:none}.premium-table th[data-sort]{-webkit-user-select:none;user-select:none;transition:background .2s;position:relative}.premium-table th[data-sort]:hover{background:#f43f5e1a}.premium-table th[data-sort] .sort-indicator{opacity:.3;margin-left:4px;display:inline-block}.premium-table th[data-sort]:after{content:"⇅";opacity:.3;margin-left:6px;font-size:11px}.premium-table th.sort-asc:after{content:"↑";opacity:1;color:var(--stock-red)}.premium-table th.sort-desc:after{content:"↓";opacity:1;color:var(--stock-red)}.table-tier-label{text-align:center;vertical-align:middle;border-right:1px solid var(--border-color);background:var(--bg-card);z-index:5;font-size:13px;font-weight:700;position:sticky;left:0}.tier-highest{color:var(--accent-gold);background:var(--accent-gold-light)}.tier-second{color:#f59e0b;background:#f59e0b14}.tier-middle{color:var(--accent-blue);background:var(--accent-blue-light)}.tier-low{color:var(--stock-green);background:var(--stock-green-light)}.tier-first{color:var(--text-secondary);background:#ffffff05}.table-stock-name{color:var(--text-primary);cursor:pointer;font-weight:600}.table-stock-name:hover{color:var(--stock-red)}.table-stock-code{font-family:var(--font-outfit);color:var(--text-muted);font-size:12px}.table-board-count{font-family:var(--font-outfit);color:var(--stock-red);text-align:center;font-weight:700}.table-time{font-family:var(--font-outfit);color:var(--text-secondary);text-align:center;font-size:12px}.table-strength{color:var(--accent-gold);text-align:right;font-weight:600}.table-turnover,.table-volume{font-family:var(--font-outfit);text-align:right;color:var(--text-secondary);font-weight:500}.table-reason{color:var(--text-secondary);white-space:normal;max-width:300px;font-size:12px;line-height:1.5}.empty-cell{color:var(--text-muted);padding:24px;font-size:12px;font-style:italic}.panel-header-controls{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.view-mode-toggle{border-radius:var(--radius-sm);background:#0f172a66;border:1px solid #ffffff0d;align-items:center;gap:2px;padding:3px 4px;display:flex}.view-mode-toggle .toggle-btn{align-items:center;gap:4px;padding:4px 10px;font-size:11px;display:flex}.view-mode-toggle .toggle-btn svg{flex-shrink:0}.export-csv-btn{border-radius:var(--radius-sm);color:var(--stock-green);cursor:pointer;transition:var(--transition-fast);background:#10b9811a;border:1px solid #10b98140;align-items:center;gap:5px;padding:5px 12px;font-size:12px;font-weight:600;display:flex}.export-csv-btn:hover{background:#10b98133;border-color:#10b98180;transform:translateY(-1px);box-shadow:0 3px 10px #10b98126}.ladder-table-container{box-shadow:none;background:0 0;border:none}.ladder-rank-table{min-width:1000px}.ladder-rank-table th{z-index:10;-webkit-user-select:none;user-select:none;position:sticky;top:0}.ladder-rank-table th[style*="cursor: pointer"]:hover{background:#f43f5e14}.ladder-rank-table th.sort-asc:after,.ladder-rank-table th.sort-desc:after{opacity:1;color:var(--stock-red);margin-left:4px;font-size:10px}.ladder-rank-table th.sort-asc:after{content:"↑"}.ladder-rank-table th.sort-desc:after{content:"↓"}.table-rank{font-family:var(--font-outfit);text-align:center;vertical-align:middle;width:50px;font-size:15px;font-weight:800}.rank-top{color:var(--accent-gold);text-shadow:0 0 8px #f59e0b66}.rank-high{color:var(--stock-red);text-shadow:0 0 6px #f43f5e4d}.rank-mid{color:var(--accent-blue)}.rank-normal{color:var(--text-muted)}.table-board-type{text-align:center;color:var(--text-muted);font-size:11px;font-weight:500}.table-concepts{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.table-concept-tag{color:var(--accent-blue);cursor:pointer;transition:var(--transition-fast);white-space:nowrap;background:#3b82f614;border:1px solid #3b82f626;border-radius:4px;padding:2px 6px;font-size:10px}.table-concept-tag:hover{color:#60a5fa;background:#3b82f633;border-color:#3b82f666}.premium-table tbody tr.row-selected{box-shadow:inset 3px 0 0 var(--stock-red);background:#f43f5e14}.premium-table tbody tr.row-selected td{color:var(--text-primary)}.table-footer-info{color:var(--text-muted);border-radius:0 0 var(--radius-md) var(--radius-md);background:#0f172a4d;border-top:1px solid #ffffff0a;padding:10px 16px;font-size:12px}.table-count-highlight{color:var(--stock-red);font-weight:700;font-family:var(--font-outfit);font-size:13px}footer{text-align:center;border-top:1px solid var(--border-color);margin-top:20px;padding:30px 0}.disclaimer{color:var(--text-muted);max-width:800px;margin:0 auto;font-size:11px;line-height:1.6}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@media (width<=1024px){.dashboard-grid{grid-template-columns:1fr;min-width:0;max-width:100%}}@media (width<=768px){.app-container{padding:10px}.unified-header{flex-direction:column;align-items:stretch;gap:12px;padding:12px}header{flex-direction:column;align-items:stretch;padding:12px!important}.header-left{flex-direction:column;align-items:stretch;gap:10px;width:100%}.logo-section{justify-content:space-between;width:100%}.sentiment-divider,.controls-divider{display:none!important}.sentiment-status-mini{border-radius:var(--radius-sm);background:#ffffff05;border:1px solid #ffffff0a;justify-content:flex-start;width:100%;padding:8px 12px;box-shadow:inset 0 1px 1px #ffffff03}.sentiment-stats-horizontal{grid-template-columns:repeat(2,1fr);gap:8px;width:100%;display:grid}.sentiment-stat-item-mini{box-sizing:border-box;justify-content:space-between;width:100%;padding:6px 12px}.header-right{flex-direction:column;align-items:stretch;gap:10px;width:100%}.date-navigator{box-sizing:border-box;justify-content:space-between;width:100%}.date-btn{padding:6px 16px}.refresh-controls{justify-content:space-between;gap:10px;width:100%}.auto-refresh-group{flex-grow:1;justify-content:center;padding:5px 12px}.refresh-btn{flex-grow:1;justify-content:center;padding:6px 16px}.ladder-table-container{-webkit-overflow-scrolling:touch;box-sizing:border-box;scrollbar-width:thin;scrollbar-color:#ffffff1f transparent;width:100%;max-width:100%;overflow-x:auto}.ladder-table-container::-webkit-scrollbar{height:5px}.ladder-table-container::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#ffffff26}.premium-table th,.premium-table td{padding:8px 6px;font-size:11px}.table-reason{max-width:180px}.primary-tab{padding:8px 2px;font-size:14px}.filter-bar{flex-direction:column;align-items:stretch;gap:10px}.subtabs{white-space:nowrap;scrollbar-width:none;justify-content:space-around;width:100%;overflow-x:auto}.subtabs::-webkit-scrollbar{display:none}.sub-tab{flex-shrink:0}.search-wrapper{width:100%}.concept-metrics{grid-template-columns:repeat(3,1fr);gap:6px;font-size:11px}.concept-sort-controls{flex-wrap:wrap;gap:4px}.concept-sort-btn{padding:3px 8px;font-size:10px}.ladder-row{grid-template-columns:1fr;gap:8px}.ladder-badge{align-self:flex-start;padding:4px 10px;font-size:11px}.panel{box-sizing:border-box;min-width:0;max-width:100%;padding:12px}.panel-header{flex-direction:column;align-items:stretch;gap:8px}.time-type-toggle{justify-content:center;width:100%;margin:0}.panel-action{text-align:right}.ladder-stock-band{border-radius:var(--radius-sm);background:#ffffff03;border:1px solid #ffffff08;flex-direction:column;align-items:stretch;gap:8px;padding:8px}.chain-connector{display:none}.concept-synergy-chain{box-sizing:border-box;gap:6px 4px;width:100%;padding:6px 10px;font-size:11px}.chain-node{gap:4px;padding:3px 6px;font-size:11px}.chain-node .node-time{font-size:9px}.chain-arrow{margin:0 -2px;font-size:9px}.concept-ladder-chain{gap:6px 4px;font-size:11px}.concept-ladder-chain .chain-node{padding:3px 6px}.tabs-container{white-space:nowrap;scrollbar-width:none;-ms-overflow-style:none;gap:16px;overflow-x:auto}.tabs-container::-webkit-scrollbar{display:none}.primary-tab{flex-shrink:0;display:inline-block}}@media (width<=480px){.indices-grid{grid-template-columns:1fr}.grid-row-cards{grid-template-columns:repeat(auto-fill,minmax(125px,1fr));gap:8px}.stock-card{padding:6px 10px;min-width:0!important}.stock-name{font-size:13px}.stock-code,.stock-time{font-size:10px}.stock-status-badge{padding:0 3px;font-size:8px}}.logo-section span.badge-real{font-weight:600;box-shadow:0 0 10px #f43f5e26;color:var(--stock-red)!important;background:var(--stock-red-light)!important;border-color:#f43f5e66!important}.logo-section span.badge-mock{color:var(--text-muted)!important;background:#ffffff0d!important;border-color:#ffffff1a!important}.refresh-controls{align-items:center;gap:12px;display:flex}.auto-refresh-group{border-radius:var(--radius-sm);-webkit-backdrop-filter:var(--glass-blur);background:#ffffff08;border:1px solid #ffffff14;align-items:center;gap:8px;padding:4px 10px;display:flex}.auto-refresh-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:flex}.auto-refresh-toggle input{display:none}.toggle-slider{border-radius:var(--radius-full);width:32px;height:18px;transition:var(--transition-fast);background-color:#ffffff1a;display:inline-block;position:relative}.toggle-slider:before{content:"";background-color:var(--text-secondary);width:14px;height:14px;transition:var(--transition-fast);box-shadow:var(--shadow-sm);border-radius:50%;position:absolute;bottom:2px;left:2px}.auto-refresh-toggle input:checked+.toggle-slider{background-color:var(--stock-red);box-shadow:0 0 10px var(--stock-red-glow)}.auto-refresh-toggle input:checked+.toggle-slider:before{background-color:var(--text-primary);transform:translate(14px)}.toggle-text{color:var(--text-secondary);letter-spacing:.5px;font-size:13px;font-weight:500}.auto-refresh-toggle input:checked~.toggle-text{color:var(--text-primary)}.interval-input-wrapper{transition:var(--transition-fast);background:#0b0f1999;border:1px solid #ffffff1f;border-radius:6px;align-items:center;gap:3px;padding:2px 6px;display:flex}.interval-input-wrapper:focus-within{border-color:#f43f5e99;box-shadow:0 0 8px #f43f5e33}.refresh-interval-input{width:34px;color:var(--stock-red);font-family:var(--font-outfit);text-align:center;background:0 0;border:none;outline:none;font-size:13px;font-weight:700}.refresh-interval-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.refresh-interval-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.refresh-interval-input{-moz-appearance:textfield}.interval-unit{color:var(--text-muted);font-size:11px;font-weight:500}.refresh-btn{border-radius:var(--radius-sm);background:linear-gradient(135deg, var(--stock-red), var(--accent-gold));color:#fff;cursor:pointer;transition:var(--transition-fast);-webkit-backdrop-filter:var(--glass-blur);border:1px solid #ffffff26;align-items:center;gap:6px;padding:5px 12px;font-size:13px;font-weight:600;display:flex;box-shadow:0 4px 12px #f43f5e40}.refresh-btn:hover:not(:disabled){border-color:#ffffff40;transform:translateY(-1px);box-shadow:0 6px 16px #f43f5e59}.refresh-btn:active:not(:disabled){transform:translateY(1px)}.refresh-btn:disabled{cursor:not-allowed;color:var(--text-muted)!important;box-shadow:none!important;background:#ffffff0d!important;border-color:#ffffff0d!important}.refresh-btn svg{transition:transform .2s}.refresh-btn:hover:not(:disabled) svg{transform:rotate(30deg)}.spin{animation:1s linear infinite css-spin}@keyframes css-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.indices-container{-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);background:#1e293b40;border:1px solid #ffffff0f;margin-bottom:20px;padding:16px}.indices-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.index-card{border-radius:var(--radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none;background:#0f172a66;border:1px solid #ffffff0a;flex-direction:column;gap:8px;padding:12px 14px;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex;position:relative;overflow:hidden}.index-card:after{content:"";opacity:.8;width:3px;height:100%;position:absolute;top:0;left:0}.index-card.up:after{background:var(--stock-red);box-shadow:0 0 8px var(--stock-red-glow)}.index-card.down:after{background:#10b981;box-shadow:0 0 8px #10b98180}.index-card:hover{background:#ffffff08;border-color:#ffffff1f;transform:translateY(-2px);box-shadow:0 10px 20px #0000004d}.index-card.active{background:#0f172ab3;border-color:#fff3;box-shadow:0 0 15px #ffffff0d}.index-card.up.active{border-color:#ef444459;box-shadow:0 0 12px #ef44441f}.index-card.down.active{border-color:#10b98159;box-shadow:0 0 12px #10b9811f}.index-card-header{justify-content:space-between;align-items:center;display:flex}.index-name{color:var(--text-primary);letter-spacing:.5px;font-size:13px;font-weight:700}.index-code{color:var(--text-muted);font-size:11px;font-family:var(--font-outfit)}.index-card-body{justify-content:space-between;align-items:flex-end;display:flex}.index-price-group{flex-direction:column;gap:2px;display:flex}.index-price{font-size:18px;font-weight:800;font-family:var(--font-outfit);letter-spacing:-.5px}.index-card.up .index-price{color:var(--stock-red);text-shadow:0 0 10px #ef444426}.index-card.down .index-price{color:#10b981;text-shadow:0 0 10px #10b98126}.index-change-group{font-size:12px;font-weight:600;font-family:var(--font-outfit);align-items:center;gap:6px;display:flex}.index-card.up .index-change,.index-card.up .index-change-val{color:var(--stock-red)}.index-card.down .index-change,.index-card.down .index-change-val{color:#10b981}.index-change-val{opacity:.85;font-weight:500}.index-sparkline-wrapper{align-items:center;height:26px;display:flex}.sparkline-svg{filter:drop-shadow(0 0 3px #ffffff0d);opacity:.9;transition:opacity .2s}.index-card:hover .sparkline-svg{opacity:1}.sparkline-fallback path{animation:2s ease-in-out infinite pulse-stroke}@keyframes pulse-stroke{0%,to{opacity:.4}50%{opacity:.8}}@media (width<=768px){.indices-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.indices-grid{grid-template-columns:1fr}}.column-visibility-dropdown-container{position:relative}.column-select-btn{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:5px 12px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.column-select-btn:hover{color:var(--text-primary);background:#ffffff0d}.column-select-btn.active{box-shadow:0 0 10px #f43f5e33;border:1px solid var(--stock-red)!important;color:var(--stock-red)!important;background:#f43f5e26!important}.column-select-menu{-webkit-backdrop-filter:blur(20px);z-index:100;background:#0f172af2;border:1px solid #ffffff14;border-radius:8px;flex-direction:column;gap:8px;width:180px;padding:12px;animation:.2s ease-out fadeIn;display:flex;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 10px 25px #00000080}.column-select-title{color:var(--text-muted);border-bottom:1px solid #ffffff0f;padding-bottom:4px;font-size:11px;font-weight:700}.column-select-list{flex-direction:column;gap:6px;max-height:250px;padding-right:4px;display:flex;overflow-y:auto}.column-select-item{cursor:pointer;color:var(--text-secondary);-webkit-user-select:none;user-select:none;align-items:center;gap:8px;padding:2px 0;font-size:12px;transition:color .2s;display:flex}.column-select-item:hover{color:var(--text-primary)}.column-select-item input{cursor:pointer;accent-color:var(--stock-red)}.indices-header-bar{border-bottom:1px solid #ffffff0a;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;display:flex}.indices-title{color:var(--text-muted);letter-spacing:.5px;font-size:12px;font-weight:700}.close-indices-btn{color:var(--text-muted);cursor:pointer;-webkit-backdrop-filter:var(--glass-blur);background:#ffffff0a;border:1px solid #ffffff14;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:600;transition:all .2s}.close-indices-btn:hover{border-color:var(--stock-red);color:var(--stock-red);background:#f43f5e26;box-shadow:0 0 8px #f43f5e26}.table-board-type{text-align:center}.interactive-board{cursor:pointer;transition:all .2s}.interactive-board:hover{box-shadow:inset 3px 0 0 var(--stock-red);background:#f43f5e14!important}.table-board-group{flex-direction:column;align-items:center;gap:2px;display:flex}.table-board-name{color:var(--text-primary);font-weight:600}.table-board-index{opacity:.85;font-size:10px;font-weight:700;font-family:var(--font-outfit)}.table-board-index.trend-up{color:var(--stock-red)!important}.table-board-index.trend-down{color:var(--stock-green)!important}
