:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Microsoft YaHei,sans-serif;line-height:1.5;font-weight:400;--miku-green: #39C5BB;--miku-green-light: #E0F2F1;--miku-green-dark: #00B894;color:#333;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--miku-green);text-decoration:inherit}a:hover{color:var(--miku-green-dark)}body{margin:0;min-width:320px;min-height:100vh;background-color:#fff}h1{font-size:2em;line-height:1.1;color:var(--miku-green)}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--miku-green);color:#fff;cursor:pointer;transition:all .25s ease}button:hover{background-color:var(--miku-green-dark);box-shadow:0 4px 12px #39c5bb4d}button:focus,button:focus-visible{outline:3px solid var(--miku-green-light)}.card{padding:2em;background:#f8fffe;border-radius:12px;border:1px solid var(--miku-green-light)}#app{max-width:1400px;margin:0 auto;padding:2rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Microsoft YaHei,sans-serif;background:#fff;color:#333;min-height:100vh}.dashboard{max-width:1400px;margin:0 auto;padding:20px}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #39C5BB}.header h1{font-size:1.8rem;color:#39c5bb;font-weight:700;display:flex;align-items:center;gap:12px}.header-logo{height:40px;width:auto}.last-update{color:#666;font-size:.9rem}.servers-section{margin-bottom:30px}.servers-section h2{margin-bottom:20px;color:#39c5bb;font-weight:700}.servers-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px}.server-card{background:#f8fffe;border-radius:16px;padding:20px;border:1px solid #e0f2f1;box-shadow:0 2px 12px #39c5bb1a;transition:transform .2s,box-shadow .2s}.server-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px #39c5bb33}.server-card.host-server{border:2px solid #39C5BB;background:linear-gradient(135deg,#f8fffe,#e8f8f7)}.server-header{display:flex;align-items:center;gap:12px;margin-bottom:15px;padding-bottom:12px;border-bottom:1px solid #e0f2f1}.cloud-icon{width:36px;height:36px;border-radius:8px}.server-title{flex:1}.server-title h3{font-size:1.1rem;color:#2d3436;margin-bottom:2px}.server-badge{display:inline-block;font-size:.7rem;padding:2px 8px;background:#39c5bb;color:#fff;border-radius:10px}.server-badge.agent-badge{background:#6c5ce7;margin-left:8px}.metric-bar-inline{flex:1;height:8px;background:#e0f2f1;border-radius:4px;overflow:hidden}.server-info{margin-bottom:12px}.info-compact{display:flex;justify-content:space-between;font-size:.85rem;color:#666}.server-charts{margin:15px 0}.chart-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.chart-label{width:40px;font-size:.8rem;color:#666;font-weight:500}.sparkline-large{flex:1;height:40px;background:#f0fffe;border-radius:6px}.chart-value-large{width:55px;font-size:.9rem;color:#39c5bb;font-weight:600;text-align:right}.status-online{color:#00b894;text-shadow:0 0 8px #00B894;font-size:1.2rem}.status-offline{color:#d63031;text-shadow:0 0 8px #d63031;font-size:1.2rem}.resource-detail{display:flex;justify-content:space-between;font-size:.85rem;color:#666;padding-top:10px;border-top:1px solid #e0f2f1}.services-section{margin-top:30px}.services-section h2{margin-bottom:20px;color:#39c5bb;font-weight:700}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:15px}.service-card{background:#f8fffe;border-radius:12px;padding:16px;border:1px solid #e0f2f1;box-shadow:0 2px 8px #39c5bb14;transition:all .2s ease}.service-card:hover{box-shadow:0 4px 16px #39c5bb26;transform:translateY(-1px)}.service-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid #e0f2f1}.service-icon{width:28px;height:28px;border-radius:6px}.service-name{font-weight:600;font-size:.95rem;color:#2d3436;flex:1}.server-tag{font-size:.65rem;padding:2px 6px;border-radius:8px;font-weight:500;white-space:nowrap}.tag-tencent{background:#e0f2f1;color:#39c5bb}.tag-alicloud{background:#fff3e0;color:#ff9800}.tag-agent{background:#f3e5f5;color:#8e44ad;border:1px solid #e1bee7}.tag-default{background:#f5f5f5;color:#666}.tag-icon{width:14px;height:14px;border-radius:2px}.tag-icon-svg{width:14px;height:14px}.server-tag{display:flex;align-items:center;gap:3px}.network-values{display:flex;flex-direction:column;width:70px;font-size:.65rem;font-weight:500;line-height:1.2}.net-in{color:#6c5ce7}.net-out{color:#fd79a8}.service-charts{display:flex;flex-direction:column;gap:10px}.chart-container{display:flex;align-items:center;gap:8px}.sparkline{flex:1;height:30px;background:#f0fffe;border-radius:4px}.status-dot{width:10px;height:10px;border-radius:50%;box-shadow:0 0 4px currentColor}.chart-value{width:60px;font-size:.75rem;color:#39c5bb;font-weight:600;text-align:right}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:#666;gap:15px}.spinner{width:40px;height:40px;border:3px solid #e0f2f1;border-top-color:#39c5bb;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error{background:#fff5f5;border:1px solid #fed7d7;padding:20px;border-radius:12px;text-align:center;color:#d63031}@media(max-width:768px){.servers-grid{grid-template-columns:1fr}.header{flex-direction:column;gap:10px;text-align:center}.services-grid{grid-template-columns:1fr}.info-compact{flex-direction:column;gap:4px}.agents-grid{grid-template-columns:1fr}}.agents-section{margin-top:30px}.agents-section h2{margin-bottom:20px;color:#39c5bb;font-weight:700}.agents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.agent-card{background:#f8fffe;border-radius:16px;padding:20px;border:1px solid #e0f2f1;box-shadow:0 2px 12px #39c5bb1a;transition:transform .2s,box-shadow .2s}.agent-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px #39c5bb33}.agent-icon-svg{width:32px;height:32px}.agent-card.agent-offline{opacity:.6;border-color:#ddd}.agent-header{display:flex;align-items:center;gap:12px;margin-bottom:15px;padding-bottom:12px;border-bottom:1px solid #e0f2f1}.agent-icon{font-size:28px;color:#6c5ce7;display:flex;align-items:center}.agent-title{flex:1}.agent-title h3{font-size:1.1rem;color:#2d3436;margin-bottom:2px}.agent-hostname{font-size:.8rem;color:#888}.agent-info{display:flex;justify-content:space-between;font-size:.8rem;color:#666;margin-bottom:15px}.agent-metrics{margin:15px 0}.metric-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.metric-label{width:40px;font-size:.8rem;color:#666;font-weight:500}.metric-bar{flex:1;height:8px;background:#e0f2f1;border-radius:4px;overflow:hidden}.metric-fill{height:100%;border-radius:4px;transition:width .3s ease}.metric-fill.cpu-fill{background:linear-gradient(90deg,#39c5bb,#00d9d0)}.metric-fill.mem-fill{background:linear-gradient(90deg,#00b894,#00e6a0)}.metric-fill.disk-fill{background:linear-gradient(90deg,#fdcb6e,#ffeaa7)}.metric-value{width:50px;font-size:.85rem;color:#39c5bb;font-weight:600;text-align:right}.agent-detail{display:flex;justify-content:space-between;font-size:.8rem;color:#666;padding-top:10px;border-top:1px solid #e0f2f1}.agent-last-seen{margin-top:10px;font-size:.75rem;color:#999;text-align:right}
