*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:#0f172a;color:#e2e8f0;min-height:100vh}.dashboard{max-width:1200px;margin:0 auto;padding:24px;transition:background .3s}.flash-alert{animation:flashBg .5s ease-in-out 3}@keyframes flashBg{0%,to{background:#0f172a}50%{background:#1a0a0a}}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #1e293b}.header h1{font-size:24px;font-weight:700;color:#f8fafc}.subtitle{font-size:13px;color:#64748b}.header-right{gap:16px}.header-right,.toggle{display:flex;align-items:center}.toggle{gap:8px;font-size:13px;color:#94a3b8;cursor:pointer}.toggle input{accent-color:#3b82f6}.timestamp{font-size:13px;color:#64748b}.alert-banner{background:#ef4444;color:#fff;padding:12px 16px;border-radius:8px;font-weight:700;font-size:14px;text-align:center;margin-bottom:20px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:20px;gap:20px}.card{background:#1e293b;border-radius:12px;padding:24px;border:1px solid #334155}.card h2{font-size:14px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.loading{color:#64748b;font-size:14px}.circuit-state,.state-display{display:flex;flex-direction:column}.state-display{gap:12px}.state-badge{display:inline-block;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:600;color:#fff;text-align:center;width:-moz-fit-content;width:fit-content}.state-badge.pulse{animation:badgePulse 1s ease-in-out infinite}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.state-details{display:flex;flex-direction:column;gap:4px;font-size:13px;color:#94a3b8}.btn-group{display:flex;gap:8px;margin-top:auto}.btn-fail,.btn-reset{flex:1 1;padding:8px 16px;background:#334155;border:1px solid #475569;border-radius:6px;color:#e2e8f0;font-size:13px;cursor:pointer;transition:background .2s}.btn-reset:hover{background:#475569}.btn-fail{background:#7f1d1d;border-color:#991b1b}.btn-fail:hover{background:#991b1b}.btn-fail.active{background:#dc2626;border-color:#ef4444;animation:pulse 1.5s ease-in-out infinite}.metrics-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.metric{display:flex;flex-direction:column;gap:4px}.metric-value{font-size:28px;font-weight:700;color:#f8fafc}.metric-value.success{color:#22c55e}.metric-value.danger{color:#ef4444}.metric-label{font-size:12px;color:#64748b;text-transform:uppercase}.threshold-warn{margin-top:12px;padding:8px 12px;background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#ef4444;font-size:12px;font-weight:600;text-align:center}.vitals-controls{display:flex;gap:8px;margin-bottom:16px}.vitals-controls input{flex:1 1;padding:8px 12px;background:#0f172a;border:1px solid #334155;border-radius:6px;color:#e2e8f0;font-size:13px}.vitals-controls input:focus{outline:none;border-color:#3b82f6}.vitals-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:12px;gap:12px}.vitals-grid.status-critical{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:12px}.vitals-grid.status-normal{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);border-radius:8px;padding:12px}.vitals-grid.status-warning{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.3);border-radius:8px;padding:12px}.vital{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px}.vital-icon{font-size:18px;color:#64748b}.vital-value{font-size:22px;font-weight:700;color:#f8fafc}.vital-label{font-size:11px;color:#64748b;text-transform:uppercase}.vitals-meta{display:flex;justify-content:space-between;margin-top:12px;font-size:12px;color:#64748b}.vitals-paused{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:8px;text-align:center}.pause-icon{font-size:32px;margin-bottom:8px}.pause-text{font-size:16px;font-weight:600;color:#ef4444;margin-bottom:4px}.pause-sub{font-size:12px;color:#94a3b8}.state-log{grid-column:1/-1}.log-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto}.log-entry{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#0f172a;border-radius:6px;font-size:13px}.log-time{color:#64748b;font-family:monospace;min-width:80px}.log-badge{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;color:#fff}.log-arrow{color:#475569}.load-balancer{grid-column:1/-1}.algo-selector{display:flex;gap:8px;margin-bottom:16px}.algo-btn{flex:1 1;padding:10px 16px;background:#0f172a;border:1px solid #334155;border-radius:6px;color:#94a3b8;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.algo-btn:hover{background:#1e293b;border-color:#475569;color:#e2e8f0}.algo-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.node-list{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:12px;gap:12px}.node-card{background:#0f172a;border:1px solid #334155;border-radius:8px;padding:12px}.node-card.unhealthy{border-color:#991b1b;background:rgba(153,27,27,.1)}.node-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.node-id{font-weight:600;font-size:13px;color:#f8fafc}.node-status{font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px}.node-status.healthy{background:rgba(34,197,94,.2);color:#22c55e}.node-status.down{background:rgba(239,68,68,.2);color:#ef4444}.node-stats{display:flex;flex-wrap:wrap;gap:6px}.node-stats span{font-size:11px;color:#64748b;background:#1e293b;padding:2px 6px;border-radius:4px}.node-dot{width:8px;height:8px;border-radius:50%}.algo-desc{font-size:13px;color:#94a3b8;margin-bottom:12px;padding:8px 12px;background:#0f172a;border-radius:6px;border-left:3px solid #3b82f6}.simulation{grid-column:1/-1}.sim-controls{gap:16px;margin-bottom:16px}.sim-controls,.sim-label{display:flex;align-items:center}.sim-label{gap:10px;font-size:13px;color:#94a3b8}.sim-label input[type=range]{width:150px;accent-color:#3b82f6}.sim-count{font-weight:700;color:#f8fafc;min-width:30px}.btn-simulate{padding:10px 20px;background:#3b82f6;border:none;border-radius:6px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s}.btn-simulate:hover{background:#2563eb}.btn-simulate:disabled{background:#475569;cursor:not-allowed}.sim-result{background:#0f172a;border-radius:8px;padding:16px}.sim-algo-label{font-size:13px;color:#94a3b8;margin-bottom:12px}.sim-bars{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.sim-bar-row{display:flex;align-items:center;gap:12px}.sim-bar-label{font-size:12px;font-weight:600;color:#e2e8f0;min-width:60px}.sim-bar-track{flex:1 1;height:24px;background:#1e293b;border-radius:4px;overflow:hidden}.sim-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.sim-bar-value{font-size:12px;color:#94a3b8;min-width:70px;text-align:right}.sim-explain{font-size:13px;color:#60a5fa;padding:8px 12px;background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.3);border-radius:6px;margin-top:12px}.sim-node-results{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px;margin-bottom:16px}.sim-node-card{background:#1e293b;border-radius:8px;padding:10px}.sim-node-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.sim-node-id{font-weight:600;font-size:13px;color:#f8fafc}.sim-node-stats{display:flex;flex-wrap:wrap;gap:6px;font-size:11px;color:#94a3b8}.sim-node-stats span{padding:2px 6px;background:#0f172a;border-radius:4px}.stat-ok{color:#22c55e}.stat-fail{color:#ef4444}.sim-log{margin-top:12px;background:#0f172a;border-radius:6px;overflow:hidden}.sim-log-header{padding:8px 12px;font-weight:600;color:#64748b}.sim-log-header,.sim-log-row{font-size:12px;border-bottom:1px solid #1e293b}.sim-log-row{display:flex;align-items:center;gap:10px;padding:6px 12px}.sim-log-row:last-child{border-bottom:none}.sim-log-row.ok{color:#94a3b8}.sim-log-row.fail{color:#64748b}.sim-log-node{font-weight:600;min-width:60px}.sim-log-status{min-width:16px}.sim-log-row.ok .sim-log-status{color:#22c55e}.sim-log-row.fail .sim-log-status{color:#ef4444}.sim-log-data{font-family:monospace}.sim-log-data em{font-style:normal;padding:1px 6px;border-radius:4px;font-size:10px}.sim-log-row.ok em{background:rgba(34,197,94,.15);color:#22c55e}.fail-text{color:#ef4444;font-style:italic}