:root{--bg:#0f1117;--surface:#1a1d27;--surface-hover:#222633;--border:#2a2e3d;--text:#e1e4ed;--text-dim:#8b8fa3;--green:#22c55e;--green-bg:#22c55e1a;--yellow:#eab308;--yellow-bg:#eab3081a;--red:#ef4444;--red-bg:#ef44441a;--blue:#3b82f6;--purple:#a855f7;--grey:#6b7280}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{min-height:100vh}.dashboard{max-width:1400px;margin:0 auto;padding:24px}.header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:16px;display:flex}.header h1{align-items:center;gap:10px;font-size:24px;font-weight:600;display:flex}.header-right{align-items:center;gap:16px;display:flex}.health-summary{gap:12px;font-size:14px;display:flex}.health-pill{background:var(--surface);border:1px solid var(--border);border-radius:20px;align-items:center;gap:6px;padding:4px 12px;display:flex}.refresh-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;transition:background .2s;display:flex}.refresh-btn:hover{background:var(--surface-hover)}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.host-stats-section{margin-bottom:32px}.host-stats-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.host-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px}.host-card-header{align-items:center;gap:8px;margin-bottom:16px;font-size:15px;font-weight:600;display:flex}.gauges-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.gauge{flex-direction:column;align-items:center;gap:6px;display:flex}.gauge-ring{width:64px;height:64px;position:relative}.gauge-ring svg{width:64px;height:64px;transform:rotate(-90deg)}.gauge-ring .gauge-bg{fill:none;stroke:var(--border);stroke-width:5px}.gauge-ring .gauge-fill{fill:none;stroke-width:5px;stroke-linecap:round;transition:stroke-dashoffset .6s,stroke .3s}.gauge-value{font-family:ui-monospace,monospace;font-size:13px;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.gauge-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.gauge-detail{color:var(--text-dim);text-align:center;font-size:10px}.env-section{margin-bottom:32px}.env-title{align-items:center;gap:8px;margin-bottom:16px;font-size:16px;font-weight:600;display:flex}.env-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600}.env-badge.prod{background:var(--red-bg);color:var(--red)}.env-badge.dev{color:var(--blue);background:#3b82f626}.stacks-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.stack-card{background:var(--surface);border:2px solid var(--border);cursor:pointer;border-radius:12px;padding:20px;transition:all .2s;position:relative;overflow:hidden}.stack-card:before{content:"";height:4px;position:absolute;top:0;left:0;right:0}.stack-card.health-healthy{border-color:#22c55e4d}.stack-card.health-healthy:before{background:var(--green)}.stack-card.health-degraded{border-color:#eab3084d}.stack-card.health-degraded:before{background:var(--yellow)}.stack-card.health-unhealthy{border-color:#ef44444d}.stack-card.health-unhealthy:before{background:var(--red)}.stack-card.health-error{border-color:#6b72804d}.stack-card.health-error:before{background:var(--grey)}.stack-card:hover{background:var(--surface-hover);transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.stack-card.expanded{grid-column:1/-1}.stack-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.stack-name{align-items:center;gap:10px;font-size:18px;font-weight:600;display:flex}.health-indicator{text-transform:uppercase;letter-spacing:.5px;border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-flex}.health-indicator.healthy{background:var(--green-bg);color:var(--green)}.health-indicator.degraded{background:var(--yellow-bg);color:var(--yellow)}.health-indicator.unhealthy{background:var(--red-bg);color:var(--red);animation:2s ease-in-out infinite pulse-red}.health-indicator.error{color:var(--grey);background:#6b72801a}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.7}}.status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.status-dot.healthy{background:var(--green);box-shadow:0 0 8px var(--green)}.status-dot.degraded{background:var(--yellow);box-shadow:0 0 8px var(--yellow)}.status-dot.unhealthy{background:var(--red);box-shadow:0 0 8px var(--red)}.status-dot.error{background:var(--grey)}.status-dot.lg{width:14px;height:14px}.stack-meta{color:var(--text-dim);gap:16px;font-size:13px;display:flex}.stack-meta span{align-items:center;gap:4px;display:flex}.services-list{border-top:1px solid var(--border);margin-top:16px;padding-top:12px}.service-row{border-bottom:1px solid #2a2e3d80;justify-content:space-between;align-items:center;padding:8px 0;font-size:14px;display:flex}.service-row:last-child{border-bottom:none}.service-name{align-items:center;gap:8px;font-weight:500;display:flex}.service-info{color:var(--text-dim);align-items:center;gap:12px;font-size:12px;display:flex}.replicas{border-radius:4px;padding:2px 8px;font-family:ui-monospace,monospace;font-size:12px}.replicas.ok{background:var(--green-bg);color:var(--green)}.replicas.warn{background:var(--yellow-bg);color:var(--yellow)}.replicas.bad{background:var(--red-bg);color:var(--red)}.image-tag{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.loading{height:60vh;color:var(--text-dim);justify-content:center;align-items:center;font-size:18px;display:flex}.error-banner{background:var(--red-bg);border:1px solid var(--red);color:var(--red);border-radius:8px;margin-bottom:24px;padding:12px 16px;font-size:14px}.last-updated{color:var(--text-dim);font-size:12px}.deploy-section{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:32px;padding:20px}.deploy-section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.deploy-section-title{margin:0;font-size:16px;font-weight:600}.deploy-summary{color:var(--text-dim);font-size:13px}.deploy-table-wrapper{overflow-x:auto}.deploy-table{border-collapse:collapse;width:100%;font-size:13px}.deploy-table th{text-align:left;border-bottom:2px solid var(--border);color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;padding:8px 12px;font-size:11px;font-weight:600}.deploy-table td{vertical-align:middle;border-bottom:1px solid #2a2e3d80;padding:8px 12px}.deploy-project-cell{border-right:2px solid var(--border);font-size:14px;font-weight:600}.deploy-project-name{align-items:center;gap:6px;display:flex}.deploy-svc-name{font-family:ui-monospace,monospace;font-size:12px}.deploy-ref{color:var(--text-dim);text-overflow:ellipsis;white-space:nowrap;max-width:100px;font-family:ui-monospace,monospace;font-size:11px;overflow:hidden}.source-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:600}.source-badge.source-ghcr{color:var(--blue);background:#3b82f626}.source-badge.source-git{color:#a855f7;background:#a855f726}.deploy-badge{white-space:nowrap;border-radius:12px;padding:3px 8px;font-size:11px;font-weight:600}.deploy-badge-ok{background:var(--green-bg);color:var(--green)}.deploy-badge-pending{background:var(--yellow-bg);color:var(--yellow)}.refresh-svc-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;transition:all .2s;display:flex}.refresh-svc-btn:hover{background:var(--surface-hover);color:var(--text)}.refresh-svc-btn:disabled{opacity:.4;cursor:not-allowed}tr.deploy-pending{background:#eab3080a}.deploy-log{border-top:1px solid var(--border);margin-top:20px;padding-top:16px}.deploy-log-title{margin:0 0 12px;font-size:14px;font-weight:600}.deploy-log-list{flex-direction:column;gap:6px;display:flex}.deploy-log-entry{background:#2a2e3d4d;border-radius:6px;align-items:center;gap:10px;padding:6px 8px;font-size:12px;display:flex}.deploy-log-time{color:var(--text-dim);min-width:70px;font-family:ui-monospace,monospace;font-size:11px}.deploy-log-event{text-transform:uppercase;text-align:center;border-radius:4px;min-width:100px;padding:2px 6px;font-size:10px;font-weight:600}.event-badge-ok{background:var(--green-bg);color:var(--green)}.event-badge-fail{background:var(--red-bg);color:var(--red)}.deploy-log-service{min-width:140px;font-family:ui-monospace,monospace;font-weight:500}.deploy-log-detail{color:var(--text-dim);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}@media (width<=768px){.dashboard{padding:16px}.stacks-grid{grid-template-columns:1fr}.header{flex-direction:column;align-items:flex-start;gap:12px}.gauges-grid{grid-template-columns:repeat(2,1fr)}.deploy-table{font-size:11px}.deploy-table th,.deploy-table td{padding:6px 8px}.deploy-log-entry{flex-wrap:wrap}}
