:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box;margin:0;padding:0}body{background:#0f0f1a;color:#e2e8f0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.header{display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:56px;border-bottom:1px solid #1a1a2e;background:#08080f;flex-shrink:0}.header-left{display:flex;align-items:center;gap:12px}.logo{font-size:22px;font-weight:900;background:linear-gradient(135deg,#6366f1,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-1px}.header-title{color:#374151;font-size:13px;font-weight:500}.header-right{display:flex;align-items:center;gap:10px}.update-time{font-size:12px;color:#374151}.refresh-btn{background:#13131f;border:1px solid #1e1e2e;color:#64748b;padding:7px 8px;border-radius:8px;cursor:pointer;display:flex;align-items:center;transition:all .15s}.refresh-btn:hover{background:#1e1e2e;color:#94a3b8;border-color:#2e2e42}.layout{display:flex;flex:1;overflow:hidden;width:100%}.main{flex:1;padding:28px 36px;overflow-y:auto;min-width:0;display:flex;flex-direction:column;gap:28px}.loading{text-align:center;padding:80px;color:#374151;font-size:15px}.section{display:flex;flex-direction:column;gap:16px}.section-title{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#4b5563}.cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.card{background:#111120;border:1px solid #1a1a2e;border-radius:14px;padding:20px 22px;transition:border-color .2s,transform .15s}.card:hover{border-color:#2a2a42;transform:translateY(-1px)}.card-header{display:flex;align-items:center;gap:9px;margin-bottom:14px}.card-label{font-size:12px;color:#4b5563;font-weight:500}.card-value{font-size:36px;font-weight:800;color:#f8fafc;letter-spacing:-1px;line-height:1}.card-sub{font-size:12px;color:#374151;margin-top:6px}.chart-card{background:#111120;border:1px solid #1a1a2e;border-radius:14px;padding:20px 24px;flex:1}.chart-title{font-size:11px;color:#4b5563;font-weight:600;letter-spacing:.05em;margin-bottom:14px;text-transform:uppercase}.process-list{display:flex;flex-direction:column;gap:8px}.process-item{display:flex;align-items:center;gap:14px;background:#111120;border:1px solid #1a1a2e;border-radius:10px;padding:14px 20px;transition:border-color .2s}.process-item:hover{border-color:#2a2a42}.process-name{flex:1;font-weight:600;font-size:14px;color:#cbd5e1}.process-status{font-size:12px;font-weight:500;min-width:60px}.process-status.online{color:#22c55e}.process-status.stopped,.process-status.errored{color:#ef4444}.process-cpu,.process-mem{color:#4b5563;font-size:12px;min-width:70px;text-align:right}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0f0f1a}.login-box{background:#111120;border:1px solid #1a1a2e;border-radius:20px;padding:48px 40px;display:flex;flex-direction:column;align-items:center;gap:18px;width:340px;box-shadow:0 25px 60px #00000080}.login-logo{font-size:42px;font-weight:900;background:linear-gradient(135deg,#6366f1,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-2px}.login-sub{color:#374151;font-size:13px;margin-top:-12px}.login-input{width:100%;background:#1a1a2e;border:1px solid #2a2a42;border-radius:12px;color:#e2e8f0;padding:12px 16px;font-size:15px;outline:none;text-align:center;letter-spacing:3px;transition:border-color .2s}.login-input:focus{border-color:#6366f1}.login-error{color:#ef4444;font-size:13px}.login-btn{width:100%;background:linear-gradient(135deg,#6366f1,#7c3aed);border:none;border-radius:12px;color:#fff;padding:13px;font-size:15px;font-weight:700;cursor:pointer;transition:opacity .2s,transform .15s}.login-btn:hover{opacity:.9;transform:translateY(-1px)}.login-btn:disabled{background:#1a1a2e;color:#374151;cursor:not-allowed;transform:none}.sidebar{width:380px;flex-shrink:0;border-left:1px solid #1a1a2e;display:flex;flex-direction:column;background:#08080f}.chat-panel{display:flex;flex-direction:column;height:100%}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid #1a1a2e;flex-shrink:0}.chat-header-left{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:700;color:#cbd5e1}.chat-status{font-size:11px;font-weight:600}.chat-status.online{color:#22c55e}.chat-status.offline{color:#ef4444}.chat-messages{flex:1;overflow-y:auto;padding:16px 14px;display:flex;flex-direction:column;gap:4px;scrollbar-width:thin;scrollbar-color:#1a1a2e transparent}.chat-empty{color:#374151;font-size:13px;text-align:center;padding:30px 0}.chat-msg{display:flex}.msg-bot{justify-content:flex-start}.msg-user{justify-content:flex-end}.msg-bubble{max-width:82%;padding:9px 13px;border-radius:14px;font-size:13.5px;line-height:1.45}.msg-bot .msg-bubble{background:#16162a;border-bottom-left-radius:4px;color:#e2e8f0}.msg-user .msg-bubble{background:#312e81;border-bottom-right-radius:4px;color:#f0f0ff}.msg-name{font-size:11px;color:#6366f1;font-weight:700;margin-bottom:4px}.msg-text{word-break:break-word;white-space:pre-wrap}.msg-voice{display:flex;align-items:center;gap:6px;color:#6b7280;font-size:12px;font-style:italic}.msg-time{font-size:10px;color:#374151;margin-top:5px;text-align:right}.chat-input-area{display:flex;align-items:flex-end;gap:8px;padding:14px;border-top:1px solid #1a1a2e;flex-shrink:0}.chat-input{flex:1;background:#16162a;border:1px solid #2a2a42;border-radius:12px;color:#e2e8f0;padding:10px 14px;font-size:13.5px;resize:none;outline:none;font-family:inherit;max-height:120px;line-height:1.4;transition:border-color .2s}.chat-input:focus{border-color:#6366f1}.chat-input::placeholder{color:#374151}.chat-send{background:#6366f1;border:none;border-radius:12px;color:#fff;padding:10px 12px;cursor:pointer;display:flex;align-items:center;flex-shrink:0;transition:background .15s,transform .1s}.chat-send:hover{background:#4f46e5;transform:translateY(-1px)}.chat-send:disabled{background:#1a1a2e;color:#374151;cursor:not-allowed;transform:none}.chat-img-preview{padding:10px 14px 0;display:flex;align-items:center;gap:10px;flex-shrink:0}.chat-img-preview img{height:56px;width:56px;object-fit:cover;border-radius:8px;border:1px solid #2a2a42}.chat-img-cancel{background:#1a1a2e;border:1px solid #2a2a42;color:#94a3b8;border-radius:50%;width:20px;height:20px;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-img-cancel:hover{background:#450a0a;color:#ef4444;border-color:#ef4444}.chat-img-hint{font-size:11px;color:#374151}.msg-thinking{display:flex;align-items:center;gap:5px;padding:10px 14px!important}.dot{width:7px;height:7px;border-radius:50%;background:#6366f1;animation:bounce 1.2s infinite;display:inline-block}.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}.chat-action-btn{background:#16162a;border:1px solid #2a2a42;color:#64748b;padding:9px;border-radius:10px;cursor:pointer;display:flex;align-items:center;flex-shrink:0;transition:all .15s}.chat-action-btn:hover{background:#1e1e38;color:#94a3b8}.chat-action-btn.recording{background:#450a0a;border-color:#ef4444;color:#ef4444;animation:pulse 1s infinite}.chat-action-btn:disabled{opacity:.4;cursor:not-allowed}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#1e1e2e;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#2a2a42}
