:root{--bg-base: #111827;--bg-surface: #1f2937;--bg-elevated: #374151;--bg-terminal: #0d0d0d;--bg-input: #0f172a;--text-primary: #e5e7eb;--text-secondary: #9ca3af;--text-muted: #6b7280;--text-disabled: #4b5563;--accent: #5eead4;--accent-hover: #99f6e4;--accent-dim: #2dd4bf;--accent-bg: #134e4a;--terminal-text: #5eead4;--terminal-input: #fbbf24;--terminal-ts: #4b5563;--danger: #f87171;--danger-bg: #451a1a;--danger-border: #7f1d1d;--success: #86efac;--success-bg: #14532d;--success-border: #166534;--info: #93c5fd;--info-bg: #1e3a5f;--info-border: #1e40af;--font-xs: 11px;--font-sm: 13px;--font-base: 14px;--font-md: 16px;--font-lg: 18px;--font-xl: 20px;--font-2xl: 24px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--space-9: 36px;--space-10: 40px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg-base);color:var(--text-primary);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:var(--font-base);line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:40px;padding:var(--space-2) var(--space-4);border:1px solid transparent;border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--accent);color:var(--bg-base);border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn-secondary{background:var(--bg-elevated);color:var(--accent);border-color:var(--bg-elevated)}.btn-secondary:hover:not(:disabled){background:var(--text-disabled)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:var(--text-disabled)}.btn-ghost:hover:not(:disabled){color:var(--text-primary);border-color:var(--text-secondary)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}.btn-danger:hover:not(:disabled){background:var(--danger-border)}.btn-sm{min-height:32px;padding:var(--space-1) var(--space-3);font-size:var(--font-xs)}.form-input,.form-select{min-height:40px;padding:var(--space-2) var(--space-3);background:var(--bg-input);color:var(--text-primary);border:1px solid var(--text-disabled);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-sm);width:100%;transition:border-color .15s ease,box-shadow .15s ease}.form-input:focus,.form-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #5eead426}.form-input::placeholder{color:var(--text-muted)}.form-input:disabled{opacity:.5;cursor:not-allowed}.form-label{display:block;color:var(--text-secondary);font-size:var(--font-sm);font-weight:500;margin-bottom:var(--space-1)}.form-group{margin-bottom:var(--space-4)}.form-checkbox{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--font-sm);color:var(--text-secondary)}.form-checkbox input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}.card{background:var(--bg-surface);border:1px solid var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:0 1px 3px #0000004d,0 1px 2px #0003}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);color:var(--text-muted);font-size:var(--font-sm)}.page{max-width:960px;margin:0 auto;padding:var(--space-5);height:100%;overflow-y:auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.page-title{font-size:var(--font-xl);font-weight:600;color:var(--accent)}.nav-links{display:flex;gap:var(--space-4);align-items:center}.error-message{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--font-sm);margin-bottom:var(--space-4)}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:9999;display:flex;flex-direction:column;gap:var(--space-2)}.toast{padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:500;animation:slideIn .3s ease;max-width:360px;word-break:break-word}.toast-success{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.toast-error{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.toast-info{background:var(--info-bg);color:var(--info);border:1px solid var(--info-border)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.spinner{border:3px solid var(--bg-elevated);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}.spinner-sm{width:16px;height:16px;border-width:2px}.spinner-md{width:24px;height:24px}.spinner-lg{width:40px;height:40px;border-width:4px}@keyframes spin{to{transform:rotate(360deg)}}.terminal-output{background:var(--bg-terminal);font-family:Courier New,Courier,monospace;font-size:var(--font-base);padding:var(--space-3);overflow-y:auto;white-space:pre-wrap;word-wrap:break-word}.terminal-line{padding:1px 0;position:relative;font-family:Courier New,Courier,monospace}.terminal-line-output{color:var(--terminal-text)}.terminal-line-input{color:var(--terminal-input)}.terminal-line-command-block{background:var(--bg-surface);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);margin:var(--space-1) 0}.terminal-line-bookmark-marker{border-left:3px solid var(--accent);padding-left:var(--space-2);color:var(--accent-dim)}.terminal-timestamp{color:var(--terminal-ts);font-size:var(--font-xs);margin-right:var(--space-2)}.bookmark-icon{position:absolute;left:var(--space-2);top:50%;transform:translateY(-50%);opacity:.2;cursor:pointer;color:var(--text-muted);font-size:var(--font-sm);transition:opacity .15s,color .15s}.terminal-line:hover .bookmark-icon{opacity:.5}.bookmark-icon.active{opacity:1;color:var(--danger)}.terminal-input-container{display:flex;align-items:stretch;background:var(--bg-input);border-top:1px solid var(--bg-elevated)}.terminal-input{flex:1;min-height:40px;padding:var(--space-2) var(--space-3);background:transparent;color:var(--terminal-input);font-family:Courier New,Courier,monospace;font-size:var(--font-base);border:none;outline:none;white-space:pre-wrap;word-wrap:break-word;overflow-y:auto;max-height:120px}.terminal-input:empty:before{content:attr(data-placeholder);color:var(--text-muted)}.terminal-input.disabled{opacity:.4;pointer-events:none}.history-arrows{display:flex;flex-direction:column;justify-content:center;gap:2px;padding:var(--space-1)}.history-arrows button{background:var(--bg-elevated);border:none;color:var(--text-secondary);cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm);font-size:var(--font-xs)}.history-arrows button:active{background:var(--accent-bg)}.client-page{display:flex;flex-direction:column;height:100%}.client-topbar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--bg-surface);border-bottom:1px solid var(--bg-elevated);flex-wrap:wrap}.client-topbar-right{display:flex;align-items:center;gap:var(--space-3);margin-left:auto}.client-output-area{flex:1;overflow:hidden;display:flex;flex-direction:column}.mobile-buttons{display:flex;gap:var(--space-2);padding:var(--space-2) var(--space-3);overflow-x:auto;background:var(--bg-surface);border-top:1px solid var(--bg-elevated);-webkit-overflow-scrolling:touch}.mobile-buttons button{flex-shrink:0;background:var(--bg-elevated);color:var(--accent);border:1px solid var(--accent-bg);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);font-family:inherit;font-size:var(--font-sm);cursor:pointer;white-space:nowrap;min-height:36px}.mobile-buttons button:active{background:var(--accent-bg)}.character-select{min-width:160px}.settings-section{margin-bottom:var(--space-8)}.settings-section h2{font-size:var(--font-lg);font-weight:600;color:var(--accent);margin-bottom:var(--space-4);padding-bottom:var(--space-2);border-bottom:1px solid var(--bg-elevated)}.settings-list{display:flex;flex-direction:column;gap:var(--space-3)}.settings-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--bg-elevated)}.settings-item-actions{display:flex;gap:var(--space-2)}.logs-page{display:flex;height:100%}.logs-sidebar{width:280px;min-width:280px;background:var(--bg-surface);border-right:1px solid var(--bg-elevated);display:flex;flex-direction:column;overflow-y:auto}.logs-sidebar-section{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--bg-elevated)}.logs-sidebar-section h3{font-size:var(--font-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.5px}.logs-date-list{display:flex;flex-direction:column;gap:2px}.logs-date-item{padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-sm);color:var(--text-secondary);transition:all .1s}.logs-date-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.logs-date-item.active{background:var(--accent-bg);color:var(--accent)}.logs-bookmark-item{padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-xs);color:var(--text-muted);transition:all .1s}.logs-bookmark-item:hover{background:var(--bg-elevated);color:var(--text-secondary)}.logs-bookmark-note{color:var(--accent-dim)}.logs-bookmark-preview{color:var(--text-disabled);font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.logs-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.logs-header{padding:var(--space-3) var(--space-4);background:var(--bg-surface);border-bottom:1px solid var(--bg-elevated);display:flex;align-items:center;justify-content:space-between}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-5)}.auth-card{width:100%;max-width:400px}.auth-title{text-align:center;font-size:var(--font-2xl);font-weight:600;color:var(--accent);margin-bottom:var(--space-6)}.auth-footer{text-align:center;margin-top:var(--space-4);font-size:var(--font-sm);color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4)}.modal{background:var(--bg-surface);border:1px solid var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--space-6);max-width:480px;width:100%}.modal h3{font-size:var(--font-lg);font-weight:600;color:var(--danger);margin-bottom:var(--space-4)}.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-5)}.highlight-rule{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--bg-surface);border-radius:var(--radius-sm)}.highlight-color-preview{width:20px;height:20px;border-radius:var(--radius-sm);border:1px solid var(--bg-elevated)}.bookmark-flash{animation:flashHighlight 1.5s ease-out}@keyframes flashHighlight{0%{background:var(--accent-bg)}to{background:transparent}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-disabled)}.app-layout{display:flex;height:100vh}.app-main{flex:1;overflow:hidden;height:100vh}.sidebar-collapsed .app-main{padding-left:44px}.sidebar{width:180px;min-width:180px;background:var(--bg-surface);border-right:1px solid var(--bg-elevated);display:flex;flex-direction:column;justify-content:space-between;transition:width .2s ease,min-width .2s ease,transform .2s ease;overflow:hidden}.sidebar:not(.open){width:0;min-width:0;border-right:none}.sidebar-toggle{position:fixed;top:var(--space-2);left:var(--space-2);z-index:101;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-surface);border:1px solid var(--bg-elevated);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-lg);cursor:pointer;line-height:1}.sidebar-toggle:hover{color:var(--text-primary);border-color:var(--text-secondary)}.sidebar-toggle:active{background:var(--bg-elevated)}.sidebar-overlay{display:none}.sidebar-nav{display:flex;flex-direction:column;padding:var(--space-3);padding-top:48px;gap:var(--space-1)}.sidebar-link{display:block;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-sm);font-weight:500;transition:all .15s ease;text-decoration:none}.sidebar-link:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar-link.active{background:var(--accent-bg);color:var(--accent)}.sidebar-footer{padding:var(--space-3);border-top:1px solid var(--bg-elevated);display:flex;flex-direction:column;gap:var(--space-2)}.sidebar-username{font-size:var(--font-sm);color:var(--text-muted);padding:0 var(--space-3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.terminal-output{font-size:var(--font-xs)}.sidebar{position:fixed;top:0;left:0;width:180px;min-width:180px;height:100vh;z-index:100;transform:translate(-100%);box-shadow:none;transition:transform .2s ease}.sidebar:not(.open){width:180px;min-width:180px;border-right:1px solid var(--bg-elevated)}.sidebar.open{transform:translate(0);box-shadow:4px 0 16px #0006}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:99;background:#00000080}.logs-sidebar{width:220px;min-width:220px}}
