:root{--bg-primary:#0F0A1A;--bg-secondary:#1A1128;--bg-tertiary:#241B35;--bg-glass:rgba(30,20,50,0.6);--border:rgba(108,99,255,0.15);--border-hover:rgba(108,99,255,0.35);--text-primary:#F0ECF6;--text-secondary:#A89EC8;--text-muted:#6E5F8A;--accent:#6C63FF;--cyan:#00D9FF;--pink:#FF6B9D;--green:#4ADE80;--yellow:#FFD93D;--orange:#FB923C;--red:#EF4444;--radius:8px;--transition:0.2s cubic-bezier(0.4,0,0.2,1);--font:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;--mono:'SF Mono','Fira Code','Cascadia Code',monospace}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased}
.app-container{display:flex;flex-direction:column;height:100vh}
.app-header{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:12px 20px;z-index:10;flex-shrink:0}
.header-content{display:flex;align-items:center;justify-content:space-between}
.logo-group{display:flex;align-items:center;gap:12px}
.logo-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,rgba(108,99,255,0.15),rgba(74,222,128,0.1));border-radius:var(--radius);border:1px solid var(--border)}
.app-header h1{font-size:1.1rem;font-weight:700;background:linear-gradient(135deg,var(--accent),var(--green));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.header-actions{display:flex;gap:8px}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:none;border-radius:var(--radius);font-family:var(--font);font-size:0.8rem;font-weight:600;cursor:pointer;transition:all var(--transition);white-space:nowrap}
.btn:disabled{opacity:0.4;cursor:not-allowed}
.btn-primary{background:linear-gradient(135deg,var(--accent),#8B5CF6);color:#fff;box-shadow:0 2px 12px rgba(108,99,255,0.3)}
.btn-primary:hover{box-shadow:0 4px 20px rgba(108,99,255,0.5);transform:translateY(-1px)}
.btn-secondary{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border)}
.btn-secondary:hover{border-color:var(--border-hover);color:var(--text-primary)}
.btn-ghost{background:transparent;color:var(--text-muted)}
.btn-ghost:hover{color:var(--text-secondary);background:rgba(255,255,255,0.05)}
.main-content{display:flex;flex:1;overflow:hidden}
.editor-panel{display:flex;flex-direction:column;width:50%;border-right:1px solid var(--border)}
.panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--bg-secondary)}
.panel-title{font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--text-muted)}
.editor-wrapper{display:flex;flex:1;overflow:hidden}
.line-numbers{padding:12px 8px 12px 12px;background:var(--bg-secondary);color:var(--text-muted);font-family:var(--mono);font-size:0.78rem;line-height:1.6;text-align:right;user-select:none;overflow:hidden;min-width:40px;border-right:1px solid var(--border)}
.yaml-editor{flex:1;padding:12px;background:var(--bg-primary);color:var(--text-primary);font-family:var(--mono);font-size:0.78rem;line-height:1.6;border:none;resize:none;outline:none;overflow:auto;tab-size:2}
.yaml-editor::placeholder{color:var(--text-muted)}
.results-panel{display:flex;flex-direction:column;width:50%;overflow:hidden}
.tabs{display:flex;background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:0 8px;gap:2px}
.tab{padding:10px 16px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-family:var(--font);font-size:0.82rem;font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;gap:6px}
.tab:hover{color:var(--text-secondary)}
.tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.badge{background:var(--bg-tertiary);color:var(--text-muted);padding:1px 7px;border-radius:10px;font-size:0.7rem;font-weight:700}
.tab.active .badge{background:rgba(108,99,255,0.2);color:var(--accent)}
.tab-content{display:none;flex:1;overflow-y:auto;padding:16px}
.tab-content.active{display:flex;flex-direction:column}
.empty-results{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;flex:1;text-align:center;color:var(--text-muted);padding:40px}
.empty-results p{font-size:0.9rem}
.issues-list{list-style:none;display:flex;flex-direction:column;gap:8px}
.issue-item{display:flex;gap:12px;padding:12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--transition)}
.issue-item:hover{border-color:var(--border-hover)}
.issue-icon{flex-shrink:0;width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:0.85rem}
.issue-icon.error{background:rgba(239,68,68,0.12);color:var(--red)}
.issue-icon.warning{background:rgba(251,146,60,0.12);color:var(--orange)}
.issue-icon.info{background:rgba(0,217,255,0.1);color:var(--cyan)}
.issue-icon.success{background:rgba(74,222,128,0.12);color:var(--green)}
.issue-body{flex:1;min-width:0}
.issue-title{font-size:0.85rem;font-weight:600;margin-bottom:2px}
.issue-desc{font-size:0.78rem;color:var(--text-secondary);line-height:1.4}
.issue-line{font-size:0.72rem;color:var(--text-muted);margin-top:4px;font-family:var(--mono)}
.diagram-container{flex:1;display:flex;flex-direction:column;gap:16px}
.job-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:14px;transition:border-color var(--transition)}
.job-card:hover{border-color:var(--border-hover)}
.job-name{font-size:0.9rem;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.job-name .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.job-needs{font-size:0.72rem;color:var(--text-muted);margin-bottom:8px;font-family:var(--mono)}
.step-list{display:flex;flex-direction:column;gap:4px}
.step-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-primary);border-radius:6px;font-size:0.78rem;color:var(--text-secondary)}
.step-item .step-num{font-family:var(--mono);color:var(--text-muted);font-size:0.7rem;min-width:20px}
.step-item .uses-tag{font-family:var(--mono);font-size:0.7rem;color:var(--accent);background:rgba(108,99,255,0.1);padding:1px 6px;border-radius:4px;margin-left:auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}
.info-cards{display:flex;flex-direction:column;gap:12px}
.info-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.info-card h3{font-size:0.82rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:8px}
.info-card .info-value{font-size:0.88rem;color:var(--text-primary);font-weight:500}
.info-tags{display:flex;flex-wrap:wrap;gap:6px}
.info-tag{padding:3px 10px;border-radius:20px;font-size:0.75rem;font-weight:600;border:1px solid}
.info-tag.trigger{border-color:var(--green);color:var(--green);background:rgba(74,222,128,0.08)}
.info-tag.secret{border-color:var(--yellow);color:var(--yellow);background:rgba(255,217,61,0.08)}
.info-tag.env{border-color:var(--cyan);color:var(--cyan);background:rgba(0,217,255,0.08)}
@media(max-width:768px){.main-content{flex-direction:column}.editor-panel,.results-panel{width:100%}.editor-panel{max-height:40vh;border-right:none;border-bottom:1px solid var(--border)}.app-header h1{font-size:0.95rem}}
.yaml-editor::-webkit-scrollbar,.tab-content::-webkit-scrollbar{width:6px}
.yaml-editor::-webkit-scrollbar-track,.tab-content::-webkit-scrollbar-track{background:transparent}
.yaml-editor::-webkit-scrollbar-thumb,.tab-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
