@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400 600;font-display:swap;src:url(/tor-ts/assets/jetbrains-mono-D-8-_w7P.woff2) format("woff2")}@font-face{font-family:Outfit;font-style:normal;font-weight:300 700;font-display:swap;src:url(/tor-ts/assets/outfit-DKci6EPJ.woff2) format("woff2")}:root{--bg-primary: #0a0e17;--bg-secondary: #121a2b;--bg-tertiary: #1a2540;--bg-elevated: #1f2d4a;--text-primary: #e8edf5;--text-secondary: #8b99b3;--text-muted: #5a6a8a;--accent-primary: #7c5cff;--accent-secondary: #00d4aa;--accent-tertiary: #ff6b9d;--accent-glow: rgba(124, 92, 255, .4);--status-connecting: #ffa726;--status-connected: #00d4aa;--status-error: #ff5252;--status-disconnected: #5a6a8a;--border-color: rgba(124, 92, 255, .2);--border-subtle: rgba(255, 255, 255, .06);--shadow-glow: 0 0 30px rgba(124, 92, 255, .15);--font-sans: "Outfit", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:radial-gradient(ellipse at 20% 0%,rgba(124,92,255,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(0,212,170,.06) 0%,transparent 50%),var(--bg-primary)}#app{min-height:100vh;display:flex;flex-direction:column}.warning-banner{display:flex;align-items:center;gap:10px;padding:6px 24px;background:#ff52521f;border-bottom:1px solid rgba(255,82,82,.25);color:#ff8a80;font-size:12px}.warning-icon{font-size:14px;flex-shrink:0}.warning-text{flex:1}.warning-text strong{color:#ff5252}.warning-dismiss{background:transparent;border:none;color:#ff8a80;font-size:14px;cursor:pointer;padding:2px;opacity:.7;transition:opacity .2s}.warning-dismiss:hover{opacity:1}.header{display:flex;align-items:center;justify-content:space-between;padding:8px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle)}.logo{display:flex;align-items:center;gap:8px}.onion-icon{font-size:20px;filter:drop-shadow(0 0 6px rgba(124,92,255,.5))}.logo-text{font-size:18px;font-weight:600;letter-spacing:-.3px}.logo .accent{color:var(--accent-primary)}.status-container{display:flex;align-items:center;gap:8px;padding:4px 12px;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.status-indicator{width:8px;height:8px;border-radius:50%;background:var(--status-disconnected);transition:background-color .3s,box-shadow .3s}.status-indicator.connecting{background:var(--status-connecting);box-shadow:0 0 10px var(--status-connecting);animation:pulse 1.5s ease-in-out infinite}.status-indicator.connected{background:var(--status-connected);box-shadow:0 0 10px var(--status-connected)}.status-indicator.error{background:var(--status-error);box-shadow:0 0 10px var(--status-error)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{font-size:11px;font-weight:500;color:var(--text-secondary);font-family:var(--font-mono)}.main{flex:1;display:flex;flex-direction:column;padding:16px 24px;gap:16px;max-width:1200px;width:100%;margin:0 auto}.url-bar-container{display:flex;gap:8px;align-items:center}.nav-buttons{display:flex;gap:4px}.nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .15s}.nav-btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}.nav-btn:active:not(:disabled){transform:scale(.95)}.nav-btn:disabled{opacity:.4;cursor:not-allowed}.url-bar{display:flex;align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:4px;flex:1;transition:border-color .2s,box-shadow .2s}.url-bar:focus-within{border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.url-prefix{display:flex;align-items:center;padding:0 8px 0 12px}.lock-icon{font-size:14px;opacity:.7}#url-input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:13px;font-family:var(--font-mono);padding:8px 0;min-width:200px}#url-input::placeholder{color:var(--text-muted)}.browse-btn{display:flex;align-items:center;justify-content:center;min-width:50px;padding:8px 16px;background:linear-gradient(135deg,var(--accent-primary) 0%,#5a3fd4 100%);color:#fff;border:none;border-radius:var(--radius-md);font-size:13px;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:transform .15s,box-shadow .15s}.browse-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #7c5cff59}.browse-btn:active:not(:disabled){transform:translateY(0)}.browse-btn:disabled{opacity:.6;cursor:not-allowed}.btn-loading{display:flex;align-items:center}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.mode-tabs{display:flex;gap:4px;background:var(--bg-secondary);padding:4px;border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.mode-tab{padding:6px 16px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);font-size:12px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all .2s}.mode-tab:hover{color:var(--text-secondary)}.mode-tab.active{background:var(--accent-primary);color:#fff}.content-area{flex:1;display:flex;flex-direction:column;min-height:0}.mode-panel{flex:1;display:flex;flex-direction:column;gap:12px;min-height:0}.mode-panel[hidden]{display:none}.circuit-panel{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.circuit-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle)}.circuit-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.circuit-status{font-size:11px;font-family:var(--font-mono);color:var(--text-muted)}.circuit-path{display:flex;align-items:stretch;justify-content:center;padding:16px;gap:0;overflow-x:auto}.circuit-segment{display:flex;align-items:center;flex-shrink:0}.circuit-segment.last .circuit-connection{display:none}.circuit-node{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 12px;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-subtle);min-width:80px;position:relative;transition:border-color .2s}.circuit-node.connected{border-color:var(--status-connected)}.circuit-node.connecting{border-color:var(--status-connecting)}.node-icon{font-size:20px}.node-info{text-align:center}.node-label{font-size:10px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.node-name{font-size:10px;font-family:var(--font-mono);color:var(--text-muted);max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.node-status{position:absolute;top:6px;right:6px;width:6px;height:6px;border-radius:50%;background:var(--status-disconnected)}.node-status.connected{background:var(--status-connected);box-shadow:0 0 6px var(--status-connected)}.node-status.connecting{background:var(--status-connecting);box-shadow:0 0 6px var(--status-connecting);animation:pulse 1s ease-in-out infinite}.circuit-connection{display:flex;flex-direction:column;align-items:center;padding:0 4px;min-width:50px}.connection-line{width:100%;height:2px;background:var(--border-subtle);position:relative}.connection-line:after{content:"→";position:absolute;right:-4px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:12px}.circuit-segment .circuit-node.connected+.circuit-connection .connection-line{background:linear-gradient(90deg,var(--status-connected),var(--border-subtle))}.connection-protocol{font-size:9px;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;margin-top:4px;padding:2px 6px;background:var(--bg-primary);border-radius:var(--radius-sm)}.consensus-panel{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.consensus-panel.downloading{border-color:var(--accent-primary);box-shadow:0 0 20px #7c5cff26}.consensus-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle)}.consensus-title{font-size:12px;font-weight:600;color:var(--text-secondary)}.consensus-status{font-size:11px;font-family:var(--font-mono);color:var(--text-muted)}.consensus-cached{padding:12px 16px}.consensus-cached[hidden]{display:none}.cached-info{display:flex;justify-content:space-between;gap:16px}.cached-stat{display:flex;flex-direction:column;gap:2px}.cached-badge,.cached-badge.fresh{color:var(--status-connected)!important}.cached-badge.valid{color:var(--status-connecting)!important}.consensus-refresh{background:transparent;border:1px solid var(--border-subtle);color:var(--text-muted);padding:3px 10px;border-radius:var(--radius-sm);font-size:11px;cursor:pointer;transition:all .2s;margin-left:auto}.consensus-refresh:hover{color:var(--text-primary);border-color:var(--text-muted)}.consensus-refresh[hidden]{display:none}.consensus-downloading{padding:12px 16px}.consensus-downloading[hidden]{display:none}.progress-bar-container{width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden;margin-bottom:12px}.progress-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);border-radius:3px;transition:width .3s ease;box-shadow:0 0 8px #7c5cff80}.progress-stats{display:flex;justify-content:space-between;gap:16px}.progress-stat{display:flex;flex-direction:column;gap:2px}.stat-label{font-size:10px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:13px;font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.log-panel{flex:1;min-height:150px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.log-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle)}.log-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.log-clear{background:transparent;border:1px solid var(--border-subtle);color:var(--text-muted);padding:3px 10px;border-radius:var(--radius-sm);font-size:11px;cursor:pointer;transition:color .2s,border-color .2s}.log-clear:hover{color:var(--text-primary);border-color:var(--text-muted)}.log-content{flex:1;overflow-y:auto;padding:10px 16px;font-family:var(--font-mono);font-size:11px;line-height:1.7}.log-entry{display:flex;gap:10px}.log-time{color:var(--text-muted);flex-shrink:0}.log-message{color:var(--text-secondary)}.log-message.success{color:var(--accent-secondary)}.log-message.error{color:var(--status-error)}.log-message.info{color:var(--accent-primary)}.browser-panel{flex:1;display:flex;flex-direction:column;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;min-height:400px}.browser-info-bar{display:flex;align-items:center;padding:6px 12px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle)}.browser-info{font-size:10px;color:var(--text-muted)}.content-iframe{flex:1;width:100%;border:none;background:#fff}.footer{padding:8px 24px;background:var(--bg-secondary);border-top:1px solid var(--border-subtle);text-align:center}.footer p{font-size:11px;color:var(--text-muted)}.footer strong{color:var(--accent-secondary);font-weight:500}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}[hidden]{display:none!important}@media(max-width:900px){.url-bar-container{flex-direction:column}.url-bar{width:100%}.mode-tabs{width:100%;justify-content:center}.circuit-path{padding:12px}}@media(max-width:600px){.main{padding:12px 16px}.header{padding:8px 16px}.warning-banner{padding:6px 16px}.circuit-node{min-width:65px;padding:8px}.node-icon{font-size:16px}.circuit-connection{min-width:35px}}
