*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0f;--bg2: #12121a;--bg3: #1a1a25;--border: #1e1e2e;--text: #e2e8f0;--text2: #94a3b8;--text3: #64748b;--green: #22c55e;--green-dim: rgba(34, 197, 94, .15);--red: #ef4444;--red-dim: rgba(239, 68, 68, .15);--blue: #3b82f6;--blue-dim: rgba(59, 130, 246, .15);--accent: #6366f1;--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--mono: "JetBrains Mono", "Fira Code", monospace}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}.app{min-height:100%;display:flex;flex-direction:column}.header{background:var(--bg2);border-bottom:1px solid var(--border);padding:0 24px;position:sticky;top:0;z-index:10}.header-inner{max-width:1100px;margin:0 auto;height:60px;display:flex;align-items:center;justify-content:space-between;gap:16px}.header-left{display:flex;align-items:center;gap:12px;color:var(--text)}.header-left h1{font-size:15px;font-weight:600;line-height:1.2}.site-link{font-size:11px;color:var(--text3);text-decoration:none;display:flex;align-items:center;gap:4px;transition:color .15s}.site-link:hover{color:var(--accent)}.header-right{display:flex;align-items:center;gap:12px}.repo-link{font-size:12px;color:var(--text3);text-decoration:none;font-family:var(--mono);transition:color .15s}.repo-link:hover{color:var(--text)}.refresh-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);border-radius:6px;padding:6px 8px;cursor:pointer;display:flex;align-items:center;transition:background .15s,color .15s}.refresh-btn:hover{background:var(--border);color:var(--text)}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.live-indicator{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:600;letter-spacing:.5px;padding:3px 10px;border-radius:20px;transition:all .3s}.live-indicator.live{background:var(--green-dim);color:var(--green);border:1px solid rgba(34,197,94,.3)}.live-indicator.live svg{animation:pulse-glow 1.5s ease-in-out infinite}.live-indicator.disconnected{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3)}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.4}}.main{max-width:1100px;margin:0 auto;padding:24px;width:100%;flex:1}.stats-bar{display:flex;gap:12px;margin-bottom:20px}.stat{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:12px 20px;display:flex;flex-direction:column;min-width:80px}.stat-num{font-size:24px;font-weight:700;line-height:1}.stat-label{font-size:11px;color:var(--text3);margin-top:4px}.stat-success .stat-num{color:var(--green)}.stat-failed .stat-num{color:var(--red)}.stat-building .stat-num{color:var(--blue)}.filter-bar{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.filter-btn{background:transparent;border:1px solid var(--border);color:var(--text3);border-radius:6px;padding:5px 14px;font-size:12px;font-family:var(--font);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px}.filter-btn:hover{border-color:var(--text3);color:var(--text2)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.pulse-dot{width:6px;height:6px;background:var(--blue);border-radius:50%;animation:pulse-dot-anim 1s ease-in-out infinite}@keyframes pulse-dot-anim{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.7}}.deploy-list{display:flex;flex-direction:column;gap:8px}.state-msg{text-align:center;color:var(--text3);padding:48px 0;font-size:14px}.state-msg.error{color:var(--red)}.deploy-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .15s,box-shadow .3s}.deploy-card:hover{border-color:#2e2e3e}.deploy-card.success .deploy-header{border-left:3px solid var(--green)}.deploy-card.failed .deploy-header{border-left:3px solid var(--red)}.deploy-card.building .deploy-header{border-left:3px solid var(--blue)}.deploy-card.new-card{animation:slide-in .3s ease-out,glow-blue 1.5s ease-out}@keyframes slide-in{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes glow-blue{0%{box-shadow:0 0 #3b82f666}50%{box-shadow:0 0 0 4px #3b82f61a}to{box-shadow:0 0 #3b82f600}}.deploy-header{padding:14px 16px;display:flex;align-items:flex-start;justify-content:space-between;cursor:pointer;gap:12px}.deploy-left{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0}.deploy-info{flex:1;min-width:0}.deploy-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.deploy-branch{font-size:14px;font-weight:600;color:var(--text)}.deploy-commit{display:flex;align-items:center;gap:4px;font-size:12px;font-family:var(--mono);color:var(--text3);background:var(--bg3);padding:1px 7px;border-radius:4px}.deploy-badge{font-size:10px;font-weight:600;padding:1px 7px;border-radius:4px;letter-spacing:.5px}.deploy-badge.success{background:var(--green-dim);color:var(--green)}.deploy-badge.failed{background:var(--red-dim);color:var(--red)}.deploy-badge.building{background:var(--blue-dim);color:var(--blue);animation:pulse-badge 1.5s ease-in-out infinite}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.7}}.deploy-meta{display:flex;align-items:center;gap:12px;font-size:11px;color:var(--text3);margin-bottom:4px}.deploy-meta span{display:flex;align-items:center;gap:4px}.deploy-message{font-size:12px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:600px}.deploy-right{display:flex;align-items:center}.expand-btn{background:none;border:none;color:var(--text3);cursor:pointer;padding:4px;display:flex;border-radius:4px;transition:background .15s,color .15s}.expand-btn:hover{background:var(--bg3);color:var(--text)}.deploy-logs{border-top:1px solid var(--border);background:var(--bg)}.logs-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border)}.logs-title{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}.logs-id{font-size:10px;font-family:var(--mono);color:var(--text3)}.logs-content{padding:12px 16px;max-height:400px;overflow-y:auto;font-family:var(--mono);font-size:12px;line-height:1.7}.logs-content::-webkit-scrollbar{width:6px}.logs-content::-webkit-scrollbar-track{background:var(--bg)}.logs-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.log-line{color:var(--text2);white-space:pre-wrap;word-break:break-all}.log-error{color:var(--red)}.log-warn{color:#f59e0b}.log-building{color:var(--blue)}.cursor-blink{display:inline-block;animation:blink .8s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.spinner-ring{display:inline-block;width:16px;height:16px;border:2px solid var(--blue-dim);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:640px){.stats-bar{display:grid;grid-template-columns:1fr 1fr}.deploy-message{display:none}}
