:root{--bg-primary:#0d1117;--bg-secondary:#161b22;--bg-tertiary:#21262d;--text-primary:#f0f6fc;--text-secondary:#8b949e;--border-color:#30363d;--accent-green:#4ade80;--accent-red:#ff7b7b;--accent-blue:#58a6ff;--accent-yellow:#f0b429}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.navbar{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex}.navbar-brand{color:var(--text-primary);align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;display:flex}.badge{background:var(--accent-blue);color:#fff;border-radius:4px;padding:.25rem .5rem;font-size:.75rem}.status-indicator{align-items:center;gap:.5rem;font-size:.875rem;display:flex}.status-dot{background:var(--accent-red);border-radius:50%;width:8px;height:8px}.status-dot.connected{background:var(--accent-green);animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:1rem}.card-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);border-radius:12px 12px 0 0;justify-content:space-between;align-items:center;padding:.75rem 1rem;font-weight:600;display:flex}.card-body{padding:1rem}.table-container{max-height:400px;overflow-y:auto}table{border-collapse:collapse;width:100%}thead th{color:#8b949e;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--accent-blue);text-align:left;z-index:10;background:#0d1117;padding:.75rem;font-size:.8rem;font-weight:600;position:sticky;top:0}tbody tr{border-bottom:1px solid var(--border-color)}tbody tr:nth-child(odd){background-color:#1c2128}tbody tr:nth-child(2n){background-color:#22272e}tbody tr:hover{background-color:#2d333b}tbody td{color:#fff;padding:.6rem .75rem}.stock-name{color:#fff;font-weight:700}.stock-code{color:#9ca3af;font-size:.75rem}.text-up{color:#ff7b7b!important}.text-down{color:#4ade80!important}.text-flat{color:#9ca3af!important}.signal-badge{border-radius:4px;align-items:center;gap:4px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.signal-buy{color:#ff7b7b;background:#ff7b7b33;border:1px solid #ff7b7b}.signal-sell{color:#4ade80;background:#4ade8033;border:1px solid #4ade80}.index-card{background:var(--bg-tertiary);text-align:center;border-radius:8px;padding:1rem}.index-name{color:var(--text-secondary);margin-bottom:.25rem;font-size:.875rem}.index-value{font-size:1.5rem;font-weight:700}.index-change{font-size:.875rem;font-weight:600}.alert-item{background:var(--bg-tertiary);border-left:3px solid var(--accent-blue);border-radius:8px;gap:.75rem;margin-bottom:.5rem;padding:.75rem;display:flex}.alert-item.warning{border-left-color:var(--accent-yellow)}.alert-item.danger{border-left-color:var(--accent-red)}.alert-time{color:var(--text-secondary);font-size:.75rem}.btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;display:inline-flex}.btn-primary{background:var(--accent-blue);color:#fff}.btn-primary:hover{background:#4a9eff}.btn-outline{border:1px solid var(--border-color);color:var(--text-secondary);background:0 0}.btn-outline:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-danger{border:1px solid var(--accent-red);color:var(--accent-red);background:0 0}.btn-danger:hover{background:#ff7b7b1a}.btn-sm{padding:.25rem .5rem;font-size:.75rem}.form-control{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:6px;width:100%;padding:.5rem .75rem}.form-control:focus{border-color:var(--accent-blue);outline:none;box-shadow:0 0 0 2px #58a6ff40}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1rem;display:flex}.modal-body{padding:1rem}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:.5rem;padding:1rem;display:flex}.btn-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:1.5rem}.btn-close:hover{color:var(--text-primary)}.container{max-width:1400px;margin:0 auto;padding:1rem}.row{flex-wrap:wrap;margin:-.5rem;display:flex}.col-6{flex:0 0 50%;padding:.5rem}.col-12{flex:0 0 100%;padding:.5rem}@media (max-width:992px){.col-6{flex:0 0 100%}}.grid-5{grid-template-columns:repeat(5,1fr);gap:1rem;display:grid}@media (max-width:768px){.grid-5{grid-template-columns:repeat(2,1fr)}}.spinner{border:2px solid var(--border-color);border-top-color:var(--accent-blue);border-radius:50%;width:16px;height:16px;animation:1s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-secondary);padding:2rem}.refresh-timer{color:var(--text-secondary);font-size:.75rem}.toast{z-index:9999;border-radius:8px;min-width:200px;padding:12px 20px;animation:.3s slideIn;position:fixed;top:70px;right:20px;box-shadow:0 4px 12px #0000004d}.toast-info{background:var(--accent-blue);color:#fff}.toast-success{background:var(--accent-green);color:#fff}.toast-error{background:var(--accent-red);color:#fff}.toast-warning{background:var(--accent-yellow);color:#000}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#484f58}.form-group{margin-bottom:1rem}.form-label{color:var(--text-primary);margin-bottom:.5rem;font-size:.875rem;display:block}.form-hint{color:var(--text-secondary);margin-top:.25rem;font-size:.75rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.text-secondary{color:var(--text-secondary)}.text-center{text-align:center}.font-bold{font-weight:700}.mb-3{margin-bottom:.75rem}.mt-2{margin-top:.5rem}.p-0{padding:0}
