@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";
:root{--bg-base:#050505;--bg-surface:#0a0a0a;--bg-card:#ffffff08;--bg-card-hover:#ffffff0d;--bg-input:#00000080;--text-primary:#eee;--text-secondary:#888;--text-muted:#888;--accent-green:#4caf50;--accent-green-glow:#4caf5026;--accent-cyan:#38bdf8;--accent-cyan-glow:#38bdf826;--accent-red:#ef4444;--accent-pink:#e91e63;--accent-amber:#f59e0b;--border:#ffffff14;--border-subtle:#ffffff0d;--border-strong:#ffffff26;--shadow-sm:0 2px 8px #0006;--shadow-md:0 4px 20px #0009;--shadow-lg:0 8px 40px #000c;--radius-sm:4px;--radius:8px;--radius-lg:12px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-base);height:100%;color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}a{color:var(--accent-cyan);text-decoration:none;transition:color .2s}a:hover{color:#7dd3fc}.btn-primary{background:var(--accent-green);color:#000;border-radius:var(--radius-sm);cursor:pointer;text-transform:uppercase;letter-spacing:.05em;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 28px;font-family:inherit;font-size:.88rem;font-weight:700;transition:all .2s;display:inline-flex}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-sm);background:#45a049;transform:translateY(-1px)}.btn-primary:disabled{color:#555;cursor:not-allowed;background:#222}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:.85rem;transition:all .2s;display:inline-flex}.btn-ghost:hover{color:var(--text-primary);border-color:var(--border-strong);background:#ffffff08}.btn-sm{border-radius:var(--radius-sm);cursor:pointer;border:none;padding:5px 14px;font-family:inherit;font-size:.78rem;font-weight:500;transition:all .2s}.btn-view{color:var(--accent-cyan);background:#38bdf81a;border:1px solid #38bdf833}.btn-view:hover{background:#38bdf833}.btn-delete{color:var(--accent-red);background:#ef44441a;border:1px solid #ef444433}.btn-delete:hover{background:#ef444433}.btn-unlock{color:var(--accent-green);background:#4caf501a;border:1px solid #4caf5033}.btn-unlock:hover:not(:disabled){background:#4caf5033}.btn-lock{color:var(--accent-amber);background:#f59e0b1a;border:1px solid #f59e0b33}.btn-lock:hover:not(:disabled){background:#f59e0b33}.btn-sm:disabled{opacity:.5;cursor:not-allowed}.btn-back{color:var(--text-primary);border-radius:var(--radius-sm);background:#ffffff0d;align-items:center;gap:8px;padding:10px 20px;font-weight:500;transition:all .2s;display:inline-flex}.btn-back:hover{color:var(--text-primary);background:#ffffff1a}.btn-loading{align-items:center;gap:8px;display:inline-flex}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px;border-radius:var(--radius-sm)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.spinner{border:2px solid #fff3;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}.spinner-sm{vertical-align:middle;border:2px solid #ffffff26;border-top-color:currentColor;border-radius:50%;width:12px;height:12px;animation:.6s linear infinite spin;display:inline-block}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-secondary);letter-spacing:.05em;text-transform:uppercase;font-size:.78rem;font-weight:500}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group select{background:var(--bg-input);border-radius:var(--radius-sm);color:var(--text-primary);border:1px solid #333;outline:none;padding:11px 14px;font-family:inherit;font-size:.95rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:var(--accent-green);box-shadow:0 0 0 1px var(--accent-green)}.form-group input::placeholder{color:var(--text-muted)}.form-group select option{color:var(--text-primary);background:#111}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (max-width:640px){.form-row{grid-template-columns:1fr}}.file-upload-area{position:relative}.file-upload-area input[type=file]{opacity:0;cursor:pointer;z-index:2;position:absolute;inset:0}.file-upload-label{border-radius:var(--radius-sm);color:var(--text-secondary);border:1px dashed #333;align-items:center;gap:12px;padding:16px 20px;font-size:.9rem;transition:all .2s;display:flex}.file-upload-area:hover .file-upload-label{border-color:var(--accent-green);color:var(--accent-green);background:var(--accent-green-glow)}.alert-error{border-radius:var(--radius-sm);color:var(--accent-red);background:#ef44441a;border:1px solid #ef444433;margin-top:16px;padding:14px 18px;font-size:.9rem}.alert-success{border-radius:var(--radius-sm);color:var(--accent-green);background:#4caf501a;border:1px solid #4caf5033;flex-wrap:wrap;align-items:center;gap:12px;margin-top:16px;padding:14px 18px;font-size:.9rem;display:flex}.alert-success a{color:var(--accent-cyan);margin-left:auto;font-weight:500}.ticker-badge{color:#aaa;border-radius:var(--radius-sm);letter-spacing:.05em;background:#ffffff0d;border:1px solid #ffffff1a;padding:3px 10px;font-family:ui-monospace,SF Mono,Consolas,monospace;font-size:.75rem;font-weight:600;display:inline-block}.ticker-badge-lg{color:#aaa;border-radius:var(--radius-sm);letter-spacing:.05em;background:#ffffff0d;border:1px solid #ffffff1a;padding:3px 12px;font-family:ui-monospace,SF Mono,Consolas,monospace;font-size:.8rem;font-weight:600;display:inline-block}.status-badge{border-radius:var(--radius-sm);letter-spacing:.04em;text-transform:uppercase;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-block}.status-approved{color:var(--accent-green);background:#4caf501a;border:1px solid #4caf5033}.status-locked{color:var(--accent-amber);background:#f59e0b1a;border:1px solid #f59e0b33}.login-container{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-lg);background:#0a0a0a;padding:40px 32px}.login-header{text-align:center;margin-bottom:32px}.login-icon{border-radius:var(--radius-lg);width:56px;height:56px;color:var(--accent-green);background:#4caf501a;border:1px solid #4caf5033;justify-content:center;align-items:center;margin-bottom:16px;display:inline-flex}.login-header h1{color:var(--text-primary);letter-spacing:-.01em;font-size:1.5rem;font-weight:700}.login-header p{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:4px;font-size:.88rem}.login-card form{flex-direction:column;gap:20px;display:flex}.login-error{border-radius:var(--radius-sm);color:var(--accent-red);text-align:center;background:#ef44441a;border:1px solid #ef444433;padding:10px 14px;font-size:.85rem}.login-toggle{text-align:center;margin-top:8px}.login-toggle p{color:var(--text-secondary);font-size:.85rem}.login-toggle button{color:var(--accent-green);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:.85rem;font-weight:600}.login-toggle button:hover{color:#45a049}.dashboard-container{background:var(--bg-base);flex-direction:column;min-height:100vh;display:flex}.dashboard-header{background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;padding:20px 40px;display:flex;position:sticky;top:0}.dashboard-brand{color:var(--accent-green);align-items:center;gap:12px;display:flex}.dashboard-brand h1{color:var(--text-primary);letter-spacing:.03em;text-transform:uppercase;font-size:1.15rem;font-weight:700}.dashboard-signout{align-items:center;gap:6px;display:inline-flex}.dashboard-subtitle{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem}.dashboard-main{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:40px 24px 64px}.dashboard-main>h2{text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);border-bottom:1px solid var(--border);margin-bottom:20px;padding-bottom:12px;font-size:.75rem;font-weight:600}.empty-state-dashboard{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:120px 20px;display:flex}.empty-state-dashboard h2{color:var(--text-secondary);font-size:1.1rem;font-weight:400}.empty-state-dashboard p{color:var(--text-muted);max-width:400px;font-size:.9rem}.chart-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;display:grid}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;color:inherit;align-items:center;gap:16px;padding:20px 24px;text-decoration:none;transition:all .2s;display:flex}.chart-card:hover{border-color:var(--border-strong);background:var(--bg-card-hover);box-shadow:var(--shadow-sm);color:inherit;transform:translateY(-2px)}.chart-card-icon{border-radius:var(--radius-sm);width:44px;height:44px;color:var(--accent-green);background:#4caf5014;border:1px solid #4caf5026;flex-shrink:0;justify-content:center;align-items:center;display:flex}.chart-card-content{flex:1;min-width:0}.chart-card-content h3{white-space:nowrap;text-overflow:ellipsis;color:var(--text-primary);margin-bottom:6px;font-size:.95rem;font-weight:600;overflow:hidden}.chart-card-meta{align-items:center;gap:10px;display:flex}.chart-date{color:var(--text-muted);font-size:.78rem}.chart-card-arrow{color:var(--text-muted);flex-shrink:0;transition:all .2s}.chart-card:hover .chart-card-arrow{color:var(--accent-green);transform:translate(2px,-2px)}.dashboard-footer{text-align:center;border-top:1px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;padding:20px;font-size:.78rem}.admin-container{background:var(--bg-base);min-height:100vh}.admin-header{background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;padding:20px 40px;display:flex;position:sticky;top:0}.admin-header-left{color:var(--accent-green);align-items:center;gap:12px;display:flex}.admin-header-left h1{color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;font-size:1rem;font-weight:700}.admin-main{max-width:960px;margin:0 auto;padding:40px 24px}.upload-section,.charts-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:20px;padding:28px}.upload-section h2,.charts-section h2{text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:4px;font-size:.75rem;font-weight:600}.section-desc{color:var(--text-muted);margin-bottom:24px;font-size:.85rem}.upload-form{flex-direction:column;gap:20px;display:flex}.charts-table-wrapper{margin-top:16px;overflow-x:auto}.charts-table{border-collapse:collapse;width:100%}.charts-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:10px 14px;font-size:.7rem;font-weight:600}.charts-table tbody tr{border-bottom:1px solid var(--border-subtle);transition:background .15s}.charts-table tbody tr:hover{background:#ffffff05}.charts-table td{padding:12px 14px;font-size:.88rem}.chart-title-cell{color:var(--text-primary);font-weight:500}.date-cell{color:var(--text-secondary);font-size:.82rem}.actions-cell{gap:8px;display:flex}.empty-state{color:var(--text-muted);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:40px 20px;display:flex}.section-header-row{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:4px;display:flex}.btn-refresh{flex-shrink:0;align-items:center;gap:6px;margin-top:2px;display:inline-flex}.users-table td{vertical-align:middle}.chart-fullscreen{background:var(--bg-base);flex-direction:column;height:100vh;display:flex;overflow:hidden}.chart-topbar{background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:10;flex-shrink:0;align-items:center;gap:16px;padding:14px 24px;display:flex}.chart-back-link{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-secondary);border:1px solid var(--border);justify-content:center;align-items:center;transition:all .2s;display:flex}.chart-back-link:hover{color:var(--text-primary);border-color:var(--border-strong);background:#ffffff0d}.chart-topbar-info{flex:1}.chart-topbar-info h1{text-transform:uppercase;letter-spacing:.03em;color:var(--text-primary);font-size:.95rem;font-weight:600;line-height:1.3}.chart-topbar-meta{align-items:center;gap:12px;margin-top:4px;display:flex}.chart-legend{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:6px;font-size:.75rem;display:flex}.legend-dot{border-radius:2px;width:10px;height:3px;display:inline-block}.chart-container{flex:1;width:100%;min-height:0}.chart-color-controls{flex-shrink:0;align-items:center;gap:8px;display:flex}.color-picker-btn{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff0a;align-items:center;gap:7px;padding:5px 10px 5px 7px;transition:all .2s;display:flex;position:relative}.color-picker-btn:hover{border-color:var(--border-strong);background:#ffffff14}.color-swatch{border:1px solid #ffffff2e;border-radius:3px;flex-shrink:0;width:14px;height:14px;transition:transform .15s;display:block}.color-picker-btn:hover .color-swatch{transform:scale(1.15)}.color-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;font-size:.72rem;font-weight:500}.projection-shift-controls{border:1px solid var(--border);border-radius:var(--radius-sm);background:#ffffff0a;flex-shrink:0;align-items:center;gap:2px;padding:2px;display:flex}.projection-shift-btn{width:28px;height:26px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;padding:0;font-family:inherit;font-size:.85rem;transition:all .15s;display:flex}.projection-shift-btn:hover{color:var(--text-primary);background:#ffffff14}.projection-shift-btn:active{color:var(--accent-green);background:#4caf5026}.projection-shift-count{min-width:32px;height:26px;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:3px;justify-content:center;align-items:center;padding:0 4px;font-family:ui-monospace,SF Mono,Consolas,monospace;font-size:.7rem;font-weight:600;transition:all .15s;display:flex}.projection-shift-count:hover{color:var(--text-secondary);background:#ffffff0f}.projection-shift-count.active{color:var(--accent-green)}.projection-shift-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;align-self:center;margin-right:4px;font-size:.65rem;font-weight:500}.chart-fullscreen-loading{background:var(--bg-base);height:100vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:20px;display:flex}.chart-loading-spinner{border:2px solid #ffffff14;border-top-color:var(--accent-green);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.chart-fullscreen-error{background:var(--bg-base);height:100vh;color:var(--accent-red);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.chart-fullscreen-error h2{color:var(--text-primary);font-size:1.2rem}.pending-container{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.pending-card{border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;width:100%;max-width:460px;box-shadow:var(--shadow-lg);background:#0a0a0a;padding:48px 32px}@keyframes pulse-glow{0%,to{box-shadow:0 0 #f59e0b00}50%{box-shadow:0 0 20px 4px #f59e0b1a}}.pending-icon{width:80px;height:80px;color:var(--accent-amber);background:#f59e0b14;border:1px solid #f59e0b33;border-radius:50%;justify-content:center;align-items:center;margin-bottom:24px;animation:2s ease-in-out infinite pulse-glow;display:inline-flex}.pending-card h1{text-transform:uppercase;letter-spacing:-.01em;margin-bottom:12px;font-size:1.4rem;font-weight:600}.pending-card p{color:var(--text-secondary);margin-bottom:28px;font-size:.9rem;line-height:1.6}.pending-actions{justify-content:center;gap:12px;display:flex}.pending-actions .btn-ghost{align-items:center;gap:6px;display:inline-flex}@media (max-width:768px){.dashboard-header{padding:16px 20px}.dashboard-main{padding:24px 16px 48px}.admin-header{padding:16px 20px}.admin-main{padding:24px 16px}.upload-section,.charts-section{padding:20px 16px}.chart-grid{grid-template-columns:1fr}.chart-topbar{padding:12px 16px}.chart-topbar-info h1{font-size:.85rem}}.compare-page{background:var(--bg-base);flex-direction:column;height:100vh;display:flex;overflow:hidden}.compare-header{background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 24px;display:flex}.compare-header-left{text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);align-items:center;gap:12px;font-size:.82rem;font-weight:600;display:flex}.compare-header-right{align-items:center;gap:10px;display:flex}.compare-toggle-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:#ffffff0a;align-items:center;gap:6px;padding:5px 12px;font-family:inherit;font-size:.74rem;font-weight:500;transition:all .2s;display:inline-flex}.compare-toggle-btn:hover{border-color:var(--border-strong);color:var(--text-primary);background:#ffffff12}.compare-toggle-btn.active{border-color:var(--accent-cyan);color:var(--accent-cyan);background:#38bdf814}.compare-body{flex:1;min-height:0;display:flex}.compare-sidebar{border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:4px;width:280px;padding:16px;display:flex;overflow-y:auto}.compare-sidebar-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:8px;font-size:.68rem;font-weight:600}.compare-loading{justify-content:center;align-items:center;padding:32px 0;display:flex}.compare-empty{color:var(--text-muted);text-align:center;padding:32px 0;font-size:.85rem}.compare-chart-list{flex-direction:column;flex:1;gap:4px;list-style:none;display:flex}.compare-chart-item{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);cursor:pointer;background:0 0;align-items:center;gap:10px;padding:9px 10px;transition:all .15s;display:flex}.compare-chart-item:hover{border-color:var(--border);background:#ffffff08}.compare-chart-item.selected{background:#ffffff0a;border-color:#ffffff24}.compare-item-swatch{border:1px solid;border-radius:3px;flex-shrink:0;width:12px;height:12px;transition:all .15s}.compare-item-info{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.compare-item-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:500;overflow:hidden}.compare-item-meta{align-items:center;gap:6px;display:flex}.compare-error{color:var(--accent-red);margin-top:8px;font-size:.8rem}.compare-run-btn{flex-shrink:0;width:100%;margin-top:12px}.compare-legend{flex-direction:column;gap:6px;display:flex}.compare-legend-item{align-items:center;gap:8px;display:flex}.compare-legend-swatch{border-radius:2px;flex-shrink:0;width:24px;height:3px}.compare-legend-title{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.compare-legend-hint{color:var(--text-muted);border-top:1px solid var(--border-subtle);margin-top:10px;padding-top:10px;font-size:.72rem;line-height:1.5}.compare-shift-group{flex-shrink:0;align-items:center;gap:4px;display:flex}.compare-shift-btn{cursor:pointer;background:0 0;border:1px solid;border-radius:3px;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-family:inherit;font-size:.75rem;line-height:1;transition:background .15s;display:flex}.compare-shift-btn:hover{background:#ffffff0f}.compare-shift-count{text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;min-width:26px;font-family:ui-monospace,monospace;font-size:.72rem;font-weight:600;transition:color .15s}.compare-chart-area{background:#050505;flex-direction:column;flex:1;min-width:0;display:flex}.compare-placeholder{color:var(--text-muted);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:32px;font-size:.88rem;display:flex}.compare-placeholder strong{color:var(--text-secondary)}.compare-canvas{flex:1;width:100%;min-height:0}@media (max-width:768px){.compare-body{flex-direction:column}.compare-sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%;max-height:240px}.compare-chart-list{flex-flow:wrap}.compare-chart-item{min-width:160px}}.algo-page{background:var(--bg-base);height:100vh;display:flex;overflow:hidden}.algo-sidebar{background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:320px;display:flex;overflow-y:auto}.algo-sidebar-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:20px 20px 16px;display:flex}.algo-brand{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-secondary);border:1px solid var(--border);flex-shrink:0;justify-content:center;align-items:center;text-decoration:none;transition:all .2s;display:flex}.algo-brand:hover{color:var(--text-primary);border-color:var(--border-strong);background:#ffffff0d}.algo-sidebar-title{color:#a78bfa;text-transform:uppercase;letter-spacing:.03em;margin:0;font-size:.95rem;font-weight:700}.algo-sidebar-subtitle{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:2px 0 0;font-size:.72rem}.algo-chart-list{flex-direction:column;flex:1;gap:4px;padding:12px;display:flex;overflow-y:auto}.algo-loading{justify-content:center;align-items:center;gap:8px;padding:32px 0;display:flex}.algo-empty{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:40px 16px;font-size:.85rem;display:flex}.algo-chart-item{border-radius:var(--radius);border:1px solid var(--border-subtle);cursor:pointer;text-align:left;width:100%;color:inherit;background:0 0;align-items:center;gap:12px;padding:12px 14px;font-family:inherit;transition:all .15s;display:flex}.algo-chart-item:hover{background:#a78bfa0a;border-color:#a78bfa26}.algo-chart-item.selected{background:#a78bfa14;border-color:#a78bfa4d}.algo-item-dot{opacity:.5;background:#a78bfa;border-radius:50%;flex-shrink:0;width:10px;height:10px;transition:all .2s}.algo-chart-item.selected .algo-item-dot{opacity:1;animation:2s infinite pulse;box-shadow:0 0 8px #a78bfa80}.algo-item-info{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.algo-item-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.algo-item-meta{align-items:center;gap:8px;display:flex}.algo-item-date{color:var(--text-muted);font-size:.72rem}.algo-sidebar-legend{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding:16px 20px;display:flex}.algo-legend-item{align-items:center;gap:8px;display:flex}.algo-legend-text{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem}.algo-main{background:var(--bg-base);flex-direction:column;flex:1;min-width:0;display:flex}.algo-placeholder{color:var(--text-muted);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:32px;font-size:.88rem;display:flex}.algo-placeholder strong{color:var(--text-secondary);font-size:1rem}.algo-placeholder p{max-width:360px;line-height:1.6}.algo-topbar{background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:16px;padding:12px 24px;display:flex}.algo-topbar-info{flex:1}.algo-topbar-info h2{text-transform:uppercase;letter-spacing:.03em;color:var(--text-primary);margin:0;font-size:.92rem;font-weight:600}.algo-topbar-meta{align-items:center;gap:10px;margin-top:3px;display:flex}.algo-chart-container{flex:1;width:100%;min-height:0}@media (max-width:768px){.algo-page{flex-direction:column}.algo-sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%;max-height:200px}.algo-topbar{flex-wrap:wrap;gap:8px;padding:10px 16px}.algo-topbar-info h2{font-size:.82rem}}
