:root{--color-bg-primary: #0A0A0A;--color-bg-secondary: #1A1A1A;--color-bg-tertiary: #2A2A2A;--color-text-primary: #FFFFFF;--color-text-secondary: #B8B8B8;--color-text-tertiary: #808080;--color-accent-primary: #2563EB;--color-accent-hover: #1D4ED8;--color-accent-light: rgba(37, 99, 235, .1);--color-success: #10B981;--color-warning: #F59E0B;--color-error: #EF4444;--color-border: #333333;--color-border-light: #404040;font-family:Montserrat,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;font-weight:400;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -1px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -2px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 10px 10px -5px rgba(0, 0, 0, .3);color-scheme:dark;color:var(--color-text-primary);background-color:var(--color-bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;overflow:hidden;width:100vw;height:100vh;background-color:var(--color-bg-primary)}#root{width:100%;height:100%}.app-container{position:relative;width:100%;height:100%;overflow:hidden}button{font-family:Montserrat,sans-serif;font-weight:500;cursor:pointer;transition:all var(--transition-base);border:none;outline:none}button:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{font-family:Montserrat,sans-serif;transition:all var(--transition-base)}input:focus,select:focus,textarea:focus{outline:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}*{box-sizing:border-box;margin:0;padding:0}.node-info-container{position:fixed;top:20px;left:50%;transform:translate(-50%) translateY(-20px) scale(.95);display:flex;align-items:flex-start;gap:12px;opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:100}.node-info-container.visible{transform:translate(-50%) translateY(0) scale(1);opacity:1;pointer-events:auto}.node-info-panel{background:#1a1a1af2;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px 24px;min-width:300px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 32px #0006}.node-info-container.pinned .node-info-panel{border-color:#2563eb66;box-shadow:0 8px 32px #0006,0 0 0 2px #2563eb33}.node-info-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1);gap:12px}.node-info-title-section{display:flex;align-items:center;gap:8px}.node-info-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.node-pin-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-size:16px;padding:0;position:relative}.node-pin-btn .keyboard-hint{position:absolute;bottom:-2px;right:-2px;background:#2563ebe6;color:#fff;font-size:8px;font-weight:600;padding:1px 3px;border-radius:2px;font-family:Courier New,monospace;pointer-events:none;box-shadow:0 1px 3px #0000004d;opacity:.8;transition:opacity .2s ease}.node-pin-btn:hover{background:#ffffff1a;border-color:#fff3;color:var(--text-primary);transform:translateY(-1px)}.node-pin-btn:hover .keyboard-hint{opacity:1}.node-pin-btn:active{transform:translateY(0)}.node-pin-btn.pinned{background:#2563eb26;border-color:var(--accent-color);color:var(--accent-color)}.node-pin-btn.pinned:hover{background:#2563eb40}.node-info-id{font-size:12px;font-family:Courier New,monospace;color:var(--accent-color);background:#2563eb1a;padding:4px 8px;border-radius:4px}.node-info-actions{display:flex;flex-direction:column;gap:6px;background:#1a1a1af2;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:6px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 32px #0006}.triage-controls{display:flex;align-items:center;gap:6px}.severity-selector{display:flex;gap:4px}.severity-chip{width:18px;height:18px;border-radius:50%;border:1px solid rgba(255,255,255,.2);cursor:pointer;transition:transform .1s ease,box-shadow .1s ease}.severity-chip.selected{box-shadow:0 0 0 2px #fff3;transform:translateY(-1px)}.severity-chip.black{background:#4b5563}.severity-chip.green{background:#10b981}.severity-chip.yellow{background:#f59e0b}.severity-chip.red{background:#ef4444}.node-action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:16px;padding:0;position:relative}.node-action-btn .keyboard-hint{position:absolute;bottom:-2px;right:-2px;background:#2563ebe6;color:#fff;font-size:8px;font-weight:600;padding:1px 3px;border-radius:2px;font-family:Courier New,monospace;pointer-events:none;box-shadow:0 1px 3px #0000004d;opacity:.8;transition:opacity .2s ease}.node-action-btn.active{background:#10b98126;border-color:#10b98166;color:#10b981}.node-action-btn.active .keyboard-hint{background:#10b981e6}.node-action-btn:hover:not(:disabled){background:#ffffff1a;border-color:#fff3;transform:translateY(-1px)}.node-action-btn.active:hover:not(:disabled){background:#10b98140;border-color:#10b98180}.node-action-btn:hover:not(:disabled) .keyboard-hint{opacity:1}.node-action-btn:active:not(:disabled){transform:translateY(0)}.node-action-btn:disabled{opacity:.3;cursor:not-allowed}.node-action-btn:disabled .keyboard-hint{display:none}.node-action-btn.delete-btn{color:var(--error-color);border-color:#ef44444d}.node-action-btn.delete-btn:hover:not(:disabled){background:#ef444426;border-color:var(--error-color)}.node-action-btn.triage-btn{color:#ef4444;border-color:#ef44444d}.node-action-btn.triage-btn:hover:not(:disabled){background:#ef444426;border-color:#ef4444}.node-info-content{display:flex;flex-direction:column;gap:8px}.node-info-row{display:flex;justify-content:space-between;align-items:center;font-size:14px}.node-info-label{color:var(--text-secondary);font-weight:500}.node-info-value{color:var(--text-primary);font-family:Courier New,monospace;font-size:13px}.node-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}.node-info-stat{display:flex;flex-direction:column;gap:2px;padding:6px 8px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:4px}.node-info-stat.queued{background:#f59e0b14;border-color:#f59e0b4d}.stat-label{font-size:10px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.stat-value{font-size:13px;font-weight:600;color:var(--text-primary);font-family:Courier New,monospace}.routing-status-badge{padding:8px 10px;border-radius:6px;border:1px solid;background:#ffffff08;display:flex;flex-direction:column;gap:6px}.routing-status-badge[data-mode=intelligent]{border-color:#10b9814d;background:#10b9810d}.routing-status-badge[data-mode=flooding]{border-color:#f59e0b4d;background:#f59e0b0d}.routing-status-badge[data-mode=inactive]{border-color:#a855f74d;background:#a855f70d}.routing-status-badge[data-mode=no-connections]{border-color:#6b72804d;background:#6b72800d}.routing-badge-header{display:flex;align-items:center;gap:6px}.routing-badge-icon{font-size:14px}.routing-badge-mode{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.routing-status-badge[data-mode=intelligent] .routing-badge-mode{color:#10b981}.routing-status-badge[data-mode=flooding] .routing-badge-mode{color:#f59e0b}.routing-status-badge[data-mode=inactive] .routing-badge-mode{color:#a855f7}.routing-status-badge[data-mode=no-connections] .routing-badge-mode{color:#6b7280}.routing-badge-stats{display:flex;gap:8px;font-size:11px;padding-left:20px}.route-stat{font-family:Courier New,monospace;font-weight:600}.route-stat.active{color:#10b981}.route-stat.expired{color:#ef4444}.route-stat.inactive{color:#a855f7}.routing-badge-reason{font-size:10px;color:var(--text-secondary);font-style:italic;padding-left:20px}.node-detail-panel{position:fixed;left:20px;top:20px;bottom:80px;width:320px;background:#1a1a1afa;border:1px solid rgba(255,255,255,.1);border-radius:12px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 32px #0006;display:flex;flex-direction:column;z-index:100;overflow:hidden}.node-detail-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.node-detail-header h2{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.close-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-size:18px;padding:0}.close-btn:hover{background:#ffffff1a;border-color:#fff3;color:var(--text-primary)}.node-detail-content{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.node-detail-content::-webkit-scrollbar{width:8px}.node-detail-content::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.node-detail-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.node-detail-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.node-detail-card{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:12px}.node-detail-card-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.node-detail-title{display:flex;align-items:center;gap:8px}.node-color-indicator{width:12px;height:12px;border-radius:50%;border:2px solid rgba(255,255,255,.3)}.node-detail-id{font-family:Courier New,monospace;font-size:13px;color:var(--accent-color);font-weight:600}.remove-from-panel-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-size:14px;padding:0}.remove-from-panel-btn:hover{background:#ef444426;border-color:var(--error-color);color:var(--error-color)}.node-detail-section{display:flex;flex-direction:column;gap:8px}.node-detail-section h3{margin:0;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.detail-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:4px 0}.detail-label{color:var(--text-secondary);font-weight:500}.detail-value{color:var(--text-primary);font-family:Courier New,monospace;font-size:12px}.detail-placeholder{padding:12px;text-align:center;color:var(--text-secondary);font-size:12px;font-style:italic;background:#ffffff05;border-radius:4px;border:1px dashed rgba(255,255,255,.1)}.connection-list{display:flex;flex-direction:column;gap:4px}.connection-item{padding:6px 10px;background:#2563eb1a;border:1px solid rgba(37,99,235,.2);border-radius:4px;font-family:Courier New,monospace;font-size:11px;color:var(--accent-color)}.comparison-hint{padding:12px 20px;text-align:center;font-size:12px;color:var(--accent-color);background:#2563eb1a;border-top:1px solid rgba(37,99,235,.2);flex-shrink:0}.routing-table{display:flex;flex-direction:column;gap:12px}.routing-entry{padding:10px;background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:6px;display:flex;flex-direction:column;gap:8px}.routing-sink-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.1)}.routing-sink-id{font-family:Courier New,monospace;font-size:12px;color:#a5b4fc;font-weight:600}.routing-status{font-size:11px;font-weight:600;display:flex;align-items:center;gap:4px}.routing-next-hops{display:flex;flex-direction:column;gap:6px}.next-hop-item{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;background:#10b9811a;border:1px solid rgba(16,185,129,.2);border-radius:4px}.next-hop-peer{font-family:Courier New,monospace;font-size:11px;color:#6ee7b7}.next-hop-count{font-size:11px;color:var(--text-secondary);font-weight:600}.routing-metadata{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.routing-age{font-size:10px;color:var(--text-secondary);font-style:italic}.routing-table.inactive{opacity:.85}.routing-entry.inactive{background:#a855f714;border:1px solid rgba(168,85,247,.3)}.routing-entry.inactive .routing-sink-id{color:#c4b5fd}.next-hop-item.inactive{background:#a855f71a;border:1px solid rgba(168,85,247,.2);opacity:.7}.next-hop-item.inactive .next-hop-peer{color:#d8b4fe}.section-description{font-size:11px;color:var(--text-secondary);margin:-4px 0 8px;font-style:italic}.triage-queue-list{display:flex;flex-direction:column;gap:6px}.queued-triage-item{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:6px;transition:all .2s ease}.queued-triage-item:hover{background:#f59e0b26;border-color:#f59e0b66}.queued-triage-id{font-family:Courier New,monospace;font-size:11px;color:#fcd34d;font-weight:600}.queued-triage-severity{font-size:10px;font-weight:700;letter-spacing:.4px;padding:2px 6px;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.15)}.queued-triage-severity[data-severity=black]{color:#9ca3af;border-color:#9ca3af4d}.queued-triage-severity[data-severity=green]{color:#10b981;border-color:#10b9814d}.queued-triage-severity[data-severity=yellow]{color:#f59e0b;border-color:#f59e0b4d}.queued-triage-severity[data-severity=red]{color:#ef4444;border-color:#ef44444d}.queued-triage-time{font-size:10px;color:var(--text-secondary);font-style:italic}.keyboard-help-toggle{position:fixed;bottom:20px;right:20px;width:40px;height:40px;background:#1a1a1af2;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-primary);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:200;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 32px #0006}.keyboard-help-toggle:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-2px);box-shadow:0 12px 40px #00000080}.keyboard-shortcuts-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.keyboard-shortcuts-panel{background:#1a1a1afa;border:2px solid rgba(37,99,235,.5);border-radius:16px;max-width:800px;max-height:80vh;width:90%;display:flex;flex-direction:column;box-shadow:0 24px 48px #00000080;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.shortcuts-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:2px solid rgba(255,255,255,.1)}.shortcuts-header h2{margin:0;font-size:24px;font-weight:600;color:var(--text-primary)}.shortcuts-close{background:transparent;border:none;color:var(--text-secondary);font-size:32px;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;border-radius:4px}.shortcuts-close:hover{background:#ffffff1a;color:var(--text-primary)}.shortcuts-content{flex:1;overflow-y:auto;padding:24px 32px;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:32px}.shortcuts-content::-webkit-scrollbar{width:8px}.shortcuts-content::-webkit-scrollbar-track{background:#ffffff0d}.shortcuts-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.shortcuts-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.shortcuts-category{display:flex;flex-direction:column;gap:12px}.shortcuts-category h3{margin:0;font-size:14px;font-weight:600;color:var(--accent-color);text-transform:uppercase;letter-spacing:1px;padding-bottom:8px;border-bottom:1px solid rgba(37,99,235,.3)}.shortcuts-list{display:flex;flex-direction:column;gap:12px}.shortcut-item{display:flex;align-items:center;gap:16px;padding:8px 12px;background:#ffffff08;border-radius:8px;transition:background .2s ease}.shortcut-item:hover{background:#ffffff0d}.shortcut-keys{display:flex;align-items:center;gap:4px;min-width:120px}.shortcut-keys kbd{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:4px 8px;font-family:Courier New,monospace;font-size:12px;font-weight:600;color:var(--text-primary);box-shadow:0 2px 4px #0003;min-width:32px;text-align:center}.key-separator{color:var(--text-secondary);font-size:12px;padding:0 2px}.shortcut-description{color:var(--text-secondary);font-size:14px;flex:1}.shortcuts-footer{padding:16px 32px;text-align:center;color:var(--text-secondary);font-size:13px;border-top:2px solid rgba(255,255,255,.1)}.shortcuts-footer kbd{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:2px 6px;font-family:Courier New,monospace;font-size:12px;color:var(--text-primary);margin:0 4px}.simulation-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;background-color:var(--color-bg-primary);touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.simulation-canvas canvas{display:block;width:100%;height:100%;touch-action:none}.keyboard-nav-hint{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#2563ebf2;color:#fff;padding:8px 16px;border-radius:20px;font-size:13px;font-weight:500;box-shadow:0 4px 12px #2563eb66;z-index:150;animation:slideUpFade .3s ease;pointer-events:none}.keyboard-nav-hint kbd{background:#fff3;padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:11px;margin:0 2px}@keyframes slideUpFade{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.sidebar-toggle{position:fixed;top:24px;right:24px;z-index:1001;width:48px;height:48px;border-radius:8px;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);color:var(--color-text-primary);display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-md);padding:0}.sidebar-toggle svg{display:block}.sidebar-toggle:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-accent-primary);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.sidebar-toggle:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.bottom-controls{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:1001;display:flex;gap:12px}.bottom-control-button{width:48px;height:48px;border-radius:8px;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);color:var(--color-text-primary);display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-md);position:relative;padding:0}.bottom-control-button svg{display:block}.bottom-control-button:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-accent-primary);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.bottom-control-button:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.bottom-control-button:after{content:attr(title);position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);padding:6px 12px;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-primary);font-size:.75rem;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:all var(--transition-base);box-shadow:var(--shadow-md)}.bottom-control-button:hover:after{opacity:1;transform:translate(-50%) translateY(-12px)}.sidebar{position:fixed;top:20px;right:-420px;width:380px;height:calc(100vh - 40px);background-color:var(--color-bg-secondary);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:12px;z-index:1000;transition:all var(--transition-slow);display:flex;flex-direction:column;box-shadow:var(--shadow-xl);opacity:0;transform:translate(20px) scale(.95)}.sidebar.open{right:20px;opacity:1;transform:translate(0) scale(1)}.sidebar-header{padding:32px 24px 24px;border-bottom:1px solid var(--color-border);border-radius:12px 12px 0 0}.sidebar-header h2{margin:0;color:var(--color-text-primary);font-size:1.25rem;font-weight:600;letter-spacing:-.025em}.sidebar-tabs{display:flex;border-bottom:1px solid var(--color-border);background-color:var(--color-bg-primary)}.sidebar-tabs .tab{flex:1;padding:16px 24px;background:transparent;border-bottom:2px solid transparent;color:var(--color-text-secondary);font-size:.875rem;font-weight:500;letter-spacing:.025em;text-transform:uppercase;transition:all var(--transition-base);position:relative}.sidebar-tabs .tab:hover{color:var(--color-text-primary);background-color:var(--color-accent-light)}.sidebar-tabs .tab.active{color:var(--color-accent-primary);border-bottom-color:var(--color-accent-primary);background-color:transparent}.sidebar-content{flex:1;padding:24px;overflow-y:auto;overflow-x:hidden;border-radius:0 0 12px 12px}.sidebar-content h3{margin-top:0;margin-bottom:24px;color:var(--color-text-primary);font-size:1rem;font-weight:600;letter-spacing:-.025em}.controls-panel .control-group{margin-bottom:24px}.controls-panel .control-group:last-child{margin-bottom:0}.controls-panel label{display:block;margin-bottom:10px;color:var(--color-text-secondary);font-size:.813rem;font-weight:500;letter-spacing:.025em;text-transform:uppercase}.controls-panel input[type=number]{width:100%;padding:12px 16px;background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-primary);font-size:.938rem;font-weight:500;transition:all var(--transition-base)}.controls-panel input[type=number]:hover{border-color:var(--color-border-light)}.controls-panel input[type=number]:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-light)}.controls-panel input[type=range]{width:100%;height:6px;background:var(--color-bg-primary);border-radius:3px;outline:none;-webkit-appearance:none;appearance:none}.controls-panel input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;background:var(--color-accent-primary);border-radius:50%;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.controls-panel input[type=range]::-webkit-slider-thumb:hover{background:var(--color-accent-hover);transform:scale(1.1);box-shadow:var(--shadow-md)}.controls-panel input[type=range]::-moz-range-thumb{width:18px;height:18px;background:var(--color-accent-primary);border:none;border-radius:50%;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.controls-panel input[type=range]::-moz-range-thumb:hover{background:var(--color-accent-hover);transform:scale(1.1);box-shadow:var(--shadow-md)}.control-hint{display:block;margin-top:6px;font-size:.75rem;color:var(--color-text-tertiary);font-style:italic;opacity:.8}.control-button{flex:1;padding:12px 20px;background-color:var(--color-bg-primary);border:1px solid var(--color-border);color:var(--color-text-primary);border-radius:6px;font-size:.875rem;font-weight:500;transition:all var(--transition-base)}.control-button:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-border-light);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.control-button:active{transform:translateY(0);box-shadow:none}.control-button.primary{background-color:var(--color-accent-primary);border-color:var(--color-accent-primary);color:#fff}.control-button.primary:hover{background-color:var(--color-accent-hover);border-color:var(--color-accent-hover)}.control-button.success{background-color:var(--color-success);border-color:var(--color-success);color:#fff}.control-button.warning{background-color:var(--color-warning);border-color:var(--color-warning);color:#fff}.control-button.error{background-color:var(--color-error);border-color:var(--color-error);color:#fff}.control-group:has(.control-button){display:flex;gap:12px}.info-panel .info-item{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--color-border)}.info-panel .info-item:first-child{padding-top:0}.info-panel .info-item:last-child{border-bottom:none;padding-bottom:0}.info-label{color:var(--color-text-secondary);font-size:.875rem;font-weight:500;letter-spacing:.025em}.info-value{color:var(--color-text-primary);font-weight:600;font-size:1.125rem;font-variant-numeric:tabular-nums}.info-value.success{color:var(--color-success)}.info-value.warning{color:var(--color-warning)}.info-value.error{color:var(--color-error)}@media (max-width: 768px){.sidebar{width:calc(100% - 32px);left:16px;right:auto;transform:translateY(20px) scale(.95)}.sidebar.open{right:auto;left:16px;transform:translateY(0) scale(1)}.sidebar-toggle{top:16px;right:16px;width:44px;height:44px}.bottom-controls{bottom:16px}.bottom-control-button{width:44px;height:44px;font-size:18px}}@media (max-width: 480px){.sidebar{top:16px;height:calc(100vh - 32px)}}
