:root{--bg: #0b0d10;--panel: #14181d;--panel-alt: #1b2026;--border: #262c33;--text: #e6e6e6;--muted: #8b94a0;--accent: #7aa2f7;--alice: #a6e3a1;--bob: #f5c2e7;--server: #fab387;--system: #94e2d5;--warn: #f9e2af;--error: #f38ba8;--mono: "SF Mono", "Menlo", "Consolas", "Liberation Mono", monospace;color-scheme:dark}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;width:100%}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5}button{font-family:inherit;font-size:13px;padding:6px 12px;background:var(--panel-alt);color:var(--text);border:1px solid var(--border);border-radius:4px;cursor:pointer}button:hover:not(:disabled){border-color:var(--accent)}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--accent);color:#0b0d10;border-color:var(--accent)}button.warn{background:var(--warn);color:#0b0d10;border-color:var(--warn)}button.danger{background:var(--error);color:#0b0d10;border-color:var(--error)}input,textarea{font-family:inherit;font-size:13px;padding:6px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;width:100%}input:focus,textarea:focus{outline:none;border-color:var(--accent)}.app{display:grid;grid-template-columns:1fr 1fr;height:100vh;width:100vw;overflow:hidden}.panel{display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--border)}.panel:last-child{border-right:none}.panel-header{padding:10px 14px;background:var(--panel);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px}.panel-header h2{margin:0;font-size:14px;font-weight:600}.panel-header .subtitle{color:var(--muted);font-size:12px}.panel-body{flex:1;overflow-y:auto;padding:12px}.row{display:flex;gap:12px}.col{display:flex;flex-direction:column;gap:8px}.card{background:var(--panel);border:1px solid var(--border);border-radius:6px;overflow:hidden}.card-header{padding:8px 12px;background:var(--panel-alt);border-bottom:1px solid var(--border);font-weight:600;font-size:13px;display:flex;align-items:center;justify-content:space-between}.card-body{padding:10px 12px}.muted{color:var(--muted)}.mono{font-family:var(--mono);font-size:12px;word-break:break-all}.actor-Alice{color:var(--alice)}.actor-Bob{color:var(--bob)}.actor-Server{color:var(--server)}.actor-System{color:var(--system)}.level-warn{color:var(--warn)}.level-error{color:var(--error)}.inboxes{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.inbox{display:flex;flex-direction:column;min-height:200px}.inbox-messages{padding:8px 12px;display:flex;flex-direction:column;gap:6px;min-height:180px;max-height:40vh;overflow-y:auto}.msg{padding:6px 8px;border-radius:4px;background:var(--panel-alt);border-left:3px solid var(--border);font-size:13px}.msg.from-Alice{border-left-color:var(--alice)}.msg.from-Bob{border-left-color:var(--bob)}.msg.failed{border-left-color:var(--error);opacity:.8}.msg .meta{font-size:11px;color:var(--muted);margin-top:2px}.compose{display:flex;gap:6px;padding:8px 12px;border-top:1px solid var(--border);background:var(--panel-alt)}.compose input{flex:1}.attack-row{display:flex;flex-wrap:wrap;gap:6px}.server-memory{display:flex;flex-direction:column;gap:6px}.server-memory-entry{padding:8px;background:var(--panel-alt);border:1px solid var(--border);border-radius:4px;font-size:12px}.server-memory-entry .row{gap:6px;margin-top:4px}.server-memory-entry button{font-size:11px;padding:3px 8px}.log-controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.filter-chip{padding:3px 8px;border-radius:12px;border:1px solid var(--border);background:var(--panel-alt);font-size:12px;cursor:pointer}.filter-chip.on{background:var(--accent);color:#0b0d10;border-color:var(--accent)}.event-list{display:flex;flex-direction:column;gap:6px}.event{border:1px solid var(--border);border-left:3px solid var(--border);border-radius:4px;background:var(--panel);overflow:hidden}.event.event-warn{border-left-color:var(--warn)}.event.event-error{border-left-color:var(--error)}.event-head{padding:6px 10px 4px;display:flex;gap:10px;align-items:baseline;cursor:pointer;font-size:12px}.event-head:hover{background:var(--panel-alt)}.event-head .actor{font-weight:600;min-width:50px}.event-head .op{font-family:var(--mono);color:var(--muted)}.event-head .time{color:var(--muted);font-size:11px}.event-head .event-expand{margin-left:auto;color:var(--muted);font-size:11px}.event-lines{padding:2px 10px 8px;display:grid;grid-template-columns:max-content 1fr;column-gap:10px;row-gap:3px;font-size:12px;line-height:1.45}.event-line{display:contents}.event-line-label{color:var(--muted);font-size:11px;letter-spacing:.02em;white-space:nowrap;padding-top:1px;-webkit-user-select:none;user-select:none}.event-line-body{color:var(--text);word-break:break-word}.event-line-command .event-line-body{color:var(--text);font-size:12px}.event-line-paper .event-line-body{color:var(--accent)}.event-line-paper .event-line-label{color:var(--accent);opacity:.85}.event.event-error .event-line-natural .event-line-body{color:var(--error)}.event-body{padding:10px 12px;border-top:1px solid var(--border);background:var(--panel-alt)}.event-body-title{font-size:11px;color:var(--muted);margin-bottom:6px;letter-spacing:.05em;text-transform:uppercase}.kv{display:grid;grid-template-columns:max-content 1fr;gap:4px 10px;font-size:12px;margin-top:4px}.kv .k{color:var(--muted);font-family:var(--mono)}.kv .v{font-family:var(--mono);word-break:break-all}.modal-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:16px;max-width:80vw;max-height:80vh;overflow:auto;min-width:500px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.modal-header h3{margin:0}.tour-launcher{position:fixed;bottom:16px;right:16px;z-index:80}.tour-launcher button{background:var(--accent);color:#0b0d10;border-color:var(--accent);box-shadow:0 2px 8px #0006;font-weight:600}.tour-panel{position:fixed;bottom:16px;right:16px;width:360px;max-width:calc(100vw - 32px);max-height:calc(100vh - 32px);overflow-y:auto;background:var(--panel);border:1px solid var(--accent);border-radius:8px;padding:14px 14px 12px;z-index:80;box-shadow:0 4px 16px #00000080}.tour-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.tour-step-count{font-size:11px;color:var(--muted);letter-spacing:.05em;text-transform:uppercase}.tour-title{margin:4px 0 8px;font-size:15px;color:var(--accent)}.tour-body{margin:0 0 10px;font-size:13px;line-height:1.55;color:var(--text)}.tour-hint{margin-bottom:10px;padding:6px 8px;background:var(--panel-alt);border-left:2px solid var(--accent);font-size:12px;color:var(--muted)}.tour-error{margin-bottom:10px;padding:6px 8px;background:var(--panel-alt);border-left:2px solid var(--error);font-size:12px;color:var(--error)}.tour-panel-footer{display:flex;justify-content:space-between;gap:8px;margin-top:6px}.event.event-highlight{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 12px #7aa2f759;transition:box-shadow .2s ease-in-out,border-color .2s ease-in-out}
