:root{font-family:Inter,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}}.layout{display:flex;min-height:100vh;background:hsl(var(--background))}.sidebar{background:hsl(var(--card));color:hsl(var(--foreground));display:flex;flex-direction:column;position:fixed;left:0;top:0;width:260px;height:100vh;z-index:1000;border-right:1px solid hsl(var(--border));box-shadow:4px 0 24px #0000001f}[data-theme=dark] .sidebar{background:#020817;border-right:1px solid rgba(255,255,255,.08)}.sidebar-header{padding:1.5rem 1.25rem;border-bottom:1px solid hsl(var(--border));display:flex;align-items:center}[data-theme=dark] .sidebar-header{border-bottom:1px solid rgba(255,255,255,.08)}.logo{display:flex;align-items:center;gap:.75rem;font-size:1.125rem;font-weight:700}.logo-svg{color:hsl(var(--primary));flex-shrink:0}[data-theme=dark] .logo-svg{color:#60a5fa}.logo-text{color:hsl(var(--foreground));white-space:nowrap;letter-spacing:-.02em}[data-theme=dark] .logo-text{color:#fff}.nav-menu{flex:1;padding:.75rem;overflow-y:auto;overflow-x:hidden}.nav-item{width:100%;position:relative;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;margin-bottom:.25rem;background:transparent;border:none;border-radius:.5rem;color:hsl(var(--muted-foreground));cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);text-align:left;font-family:inherit}.nav-item:hover{background:hsl(var(--accent));color:hsl(var(--accent-foreground))}[data-theme=dark] .nav-item:hover{background:#ffffff0f;color:#e2e8f0}.nav-item.active{background:hsl(var(--primary) / .12);color:hsl(var(--primary))}[data-theme=dark] .nav-item.active{background:#3b82f61f;color:#60a5fa}.nav-item.active .nav-icon{color:hsl(var(--primary))}[data-theme=dark] .nav-item.active .nav-icon{color:#60a5fa}.nav-item.active .nav-label{color:#fff;font-weight:600}.nav-item.active .nav-description{color:#94a3b8}.nav-icon{width:20px;height:20px;min-width:20px;display:flex;align-items:center;justify-content:center;color:hsl(var(--muted-foreground));transition:color .15s}.nav-item:hover .nav-icon{color:hsl(var(--accent-foreground))}[data-theme=dark] .nav-icon{color:#64748b}[data-theme=dark] .nav-item:hover .nav-icon{color:#cbd5e1}.nav-content{display:flex;flex-direction:column;gap:.125rem;overflow:hidden;flex:1}.nav-label{font-size:.875rem;font-weight:500;white-space:nowrap;color:inherit;transition:color .15s}.nav-description{font-size:.75rem;opacity:.65;white-space:nowrap;color:inherit;transition:opacity .15s}.nav-indicator{position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:#60a5fa;border-radius:0 2px 2px 0;box-shadow:0 0 8px #60a5fa66}.sidebar-footer{padding:1rem;border-top:1px solid hsl(var(--border));background:hsl(var(--muted) / .3)}[data-theme=dark] .sidebar-footer{border-top:1px solid rgba(255,255,255,.08);background:#0003}.user-info{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;padding:.5rem;border-radius:.5rem;background:#ffffff08}.user-avatar{width:36px;height:36px;min-width:36px;border-radius:8px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;color:#fff;box-shadow:0 2px 8px #3b82f64d}.user-details{overflow:hidden;flex:1;min-width:0}.user-name{font-size:.875rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:hsl(var(--foreground))}[data-theme=dark] .user-name{color:#fff}.user-email{font-size:.75rem;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:hsl(var(--muted-foreground))}[data-theme=dark] .user-email{color:#94a3b8}.logout-btn{width:100%;padding:.625rem 1rem;background:hsl(var(--destructive) / .1);border:1px solid hsl(var(--destructive) / .2);color:hsl(var(--destructive));border-radius:.5rem;cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:.5rem}.logout-btn:hover{background:hsl(var(--destructive) / .15);border-color:hsl(var(--destructive) / .3);transform:translateY(-1px);box-shadow:0 2px 8px hsl(var(--destructive) / .2)}[data-theme=dark] .logout-btn{background:#ef44441a;border-color:#ef444433;color:#fca5a5}[data-theme=dark] .logout-btn:hover{background:#ef444426;border-color:#ef44444d;color:#f87171}.logout-btn svg{width:16px;height:16px}.theme-toggle-btn{width:100%;padding:.625rem 1rem;margin-bottom:.5rem;background:hsl(var(--accent));border:1px solid hsl(var(--border));color:hsl(var(--accent-foreground));border-radius:.5rem;cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:.5rem}.theme-toggle-btn:hover{background:hsl(var(--accent) / .8);transform:translateY(-1px)}.theme-toggle-btn svg{width:16px;height:16px}[data-theme=dark] .theme-toggle-btn{background:#ffffff0d;border-color:#ffffff1a;color:#cbd5e1}[data-theme=dark] .theme-toggle-btn:hover{background:#ffffff1a;color:#e2e8f0}.main-content{flex:1;margin-left:260px;height:100vh;background:hsl(var(--background));transition:margin-left .2s ease,background-color .2s;overflow-y:auto;overflow-x:hidden;position:relative}.nav-menu::-webkit-scrollbar{width:6px}.nav-menu::-webkit-scrollbar-track{background:transparent}.nav-menu::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.nav-menu::-webkit-scrollbar-thumb:hover{background:#ffffff40}@media (max-width: 768px){.sidebar{transform:translate(-100%);box-shadow:none}.main-content{margin-left:0!important}}.login-page{min-height:100vh;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#0f172a}.login-background{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0;background:radial-gradient(circle at top left,#1e293b,#0f172a)}.bg-shape{position:absolute;filter:blur(80px);border-radius:50%;z-index:1;opacity:.4}.bg-shape-1{width:500px;height:500px;background:#3b82f6;top:-100px;left:-100px;animation:float 20s infinite alternate}.bg-shape-2{width:400px;height:400px;background:#6366f1;bottom:-50px;right:-50px;animation:float 15s infinite alternate-reverse}@keyframes float{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.login-container{position:relative;z-index:10;width:100%;max-width:440px;padding:2rem;animation:fadeIn .8s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-card{background:#ffffff0d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:1.5rem;padding:3rem;box-shadow:0 25px 50px -12px #00000080}.login-header{text-align:center;margin-bottom:2.5rem}.login-brand{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1rem}.brand-logo{color:#3b82f6;background:#3b82f61a;padding:.5rem;border-radius:.75rem;display:flex;align-items:center;justify-content:center}.brand-name{font-size:1.75rem;font-weight:700;color:#fff;margin:0;letter-spacing:-.025em}.login-subtitle{color:#94a3b8;font-size:.9375rem;margin:0}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{font-size:.8125rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.form-input{background:#0f172a99;border:1px solid rgba(255,255,255,.1);border-radius:.75rem;padding:.875rem 1rem;color:#fff;font-size:1rem;transition:all .2s ease}.form-input::placeholder{color:#475569}.form-input:focus{outline:none;border-color:#3b82f6;background:#0f172acc;box-shadow:0 0 0 4px #3b82f626}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#fca5a5;padding:1rem;border-radius:.75rem;font-size:.875rem;display:flex;align-items:center;gap:.75rem}.login-button{margin-top:.5rem;background:#3b82f6;color:#fff;border:none;border-radius:.75rem;padding:1rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.login-button:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 10px 15px -3px #3b82f64d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.button-loader{display:flex;align-items:center;gap:.75rem}.spinner{animation:rotate 2s linear infinite;width:20px;height:20px}.spinner .path{stroke:#fff;stroke-linecap:round;animation:dash 1.5s ease-in-out infinite}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.login-footer{text-align:center;margin-top:2rem;color:#64748b;font-size:.8125rem}@media (max-width: 480px){.login-container{padding:1rem}.login-card{padding:2rem}}.dashboard-container{padding:2rem;max-width:1400px;margin:0 auto;background:hsl(var(--background));min-height:100vh}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.dashboard-header h1{font-size:2.25rem;font-weight:700;color:hsl(var(--foreground));margin-bottom:.5rem;letter-spacing:-.02em}:root .dashboard-header h1{color:#020817;font-weight:800}[data-theme=dark] .dashboard-header h1{color:hsl(var(--foreground));text-shadow:0 1px 3px rgba(0,0,0,.3)}.dashboard-subtitle{font-size:.875rem;color:hsl(var(--muted-foreground));margin:0}:root .dashboard-subtitle{color:#606f85;font-weight:500}[data-theme=dark] .dashboard-subtitle{color:hsl(var(--muted-foreground));opacity:.9}.btn-refresh{padding:.625rem 1rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:calc(var(--radius) - 2px);cursor:pointer;font-size:.875rem;font-weight:500;color:hsl(var(--foreground));transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}.btn-refresh:hover{background:hsl(var(--accent));border-color:hsl(var(--accent))}.btn-refresh svg{width:16px;height:16px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-bottom:2rem}.stat-card{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:var(--radius);padding:1.5rem;transition:all .2s;box-shadow:0 1px 2px #0000000d;display:flex;flex-direction:column;justify-content:space-between;min-height:160px;box-sizing:border-box;position:relative;overflow:hidden}.stat-success-bar,.stat-error-bar{height:3px;border-radius:999px;margin-bottom:.5rem;opacity:.8}.stat-success-bar{background:#16a249}.stat-error-bar{background:#ef4343}[data-theme=dark] .stat-success-bar{background:#1fe066}[data-theme=dark] .stat-error-bar{background:#f37272}:root .stat-card{background:#fff;border:1px solid hsl(214.3 31.8% 91.4%);box-shadow:0 1px 3px #0000000d}[data-theme=dark] .stat-card{background:hsl(var(--card) / .4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid hsl(var(--border) / .5);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.stat-card:hover{transform:translateY(-2px);border-color:hsl(var(--primary) / .3)}.stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.stat-label{font-size:.75rem;font-weight:600;color:hsl(var(--muted-foreground));text-transform:uppercase;letter-spacing:.05em}.stat-icon{font-size:1.25rem;opacity:.7}.stat-value{font-size:2rem;font-weight:700;color:hsl(var(--foreground));margin-bottom:.5rem;line-height:1.1}.stat-footer{display:flex;flex-direction:column;gap:.125rem;margin-top:auto}.stat-change{font-size:.8125rem;font-weight:600;display:inline-flex;align-items:center;gap:.25rem}.stat-description{font-size:.7rem;color:hsl(var(--muted-foreground));opacity:.8}.dashboard-section{background:hsl(var(--card));border:1px solid hsl(var(--border) / .6);border-radius:var(--radius);padding:1.5rem;margin-bottom:2rem;width:100%;box-sizing:border-box}:root .dashboard-section{background:#fff;border:1px solid hsl(214.3 31.8% 91.4%)}[data-theme=dark] .dashboard-section{background:hsl(var(--card) / .3);border:1px solid hsl(var(--border) / .4)}.table-wrapper{width:100%;overflow-x:auto;border-radius:calc(var(--radius) - 2px);border:1px solid hsl(var(--border) / .6);background:transparent}.data-table{width:100%;border-collapse:collapse;background:transparent}.data-table thead{background:hsl(var(--muted) / .3)}.data-table th{padding:.75rem 1rem;font-size:.75rem;font-weight:600;color:hsl(var(--muted-foreground));text-align:left;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid hsl(var(--border) / .6);white-space:nowrap}.data-table td{padding:1rem;border-bottom:1px solid hsl(var(--border) / .4);font-size:.8125rem;color:hsl(var(--foreground));vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:hsl(var(--accent) / .3)}.data-table th:last-child,.data-table td:last-child{text-align:right;width:100px}.data-table code{background:hsl(var(--muted) / .5);padding:.125rem .375rem;border-radius:4px;font-size:.75rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,monospace;color:hsl(var(--primary));border:1px solid hsl(var(--border) / .5)}:root .data-table code{background:#f1f5f9;border:1px solid hsl(214.3 31.8% 85%);color:#020817;font-weight:500}[data-theme=dark] .data-table code{background:hsl(var(--muted) / .5);border:1px solid hsl(var(--border));color:hsl(var(--foreground))}.flow-name-cell{display:flex;flex-direction:column;gap:.25rem}:root .flow-name{font-weight:600;color:#020817}[data-theme=dark] .flow-name{font-weight:600;color:hsl(var(--foreground))}.flow-description{font-size:.75rem;color:hsl(var(--muted-foreground))}:root .flow-description{color:#606f85;font-weight:500}[data-theme=dark] .flow-description{color:hsl(var(--muted-foreground));opacity:.85}.date-cell{color:hsl(var(--muted-foreground));font-size:.8125rem}:root .date-cell{color:#606f85;font-weight:500}[data-theme=dark] .date-cell{color:hsl(var(--muted-foreground));opacity:.9}.no-data{text-align:center;padding:3rem!important;color:hsl(var(--muted-foreground))}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize;border:1px solid transparent}.badge-success{background:#16a2491a;color:#16a249;border-color:#16a24933}:root .badge-success{background:#16a24926;color:#12873d;border-color:#16a2494d;font-weight:600}[data-theme=dark] .badge-success{background:#16a24933;color:#1fe066;border-color:#16a24966}.badge-error{background:#ef43431a;color:#ef4343;border-color:#ef434333}:root .badge-error{background:#ef434326;color:#eb1414;border-color:#ef43434d;font-weight:600}[data-theme=dark] .badge-error{background:#ef434333;color:#f37272;border-color:#ef434366}.badge-warning{background:#f59f0a1a;color:#f59f0a;border-color:#f59f0a33}:root .badge-warning{background:#f59f0a26;color:#c47f08;border-color:#f59f0a4d;font-weight:600}[data-theme=dark] .badge-warning{background:#f59f0a33;color:#f7b23b;border-color:#f59f0a66}.badge-info{background:#3c83f61a;color:#3c83f6;border-color:#3c83f633}:root .badge-info{background:#3c83f626;color:#0b64f4;border-color:#3c83f64d;font-weight:600}[data-theme=dark] .badge-info{background:#3c83f633;color:#6da2f8;border-color:#3c83f666}.badge-secondary{background:hsl(var(--muted));color:hsl(var(--muted-foreground));border-color:hsl(var(--border))}.progress-container{display:flex;align-items:center;gap:.5rem;width:100%}.progress-bar-wrapper{flex:1;height:.5rem;background:hsl(var(--muted));border-radius:9999px;overflow:hidden;position:relative}.progress-bar{height:100%;background:#16a249;border-radius:9999px;transition:width .3s}.progress-text{font-size:.75rem;font-weight:500;color:hsl(var(--muted-foreground));min-width:3rem;text-align:right}.btn-small{padding:.375rem .75rem;background:hsl(var(--primary));color:hsl(var(--primary-foreground));border:1px solid hsl(var(--primary));border-radius:calc(var(--radius) - 2px);cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.btn-small:hover{background:hsl(var(--primary) / .9);border-color:hsl(var(--primary) / .9)}@media (max-width: 768px){.dashboard-container{padding:1rem}.dashboard-header{flex-direction:column;gap:1rem}.dashboard-header h1{font-size:1.75rem}.stats-grid{grid-template-columns:1fr}.dashboard-section{padding:1rem}.section-header{flex-direction:column;gap:1rem}.table-wrapper{font-size:.75rem}.data-table th,.data-table td{padding:.5rem}}.flows-container{padding:1.5rem;max-width:1600px;margin:0 auto;min-height:calc(100vh - 4rem);background:hsl(var(--background))}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.header-content{display:flex;align-items:center;gap:1rem}.header-icon{width:48px;height:48px;background:hsl(var(--primary) / .1);border-radius:.75rem;display:flex;align-items:center;justify-content:center;color:hsl(var(--primary))}.header-content h1{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground));margin:0}.page-description{color:hsl(var(--muted-foreground));font-size:.875rem;margin:.25rem 0 0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.75rem;overflow:hidden;box-shadow:0 1px 3px #0000001a}.stat-card-content{padding:1.25rem;display:flex;justify-content:space-between;align-items:flex-start}.stat-info{display:flex;flex-direction:column;gap:.5rem}.stat-label{font-size:.75rem;font-weight:500;color:hsl(var(--muted-foreground));text-transform:uppercase;letter-spacing:.025em}.stat-value{font-size:1.75rem;font-weight:700;color:hsl(var(--foreground));line-height:1}.stat-icon{width:40px;height:40px;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.stat-icon-default{background:hsl(var(--muted));color:hsl(var(--muted-foreground))}.stat-icon-primary{background:hsl(var(--primary) / .1);color:hsl(var(--primary))}.stat-icon-success{background:#16a2491a;color:#16a249}.stat-icon-error{background:hsl(var(--destructive) / .1);color:hsl(var(--destructive))}.stat-bar{height:4px;width:100%}.stat-bar-default{background:hsl(var(--muted))}.stat-bar-primary{background:hsl(var(--primary))}.stat-bar-success{background:#16a249}.stat-bar-error{background:hsl(var(--destructive))}.search-filters-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.search-wrapper{flex:1;max-width:400px;position:relative;display:flex;align-items:center;background:#0f1729;border:1px solid hsl(var(--border));border-radius:.5rem;transition:all .2s}.search-wrapper:focus-within{border-color:hsl(var(--primary));box-shadow:0 0 0 2px hsl(var(--primary) / .15)}.search-wrapper .search-icon{position:absolute;left:.875rem;color:hsl(var(--muted-foreground));pointer-events:none}.search-wrapper input{width:100%;padding:.5rem 2.5rem;background:transparent!important;border:none;font-size:.875rem;color:hsl(var(--foreground));outline:none}.search-wrapper input::placeholder{color:hsl(var(--muted-foreground));opacity:1}.search-wrapper input:-webkit-autofill,.search-wrapper input:-webkit-autofill:hover,.search-wrapper input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 30px hsl(222 47% 11%) inset!important;-webkit-text-fill-color:hsl(var(--foreground))!important}.search-clear{position:absolute;right:.5rem;padding:.25rem;background:transparent;border:none;cursor:pointer;color:hsl(var(--muted-foreground));display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .15s}.search-clear:hover{color:hsl(var(--foreground));background:hsl(var(--muted))}.filter-buttons{display:flex;gap:.5rem}.filter-dropdown{position:relative}.filter-btn{padding:.5rem 1.75rem .5rem .75rem;background:#0f1729;border:1px solid hsl(var(--border));border-radius:.5rem;font-size:.8125rem;color:hsl(var(--muted-foreground));cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%236b7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;min-width:90px;transition:all .15s}.filter-btn:hover{border-color:hsl(var(--primary) / .5)}.filter-btn:focus{outline:none;border-color:hsl(var(--primary))}.filter-btn.active{background-color:hsl(var(--primary) / .1);border-color:hsl(var(--primary) / .3);color:hsl(var(--primary))}.results-row{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.results-count{font-size:.875rem;font-weight:500;color:hsl(var(--foreground))}.active-filters{display:flex;gap:.5rem;flex-wrap:wrap}.filter-chip{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .5rem .25rem .75rem;background:hsl(var(--muted));border-radius:9999px;font-size:.75rem;font-weight:500;color:hsl(var(--foreground))}.filter-chip button{display:flex;align-items:center;justify-content:center;padding:.125rem;background:transparent;border:none;cursor:pointer;color:hsl(var(--muted-foreground));border-radius:50%;transition:all .15s}.filter-chip button:hover{color:hsl(var(--foreground));background:hsl(var(--background))}.flows-table{width:100%;border-collapse:collapse}.flows-table thead tr{border-bottom:1px solid hsl(var(--border))}.flows-table th{padding:.625rem .75rem;font-size:.6875rem;font-weight:500;color:hsl(var(--muted-foreground));text-transform:uppercase;letter-spacing:.025em;text-align:left;background:transparent}.flows-table th.col-status{width:60px;text-align:center}.flows-table th.col-flow{min-width:250px}.flows-table th.col-type{width:80px}.flows-table th.col-layer{width:100px}.flows-table th.col-success,.flows-table th.col-lastrun{width:120px}.flows-table th.col-actions{width:130px;text-align:right}.flows-table tbody .table-row{cursor:pointer;transition:background .15s;border-bottom:1px solid hsl(var(--border))}.flows-table tbody .table-row:last-child{border-bottom:none}.flows-table tbody .table-row:hover{background:hsl(var(--muted) / .5)}.flows-table td{padding:.625rem .75rem;vertical-align:middle;color:hsl(var(--foreground));font-size:.8125rem}.flows-table td.col-status{text-align:center}.flows-table td.col-actions{text-align:right}.status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:#16a249}.status-dot.status-active{background:#16a249;animation:pulse-glow 2s ease-in-out infinite}.status-dot.status-inactive,.status-dot.status-archived{background:hsl(var(--muted-foreground))}.status-dot.status-error{background:hsl(var(--destructive));animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.5}}.flow-info{display:flex;flex-direction:column;gap:.125rem}.flow-name{font-weight:600;font-size:.8125rem;color:hsl(var(--foreground));line-height:1.2}.flow-desc{font-size:.75rem;color:hsl(var(--muted-foreground));line-height:1.2;max-width:280px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.type-badge{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:.375rem;font-size:.6875rem;font-weight:600;font-family:SF Mono,Monaco,Courier New,monospace;border:1px solid}.type-badge.type-odoo{background:#f59f0a1a;color:#f59f0a;border-color:#f59f0a33}.type-badge.type-sql{background:hsl(var(--primary) / .1);color:hsl(var(--primary));border-color:hsl(var(--primary) / .2)}.type-badge.type-api{background:#14b8a51a;color:#14b8a5;border-color:#14b8a533}.layer-badge{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:.375rem;font-size:.6875rem;font-weight:600;border:1px solid}.layer-badge.layer-bronze{background:#f974151a;color:#f97415;border-color:#f9741533}.layer-badge.layer-silver{background:#8b97a71a;color:#8b97a7;border-color:#8b97a733}.layer-badge.layer-gold{background:#e7b0081a;color:#e7b008;border-color:#e7b00833}.destination-code{display:inline-block;padding:.25rem .5rem;background:hsl(var(--muted));border-radius:.25rem;font-size:.75rem;font-family:SF Mono,Monaco,Courier New,monospace;color:hsl(var(--foreground))}.success-cell{display:flex;align-items:center;gap:.5rem}.success-bar{width:48px;height:6px;background:hsl(var(--muted));border-radius:3px;overflow:hidden}.success-fill{height:100%;border-radius:3px;transition:width .3s ease}.success-fill.high{background:#16a249}.success-fill.medium{background:#f59f0a}.success-fill.low{background:hsl(var(--destructive))}.success-text{font-size:.8125rem;font-weight:600;font-variant-numeric:tabular-nums}.success-text.high{color:#16a249}.success-text.medium{color:#f59f0a}.success-text.low{color:hsl(var(--destructive))}.lastrun-text{font-size:.8125rem;color:hsl(var(--muted-foreground))}.action-buttons{display:flex;align-items:center;justify-content:flex-end;gap:.125rem}.action-btn{width:28px;height:28px;border:none;border-radius:.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;background:transparent;color:hsl(var(--muted-foreground))}.action-btn:hover{background:hsl(var(--muted));color:hsl(var(--foreground))}.action-btn.run:hover:not(:disabled){background:#16a2491a;color:#16a249}.action-btn.run:disabled{opacity:.4;cursor:not-allowed}.action-btn.view:hover{background:hsl(var(--primary) / .1);color:hsl(var(--primary))}.action-btn.delete:hover{background:hsl(var(--destructive) / .1);color:hsl(var(--destructive))}.action-btn svg{width:14px;height:14px}.text-muted{color:hsl(var(--muted-foreground))}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem;padding:1rem}.pagination-btn{padding:.5rem 1rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.375rem;cursor:pointer;font-size:.8125rem;font-weight:500;color:hsl(var(--foreground));transition:all .15s}.pagination-btn:hover:not(:disabled){background:hsl(var(--muted))}.pagination-info{font-size:.8125rem;color:hsl(var(--muted-foreground));font-weight:500}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}.modal-content{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:1rem;width:100%;max-width:420px;box-shadow:0 20px 25px -5px #0003;animation:slideUp .2s ease}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid hsl(var(--border));background:hsl(var(--muted) / .5);border-radius:0 0 1rem 1rem}.btn-cancel:hover{background:hsl(var(--muted))}.btn-delete{padding:.5rem 1rem;background:hsl(var(--destructive));border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:600;color:hsl(var(--destructive-foreground));transition:all .15s}.btn-delete:hover{background:hsl(var(--destructive) / .9)}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1024px){.flows-table th.col-layer,.flows-table td.col-layer{display:none}}@media (max-width: 768px){.flows-container{padding:1rem}.stats-grid{grid-template-columns:1fr 1fr;gap:.75rem}.search-filters-row{flex-direction:column;align-items:stretch}.search-box{max-width:none}.filter-buttons{justify-content:flex-start;flex-wrap:wrap}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.flows-table th.col-destination,.flows-table td.col-destination,.flows-table th.col-success,.flows-table td.col-success{display:none}}.flow-detail-container{padding:0;max-width:1400px;margin:0 auto;min-height:100vh;position:relative;background:hsl(var(--background));height:100%;width:100%}.pipeline-info-section,.config-table-section,.dependencies-section,.section-tabs,.section-content{padding-left:2rem;padding-right:2rem}.pipeline-info-section{padding-top:1.5rem}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:hsl(var(--muted-foreground));gap:1rem}.error-state{text-align:center;padding:3rem;color:hsl(var(--destructive));font-size:1rem}.page-header-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1rem 2rem;border-bottom:1px solid hsl(var(--border));background:hsl(var(--card));position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #0000000d}.btn-back{padding:.5rem 1rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;color:hsl(var(--foreground));transition:all .2s ease;display:inline-flex;align-items:center;gap:.25rem}.btn-back:hover{background:hsl(var(--accent));border-color:hsl(var(--accent))}.header-actions{display:flex;gap:.5rem;align-items:center}.btn-danger{padding:.5rem 1rem!important;background:hsl(var(--card))!important;color:hsl(var(--muted-foreground))!important;border:1px solid hsl(var(--border))!important;border-radius:.5rem!important;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;display:inline-flex;align-items:center;gap:.375rem}.btn-danger:hover{background:hsl(var(--destructive) / .1)!important;color:hsl(var(--destructive))!important;border-color:hsl(var(--destructive) / .3)!important}.btn-primary{padding:.5rem 1.25rem;background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;display:inline-flex;align-items:center;gap:.375rem;box-shadow:0 1px 2px #4f46e526}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#4338ca,#4f46e5);box-shadow:0 4px 12px #4f46e540;transform:translateY(-1px)}.header-actions{display:flex;gap:.75rem;align-items:center;height:38px}.mode-selector{display:flex;gap:.5rem;align-items:center;height:100%}.header-actions .btn-primary,.header-actions .btn-danger,.mode-select,.btn-cancel-small{height:38px!important;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;margin:0}.mode-select{padding:0 2rem 0 .75rem;border:1px solid hsl(var(--border));border-radius:.5rem;font-size:.875rem;background:hsl(var(--card));color:hsl(var(--foreground));cursor:pointer}.btn-cancel-small{width:38px;border:1px solid hsl(var(--border));background:hsl(var(--card));border-radius:.5rem;cursor:pointer;font-size:1rem;color:hsl(var(--muted-foreground));transition:all .2s ease;padding:0}.btn-edit-outline{padding:.5rem 1rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;color:hsl(var(--foreground));transition:all .2s ease}.btn-edit-outline:hover{background:hsl(var(--accent));border-color:hsl(var(--border))}.btn-save{padding:.5rem 1rem;background:#10b981;color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s}.btn-save:hover{background:#059669}.btn-cancel-edit{padding:.5rem 1rem;background:transparent;color:hsl(var(--muted-foreground));border:none;cursor:pointer;font-size:.875rem;font-weight:500}.btn-cancel-edit:hover{color:hsl(var(--foreground))}.edit-info-fields{display:flex;flex-direction:column;gap:.75rem}.edit-input-title{font-size:1.5rem;font-weight:700;padding:.5rem;border:1px solid hsl(var(--border));border-radius:.375rem;color:hsl(var(--foreground));background:hsl(var(--card));width:100%}.edit-textarea-desc{font-size:.875rem;padding:.75rem;border:1px solid hsl(var(--border));border-radius:.375rem;color:hsl(var(--foreground));background:hsl(var(--card));width:100%;min-height:80px;resize:vertical}.edit-input{width:100%;padding:.375rem .5rem;border:1px solid hsl(var(--border));border-radius:.25rem;font-size:.875rem;background:hsl(var(--card));color:hsl(var(--foreground))}.fields-scroll-container{max-height:280px;overflow-y:auto;padding:.75rem;background:hsl(var(--muted) / .3);border:1px solid hsl(var(--border));border-radius:.5rem;scrollbar-width:thin;scrollbar-color:hsl(var(--muted-foreground) / .3) transparent}.fields-scroll-container::-webkit-scrollbar{width:6px}.fields-scroll-container::-webkit-scrollbar-track{background:transparent}.fields-scroll-container::-webkit-scrollbar-thumb{background-color:hsl(var(--muted-foreground) / .3);border-radius:10px}.fields-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem;align-items:start}.field-tag{background:hsl(var(--card));color:hsl(var(--foreground));padding:.375rem .625rem;border:1px solid hsl(var(--border));border-radius:.375rem;font-size:.75rem;font-weight:500;display:flex;align-items:center;gap:.4rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 1px 2px #0000000d}.field-icon-tiny{font-size:.85rem;flex-shrink:0}.remove-field{background:none;border:none;color:hsl(var(--muted-foreground));font-size:1.125rem;cursor:pointer;padding:0;line-height:1}.remove-field:hover{color:hsl(var(--destructive))}.no-fields{color:hsl(var(--muted-foreground));font-style:italic;font-size:.8125rem}.fields-table-container{width:100%;overflow-x:auto}.fields-search-container{margin-bottom:1rem}.fields-search-input{width:100%;max-width:400px;padding:.625rem 1rem;border:1px solid hsl(var(--border));border-radius:.5rem;font-size:.875rem;background:hsl(var(--card));color:hsl(var(--foreground));transition:all .2s ease}.fields-search-input:focus{outline:none;border-color:hsl(var(--primary));box-shadow:0 0 0 3px hsl(var(--primary) / .1)}.fields-search-input::placeholder{color:hsl(var(--muted-foreground))}.fields-table{width:100%;border-collapse:collapse;font-size:.875rem}.fields-table thead{background:hsl(var(--muted) / .5)}.fields-table th{text-align:left;padding:.75rem 1rem;font-size:.75rem;font-weight:600;color:hsl(var(--muted-foreground));text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid hsl(var(--border));white-space:nowrap}.fields-table td{padding:.25rem 1rem!important;border-bottom:1px solid hsl(var(--border));color:hsl(var(--foreground))!important;vertical-align:middle!important;height:2.25rem!important}.field-order{text-align:center;color:hsl(var(--muted-foreground));font-weight:500;width:40px}.field-technical-name{padding-right:2rem!important}.field-technical-name code{display:inline-flex!important;align-items:center!important;background:hsl(var(--muted))!important;padding:.15rem .4rem!important;border-radius:.25rem!important;font-size:.75rem!important;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,monospace!important;color:hsl(var(--primary))!important;font-weight:500!important;line-height:1!important;margin:0!important}.field-label{color:hsl(var(--foreground))!important;font-weight:500!important;font-size:.8125rem!important;line-height:1!important}.field-type-cell{width:100px}.type-badge-wrapper{display:flex!important;align-items:center!important;height:100%!important}.type-badge-new{display:inline-flex!important;align-items:center!important;justify-content:center!important;gap:.2rem!important;padding:.15rem .4rem!important;border-radius:.15rem!important;font-size:.55rem!important;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace!important;font-weight:800!important;white-space:nowrap!important;line-height:1!important;letter-spacing:.02em!important;border:1px solid!important;box-sizing:border-box!important}.type-icon{display:flex!important;align-items:center!important;justify-content:center!important;font-size:.65rem!important;line-height:1!important}.type-text{display:inline-block!important;text-transform:uppercase!important;line-height:1!important}html[data-theme=dark] .type-badge-new{background:#60a5fa26!important;border-color:#60a5fa66!important;color:#93c5fd!important}html[data-theme=dark] .type-badge-new .type-icon,html[data-theme=dark] .type-badge-new .type-text{color:#93c5fd!important}html:not([data-theme=dark]) .type-badge-new{background:#3b82f61a!important;border-color:#3b82f64d!important;color:#2563eb!important}html:not([data-theme=dark]) .type-badge-new .type-icon,html:not([data-theme=dark]) .type-badge-new .type-text{color:#2563eb!important}.no-type{color:hsl(var(--muted-foreground));font-style:italic}.field-multilevel{min-width:200px}.multilevel-info{display:flex;align-items:center;gap:.5rem;font-size:.8125rem}.multilevel-base{color:hsl(var(--primary));font-weight:500;font-family:SF Mono,Monaco,monospace}.multilevel-separator{color:hsl(var(--muted-foreground));font-size:.875rem}.multilevel-related{color:hsl(var(--foreground));font-family:SF Mono,Monaco,monospace}.no-multilevel{color:hsl(var(--muted-foreground));font-style:italic}.no-fields-message{padding:2rem;text-align:center}.add-field-input{border:1px dashed hsl(var(--border));border-radius:.25rem;padding:.25rem .5rem;font-size:.8125rem;outline:none;width:120px;background:hsl(var(--card));color:hsl(var(--foreground))}.add-field-input:focus{border-style:solid;border-color:hsl(var(--primary))}.pipeline-info-section{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.5rem;padding:1.5rem;margin-bottom:1.5rem}.info-main{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid hsl(var(--border))}.pipeline-title-row{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.pipeline-title-row h1{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground));margin:0}.status-pill{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-pill.status-active{background:#16a24933;color:#16a249}[data-theme=dark] .status-pill.status-active{background:#16a2494d;color:#1fe066}.status-pill.status-inactive{background:hsl(var(--destructive) / .2);color:hsl(var(--destructive))}[data-theme=dark] .status-pill.status-inactive{background:hsl(var(--destructive) / .3);color:hsl(var(--destructive))}.status-pill.status-archived{background:hsl(var(--muted));color:hsl(var(--muted-foreground))}.pipeline-desc{color:hsl(var(--muted-foreground));font-size:.875rem;margin:0}.quick-stats-row{display:flex;align-items:center;gap:2rem}.quick-stat{display:flex;align-items:baseline;gap:.5rem}.stat-num{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground))}.quick-stat.success .stat-num{color:#16a249}.quick-stat.error .stat-num{color:hsl(var(--destructive))}.stat-name{font-size:.8125rem;color:hsl(var(--muted-foreground));font-weight:500}.stat-divider{width:1px;height:24px;background:hsl(var(--border))}.config-table-section{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.5rem;padding:1.5rem;margin-bottom:1.5rem}.config-table-section h2{font-size:1rem;font-weight:600;color:hsl(var(--foreground));margin:0 0 1rem}.config-table{width:100%;border-collapse:collapse}.config-table td{padding:.625rem 0;font-size:.875rem;border-bottom:1px solid hsl(var(--border))}.config-table tr:last-child td{border-bottom:none}.config-key{color:hsl(var(--muted-foreground));font-weight:500;width:120px}.config-val{color:hsl(var(--foreground));padding-right:2rem}.config-val code{background:hsl(var(--muted));padding:.25rem .5rem;border-radius:.25rem;font-size:.8125rem;font-family:SF Mono,Monaco,monospace;color:hsl(var(--primary))}.dependencies-section{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.75rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem 2rem;margin-bottom:2rem}.dependencies-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid hsl(var(--border))}.dependencies-header h2{font-size:1.25rem;font-weight:600;color:hsl(var(--foreground));margin:0}.btn-secondary{padding:.5rem 1rem;background:hsl(var(--muted));color:hsl(var(--foreground));border:1px solid hsl(var(--border));border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.btn-secondary:hover:not(:disabled){background:hsl(var(--accent));border-color:hsl(var(--border))}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.loading-deps{padding:2rem;text-align:center;color:hsl(var(--muted-foreground))}.dependencies-content{display:flex;flex-direction:column;gap:2rem}.depends-on h3,.dependents h3{font-size:1rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:1rem}.dependency-list{list-style:none;padding:0;margin:0}.dependency-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:hsl(var(--muted) / .3);border-radius:.5rem;margin-bottom:.5rem;border:1px solid hsl(var(--border));transition:all .2s}.dependency-item:hover{background:hsl(var(--accent) / .5);border-color:hsl(var(--border))}.dep-icon{font-size:1.25rem}.dep-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.dep-link{color:hsl(var(--primary));cursor:pointer;font-weight:500;text-decoration:none}.dep-link:hover{text-decoration:underline}.dep-model{font-size:.75rem;color:hsl(var(--muted-foreground));font-family:Courier New,monospace}.dep-field{font-size:.75rem;color:hsl(var(--muted-foreground));font-style:italic;opacity:.8}.no-dependencies{padding:2rem;text-align:center;color:hsl(var(--muted-foreground))}.no-dependencies .help-text{font-size:.875rem;color:hsl(var(--muted-foreground));margin-top:.5rem;opacity:.8}.section-tabs{display:flex;gap:0;border-bottom:2px solid hsl(var(--border));margin-bottom:0}.section-tab{padding:.75rem 1.25rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;font-size:.875rem;font-weight:500;color:hsl(var(--muted-foreground));transition:all .15s}.section-tab:hover{color:hsl(var(--foreground))}.section-tab.active{color:hsl(var(--primary));border-bottom-color:hsl(var(--primary))}.section-content{background:hsl(var(--card));border:1px solid hsl(var(--border));border-top:none;border-radius:0 0 .5rem .5rem;padding:1.5rem;min-height:300px}.empty-runs{text-align:center;padding:3rem;color:hsl(var(--muted-foreground))}.runs-table th{text-align:left;padding:.75rem 1rem;font-size:.75rem;font-weight:600;color:hsl(var(--muted-foreground));text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid hsl(var(--border))}.runs-table td{padding:.875rem 1rem;font-size:.875rem;border-bottom:1px solid hsl(var(--border));color:hsl(var(--foreground))}.runs-table code{background:hsl(var(--muted));padding:.125rem .375rem;border-radius:.25rem;font-size:.75rem;font-family:SF Mono,Monaco,monospace;color:hsl(var(--foreground))}.run-status{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.run-status.status-success{background:#16a24933;color:#16a249}[data-theme=dark] .run-status.status-success{background:#16a2494d;color:#1fe066}.run-status.status-error{background:hsl(var(--destructive) / .2);color:hsl(var(--destructive))}[data-theme=dark] .run-status.status-error{background:hsl(var(--destructive) / .3);color:hsl(var(--destructive))}.run-status.status-warning{background:#f59f0a33;color:#f59f0a}[data-theme=dark] .run-status.status-warning{background:#f59f0a4d;color:#f7b23b}.run-status.status-info{background:hsl(var(--primary) / .2);color:hsl(var(--primary))}[data-theme=dark] .run-status.status-info{background:hsl(var(--primary) / .3);color:hsl(var(--primary))}.run-status.status-secondary{background:hsl(var(--muted));color:hsl(var(--muted-foreground))}.btn-link{background:none;border:none;color:hsl(var(--primary));cursor:pointer;font-size:.8125rem;font-weight:500}.btn-link:hover{text-decoration:underline}.preview-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.preview-type-btns{display:flex;gap:.25rem}.type-btn{padding:.5rem 1rem;background:hsl(var(--muted));border:1px solid hsl(var(--border));border-radius:.375rem;cursor:pointer;font-size:.8125rem;font-weight:500;color:hsl(var(--muted-foreground));transition:all .15s}.type-btn:hover{background:hsl(var(--accent))}.type-btn.active{background:hsl(var(--primary));color:hsl(var(--primary-foreground));border-color:hsl(var(--primary))}.btn-refresh{padding:.375rem .75rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.375rem;cursor:pointer;font-size:.8125rem;color:hsl(var(--foreground))}.preview-loading,.preview-error,.preview-empty{text-align:center;padding:3rem;color:hsl(var(--muted-foreground))}.preview-error{color:hsl(var(--destructive))}.preview-error .help-text{margin-top:.5rem;font-size:.875rem;color:hsl(var(--muted-foreground))}.preview-meta{display:flex;gap:1.5rem;margin-bottom:1rem;font-size:.8125rem;color:hsl(var(--muted-foreground))}.preview-meta strong{color:hsl(var(--foreground))}.preview-table-wrap{overflow-x:auto;border:1px solid hsl(var(--border));border-radius:.375rem}.preview-table{width:100%;border-collapse:collapse;font-size:.8125rem}.preview-table th{text-align:left;padding:.625rem .75rem;background:hsl(var(--muted) / .5);font-size:.75rem;font-weight:600;color:hsl(var(--foreground));border-bottom:1px solid hsl(var(--border));white-space:nowrap}.preview-table td{padding:.5rem .75rem;border-bottom:1px solid hsl(var(--border));color:hsl(var(--foreground));max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-table tbody tr:hover{background:hsl(var(--accent) / .5)}.null-val{color:hsl(var(--muted-foreground));font-style:italic;font-size:.75rem;opacity:.7}.modal-content{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.5rem;width:100%;max-width:400px;box-shadow:0 20px 25px -5px #0003}.modal-header{padding:1rem 1.25rem;border-bottom:1px solid hsl(var(--border))}.modal-header h3{margin:0;font-size:1rem;font-weight:600;color:hsl(var(--foreground))}.modal-body{padding:1.25rem}.modal-body p{margin:0 0 .5rem;color:hsl(var(--foreground));font-size:.875rem}.modal-body .modal-warning{color:hsl(var(--destructive));font-size:.8125rem}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid hsl(var(--border));background:hsl(var(--muted) / .5)}.modal-btn-cancel{padding:.5rem 1rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;color:hsl(var(--foreground))}.modal-btn-cancel:hover{background:hsl(var(--accent))}.modal-btn-delete{padding:.5rem 1rem;background:hsl(var(--destructive));border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:600;color:hsl(var(--destructive-foreground))}.modal-btn-delete:hover{background:hsl(var(--destructive) / .9)}.modal-btn-delete:disabled,.modal-btn-cancel:disabled{opacity:.6;cursor:not-allowed}.field-selector-edit{display:flex;flex-direction:column;gap:1rem}.loading-fields{color:hsl(var(--muted-foreground));font-size:.875rem;padding:1rem}.available-fields-grid{display:flex;flex-direction:column;gap:.25rem;max-height:400px;overflow-y:auto;border:1px solid hsl(var(--border));border-radius:.5rem;padding:.75rem;background:hsl(var(--muted) / .3)}.field-item-edit{position:relative}.field-checkbox{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:.375rem;cursor:pointer;transition:all .15s;background:hsl(var(--card));border:1px solid hsl(var(--border))}.field-checkbox:hover{border-color:hsl(var(--primary));background:hsl(var(--primary) / .05)}.field-checkbox.selected{border-color:hsl(var(--primary));background:hsl(var(--primary) / .1)}.field-checkbox.related{margin-left:1.5rem;background:#f59f0a1a;border-color:#f59f0a4d}.field-checkbox.related.selected{background:#f59f0a33;border-color:#f59f0a80}.field-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:hsl(var(--primary))}.field-icon-edit{font-size:1rem}.field-icon-edit.small{font-size:.875rem}.field-label-edit{font-size:.8125rem;font-weight:500;color:hsl(var(--foreground));flex:1}.field-name-edit{font-size:.7rem;background:hsl(var(--muted));padding:.125rem .375rem;border-radius:.25rem;color:hsl(var(--muted-foreground));font-family:SF Mono,Monaco,monospace}.field-type-edit{font-size:.7rem;color:hsl(var(--muted-foreground));margin-left:auto}.expand-related-btn{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:.75rem;color:hsl(var(--muted-foreground));padding:.25rem .5rem}.expand-related-btn:hover{color:hsl(var(--primary))}.related-fields-edit{display:flex;flex-direction:column;gap:.25rem;margin-top:.25rem;margin-left:1rem;padding-left:.75rem;border-left:2px solid hsl(38 92% 50% / .5)}.selected-fields-count{font-size:.75rem;color:hsl(var(--muted-foreground));text-align:right;padding-top:.5rem;border-top:1px solid hsl(var(--border))}@media (max-width: 768px){.flow-detail-container{padding:1rem}.page-header-bar{flex-direction:column;align-items:flex-start;gap:1rem}.quick-stats-row{flex-wrap:wrap;gap:1rem}.stat-divider{display:none}.config-table td{display:block;width:100%}}.flow-creator-container{padding:2rem;max-width:1400px;margin:0 auto}.creator-header{margin-bottom:3rem}.creator-header h1{font-size:2rem;font-weight:700;color:hsl(var(--foreground));margin-bottom:.5rem}.header-description{color:hsl(var(--muted-foreground));font-size:.875rem}.btn-back{padding:.625rem 1.25rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;color:hsl(var(--foreground));transition:all .2s;margin-bottom:1.5rem;display:inline-block}.btn-back:hover{background:hsl(var(--accent))}.options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-bottom:3rem}.option-card{background:hsl(var(--card));border:3px solid hsl(var(--border));border-radius:1rem;padding:2rem;cursor:pointer;transition:all .3s;position:relative;display:flex;flex-direction:column}.option-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026;border-color:hsl(var(--primary) / .5)}.recommended-badge{position:absolute;top:1rem;right:1rem;background:linear-gradient(135deg,#16a249,#12873d);color:#fff;padding:.375rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase}.option-icon{font-size:3rem;margin-bottom:1rem}.option-card h2{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground));margin-bottom:.75rem}.option-description{color:hsl(var(--muted-foreground));font-size:.875rem;margin-bottom:1.5rem;line-height:1.6}.feature-list{list-style:none;padding:0;margin:0 0 1.5rem;flex:1}.feature-list li{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.875rem;color:hsl(var(--foreground))}.check-icon{color:#16a249;font-weight:700;font-size:1rem}.option-btn{width:100%;padding:.875rem 1.5rem;color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s}.option-btn:hover{transform:scale(1.02);box-shadow:0 4px 12px #0003}.info-section{background:hsl(var(--muted) / .5);border-radius:.75rem;padding:2rem;border:1px solid hsl(var(--border))}.info-section h3{font-size:1.25rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:1.5rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.info-card{background:hsl(var(--card));padding:1.5rem;border-radius:.5rem;border:1px solid hsl(var(--border))}.info-card strong{display:block;color:hsl(var(--foreground));margin-bottom:.75rem;font-size:.875rem}.info-card ul{list-style:none;padding:0;margin:0}.info-card li{padding:.375rem 0;font-size:.8125rem;color:hsl(var(--muted-foreground));display:flex;align-items:center;gap:.5rem}.info-card li:before{content:"•";color:hsl(var(--primary));font-weight:700}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.template-card{background:hsl(var(--card));border:2px solid hsl(var(--border));border-radius:.75rem;padding:2rem;cursor:pointer;transition:all .2s;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.template-card:hover{border-color:hsl(var(--primary));transform:translateY(-2px);box-shadow:0 4px 12px hsl(var(--primary) / .15)}.template-icon{font-size:3rem}.template-card h3{font-size:1.125rem;font-weight:600;color:hsl(var(--foreground));margin:0}.template-card p{font-size:.875rem;color:hsl(var(--muted-foreground));margin:0;line-height:1.5}.template-model{background:hsl(var(--muted));padding:.375rem .75rem;border-radius:.375rem;font-family:Courier New,monospace;font-size:.75rem;color:hsl(var(--primary))}@media (max-width: 768px){.flow-creator-container{padding:1rem}.options-grid,.templates-grid,.info-grid{grid-template-columns:1fr}}.field-selector-container{padding:2rem;max-width:1400px;margin:0 auto}.progress-steps{display:flex;align-items:center;justify-content:center;margin-bottom:3rem;padding:2rem;background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.step{display:flex;flex-direction:column;align-items:center;gap:.5rem}.step-number{width:40px;height:40px;border-radius:50%;background:#e5e7eb;color:#9ca3af;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem;transition:all .3s}.step.active .step-number{background:#3b82f6;color:#fff;box-shadow:0 0 0 4px #3b82f633}.step.completed .step-number{background:#10b981;color:#fff}.step-label{font-size:.875rem;color:#6b7280;font-weight:500}.step.active .step-label{color:#3b82f6;font-weight:600}.step-divider{width:80px;height:2px;background:#e5e7eb;margin:0 1rem}.step-content{background:#fff;border-radius:.75rem;padding:2rem;box-shadow:0 1px 3px #0000001a;min-height:500px}.step-content h2{font-size:1.75rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem}.step-description{color:#6b7280;font-size:.875rem;margin-bottom:2rem}.models-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.model-card{padding:1.5rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:.75rem;cursor:pointer;transition:all .2s;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem}.model-card:hover{border-color:#3b82f6;background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.model-icon{font-size:2.5rem}.model-name{font-weight:600;color:#1a1a1a;font-size:.875rem}.model-technical{font-family:Courier New,monospace;font-size:.75rem;color:#6b7280}.step-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.header-stats{display:flex;align-items:center;gap:1rem}.stat{padding:.5rem 1rem;background:#dbeafe;color:#1e40af;border-radius:.375rem;font-size:.875rem;font-weight:600}.fields-container{display:flex;flex-direction:column;gap:2rem;max-height:600px;overflow-y:auto;padding:1rem;background:#f9fafb;border-radius:.5rem}.field-category h3{font-size:1rem;font-weight:600;color:#374151;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.fields-list{display:flex;flex-direction:column;gap:.5rem}.field-item-wrapper{background:#fff;border-radius:.5rem;overflow:hidden}.field-item{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;border:1px solid #e5e7eb;border-radius:.5rem;transition:all .2s}.field-item:hover{background:#f9fafb;border-color:#cbd5e1}.field-label{display:flex;align-items:center;gap:.75rem;flex:1;cursor:pointer}.field-label input[type=checkbox]{cursor:pointer;width:18px;height:18px}.field-icon{font-size:1.25rem}.field-icon.small{font-size:1rem}.field-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.field-name-row{display:flex;align-items:center;gap:.5rem}.field-name{font-weight:500;color:#1a1a1a;font-size:.875rem}.field-technical{font-family:Courier New,monospace;font-size:.75rem;color:#6b7280;background:#f3f4f6;padding:.125rem .375rem;border-radius:.25rem}.field-technical.small{font-size:.7rem}.field-type{font-size:.75rem;color:#9ca3af;text-transform:uppercase;font-weight:500}.field-help{font-size:.75rem;color:#9ca3af;font-style:italic}.expand-btn{padding:.375rem .75rem;background:#dbeafe;color:#1e40af;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;transition:all .2s}.expand-btn:hover{background:#bfdbfe}.related-fields{padding:1rem 1rem 1rem 3rem;background:#f0fdf4;border-left:3px solid #10b981;margin-top:.5rem}.related-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.related-model{font-size:.875rem;font-weight:600;color:#059669}.select-all-btn{padding:.25rem .625rem;background:#fff;border:1px solid #10b981;color:#059669;border-radius:.25rem;cursor:pointer;font-size:.75rem;font-weight:500;transition:all .2s}.select-all-btn:hover{background:#10b981;color:#fff}.related-field-label{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#fff;border-radius:.375rem;margin-bottom:.375rem;cursor:pointer;transition:all .2s}.related-field-label:hover{background:#f9fafb}.related-field-label input[type=checkbox]{cursor:pointer}.review-grid{display:grid;gap:1.5rem}.review-section{padding:1.5rem;background:#f9fafb;border-radius:.5rem;border:1px solid #e5e7eb}.review-section.full{grid-column:1 / -1}.review-section h3{font-size:1rem;font-weight:600;color:#374151;margin-bottom:1rem}.form-input,.form-textarea{width:100%;padding:.875rem;border:1px solid #e2e8f0;border-radius:.5rem;font-size:.875rem;font-family:inherit;background:#fff;color:#1e293b;transition:all .2s}.form-input:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f60d}.form-input::placeholder,.form-textarea::placeholder{color:#94a3b8}.config-summary{display:flex;flex-direction:column;gap:.75rem}.summary-item{font-size:.875rem;color:#374151}.summary-item strong{color:#1a1a1a}.summary-item code{background:#f3f4f6;padding:.25rem .5rem;border-radius:.25rem;font-family:Courier New,monospace;font-size:.75rem;color:#1e40af}.selected-fields-preview{padding:1rem;background:#fff;border-radius:.375rem;font-size:.8125rem;color:#374151;line-height:1.8}.field-chip{font-family:Courier New,monospace;color:#1e40af}.config-preview{background:#0f172a;color:#e2e8f0;padding:1rem;border-radius:.5rem;font-size:.8125rem;line-height:1.6;overflow-x:auto}.action-buttons{display:flex;justify-content:space-between;margin-top:2rem;padding-top:2rem;border-top:2px solid #e5e7eb}.btn-primary{background:#3b82f6;color:#fff}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999}.loader{background:#fff;padding:2rem 3rem;border-radius:.75rem;font-size:1.125rem;font-weight:600;color:#374151;box-shadow:0 4px 16px #0003}.fields-container::-webkit-scrollbar{width:8px}.fields-container::-webkit-scrollbar-track{background:#f3f4f6}.fields-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.btn-quality{padding:.5rem 1rem;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.btn-quality:hover{background:linear-gradient(135deg,#7c3aed,#4f46e5);transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.loading-quality{padding:.5rem 1rem;color:#8b5cf6;font-size:.875rem;font-weight:500}.btn-toggle-view{padding:.5rem 1rem;background:#f3f4f6;color:#374151;border:1px solid #e5e7eb;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.btn-toggle-view:hover{background:#e5e7eb}.btn-toggle-view.active{background:#dbeafe;border-color:#3b82f6;color:#1e40af}.sort-select{padding:.5rem .75rem;border:1px solid #e5e7eb;border-radius:.5rem;font-size:.875rem;background:#fff;color:#374151;cursor:pointer}.quality-summary-header{display:flex;gap:.75rem;padding:.75rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;margin-bottom:1rem;align-items:center;flex-wrap:wrap}.quality-pill{display:flex;align-items:center;gap:.5rem;background:#fff;padding:.375rem .75rem;border:1px solid #e5e7eb;border-radius:2rem;font-size:.8125rem;flex:0 0 auto}.pill-label{color:#64748b;font-weight:500}.pill-value{font-weight:700;color:#1e293b}.quality-pill.warning-pill{border-color:#f59e0b;background:#fffbeb}.quality-pill.warning-pill .pill-value{color:#b45309}.quality-pill.error-pill{border-color:#ef4444;background:#fef2f2}.quality-pill.error-pill .pill-value{color:#b91c1c}.quality-fields-list{display:flex;flex-direction:column;gap:.375rem}.quality-field-item{background:#fff;border:1px solid #e5e7eb;border-radius:.375rem;padding:.5rem .75rem;transition:all .2s}.quality-field-item:hover{border-color:#3b82f6;background:#f9fafb}.quality-field-item.selected{border-color:#3b82f6;background:#f0f7ff}.field-checkbox-row{display:flex;align-items:center;gap:.75rem;cursor:pointer;width:100%}.field-main-info{display:flex;align-items:center;gap:.5rem;width:350px;flex-shrink:0}.field-main-info .field-label{font-weight:600;color:#1f2937;font-size:.8125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.field-main-info .field-technical{font-size:.7rem;color:#9ca3af;background:#f3f4f6;padding:.125rem .375rem;border-radius:.25rem}.field-quality-bars{display:flex;gap:1rem;width:280px;flex-shrink:0}.quality-bar-container{display:flex;align-items:center;gap:.375rem;flex:1}.bar-label{font-size:.65rem;font-weight:700;color:#9ca3af;width:12px}.quality-bar{flex:1;height:6px;background:#f1f5f9;border-radius:3px;overflow:hidden}.quality-bar-fill{height:100%;border-radius:3px}.quality-bar-fill.good{background:#10b981}.quality-bar-fill.warning{background:#f59e0b}.quality-bar-fill.error{background:#ef4444}.quality-bar-fill.unique{background:#8b5cf6}.bar-value{font-size:.75rem;font-weight:600;color:#475569;width:32px}.sample-values-inline{display:flex;gap:.375rem;flex:1;overflow:hidden}.sample-tag{font-size:.7rem;padding:.125rem .5rem;background:#fef3c7;color:#92400e;border-radius:1rem;white-space:nowrap;max-width:150px;overflow:hidden;text-overflow:ellipsis;border:1px solid #fde68a}.value-distribution-container{flex:1;display:flex;flex-direction:column;gap:.375rem;overflow:hidden}.distribution-bar{display:flex;height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden;width:100%}.distribution-segment{height:100%;transition:opacity .2s}.distribution-segment:hover{opacity:.8}.distribution-legend{display:flex;flex-wrap:wrap;gap:.5rem}.dist-tag{display:flex;align-items:center;gap:.25rem;font-size:.65rem;color:#64748b;font-weight:500;white-space:nowrap}.dist-tag .dot{width:6px;height:6px;border-radius:50%}.completeness-badge{padding:.125rem .375rem;border-radius:.25rem;font-size:.7rem;font-weight:600}.completeness-badge.good{background:#d1fae5;color:#059669}.completeness-badge.warning{background:#fef3c7;color:#d97706}.completeness-badge.error{background:#fee2e2;color:#dc2626}.ordering-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(450px,1fr));gap:1.5rem;margin-bottom:2rem;padding:1.5rem;background:#fafbfc;border-radius:.75rem;border:1px solid #e2e8f0}.theme-group{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0;display:flex;flex-direction:column}.theme-header{background:#fff;padding:1rem 1.25rem;border-bottom:1px solid #f1f5f9}.theme-header h3{font-size:.9375rem;font-weight:700;color:#1e293b;margin:0!important;text-transform:uppercase;letter-spacing:.025em}.theme-fields{padding:1rem;display:flex;flex-direction:column;gap:.5rem;min-height:60px;flex:1}.ordered-field-item{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;background:#fff;border:1px solid #f1f5f9;border-radius:.5rem;cursor:grab;transition:all .2s}.ordered-field-item:hover{border-color:#3b82f6;background:#f0f9ff;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000000d}.ordered-field-item.dragging{opacity:.5;background:#f8fafc;border:2px dashed #cbd5e1}.field-drag-handle{color:#94a3b8;font-size:1rem;-webkit-user-select:none;user-select:none}.field-main{flex:1}.field-main .field-name{font-weight:600;color:#334155;font-size:.8125rem}.field-theme-select select{padding:.25rem .5rem;border:1px solid #e2e8f0;border-radius:.375rem;font-size:.7rem;background:#f8fafc;color:#64748b;cursor:pointer;outline:none}.field-theme-select select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.empty-theme{padding:1.5rem;text-align:center;color:#94a3b8;font-size:.8125rem;font-style:italic;background:#fbfcfd;border:1px dashed #e2e8f0;border-radius:.5rem}.review-footer{margin-top:3rem;padding-top:1rem}.review-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.review-section{padding:1.5rem;background:#fff;border-radius:.75rem;border:1px solid #e2e8f0;box-shadow:0 1px 2px #0000000d}.review-section h3{font-size:1.125rem;font-weight:700;color:#1a1a1a;margin-bottom:1.25rem}.summary-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.summary-row{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;padding:.5rem 0;border-bottom:1px solid #f8fafc}.summary-row span:first-child{color:#64748b;font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.025em}.summary-row code{background:#f1f5f9;padding:.25rem .5rem;border-radius:.375rem;color:#0f172a;font-family:JetBrains Mono,Courier New,monospace;font-size:.75rem;font-weight:600}.create-btn{width:100%;padding:.875rem!important;font-size:.9375rem!important;font-weight:600!important;background:#1e4ed8!important;color:#fff!important;border-radius:.5rem!important;transition:all .2s!important;border:none!important;cursor:pointer;letter-spacing:.025em;text-transform:uppercase}.create-btn:hover:not(:disabled){background:#1e3a8a!important;box-shadow:0 4px 12px #1e3a8a33!important}.create-btn:disabled{background:#94a3b8!important;cursor:not-allowed}.header-actions{display:flex;gap:.75rem}.quality-field-group{margin-bottom:.5rem}.quality-related{margin:.25rem 0 .75rem 3.5rem!important;border-left:2px solid #e2e8f0!important;background:#fafafa!important;padding:1rem!important;border-radius:0 .5rem .5rem 0}.related-fields-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:.5rem}@media (max-width: 768px){.field-selector-container,.progress-steps{padding:1rem}.models-grid,.review-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column;gap:1rem}.quality-summary-banner{flex-wrap:wrap}.field-quality-bars{flex-direction:column;gap:.5rem}.field-main-info{min-width:unset;flex-wrap:wrap}}@media (max-width: 768px){.review-info-grid{grid-template-columns:1fr}.field-main-info{width:auto;flex:1}}html[data-theme=dark] .field-selector-container{background:hsl(var(--background))}html[data-theme=dark] .progress-steps{background:hsl(var(--card));border:1px solid hsl(var(--border));box-shadow:none}html[data-theme=dark] .step-number{background:hsl(var(--muted));color:hsl(var(--muted-foreground))}html[data-theme=dark] .step.active .step-number{background:hsl(var(--primary));box-shadow:0 0 0 4px hsl(var(--primary) / .2)}html[data-theme=dark] .step.completed .step-number{background:#10b981}html[data-theme=dark] .step-label{color:hsl(var(--muted-foreground))}html[data-theme=dark] .step.active .step-label{color:hsl(var(--primary))}html[data-theme=dark] .step-divider{background:hsl(var(--border))}html[data-theme=dark] .step-content{background:hsl(var(--card));border:1px solid hsl(var(--border));box-shadow:none}html[data-theme=dark] .step-content h2{color:hsl(var(--foreground))}html[data-theme=dark] .step-description{color:hsl(var(--muted-foreground))}html[data-theme=dark] .model-card{background:hsl(var(--muted));border-color:hsl(var(--border))}html[data-theme=dark] .model-card:hover{border-color:hsl(var(--primary));background:hsl(var(--card));box-shadow:0 4px 12px #0000004d}html[data-theme=dark] .model-name{color:hsl(var(--foreground))}html[data-theme=dark] .model-technical{color:hsl(var(--muted-foreground))}html[data-theme=dark] .stat{background:hsl(var(--primary) / .15);color:hsl(var(--primary));border:1px solid hsl(var(--primary) / .3)}html[data-theme=dark] .fields-container{background:hsl(var(--muted) / .3);border:1px solid hsl(var(--border))}html[data-theme=dark] .field-category h3{color:hsl(var(--foreground));border-color:hsl(var(--border))}html[data-theme=dark] .field-item-wrapper{background:hsl(var(--card))}html[data-theme=dark] .field-item{border-color:hsl(var(--border));background:hsl(var(--card))}html[data-theme=dark] .field-item:hover{background:hsl(var(--muted));border-color:hsl(var(--muted-foreground) / .3)}html[data-theme=dark] .field-name{color:hsl(var(--foreground))}html[data-theme=dark] .field-technical{background:hsl(var(--muted));color:hsl(var(--muted-foreground))}html[data-theme=dark] .field-type,html[data-theme=dark] .field-help{color:hsl(var(--muted-foreground))}html[data-theme=dark] .expand-btn{background:hsl(var(--primary) / .15);color:hsl(var(--primary));border:1px solid hsl(var(--primary) / .3)}html[data-theme=dark] .expand-btn:hover{background:hsl(var(--primary) / .25)}html[data-theme=dark] .related-fields{background:hsl(var(--muted) / .5);border-color:#10b981}html[data-theme=dark] .related-model{color:#34d399}html[data-theme=dark] .select-all-btn{background:hsl(var(--card));border-color:#10b981;color:#34d399}html[data-theme=dark] .select-all-btn:hover{background:#10b981;color:#fff}html[data-theme=dark] .related-field-label{background:hsl(var(--card))}html[data-theme=dark] .related-field-label:hover{background:hsl(var(--muted))}html[data-theme=dark] .quality-summary-header{background:hsl(var(--muted) / .3);border-color:hsl(var(--border))}html[data-theme=dark] .quality-pill{background:hsl(var(--card));border-color:hsl(var(--border))}html[data-theme=dark] .pill-label{color:hsl(var(--muted-foreground))}html[data-theme=dark] .pill-value{color:hsl(var(--foreground))}html[data-theme=dark] .quality-pill.warning-pill{background:#f59e0b1a;border-color:#f59e0b4d}html[data-theme=dark] .quality-pill.warning-pill .pill-value{color:#fbbf24}html[data-theme=dark] .quality-pill.error-pill{background:#ef44441a;border-color:#ef44444d}html[data-theme=dark] .quality-pill.error-pill .pill-value{color:#f87171}html[data-theme=dark] .quality-field-item{background:hsl(var(--card));border-color:hsl(var(--border))}html[data-theme=dark] .quality-field-item:hover{border-color:hsl(var(--primary) / .5);background:hsl(var(--muted))}html[data-theme=dark] .quality-field-item.selected{border-color:hsl(var(--primary));background:hsl(var(--primary) / .1)}html[data-theme=dark] .field-main-info .field-label{color:hsl(var(--foreground))}html[data-theme=dark] .field-main-info .field-technical{background:hsl(var(--muted));color:hsl(var(--muted-foreground))}html[data-theme=dark] .quality-bar{background:hsl(var(--muted))}html[data-theme=dark] .bar-value{color:hsl(var(--foreground))}html[data-theme=dark] .sample-tag{background:#fbbf2426;color:#fbbf24;border-color:#fbbf244d}html[data-theme=dark] .review-section{background:hsl(var(--card));border-color:hsl(var(--border))}html[data-theme=dark] .review-section h3{color:hsl(var(--foreground))}html[data-theme=dark] .summary-row{border-color:hsl(var(--border))}html[data-theme=dark] .summary-row span:first-child{color:hsl(var(--muted-foreground))}html[data-theme=dark] .summary-row code{background:hsl(var(--muted));color:hsl(var(--foreground))}html[data-theme=dark] .form-input,html[data-theme=dark] .form-textarea{background:hsl(var(--muted));border-color:hsl(var(--border));color:hsl(var(--foreground))}html[data-theme=dark] .form-input:focus,html[data-theme=dark] .form-textarea:focus{border-color:hsl(var(--primary));background:hsl(var(--card))}html[data-theme=dark] .btn-secondary{background:hsl(var(--muted));color:hsl(var(--foreground));border-color:hsl(var(--border))}html[data-theme=dark] .btn-secondary:hover{background:hsl(var(--accent))}html[data-theme=dark] .btn-toggle-view{background:hsl(var(--muted));color:hsl(var(--foreground));border-color:hsl(var(--border))}html[data-theme=dark] .btn-toggle-view:hover{background:hsl(var(--accent))}html[data-theme=dark] .btn-toggle-view.active{background:hsl(var(--primary) / .15);border-color:hsl(var(--primary));color:hsl(var(--primary))}html[data-theme=dark] .sort-select{background:hsl(var(--muted));color:hsl(var(--foreground));border-color:hsl(var(--border))}html[data-theme=dark] .ordered-field-item{background:hsl(var(--card));border-color:hsl(var(--border))}html[data-theme=dark] .ordered-field-item:hover{border-color:hsl(var(--primary) / .5);background:hsl(var(--muted));box-shadow:0 4px 6px -1px #0003}html[data-theme=dark] .field-drag-handle{color:hsl(var(--muted-foreground))}html[data-theme=dark] .field-main .field-name{color:hsl(var(--foreground))}html[data-theme=dark] .field-theme-select select{background:hsl(var(--muted));color:hsl(var(--foreground));border-color:hsl(var(--border))}html[data-theme=dark] .empty-theme{background:hsl(var(--muted) / .3);border-color:hsl(var(--border));color:hsl(var(--muted-foreground))}html[data-theme=dark] .quality-related{background:hsl(var(--muted) / .3)!important;border-color:hsl(var(--border))!important}html[data-theme=dark] .loader{background:hsl(var(--card));color:hsl(var(--foreground));box-shadow:0 4px 16px #0006}html[data-theme=dark] .action-buttons{border-color:hsl(var(--border))}.multi-source-container{padding:2rem;max-width:1400px;margin:0 auto;overflow:visible}.builder-header{margin-bottom:2rem}.builder-header h1{font-size:2rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem}.builder-header p{color:#6b7280;font-size:.875rem}.progress-tabs{display:flex;gap:.5rem;margin-bottom:2rem;background:#fff;padding:1rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:.5rem;font-size:.875rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s}.tab:hover:not(:disabled){background:#f3f4f6;border-color:#d1d5db}.tab.active{background:#dbeafe;border-color:#3b82f6;color:#1e40af;font-weight:600}.tab.completed{background:#d1fae5;border-color:#10b981;color:#065f46}.tab:disabled{opacity:.5;cursor:not-allowed}.tab-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#fff;font-size:.75rem;font-weight:700}.tab.active .tab-icon{background:#3b82f6;color:#fff}.tab.completed .tab-icon{background:#10b981;color:#fff}.tab-text{white-space:nowrap}@media (max-width: 768px){.tab-text{display:none}.tab{padding:.75rem .5rem}}.step-content{background:#fff;border-radius:.75rem;padding:2rem;box-shadow:0 1px 3px #0000001a;max-height:calc(100vh - 350px);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.step-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #f3f4f6}.step-header h2{font-size:1.5rem;font-weight:600;color:#1a1a1a;margin:0}.sources-list{display:grid;gap:1rem;margin-bottom:2rem}.source-card{background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;transition:all .2s}.source-card:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #00000014}.source-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.source-icon{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#f9fafb;border-radius:.5rem}.source-info{flex:1}.source-info h3{font-size:1rem;font-weight:600;color:#1a1a1a;margin:0 0 .25rem}.source-name-input{font-size:1rem;font-weight:600;color:#1a1a1a;margin:0 0 .25rem;border:1px solid transparent;padding:.25rem .5rem;border-radius:.25rem;background:transparent;transition:all .2s;width:100%}.source-name-input:hover{background:#f9fafb;border-color:#e5e7eb}.source-name-input:focus{background:#fff;border-color:#3b82f6;outline:none}.source-type{font-size:.7rem;color:#6b7280;text-transform:uppercase;font-weight:600;letter-spacing:.05em}.config-preview{font-size:.875rem;color:#6b7280;padding:.75rem;background:#f9fafb;border-radius:.5rem;border:1px solid #e5e7eb}.config-preview code{background:#fff;padding:.375rem .625rem;border-radius:.25rem;font-family:Courier New,monospace;font-size:.75rem;color:#1e40af;font-weight:500}.source-config-form{margin-top:1rem;padding:1rem;background:#f9fafb;border-radius:.5rem;border:2px solid #e5e7eb}.source-summary{margin-top:1rem;padding:1rem;background:#f9fafb;border-radius:.5rem;border:1px solid #e5e7eb}.summary-item{font-size:.875rem;color:#6b7280;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.summary-item code{background:#fff;padding:.25rem .5rem;border-radius:.25rem;font-family:Courier New,monospace;font-size:.75rem;color:#1e40af;font-weight:500}.field-count{background:#dbeafe;color:#1e40af;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600}.config-form{display:flex;flex-direction:column;gap:1rem}.form-group label{font-size:.8125rem;font-weight:600;color:#374151}.name-editor{position:relative}.name-display{display:flex;align-items:center;justify-content:space-between;padding:.625rem .875rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:.5rem;cursor:pointer;transition:all .2s}.name-display:hover{background:#fff;border-color:#3b82f6}.source-name-text{font-size:.875rem;font-weight:600;color:#1f2937;flex:1}.btn-edit-name{background:none;border:none;font-size:.875rem;cursor:pointer;padding:.25rem;opacity:.5;transition:all .2s}.name-display:hover .btn-edit-name{opacity:1}.form-input,.form-select,.form-textarea{padding:.625rem .875rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;color:#1f2937;background:#fff;transition:all .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-textarea{resize:vertical;font-family:Courier New,monospace;min-height:100px}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.search-box{position:relative;padding:.75rem 1rem .5rem;background:#fff;flex-shrink:0}.search-input{width:100%;padding:.5rem 2rem .5rem .75rem;border:1px solid #e5e7eb;border-radius:.375rem;font-size:.8125rem;transition:all .2s;background:#fff}.search-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f61a}.search-input::placeholder{color:#9ca3af}.btn-clear-search{position:absolute;right:1.25rem;top:50%;transform:translateY(-50%);width:20px;height:20px;border-radius:50%;background:#f3f4f6;border:none;color:#6b7280;font-size:1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;line-height:1;padding:0}.btn-clear-search:hover{background:#e5e7eb;color:#374151}.search-results-info{font-size:.6875rem;color:#6b7280;padding:.25rem .75rem .5rem;background:#fff;flex-shrink:0}.no-fields-found{padding:2rem;text-align:center;color:#9ca3af;background:#f9fafb;border-radius:.5rem;border:2px dashed #e5e7eb;font-size:.875rem}.fields-container-split{display:grid;grid-template-columns:1fr 1fr;gap:1rem;max-height:500px}.available-fields-panel,.selected-fields-panel{display:flex;flex-direction:column;background:#fff;border:2px solid #e5e7eb;border-radius:.5rem;overflow:hidden;max-height:500px}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f9fafb;border-bottom:1px solid #e5e7eb;flex-shrink:0}.panel-header h3{font-size:.8125rem;font-weight:700;color:#374151;margin:0;text-transform:uppercase;letter-spacing:.025em}.panel-actions{display:flex;gap:.5rem;align-items:center}.btn-field-action-small{padding:.375rem .5rem;background:#fff;color:#6b7280;border:1px solid #d1d5db;border-radius:.3125rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s;line-height:1}.btn-field-action-small:hover{background:#f9fafb;border-color:#9ca3af;color:#374151}.fields-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:.5rem .75rem}.field-item{margin-bottom:.1875rem}.field-group{margin-bottom:.75rem}.field-group-header{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;background:#dbeafe;border-radius:.25rem;margin-bottom:.25rem;cursor:pointer;transition:all .2s}.field-group-header:hover{background:#bfdbfe}.field-group-toggle{font-size:.625rem;color:#3b82f6;font-weight:700;transition:transform .2s}.field-group-toggle.collapsed{transform:rotate(-90deg)}.field-group-title{font-size:.75rem;font-weight:700;color:#1e40af;flex:1}.field-group-count{font-size:.625rem;color:#3b82f6;background:#fff;padding:.125rem .375rem;border-radius:.25rem;font-weight:600}.field-group-items{display:flex;flex-direction:column}.field-group-items.collapsed{display:none}.ungrouped-section{margin-bottom:1rem}.ungrouped-header{background:#f0f9ff;border:1px solid #bae6fd;cursor:default;pointer-events:none}.ungrouped-header .field-group-toggle{display:none}.ungrouped-header .field-group-title{color:#0c4a6e}.field-row{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;gap:.5rem;padding:.3125rem .5rem;background:#f9fafb;border-radius:.25rem;border:1px solid #e5e7eb;transition:all .2s;min-height:30px}.field-row:hover{background:#f3f4f6;border-color:#d1d5db}.field-row.related{background:#fefce8;border-color:#fef08a;margin-left:1rem;padding:.25rem .4375rem}.field-info{display:contents}.field-name{font-size:.75rem;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.field-type{font-size:.5625rem;color:#6b7280;background:#fff;padding:.0625rem .25rem;border-radius:.1875rem;font-family:monospace;text-transform:uppercase;font-weight:700;letter-spacing:.025em;white-space:nowrap;line-height:1.4}.btn-add{width:24px;height:24px;border-radius:50%;background:#3b82f6;border:none;color:#fff;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;line-height:1;padding:0;flex-shrink:0}.btn-add:hover{background:#2563eb;transform:scale(1.05)}.btn-add.added{background:#10b981}.btn-add.added:hover{background:#059669}.btn-expand-small{width:20px;height:20px;border-radius:.1875rem;background:#f3f4f6;border:1px solid #e5e7eb;color:#6b7280;font-size:.5625rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}.btn-expand-small:hover{background:#e5e7eb;color:#3b82f6}.selected-fields-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:.5rem .75rem}.selected-field-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .625rem;background:#dbeafe;border:1px solid #93c5fd;border-radius:.375rem;margin-bottom:.375rem;transition:all .2s}.selected-field-item:hover{background:#bfdbfe}.field-number{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#3b82f6;color:#fff;border-radius:50%;font-size:.625rem;font-weight:700;flex-shrink:0}.selected-field-item .field-name{flex:1;font-size:.75rem;font-weight:600;color:#1e40af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-remove-field{width:20px;height:20px;border-radius:50%;background:#fff;border:1px solid #93c5fd;color:#6b7280;font-size:1rem;line-height:1;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}.btn-remove-field:hover{background:#fee2e2;border-color:#fecaca;color:#991b1b}.btn-clear-all{width:100%;padding:.5rem;background:#fff;border:1px dashed #d1d5db;border-radius:.375rem;color:#6b7280;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}.btn-clear-all:hover{background:#fee2e2;border-color:#fecaca;color:#991b1b}.empty-selection{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;color:#9ca3af;text-align:center}.empty-selection p{margin:0 0 .375rem;font-size:.875rem;font-weight:600;color:#6b7280}.empty-selection small{font-size:.75rem;color:#9ca3af}.btn-preview-small{width:28px;height:28px;border-radius:.3125rem;background:#10b981;border:none;color:#fff;font-size:.875rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-preview-small:hover:not(:disabled){background:#059669}.btn-preview-small:disabled{opacity:.5;cursor:not-allowed}.missing-dates-warning{margin:.75rem;padding:.75rem;background:#fef3c7;border:2px solid #f59e0b;border-radius:.5rem;flex-shrink:0}.warning-header{font-size:.75rem;font-weight:700;color:#92400e;margin-bottom:.5rem}.warning-content{font-size:.6875rem;color:#78350f;font-weight:600}.suggested-fields{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.btn-add-suggested{padding:.25rem .5rem;background:#fbbf24;border:1px solid #f59e0b;border-radius:.3125rem;color:#78350f;font-size:.6875rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-add-suggested:hover{background:#f59e0b;color:#fff;transform:translateY(-1px)}.btn-analyze{padding:.625rem 1.25rem;background:#8b5cf6;color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-analyze:hover:not(:disabled){background:#7c3aed;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.btn-analyze:disabled{opacity:.6;cursor:not-allowed}.quality-analysis-results{margin-bottom:2rem;padding:1.5rem;background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;flex-shrink:0}.analysis-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f3f4f6}.analysis-header h3{font-size:1.125rem;font-weight:700;color:#1f2937;margin:0}.sample-info{font-size:.75rem;color:#6b7280;background:#f9fafb;padding:.375rem .75rem;border-radius:.375rem;border:1px solid #e5e7eb}.analysis-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-bottom:1.5rem}.field-stats-card{padding:1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem}.field-stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb}.field-name-stat{font-size:.875rem;font-weight:700;color:#1f2937}.field-type-stat{font-size:.625rem;color:#6b7280;background:#fff;padding:.125rem .375rem;border-radius:.1875rem;font-family:monospace;text-transform:uppercase;font-weight:700}.stats-metrics{display:flex;flex-direction:column;gap:.75rem}.metric{display:flex;flex-direction:column;gap:.375rem}.metric-label{font-size:.75rem;font-weight:600;color:#6b7280}.metric-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.metric-fill{height:100%;transition:width .3s ease}.metric-value{font-size:.75rem;font-weight:700;color:#1f2937}.metric-info{font-size:.6875rem;color:#6b7280;display:flex;flex-direction:column;gap:.25rem}.false-warning{color:#ea580c;font-weight:600}.type-suggestion{padding:.5rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:.375rem;font-size:.75rem;color:#1e40af}.type-suggestion code{background:#fff;padding:.125rem .375rem;border-radius:.1875rem;font-weight:600;color:#3b82f6}.recommendations-section{margin-top:1.5rem;padding:1rem;background:#fef3c7;border:2px solid #fbbf24;border-radius:.5rem}.recommendations-section h4{font-size:.875rem;font-weight:700;color:#92400e;margin:0 0 .75rem}.recommendations-list{display:flex;flex-direction:column;gap:.5rem}.recommendation-item{display:flex;align-items:center;gap:.75rem;padding:.625rem;background:#fff;border-radius:.375rem;border:1px solid #fde047}.rec-icon{font-size:1rem;flex-shrink:0}.rec-text{flex:1;font-size:.8125rem;color:#78350f;font-weight:500}.btn-add-rec{padding:.375rem .75rem;background:#fbbf24;color:#78350f;border:none;border-radius:.3125rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-add-rec:hover{background:#f59e0b;color:#fff}.manual-checks-section{margin-top:1.5rem}.manual-checks-section h3{font-size:1rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.empty-state-small{padding:2rem;text-align:center;background:#f9fafb;border:2px dashed #e5e7eb;border-radius:.5rem}.empty-state-small p{margin:0;font-size:.875rem;color:#6b7280}.check-field{font-size:.75rem;color:#3b82f6;background:#eff6ff;padding:.125rem .375rem;border-radius:.1875rem;margin-left:.5rem;font-weight:600}.loading{text-align:center;padding:2rem;color:#6b7280;font-size:.875rem}.fields-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:1rem}.fields-header-left{display:flex;align-items:center;gap:1rem;flex:1}.fields-actions{display:flex;gap:.5rem}.btn-field-action{padding:.375rem .75rem;background:#fff;color:#6b7280;border:1px solid #d1d5db;border-radius:.375rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-field-action:hover{background:#f9fafb;border-color:#9ca3af;color:#374151}.btn-preview{padding:.5rem 1rem;background:#10b981;color:#fff;border:none;border-radius:.375rem;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.btn-preview:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 4px 8px #10b9814d}.btn-preview:disabled{opacity:.5;cursor:not-allowed}.field-item{display:flex;flex-direction:column}.field-note{margin-top:.5rem;padding:.75rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:.5rem;font-size:.8125rem;color:#1e40af;line-height:1.5}.field-note code{background:#fff;padding:.125rem .375rem;border-radius:.25rem;font-family:Courier New,monospace;font-size:.75rem;color:#3b82f6;font-weight:600}.incremental-note{background:#fef3c7;border-color:#fbbf24;color:#78350f}.note-header{font-size:.875rem;font-weight:700;margin-bottom:.75rem;color:#92400e}.note-content{font-size:.75rem;line-height:1.6}.note-content p{margin:.5rem 0;font-weight:600}.note-content ul{margin:.375rem 0 .75rem 1.25rem;padding:0}.note-content li{margin:.25rem 0;font-weight:400}.note-content code{background:#fff;padding:.125rem .375rem;border-radius:.1875rem;font-family:Courier New,monospace;font-size:.6875rem;color:#ea580c;font-weight:600}.note-recommendation{margin-top:.75rem;padding:.625rem;background:#fed7aa;border-radius:.375rem;border:1px solid #fb923c;font-weight:600;color:#7c2d12}.related-fields{margin-top:.375rem;margin-left:.375rem;padding-left:.5rem;border-left:2px solid #fde047;display:flex;flex-direction:column;gap:.25rem}.related-fields-header{font-size:.625rem;font-weight:600;color:#854d0e;padding:.25rem .375rem;background:#fef9c3;border-radius:.1875rem;border:1px solid #fde047}.preview-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.preview-content{background:#fff;border-radius:1rem;width:90%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040}.preview-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #f3f4f6}.preview-header h3{font-size:1.25rem;font-weight:700;color:#1f2937;margin:0}.btn-close{width:36px;height:36px;border-radius:50%;background:#f3f4f6;border:none;color:#6b7280;font-size:1.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;line-height:1}.btn-close:hover{background:#fee2e2;color:#991b1b}.preview-body{flex:1;overflow:auto;padding:1.5rem 2rem}.preview-info{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f0f9ff;border:1px solid #bae6fd;border-radius:.5rem;margin-bottom:1rem;font-size:.875rem;color:#0c4a6e}.text-muted{color:#64748b;font-size:.75rem}.preview-table-container{overflow-x:auto}.preview-table{width:100%;border-collapse:collapse;font-size:.875rem}.preview-table thead{background:#f9fafb;position:sticky;top:0;z-index:1}.preview-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb;white-space:nowrap}.preview-table td{padding:.75rem 1rem;border-bottom:1px solid #f3f4f6;color:#6b7280;max-width:300px;overflow:hidden;text-overflow:ellipsis}.preview-table tbody tr:hover{background:#f9fafb}.no-data{text-align:center;padding:3rem;color:#9ca3af;font-size:1rem}.no-data p{margin:0 0 .5rem;font-size:1.125rem;font-weight:600;color:#6b7280}.no-data small{font-size:.875rem;color:#9ca3af}.preview-footer{padding:1.5rem 2rem;border-top:2px solid #f3f4f6;display:flex;justify-content:flex-end}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:#fff;border-radius:1rem;padding:2.5rem;max-width:600px;width:90%;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content h2{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;color:#1a1a1a}.source-types-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.source-type-card{padding:2rem 1.5rem;background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;cursor:pointer;transition:all .2s;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem}.source-type-card:hover{background:#f9fafb;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.type-icon{font-size:2.5rem}.type-name{font-weight:600;color:#1a1a1a;font-size:.875rem}.merges-list,.checks-list{display:grid;gap:1rem;margin-bottom:2rem}.merge-card,.check-card{background:#f9fafb;border:2px solid #e5e7eb;border-radius:.75rem;padding:1.5rem}.merge-header,.check-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.merge-header h3,.check-header h3{font-size:1rem;font-weight:600;color:#1a1a1a;margin:0}.merge-visual{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border-radius:.5rem}.merge-source{flex:1;padding:.75rem;background:#dbeafe;border-radius:.375rem;text-align:center;font-size:.875rem;font-weight:500;color:#1e40af}.merge-operation{padding:.5rem 1rem;background:#8b5cf6;color:#fff;border-radius:.375rem;font-size:.75rem;font-weight:600;white-space:nowrap}.check-type{font-size:.75rem;color:#6b7280;text-transform:uppercase;font-weight:500}.quality-buttons{display:flex;gap:.5rem}.btn-small{padding:.5rem 1rem;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:.375rem;cursor:pointer;font-size:.75rem;font-weight:500;color:#374151;transition:all .2s}.btn-small:hover{background:#e5e7eb}.review-section{margin-bottom:2rem;padding:1.5rem;background:#f9fafb;border-radius:.75rem;border:1px solid #e5e7eb}.review-section h3{font-size:1.125rem;font-weight:600;color:#1a1a1a;margin-bottom:1rem}.summary-stats{display:flex;gap:2rem;margin-bottom:1.5rem}.stat-value{display:block;font-size:2rem;font-weight:700;color:#3b82f6;margin-bottom:.25rem}.stat-label{font-size:.75rem;color:#6b7280;text-transform:uppercase}.pipeline-preview{background:#fff;padding:1.5rem;border-radius:.5rem}.pipeline-preview h4{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:1rem}.preview-node{padding:1rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:.5rem;text-align:center;font-size:.875rem;font-weight:500;color:#374151;margin:.5rem 0}.preview-arrow{text-align:center;color:#9ca3af;font-size:1.25rem;margin:.25rem 0}.form-group label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.form-input,.form-textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;font-family:inherit}.form-input:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn-primary,.btn-secondary,.btn-cancel{padding:.75rem 1.5rem;border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background:#3b82f6;color:#fff;box-shadow:0 1px 2px #0000000d}.btn-primary:hover:not(:disabled){background:#2563eb;box-shadow:0 2px 4px #0000001a}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.btn-secondary:hover{background:#e5e7eb}.btn-cancel{background:#fff;color:#6b7280;border:1px solid #e5e7eb;width:100%;margin-top:1rem}.btn-cancel:hover{background:#f9fafb;border-color:#d1d5db}.btn-config,.btn-remove{width:32px;height:32px;border-radius:50%;background:#f3f4f6;border:1px solid #e5e7eb;color:#6b7280;cursor:pointer;font-size:1rem;font-weight:400;line-height:1;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0}.btn-config:hover{background:#dbeafe;border-color:#bfdbfe;color:#3b82f6}.btn-remove{font-size:1.25rem}.btn-remove:hover{background:#fee2e2;border-color:#fecaca;color:#991b1b}.btn-back{padding:.625rem 1.25rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;color:#374151;transition:all .2s;margin-bottom:1.5rem;display:inline-block}.btn-back:hover{background:#f3f4f6}.step-actions{display:flex;justify-content:space-between;margin-top:auto;padding-top:2rem;border-top:2px solid #f3f4f6}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem;color:#9ca3af;background:#f9fafb;border-radius:.75rem;border:2px dashed #e5e7eb;margin-bottom:2rem}.empty-icon{font-size:3.5rem;margin-bottom:1rem;opacity:.6}.empty-state h3{font-size:1.125rem;font-weight:600;color:#6b7280;margin-bottom:.5rem}.empty-state p{font-size:.875rem;color:#9ca3af}@media (max-width: 768px){.multi-source-container{padding:1rem}.progress-bar{flex-direction:column;gap:.5rem}.source-types-grid{grid-template-columns:1fr}.summary-stats{flex-direction:column;gap:1rem}}.pipeline-container{padding:2rem;height:calc(100vh - 4rem);display:flex;flex-direction:column}.pipeline-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.pipeline-header h1{font-size:2rem;font-weight:700;color:hsl(var(--foreground));margin-bottom:.5rem}.header-actions{display:flex;gap:1rem}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.btn-primary{background:hsl(var(--primary));color:hsl(var(--primary-foreground))}.btn-secondary{background:hsl(var(--muted));color:hsl(var(--foreground))}.btn-secondary:hover{background:hsl(var(--accent))}.pipeline-workspace{flex:1;display:grid;grid-template-columns:280px 1fr 320px;gap:1.5rem;min-height:0}.node-palette{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;overflow-y:auto}.node-palette h3{font-size:1rem;font-weight:600;margin-bottom:1rem;color:hsl(var(--foreground))}.palette-grid{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.palette-node{display:flex;flex-direction:column;align-items:flex-start;padding:1rem;background:hsl(var(--muted) / .5);border:2px solid hsl(var(--border));border-radius:.5rem;cursor:pointer;transition:all .2s;text-align:left}.palette-node:hover{background:hsl(var(--card));transform:translate(4px);box-shadow:0 2px 8px #0000001a;border-color:hsl(var(--primary) / .5)}.palette-icon{font-size:1.5rem;margin-bottom:.5rem}.palette-title{font-size:.875rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:.25rem}.palette-description{font-size:.75rem;color:hsl(var(--muted-foreground))}.templates-section{border-top:1px solid hsl(var(--border));padding-top:1rem}.templates-section h4{font-size:.875rem;font-weight:600;margin-bottom:.75rem;color:hsl(var(--foreground))}.template-btn{width:100%;padding:.75rem;background:linear-gradient(135deg,hsl(var(--primary)),#6b26d9);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;margin-bottom:.5rem;transition:transform .2s}.template-btn:hover{transform:scale(1.02)}.pipeline-canvas{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.75rem;box-shadow:0 1px 3px #0000001a;overflow-y:auto;padding:2rem;position:relative}.empty-canvas{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:hsl(var(--muted-foreground))}.empty-canvas h3{font-size:1.5rem;font-weight:600;color:hsl(var(--muted-foreground));margin-bottom:.5rem}.empty-canvas p{font-size:.875rem}.nodes-container{display:flex;flex-direction:column;align-items:center;gap:0}.pipeline-node-wrapper{display:flex;flex-direction:column;align-items:center;width:100%;max-width:500px}.pipeline-node{width:100%;background:hsl(var(--card));border:3px solid;border-radius:.75rem;overflow:hidden;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0000001a}.pipeline-node:hover{transform:scale(1.02);box-shadow:0 4px 12px #00000026}.pipeline-node.selected{box-shadow:0 0 0 3px hsl(var(--primary) / .3);transform:scale(1.02)}.node-header{padding:1rem;color:#fff;display:flex;align-items:center;gap:.75rem}.node-icon{font-size:1.5rem}.node-title{flex:1;font-weight:600;font-size:.875rem}.node-remove{width:24px;height:24px;border-radius:50%;background:#fff3;border:none;color:#fff;cursor:pointer;font-size:1.25rem;line-height:1;transition:background .2s}.node-remove:hover{background:#ffffff4d}.node-body{padding:1rem;background:hsl(var(--muted) / .5)}.node-config-preview{font-size:.75rem;color:hsl(var(--muted-foreground))}.node-config-preview strong{color:hsl(var(--foreground))}.node-connector{display:flex;flex-direction:column;align-items:center;height:40px;position:relative}.connector-line{width:3px;height:100%;background:linear-gradient(180deg,hsl(var(--border)),hsl(var(--muted-foreground)))}.connector-arrow{position:absolute;bottom:-5px;font-size:1.25rem;color:hsl(var(--muted-foreground))}.config-panel{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.75rem;box-shadow:0 1px 3px #0000001a;overflow:hidden;display:flex;flex-direction:column}.config-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid hsl(var(--border));background:hsl(var(--muted) / .5)}.config-header h3{font-size:1.125rem;font-weight:600;color:hsl(var(--foreground))}.close-btn{width:32px;height:32px;border-radius:50%;background:hsl(var(--muted));border:none;color:hsl(var(--muted-foreground));cursor:pointer;font-size:1.5rem;line-height:1;transition:all .2s}.close-btn:hover{background:hsl(var(--accent));color:hsl(var(--foreground))}.config-body{flex:1;padding:1.5rem;overflow-y:auto}.node-config{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:hsl(var(--foreground))}.help-text{font-size:.75rem;color:hsl(var(--muted-foreground));margin-top:-.25rem}.form-input,.form-textarea,.form-select{width:100%;padding:.75rem;border:1px solid hsl(var(--border));border-radius:.5rem;font-size:.875rem;font-family:inherit;background:hsl(var(--background));color:hsl(var(--foreground));transition:all .2s}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:hsl(var(--primary));box-shadow:0 0 0 3px hsl(var(--primary) / .1)}.form-textarea{font-family:Courier New,monospace;resize:vertical}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400!important}.checkbox-label input[type=checkbox]{cursor:pointer}.loading{text-align:center;padding:3rem;color:hsl(var(--muted-foreground))}.node-palette::-webkit-scrollbar,.pipeline-canvas::-webkit-scrollbar,.config-body::-webkit-scrollbar{width:8px}.node-palette::-webkit-scrollbar-track,.pipeline-canvas::-webkit-scrollbar-track,.config-body::-webkit-scrollbar-track{background:hsl(var(--muted) / .5)}.node-palette::-webkit-scrollbar-thumb,.pipeline-canvas::-webkit-scrollbar-thumb,.config-body::-webkit-scrollbar-thumb{background:hsl(var(--border));border-radius:4px}@media (max-width: 1200px){.pipeline-workspace{grid-template-columns:1fr}.config-panel{position:fixed;top:0;right:0;width:100%;max-width:400px;height:100vh;z-index:1000}}.runs-container{padding:1.5rem;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem}.header-actions{display:flex;gap:.75rem;align-items:center}.btn-bulk-delete{padding:.5rem 1rem;background:hsl(var(--destructive) / .1);color:hsl(var(--destructive));border:1px solid hsl(var(--destructive) / .3);border-radius:.375rem;cursor:pointer;font-size:.8125rem;font-weight:600;transition:all .2s}.btn-bulk-delete:hover{background:hsl(var(--destructive));color:hsl(var(--destructive-foreground));border-color:hsl(var(--destructive))}.btn-bulk-delete:disabled{opacity:.5;cursor:not-allowed}.page-header h1{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground));margin-bottom:.25rem}.page-description{color:hsl(var(--muted-foreground));font-size:.875rem}.btn-refresh{padding:.5rem 1rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.375rem;cursor:pointer;font-size:.8125rem;font-weight:500;color:hsl(var(--foreground));transition:all .2s}.btn-refresh:hover{background:hsl(var(--accent))}.filter-tabs{display:flex;gap:.5rem;margin-bottom:1.25rem;border-bottom:2px solid hsl(var(--border));overflow-x:auto}.tab{padding:.5rem 1rem;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:.8125rem;font-weight:500;color:hsl(var(--muted-foreground));transition:all .2s;margin-bottom:-2px;white-space:nowrap}.tab:hover{color:hsl(var(--primary))}.tab.active{color:hsl(var(--primary));border-bottom-color:hsl(var(--primary))}.runs-table{width:100%;border-collapse:collapse}.runs-table thead{background:hsl(var(--muted) / .5)}.runs-table th{text-align:left;padding:.5rem 1rem;font-size:.75rem;font-weight:600;color:hsl(var(--muted-foreground));text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid hsl(var(--border))}.checkbox-col{width:40px;padding:.5rem 0 .5rem 1rem!important;text-align:center!important}.checkbox-col input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:hsl(var(--primary))}.row-selected{background:hsl(var(--primary) / .05)!important}.runs-table th:last-child{text-align:center}.runs-table td{padding:.375rem 1rem;border-bottom:1px solid hsl(var(--border));font-size:.8125rem;color:hsl(var(--foreground));vertical-align:middle}.runs-table td:last-child{vertical-align:middle;padding:.375rem .75rem;text-align:center;border-bottom:none}.runs-table tbody tr{transition:background .2s}.runs-table tbody tr:hover{background:hsl(var(--accent) / .5)}.runs-table tbody tr.row-running{background:#f59f0a1a;border-left:3px solid hsl(38 92% 50%)}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize}.status-icon{font-size:1rem}.badge-success{background:#16a2491a;color:#16a249;border:1px solid hsl(142 76% 36% / .2)}.badge-error{background:hsl(var(--destructive) / .1);color:hsl(var(--destructive));border:1px solid hsl(var(--destructive) / .2)}.badge-warning{background:#f59f0a1a;color:#f59f0a;border:1px solid hsl(38 92% 50% / .2)}.badge-info{background:hsl(var(--primary) / .1);color:hsl(var(--primary));border:1px solid hsl(var(--primary) / .2)}.badge-secondary{background:hsl(var(--muted));color:hsl(var(--muted-foreground));border:1px solid hsl(var(--border))}.run-id{background:hsl(var(--muted));padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-family:Courier New,monospace;color:hsl(var(--primary));font-weight:500}.flow-name{font-weight:500;color:hsl(var(--foreground))}.duration-running{color:#f59f0a;font-weight:500}.records-info{display:flex;align-items:center;gap:.25rem}.records-loaded{font-weight:600;color:#16a249}.records-separator,.records-total{color:hsl(var(--muted-foreground))}.records-failed{color:hsl(var(--destructive));font-size:.75rem;margin-left:.25rem}.action-buttons{display:flex;align-items:center;justify-content:center;gap:.375rem;width:100%;border:none}.btn-small{display:inline-flex;align-items:center;justify-content:center;width:60px;height:26px;padding:0 .5rem;font-size:.7rem;font-weight:500;border-radius:.25rem;transition:all .15s;border:1px solid;cursor:pointer;box-sizing:border-box;line-height:1;white-space:nowrap;flex-shrink:0;margin:0}.btn-view{background:hsl(var(--card));color:hsl(var(--muted-foreground));border-color:hsl(var(--border))}.btn-view:hover{background:hsl(var(--accent));border-color:hsl(var(--border));color:hsl(var(--foreground))}.btn-cancel{background:hsl(var(--card));color:hsl(var(--destructive));border-color:hsl(var(--destructive) / .3)}.btn-cancel:hover{background:hsl(var(--destructive) / .1);border-color:hsl(var(--destructive) / .5);color:hsl(var(--destructive))}.btn-delete{background:hsl(var(--card));color:hsl(var(--destructive));border-color:hsl(var(--destructive) / .3)}.btn-delete:hover{background:hsl(var(--destructive) / .1);border-color:hsl(var(--destructive) / .5);color:hsl(var(--destructive))}.btn-retry{background:hsl(var(--card));color:#16a249;border-color:#16a2494d}.btn-retry:hover{background:#16a2491a;border-color:#16a24980;color:#16a249}.empty-state{text-align:center;padding:4rem 2rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h3{font-size:1.5rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:.5rem}.empty-state p{color:hsl(var(--muted-foreground));margin-bottom:2rem}.btn-primary{padding:.75rem 1.5rem;background:hsl(var(--primary));color:hsl(var(--primary-foreground));border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background .2s}.loading,.error{text-align:center;padding:3rem;font-size:1.125rem;color:hsl(var(--muted-foreground))}.modal-content{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.75rem;box-shadow:0 20px 25px -5px #0003,0 10px 10px -5px #0000001a;width:90%;max-width:500px;overflow:hidden}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid hsl(var(--border))}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:hsl(var(--foreground))}.modal-body p{margin:0 0 .75rem;color:hsl(var(--foreground));font-size:.9375rem;line-height:1.5}.modal-warning{color:hsl(var(--destructive))!important;font-size:.875rem!important;margin-top:.5rem!important}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;border-top:1px solid hsl(var(--border));background:hsl(var(--muted) / .5)}.modal-actions button{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:.375rem;border:1px solid;cursor:pointer;transition:all .15s}.modal-actions button:disabled{opacity:.5;cursor:not-allowed}.modal-actions .btn-cancel{background:hsl(var(--card));color:hsl(var(--foreground));border-color:hsl(var(--border))}.modal-actions .btn-cancel:hover:not(:disabled){background:hsl(var(--accent));border-color:hsl(var(--border))}.modal-actions .btn-delete{background:hsl(var(--destructive));color:hsl(var(--destructive-foreground));border-color:hsl(var(--destructive))}.modal-actions .btn-delete:hover:not(:disabled){background:hsl(var(--destructive) / .9);border-color:hsl(var(--destructive) / .9)}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem;padding:1rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.pagination-btn{padding:.5rem 1rem;background:hsl(var(--card));color:hsl(var(--foreground));border:1px solid hsl(var(--border));border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .15s}.pagination-btn:hover:not(:disabled){background:hsl(var(--accent));border-color:hsl(var(--border));color:hsl(var(--foreground))}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{color:hsl(var(--muted-foreground));font-size:.875rem;font-weight:500}@media (max-width: 1024px){.runs-container{padding:1rem}.table-container{overflow-x:auto}.runs-table{min-width:900px}.runs-table th,.runs-table td{padding:.75rem 1rem}}@media (max-width: 768px){.page-header{flex-direction:column;gap:1rem}.runs-table{font-size:.75rem}.runs-table th,.runs-table td{padding:.5rem}.action-buttons{flex-direction:column}}.run-detail-container{padding:1.5rem;max-width:1400px;margin:0 auto}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.header-left{display:flex;align-items:center;gap:.75rem}.btn-back{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:transparent;border:none;cursor:pointer;font-size:.8125rem;font-weight:500;color:hsl(var(--muted-foreground));transition:color .15s}.btn-back:hover{color:hsl(var(--foreground))}.header-separator{color:hsl(var(--muted-foreground));font-size:.875rem}.run-id-header{font-size:.875rem;font-weight:600;color:hsl(var(--foreground));background:hsl(var(--muted));padding:.25rem .5rem;border-radius:.25rem}.status-badge-sm{padding:.25rem .625rem;border-radius:9999px;font-size:.6875rem;font-weight:600;text-transform:uppercase}.badge-success{background:#16a2491a;color:#16a249}.badge-error{background:hsl(var(--destructive) / .1);color:hsl(var(--destructive))}.badge-warning{background:#f59f0a1a;color:#f59f0a}.badge-info{background:hsl(var(--primary) / .1);color:hsl(var(--primary))}.badge-secondary{background:hsl(var(--muted));color:hsl(var(--muted-foreground))}.header-right{display:flex;align-items:center;gap:.75rem}.auto-refresh-toggle{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:hsl(var(--muted-foreground));cursor:pointer}.auto-refresh-toggle input[type=checkbox]{cursor:pointer;accent-color:hsl(var(--primary))}.btn-retry{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#16a2491a;color:#16a249;border:1px solid hsl(142 76% 36% / .3);border-radius:.375rem;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .15s}.btn-retry:hover{background:#16a24933;border-color:#16a24980}.btn-cancel-run{padding:.375rem .75rem;background:hsl(var(--destructive) / .1);color:hsl(var(--destructive));border:1px solid hsl(var(--destructive) / .3);border-radius:.375rem;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .15s}.btn-cancel-run:hover{background:hsl(var(--destructive) / .2);border-color:hsl(var(--destructive) / .5)}.info-row{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.5rem;padding:.75rem 1rem;margin-bottom:.75rem}.info-row-main{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.flow-link{color:hsl(var(--primary));font-size:.8125rem;font-weight:600;cursor:pointer;transition:color .15s}.flow-link:hover{color:hsl(var(--primary) / .8);text-decoration:underline}.info-separator{color:hsl(var(--muted-foreground));font-size:.75rem}.info-item{display:flex;align-items:center;gap:.375rem;font-size:.75rem}.info-item .info-label{color:hsl(var(--muted-foreground))}.info-item .info-value{color:hsl(var(--foreground));font-weight:500}.stats-row{display:flex;align-items:center;gap:1rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.5rem;padding:.75rem 1rem;margin-bottom:.75rem}.stat-inline{display:flex;align-items:center;gap:.5rem;padding-right:1rem;border-right:1px solid hsl(var(--border))}.stat-inline:last-child{border-right:none;padding-right:0}.stat-inline.wide{flex:1}.stat-number{font-size:1.125rem;font-weight:700;color:hsl(var(--foreground))}.stat-number.success{color:#16a249}.stat-number.error{color:hsl(var(--destructive))}.stat-inline .stat-label{font-size:.6875rem;font-weight:500;color:hsl(var(--muted-foreground));text-transform:uppercase;letter-spacing:.025em}.stat-code{font-size:.6875rem;font-family:SF Mono,Monaco,Courier New,monospace;color:hsl(var(--muted-foreground));background:hsl(var(--muted));padding:.125rem .375rem;border-radius:.25rem}.error-banner{background:hsl(var(--destructive) / .05);border:1px solid hsl(var(--destructive) / .2);border-radius:.5rem;padding:.75rem 1rem;margin-bottom:.75rem}.error-banner-header{display:flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;color:hsl(var(--destructive));text-transform:uppercase;letter-spacing:.025em;margin-bottom:.375rem}.error-banner-content{color:hsl(var(--destructive));font-size:.8125rem;line-height:1.4}.stack-trace{margin-top:.5rem}.stack-trace summary{cursor:pointer;font-size:.75rem;color:hsl(var(--destructive) / .7);font-weight:500}.stack-trace pre{margin-top:.5rem;padding:.75rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.375rem;overflow-x:auto;font-size:.6875rem;line-height:1.5;color:hsl(var(--destructive))}.logs-section{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.5rem;overflow:hidden}.logs-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid hsl(var(--border))}.logs-title{display:flex;align-items:center;gap:.5rem}.logs-title h2{font-size:.875rem;font-weight:600;color:hsl(var(--foreground));margin:0}.log-count{font-size:.6875rem;font-weight:500;color:hsl(var(--muted-foreground));background:hsl(var(--muted));padding:.125rem .375rem;border-radius:9999px}.log-filters{display:flex;gap:.25rem}.filter-btn{padding:.25rem .625rem;background:transparent;border:1px solid hsl(var(--border));border-radius:.25rem;cursor:pointer;font-size:.6875rem;font-weight:500;color:hsl(var(--muted-foreground));transition:all .15s}.filter-btn:hover{background:hsl(var(--muted))}.filter-btn.active{background:hsl(var(--primary));color:hsl(var(--primary-foreground));border-color:hsl(var(--primary))}.logs-container{max-height:500px;overflow-y:auto;background:#0b111e;padding:.5rem;font-family:SF Mono,Monaco,Courier New,monospace}.logs-container::-webkit-scrollbar{width:6px}.logs-container::-webkit-scrollbar-track{background:#0f1729}.logs-container::-webkit-scrollbar-thumb{background:hsl(var(--muted-foreground) / .3);border-radius:3px}.no-logs{text-align:center;padding:2rem;color:hsl(var(--muted-foreground));font-size:.8125rem}.log-entry{display:flex;align-items:flex-start;gap:.5rem;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;transition:background .1s}.log-entry:hover{background:#131d34}.log-entry.log-info{border-left:2px solid hsl(var(--primary))}.log-entry.log-warning{border-left:2px solid hsl(38 92% 50%);background:#f59f0a0d}.log-entry.log-error,.log-entry.log-critical{border-left:2px solid hsl(var(--destructive));background:hsl(var(--destructive) / .05)}.log-entry.log-debug{border-left:2px solid hsl(var(--muted-foreground))}.log-time{color:hsl(var(--muted-foreground));font-size:.6875rem;white-space:nowrap;min-width:70px}.log-level{padding:.0625rem .375rem;border-radius:.125rem;font-size:.5625rem;font-weight:700;text-transform:uppercase;white-space:nowrap}.level-info{background:hsl(var(--primary));color:hsl(var(--primary-foreground))}.level-warning{background:#f59f0a;color:#000}.level-error,.level-critical{background:hsl(var(--destructive));color:hsl(var(--destructive-foreground))}.level-debug{background:hsl(var(--muted));color:hsl(var(--muted-foreground))}.log-msg{color:hsl(var(--foreground) / .9);flex:1;word-break:break-word}.loading,.error{text-align:center;padding:3rem;font-size:1rem;color:hsl(var(--muted-foreground))}.error{color:hsl(var(--destructive))}.btn-primary{margin-top:1rem;padding:.5rem 1rem;background:hsl(var(--primary));color:hsl(var(--primary-foreground));border:none;border-radius:.375rem;cursor:pointer;font-size:.8125rem;font-weight:500;transition:background .15s}@media (max-width: 768px){.run-detail-container{padding:1rem}.detail-header{flex-direction:column;align-items:flex-start;gap:.75rem}.header-left{flex-wrap:wrap}.info-row-main{flex-direction:column;align-items:flex-start;gap:.5rem}.info-separator{display:none}.stats-row{flex-wrap:wrap}.stat-inline{border-right:none;padding-right:0}.logs-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.schedules-container{padding:1.5rem;max-width:1400px;margin:0 auto;min-height:calc(100vh - 4rem);background:hsl(var(--background))}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.header-content h1{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground));margin:0 0 .25rem}.page-description{color:hsl(var(--muted-foreground));font-size:.875rem;margin:0}.btn-primary{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:hsl(var(--primary));color:hsl(var(--primary-foreground));border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s}.btn-primary:hover{background:hsl(var(--primary) / .9)}.btn-primary svg{width:14px;height:14px}.stats-bar{display:flex;align-items:center;gap:1.5rem;padding:.75rem 1.25rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.25rem}.stat-item{display:flex;align-items:baseline;gap:.5rem}.stat-value{font-size:1.25rem;font-weight:700;color:hsl(var(--foreground))}.stat-value.active{color:#16a249}.stat-value.inactive{color:hsl(var(--muted-foreground))}.stat-label{font-size:.8125rem;color:hsl(var(--muted-foreground));font-weight:500}.stat-divider{width:1px;height:32px;background:hsl(var(--border))}.info-banner{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;background:#f1f5f9;border:1px solid hsl(210 40% 85%);border-radius:.5rem;margin-bottom:1.25rem;color:#36597d;font-size:.875rem;line-height:1.5}[data-theme=dark] .info-banner{background:#172636;border-color:#264059;color:#a6bfd9}.info-banner svg{flex-shrink:0;margin-top:.125rem}.table-container{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.75rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.schedules-table{width:100%;border-collapse:separate;border-spacing:0}.schedules-table thead{border-bottom:2px solid hsl(var(--border))}.schedules-table th{text-align:left;padding:.625rem 1rem;font-size:.75rem;font-weight:600;color:hsl(var(--muted-foreground));text-transform:uppercase;letter-spacing:.05em;background:hsl(var(--muted) / .5);border:none;border-bottom:2px solid hsl(var(--border))}.schedules-table th:first-child{padding-left:1.25rem;width:70px}.schedules-table th:last-child{padding-right:1.25rem;width:100px;text-align:center}.schedules-table tbody tr{transition:background .15s}.schedules-table tbody tr:hover{background:hsl(var(--accent) / .5)}.schedules-table tbody tr.inactive-row{opacity:.6}.schedules-table td{padding:.75rem 1rem;border:none;border-bottom:1px solid hsl(var(--border));vertical-align:middle;color:hsl(var(--foreground))}.schedules-table tbody tr:last-child td{border-bottom:none}.schedules-table td:first-child{padding-left:1.25rem}.schedules-table td:last-child{padding-right:1.25rem;text-align:center}.toggle-btn{position:relative;width:44px;height:24px;background:hsl(var(--muted));border:1px solid hsl(var(--border));border-radius:12px;cursor:pointer;transition:all .2s}.toggle-btn.active{background:#16a249;border-color:#16a249}.toggle-slider{position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:all .2s;box-shadow:0 1px 3px #0003}.toggle-btn.active .toggle-slider{left:22px}.schedule-name{font-weight:600;color:hsl(var(--foreground))}.pipeline-name{font-size:.875rem;color:hsl(var(--foreground))}.schedule-summary{font-size:.8125rem;color:hsl(var(--foreground));margin-bottom:.25rem}.trigger-times-preview{display:flex;gap:.25rem;flex-wrap:wrap}.time-badge{display:inline-block;padding:.125rem .375rem;background:hsl(var(--muted));color:hsl(var(--muted-foreground));border-radius:.25rem;font-size:.6875rem;font-family:SF Mono,Monaco,Courier New,monospace}.more-times{font-size:.6875rem;color:hsl(var(--muted-foreground))}.mode-badge{display:inline-block;padding:.25rem .5rem;border-radius:.25rem;font-size:.6875rem;font-weight:600;text-transform:uppercase}.mode-badge.incremental{background:hsl(var(--primary) / .1);color:hsl(var(--primary))}.mode-badge.full{background:#f59f0a1a;color:#c47f08}.date-text{font-size:.8125rem;color:hsl(var(--muted-foreground))}.action-buttons{display:flex;align-items:center;justify-content:center;gap:.375rem}.action-btn{width:30px;height:30px;border:1px solid;border-radius:.375rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;box-shadow:0 1px 2px #0000000d;background:hsl(var(--card));flex-shrink:0}.action-btn.edit{background:hsl(var(--card));color:hsl(var(--muted-foreground));border-color:hsl(var(--border))}.action-btn.edit:hover{background:hsl(var(--accent));color:hsl(var(--foreground));border-color:hsl(var(--border));box-shadow:0 2px 4px #0000001a}.action-btn.delete{background:hsl(var(--card));color:hsl(var(--destructive));border-color:hsl(var(--destructive) / .3)}.action-btn.delete:hover{background:hsl(var(--destructive));color:hsl(var(--destructive-foreground));border-color:hsl(var(--destructive));box-shadow:0 2px 4px hsl(var(--destructive) / .2)}.action-btn svg{width:14px;height:14px;flex-shrink:0;display:block}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease;padding:1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:1rem;width:100%;max-width:420px;box-shadow:0 20px 25px -5px #0003,0 10px 10px -5px #0000001a;animation:slideUp .2s ease}.schedule-modal{max-width:560px;max-height:90vh;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid hsl(var(--border));position:sticky;top:0;background:hsl(var(--card));z-index:10;border-radius:1rem 1rem 0 0}.modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:hsl(var(--foreground))}.modal-close{background:none;border:none;padding:.25rem;cursor:pointer;color:hsl(var(--muted-foreground));transition:color .15s}.modal-close:hover{color:hsl(var(--foreground))}.modal-body{padding:1.5rem}.modal-body p{margin:0 0 .75rem;color:hsl(var(--foreground))}.modal-body .modal-warning{font-size:.875rem;color:hsl(var(--destructive));margin:0}.form-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid hsl(var(--border))}.form-section:last-of-type{border-bottom:none;margin-bottom:1rem;padding-bottom:0}.form-section h4{font-size:.875rem;font-weight:600;color:hsl(var(--foreground));margin:0 0 1rem}.form-section h4 .optional{font-weight:400;color:hsl(var(--muted-foreground));font-size:.75rem}.section-desc{font-size:.8125rem;color:hsl(var(--muted-foreground));margin:-.5rem 0 1rem}.form-row{margin-bottom:1rem}.form-row:last-child{margin-bottom:0}.form-row.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{margin-bottom:1rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-size:.8125rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:.5rem}.form-group input[type=text],.form-group input[type=date],.form-group input[type=time],.form-group select{width:100%;padding:.625rem .875rem;background:hsl(var(--background));border:1px solid hsl(var(--border));border-radius:.5rem;font-size:.875rem;color:hsl(var(--foreground));transition:border-color .15s,box-shadow .15s}.form-group input[type=text]:focus,.form-group input[type=date]:focus,.form-group input[type=time]:focus,.form-group select:focus{outline:none;border-color:hsl(var(--primary));box-shadow:0 0 0 3px hsl(var(--primary) / .1)}.form-group select{cursor:pointer}.form-hint{display:block;margin-top:.375rem;font-size:.75rem;color:hsl(var(--muted-foreground))}.checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-group input[type=checkbox]{width:16px;height:16px;cursor:pointer}.checkbox-group span{font-weight:500}.frequency-options{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1rem}.frequency-btn{display:flex;flex-direction:column;align-items:center;gap:.375rem;padding:.75rem .5rem;background:hsl(var(--background));border:1px solid hsl(var(--border));border-radius:.5rem;cursor:pointer;transition:all .15s;font-size:.75rem;color:hsl(var(--muted-foreground))}.frequency-btn:hover{border-color:hsl(var(--primary) / .5)}.frequency-btn.active{background:hsl(var(--primary) / .1);border-color:hsl(var(--primary));color:hsl(var(--primary))}.freq-icon{font-size:1.25rem}.weekday-selector{margin-top:1rem}.weekday-buttons{display:flex;gap:.375rem}.weekday-btn{flex:1;padding:.5rem .25rem;background:hsl(var(--background));border:1px solid hsl(var(--border));border-radius:.375rem;cursor:pointer;font-size:.75rem;font-weight:500;color:hsl(var(--muted-foreground));transition:all .15s}.weekday-btn:hover{border-color:hsl(var(--primary) / .5)}.weekday-btn.active{background:hsl(var(--primary));border-color:hsl(var(--primary));color:hsl(var(--primary-foreground))}.trigger-times-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.trigger-time-chip{display:flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:hsl(var(--primary) / .1);border:1px solid hsl(var(--primary) / .2);border-radius:.375rem;font-size:.875rem;font-weight:500;color:hsl(var(--primary))}.remove-time-btn{display:flex;align-items:center;justify-content:center;padding:.125rem;background:none;border:none;cursor:pointer;color:hsl(var(--primary));opacity:.7;transition:opacity .15s}.remove-time-btn:hover:not(:disabled){opacity:1}.remove-time-btn:disabled{opacity:.3;cursor:not-allowed}.add-time-row{display:flex;gap:.5rem;margin-bottom:1rem}.time-input{flex:1;padding:.5rem .75rem;background:hsl(var(--background));border:1px solid hsl(var(--border));border-radius:.375rem;font-size:.875rem;color:hsl(var(--foreground))}.time-input:focus{outline:none;border-color:hsl(var(--primary));box-shadow:0 0 0 3px hsl(var(--primary) / .1)}.btn-add-time{padding:.5rem 1rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.375rem;cursor:pointer;font-size:.8125rem;font-weight:500;color:hsl(var(--foreground));transition:all .15s}.btn-add-time:hover:not(:disabled){background:hsl(var(--accent))}.btn-add-time:disabled{opacity:.5;cursor:not-allowed}.quick-times{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.quick-label{font-size:.75rem;color:hsl(var(--muted-foreground))}.quick-time-btn{padding:.25rem .5rem;background:hsl(var(--background));border:1px solid hsl(var(--border));border-radius:.25rem;cursor:pointer;font-size:.75rem;color:hsl(var(--muted-foreground));transition:all .15s}.quick-time-btn:hover:not(:disabled){border-color:hsl(var(--primary) / .5);color:hsl(var(--foreground))}.quick-time-btn.added,.quick-time-btn:disabled{background:hsl(var(--muted));opacity:.5;cursor:not-allowed}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid hsl(var(--border));background:hsl(var(--muted) / .5);border-radius:0 0 1rem 1rem;position:sticky;bottom:0}.btn-cancel{padding:.5rem 1rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;color:hsl(var(--foreground));transition:all .15s}.btn-cancel:hover{background:hsl(var(--accent))}.btn-delete{padding:.5rem 1rem;background:hsl(var(--card));border:1px solid hsl(var(--destructive) / .3);border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:600;color:hsl(var(--destructive));transition:all .15s}.btn-delete:hover{background:hsl(var(--destructive) / .1);border-color:hsl(var(--destructive))}.btn-delete:disabled,.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:hsl(var(--muted-foreground));gap:1rem}.spinner{width:32px;height:32px;border:3px solid hsl(var(--border));border-top-color:hsl(var(--primary));border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-state{text-align:center;padding:4rem 2rem;color:hsl(var(--destructive));font-size:1rem;font-weight:500}.empty-state{text-align:center;padding:5rem 2rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:1rem;box-shadow:0 1px 3px #0000001a}.empty-state svg{margin-bottom:1.5rem;opacity:.4;color:hsl(var(--muted-foreground))}.empty-state h3{font-size:1.25rem;font-weight:600;color:hsl(var(--foreground));margin:0 0 .5rem}.empty-state p{color:hsl(var(--muted-foreground));margin:0 0 1.5rem}@media (max-width: 768px){.schedules-container{padding:1rem}.stats-bar{flex-wrap:wrap;gap:1rem}.stat-divider{display:none}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.schedules-table th:nth-child(5),.schedules-table td:nth-child(5),.schedules-table th:nth-child(6),.schedules-table td:nth-child(6){display:none}.modal-content{margin:0;max-width:100%;max-height:100vh;border-radius:0}.modal-header,.modal-actions{border-radius:0}.form-row.two-cols{grid-template-columns:1fr}.frequency-options{grid-template-columns:repeat(2,1fr)}.weekday-buttons{flex-wrap:wrap}.weekday-btn{flex:0 0 calc(25% - .375rem)}.target-type-selector{flex-direction:column}}.target-type-selector{display:flex;gap:.75rem;margin-bottom:.5rem}.target-type-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:hsl(var(--card));border:2px solid hsl(var(--border));border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;color:hsl(var(--muted-foreground));transition:all .15s}.target-type-btn:hover{border-color:hsl(var(--primary) / .5);color:hsl(var(--foreground))}.target-type-btn.active{background:hsl(var(--primary) / .1);border-color:hsl(var(--primary));color:hsl(var(--primary))}.target-icon{font-size:1rem}.target-cell{display:flex;align-items:center;gap:.5rem}.target-badge{padding:.125rem .5rem;border-radius:.25rem;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.target-badge.flow{background:#7c3bed1a;color:#7c3bed}.target-badge.profile{background:#22c1d31a;color:#22c1d3}.target-name{font-weight:500;color:hsl(var(--foreground))}.pipelines-container{padding:24px;max-width:1400px;margin:0 auto}.pipelines-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.btn-create-pipeline{padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s}.btn-create-pipeline:hover{background:#2563eb}.pipelines-filters{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;align-items:center}.search-input{flex:1;min-width:200px;max-width:400px;padding:10px 16px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.95rem}.filter-chips{display:flex;gap:8px;flex-wrap:wrap}.status-filter{padding:10px 16px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.95rem;cursor:pointer}.pipelines-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:20px}.pipeline-card{display:flex;flex-direction:column;padding:20px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;text-decoration:none;color:inherit;transition:all .2s}.pipeline-card:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.pipeline-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.pipeline-name{margin:0;font-size:1.1rem;color:var(--text-primary)}.pipeline-description{margin:0 0 12px;color:var(--text-secondary);font-size:.9rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.status-badge{padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase}.layer-badge{padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:500}.pipeline-steps-preview{display:flex;align-items:center;gap:8px;padding:12px;background:var(--bg-tertiary);border-radius:8px;margin-bottom:16px}.steps-label{color:var(--text-secondary);font-size:.85rem}.steps-count{font-weight:500;color:var(--text-primary)}.layer-badges{display:flex;gap:6px;margin-left:auto}.pipeline-stats{display:flex;gap:16px;margin-bottom:12px}.stat{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.stat-label{font-size:.75rem;color:var(--text-secondary)}.pipeline-meta{padding-top:12px;border-top:1px solid var(--border-color);margin-bottom:12px}.last-run{font-size:.85rem;color:var(--text-secondary)}.pipeline-actions{margin-top:auto}.btn-run-pipeline{width:100%;padding:10px 16px;background:#10b981;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.empty-state{text-align:center;padding:60px 20px;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color)}.empty-state h3{margin:0 0 8px;color:var(--text-primary)}.empty-state p{margin:0 0 20px;color:var(--text-secondary)}.pipeline-detail-container{padding:24px;max-width:1400px;margin:0 auto}.pipeline-detail-header{display:flex;align-items:flex-start;gap:20px;margin-bottom:24px}.btn-back{padding:8px 16px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:6px;cursor:pointer;transition:all .2s;white-space:nowrap}.header-content{flex:1}.header-title-row{display:flex;align-items:center;gap:12px}.header-title-row h1{margin:0;font-size:1.75rem;color:var(--text-primary)}.pipeline-description{margin:8px 0 0;color:var(--text-secondary);font-size:.95rem}.btn-run-pipeline{padding:12px 24px;background:#10b981;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap}.btn-run-pipeline:hover:not(:disabled){background:#059669}.btn-run-pipeline:disabled{background:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed}.status-badge{padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:500;text-transform:uppercase}.status-active{background:#22c55e26;color:#22c55e}.status-inactive{background:#9ca3af26;color:#9ca3af}.status-archived{background:#ef444426;color:#ef4444}.pipeline-stats-bar{display:flex;gap:32px;padding:20px 24px;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);margin-bottom:24px}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.stat-value.success{color:#22c55e}.stat-value.failed{color:#ef4444}.stat-label{font-size:.8rem;color:var(--text-secondary);margin-top:4px}.stat-label-only{font-size:.8rem;color:var(--text-secondary)}.stat-date{font-size:.9rem;color:var(--text-primary);margin-top:4px}.pipeline-content{display:grid;grid-template-columns:1fr 400px;gap:24px}@media (max-width: 1200px){.pipeline-content{grid-template-columns:1fr}}.section-header h2{margin:0;font-size:1.25rem;color:var(--text-primary)}.steps-section,.runs-section{background:var(--bg-secondary);border-radius:12px;padding:20px;border:1px solid var(--border-color)}.btn-add-step{padding:8px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.btn-add-step:hover{background:#2563eb}.add-step-form{display:flex;gap:12px;padding:16px;background:var(--bg-tertiary);border-radius:8px;margin-bottom:16px}.flow-select{flex:1;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary)}.layer-select{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary)}.btn-confirm-add{padding:8px 16px;background:#10b981;color:#fff;border:none;border-radius:6px;cursor:pointer}.btn-confirm-add:hover{background:#059669}.btn-cancel-add{padding:8px 16px;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer}.steps-list{display:flex;flex-direction:column;gap:12px}.step-card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;transition:all .2s}.step-card:hover{border-color:#3b82f6}.step-card.step-disabled{opacity:.6}.step-order{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:50%;font-weight:600;color:var(--text-primary);flex-shrink:0}.step-content{flex:1}.step-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.step-name{font-weight:500;color:var(--text-primary);text-decoration:none}.step-name:hover{color:#3b82f6;text-decoration:underline}.step-badges{display:flex;gap:6px}.flow-type-badge{padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:500}.flow-type-odoo{background:#8b5cf633;color:#8b5cf6}.flow-type-sql{background:#3b82f633;color:#3b82f6}.flow-type-api{background:#ec489933;color:#ec4899}.step-meta{display:flex;gap:8px;margin-top:6px}.continue-flag,.disabled-flag{font-size:.75rem;color:var(--text-secondary)}.disabled-flag{color:#ef4444}.step-actions{display:flex;gap:4px}.btn-move{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;color:var(--text-secondary);font-size:.7rem}.btn-move:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.btn-remove{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:4px;cursor:pointer;color:#ef4444;font-size:1.1rem}.btn-remove:hover{background:#ef444433}.empty-steps,.empty-runs{text-align:center;padding:32px 16px;color:var(--text-secondary)}.runs-list{display:flex;flex-direction:column;gap:12px}.run-card{padding:16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px}.run-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.run-id{font-family:monospace;font-size:.85rem;color:var(--text-secondary)}.run-status{padding:3px 10px;border-radius:12px;font-size:.7rem;font-weight:500;text-transform:uppercase}.run-pending{background:#9ca3af26;color:#9ca3af}.run-running{background:#3b82f626;color:#3b82f6}.run-completed{background:#22c55e26;color:#22c55e}.run-partial{background:#eab30826;color:#eab308}.run-failed{background:#ef444426;color:#ef4444}.run-cancelled{background:#6b728026;color:#6b7280}.run-details{display:flex;justify-content:space-between;font-size:.85rem}.run-progress{display:flex;gap:8px}.progress-text{color:var(--text-primary)}.failed-text{color:#ef4444}.run-times{display:flex;flex-direction:column;align-items:flex-end;color:var(--text-secondary);font-size:.8rem}.run-error{margin-top:8px;padding:8px 12px;background:#ef44441a;border-radius:6px;color:#ef4444;font-size:.85rem}.pipeline-creator-container{padding:24px;max-width:1200px;margin:0 auto}.pipeline-creator-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px}.pipeline-creator-header h1{margin:0;font-size:1.75rem;color:var(--text-primary)}.btn-back{padding:8px 16px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:6px;cursor:pointer;transition:all .2s}.btn-back:hover{background:var(--bg-tertiary)}.pipeline-creator-content{display:grid;grid-template-columns:1fr 350px;gap:24px}@media (max-width: 900px){.pipeline-creator-content{grid-template-columns:1fr}.info-panel{order:-1}}.pipeline-form{background:var(--bg-secondary);border-radius:12px;padding:24px;border:1px solid var(--border-color)}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:var(--text-primary);font-size:.9rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.95rem;transition:border-color .2s}.form-group textarea{resize:vertical;min-height:100px;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6}.hint{display:block;margin-top:4px;font-size:.8rem;color:var(--text-secondary)}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color)}.btn-primary{padding:12px 24px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:12px 24px;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--bg-primary)}.info-panel{background:var(--bg-secondary);border-radius:12px;padding:20px;border:1px solid var(--border-color);height:fit-content}.info-panel h3{margin:0 0 12px;font-size:1.1rem;color:var(--text-primary)}.info-panel p{margin:0 0 12px;color:var(--text-secondary);font-size:.9rem;line-height:1.5}.info-panel ul{margin:0 0 16px;padding-left:20px}.info-panel li{margin-bottom:8px;color:var(--text-secondary);font-size:.9rem;line-height:1.4}.info-panel li strong{color:var(--text-primary)}.tip{padding:12px;background:#3b82f61a;border-radius:8px;font-size:.85rem;color:var(--text-secondary)}.tip strong{color:#3b82f6}.error-message{padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;margin-bottom:16px}.run-profiles-container{padding:24px;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.page-header h1{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.page-subtitle{color:var(--text-secondary);margin:0;font-size:14px}.error-dismiss{background:none;border:none;color:#ef4444;cursor:pointer;font-size:20px;padding:0 4px}.profiles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.empty-state{grid-column:1 / -1;text-align:center;padding:60px 20px;background:var(--bg-secondary);border-radius:12px;border:1px dashed var(--border-primary)}.empty-icon{font-size:48px;margin-bottom:16px}.empty-state h3{color:var(--text-primary);margin:0 0 8px}.empty-state p{color:var(--text-secondary);margin:0 0 20px}.profile-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;padding:20px;transition:border-color .2s,box-shadow .2s}.profile-card:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px #0000001a}.profile-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.profile-title{display:flex;align-items:center;gap:10px}.profile-title h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.profile-actions{display:flex;gap:6px}.btn-icon{background:var(--bg-tertiary);border:1px solid var(--border-primary);width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s}.btn-icon.btn-run{background:#22c55e1a;border-color:#22c55e4d;color:#22c55e}.btn-icon.btn-run:hover{background:#22c55e33}.btn-icon.btn-danger:hover{background:#ef44441a;border-color:#ef44444d}.profile-description{color:var(--text-secondary);font-size:13px;margin:0 0 16px;line-height:1.5}.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;padding:12px;background:var(--bg-tertiary);border-radius:8px}.profile-stats .stat{text-align:center}.profile-stats .stat-value{display:block;font-size:20px;font-weight:600;color:var(--text-primary)}.profile-stats .stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.profile-meta{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.meta-item{display:flex;justify-content:space-between;font-size:13px}.meta-label{color:var(--text-secondary)}.meta-value{color:var(--text-primary)}.profile-options{display:flex;gap:8px;flex-wrap:wrap}.option-tag{background:var(--bg-tertiary);color:var(--text-secondary);padding:4px 8px;border-radius:4px;font-size:11px}.modal-close{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;padding:0;line-height:1}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:6px}.form-group input[type=text],.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-tertiary);color:var(--text-primary);font-size:14px;transition:border-color .2s}.form-group input[type=text]:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-primary)}.form-group textarea{resize:vertical;min-height:80px}.checkbox-group label{display:flex;align-items:flex-start;gap:10px;cursor:pointer}.checkbox-group input[type=checkbox]{margin-top:3px;width:16px;height:16px;accent-color:var(--accent-primary)}.checkbox-hint{display:block;font-size:12px;color:var(--text-secondary);font-weight:400;margin-top:2px}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding-top:12px;border-top:1px solid var(--border-primary);margin-top:12px}.loading{text-align:center;padding:60px 20px;color:var(--text-secondary)}@media (max-width: 768px){.run-profiles-container{padding:16px}.page-header{flex-direction:column;gap:16px}.profiles-grid{grid-template-columns:1fr}.modal{margin:16px;max-width:calc(100% - 32px)}}.profile-detail-container{padding:24px;max-width:1200px;margin:0 auto}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.btn-back{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:14px;padding:8px 0;transition:color .2s}.btn-back:hover{color:var(--text-primary)}.header-actions{display:flex;gap:12px}.btn-primary{background:var(--accent-primary);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s}.btn-primary:hover{background:var(--accent-hover)}.btn-primary.btn-run{background:#22c55e}.btn-primary.btn-run:hover{background:#16a34a}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-primary);padding:10px 20px;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--bg-hover)}.error-banner{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px 16px;border-radius:8px;margin-bottom:24px;display:flex;justify-content:space-between;align-items:center}.error-dismiss{background:none;border:none;color:#ef4444;cursor:pointer;font-size:20px}.profile-info-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;padding:24px;margin-bottom:24px}.profile-info-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.profile-info-header h1{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 12px 0 0;display:inline}.profile-description{color:var(--text-secondary);margin:0 0 16px;line-height:1.5}.profile-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:16px;background:var(--bg-tertiary);border-radius:8px;margin-bottom:12px}.stat-item{text-align:center}.stat-item .stat-label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:4px}.stat-item .stat-value{display:block;font-size:18px;font-weight:600;color:var(--text-primary)}.profile-options-row{display:flex;gap:8px}.option-tag{background:var(--bg-tertiary);color:var(--text-secondary);padding:4px 10px;border-radius:4px;font-size:12px}.edit-form{display:flex;flex-direction:column;gap:16px}.form-row{display:flex;gap:16px}.form-row .form-group{flex:1}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;font-weight:500;color:var(--text-primary)}.form-group input[type=text],.form-group textarea,.form-group select{padding:10px 12px;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-tertiary);color:var(--text-primary);font-size:14px}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent-primary)}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text-primary)}.checkbox-label input{width:16px;height:16px;accent-color:var(--accent-primary)}.edit-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:12px;border-top:1px solid var(--border-primary)}.items-section,.executions-section{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;padding:24px;margin-bottom:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h2{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.empty-items,.empty-executions{text-align:center;padding:40px 20px;color:var(--text-secondary)}.empty-items p,.empty-executions p{margin:0 0 16px}.items-list{display:flex;flex-direction:column;gap:8px}.item-row{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-primary)}.item-row.disabled{opacity:.5}.item-order{display:flex;align-items:center;gap:4px}.btn-move{background:var(--bg-secondary);border:1px solid var(--border-primary);width:24px;height:24px;border-radius:4px;cursor:pointer;font-size:12px;color:var(--text-secondary);transition:all .2s}.btn-move:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn-move:disabled{opacity:.3;cursor:not-allowed}.order-number{width:24px;text-align:center;font-weight:600;color:var(--text-secondary)}.item-info{display:flex;align-items:center;gap:12px;flex:1}.item-name{font-weight:500;color:var(--text-primary)}.item-meta{display:flex;gap:8px}.meta-tag{background:var(--bg-secondary);color:var(--text-secondary);padding:2px 8px;border-radius:4px;font-size:11px}.item-actions{display:flex;gap:8px}.btn-icon{background:var(--bg-secondary);border:1px solid var(--border-primary);width:28px;height:28px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text-secondary);transition:all .2s}.btn-icon:hover{background:var(--bg-hover)}.btn-icon.btn-danger:hover{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:500;text-transform:capitalize}.badge-success{background:#22c55e1a;color:#22c55e}.badge-warning{background:#eab3081a;color:#eab308}.badge-info{background:#3b82f61a;color:#3b82f6}.badge-error{background:#ef44441a;color:#ef4444}.badge-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.badge-flow{background:#9333ea1a;color:#9333ea}.badge-pipeline{background:#06b6d41a;color:#06b6d4}.executions-table{overflow-x:auto}.executions-table table{width:100%;border-collapse:collapse}.executions-table th,.executions-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-primary)}.executions-table th{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.executions-table td{font-size:14px;color:var(--text-primary)}.executions-table code{background:var(--bg-tertiary);padding:2px 6px;border-radius:4px;font-size:12px}.progress-info{display:flex;align-items:center;gap:8px}.failed-count{color:#ef4444;font-size:12px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-secondary);border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-primary)}.modal-header h2{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer}.modal-close:hover{color:var(--text-primary)}.modal form{padding:24px}.modal .form-group{margin-bottom:20px}.type-selector{display:flex;gap:8px}.type-btn{flex:1;padding:10px;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all .2s}.type-btn:hover{border-color:var(--accent-primary);color:var(--text-primary)}.type-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.no-items-hint{color:var(--text-secondary);font-size:12px;margin-top:8px}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding-top:12px;border-top:1px solid var(--border-primary)}.modal-footer button:disabled{opacity:.5;cursor:not-allowed}.loading,.error{text-align:center;padding:60px 20px;color:var(--text-secondary)}@media (max-width: 768px){.profile-detail-container{padding:16px}.detail-header{flex-direction:column;gap:16px;align-items:flex-start}.profile-stats-row{grid-template-columns:repeat(2,1fr)}.form-row{flex-direction:column}.item-row{flex-wrap:wrap}.modal{margin:16px}}.lineage-container{padding:24px;max-width:1600px;margin:0 auto}.lineage-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.header-title h1{margin:0;font-size:1.75rem;color:var(--text-primary)}.header-subtitle{margin:4px 0 0;color:var(--text-secondary);font-size:.95rem}.header-stats{display:flex;gap:24px}.header-stats .stat{display:flex;flex-direction:column;align-items:center;padding:12px 20px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.header-stats .stat-value{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.header-stats .stat-label{font-size:.8rem;color:var(--text-secondary)}.lineage-controls{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;align-items:center}.search-input{flex:1;min-width:200px;max-width:300px;padding:10px 16px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.95rem}.search-input:focus{outline:none;border-color:#3b82f6}.filter-chips{display:flex;gap:8px}.filter-chip{padding:8px 16px;border:1px solid var(--border-color);border-radius:20px;background:var(--bg-secondary);color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.filter-chip:hover{border-color:var(--text-secondary);color:var(--text-primary)}.filter-chip.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.filter-chip.filter-bronze.active{background:#d97706;border-color:#d97706}.filter-chip.filter-silver.active{background:#6b7280;border-color:#6b7280}.filter-chip.filter-gold.active{background:#eab308;border-color:#eab308;color:#1f2937}.view-toggle{display:flex;gap:0;margin-left:auto}.toggle-btn{padding:8px 16px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s}.toggle-btn:first-child{border-radius:8px 0 0 8px}.toggle-btn:last-child{border-radius:0 8px 8px 0;border-left:none}.toggle-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.graph-view{position:relative}.layers-container{display:flex;gap:16px;align-items:flex-start;padding:24px;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);overflow-x:auto}.layer-column{flex:1;min-width:280px;max-width:350px}.layer-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:8px;margin-bottom:12px;font-weight:600}.layer-header.bronze{background:#d9770626;color:#d97706}.layer-header.silver{background:#6b728026;color:#9ca3af}.layer-header.gold{background:#eab30826;color:#eab308}.layer-icon{font-size:1.2rem}.layer-count{margin-left:auto;padding:2px 8px;background:#0000001a;border-radius:10px;font-size:.8rem}.layer-nodes{display:flex;flex-direction:column;gap:8px;max-height:500px;overflow-y:auto}.node-card{padding:12px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s}.node-card:hover{border-color:#3b82f6;transform:translate(4px)}.node-card.selected{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}.node-name{font-weight:500;color:var(--text-primary);margin-bottom:6px;font-size:.9rem}.node-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.node-table{font-size:.75rem;color:var(--text-secondary);font-family:monospace}.layer-arrow{display:flex;align-items:center;color:var(--text-secondary);opacity:.5;padding-top:60px}.layer-badge{padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:500;text-transform:uppercase}.layer-bronze{background:#b4530933;color:#d97706}.layer-silver{background:#9ca3af33;color:#9ca3af}.layer-gold{background:#eab30833;color:#eab308}.flow-type-badge{padding:2px 6px;border-radius:4px;font-size:.65rem;font-weight:500;text-transform:uppercase}.flow-type-odoo{background:#9333ea26;color:#a855f7}.flow-type-sql{background:#3b82f626;color:#3b82f6}.flow-details-panel{position:absolute;top:0;right:0;width:350px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 20px #00000026;z-index:10}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--border-color)}.panel-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.close-btn{width:28px;height:28px;border:none;background:transparent;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;border-radius:4px}.close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.panel-content{padding:16px}.panel-section{margin-bottom:20px}.panel-section:last-child{margin-bottom:0}.panel-section h4{margin:0 0 12px;font-size:.9rem;color:var(--text-secondary);font-weight:500}.btn-view-flow{display:inline-block;padding:8px 16px;background:#3b82f6;color:#fff;text-decoration:none;border-radius:6px;font-size:.9rem;transition:background .2s}.btn-view-flow:hover{background:#2563eb}.dep-list{list-style:none;padding:0;margin:0}.dep-item{display:flex;align-items:center;gap:8px;padding:8px;background:var(--bg-tertiary);border-radius:6px;margin-bottom:6px}.dep-item a{color:var(--text-primary);text-decoration:none;flex:1}.dep-item a:hover{color:#3b82f6}.dep-type{font-size:.7rem;color:var(--text-secondary);background:var(--bg-secondary);padding:2px 6px;border-radius:4px}.no-deps{color:var(--text-secondary);font-size:.9rem;font-style:italic}.table-view{background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);overflow:hidden}.lineage-table{width:100%;border-collapse:collapse}.lineage-table th,.lineage-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.lineage-table th{background:var(--bg-tertiary);color:var(--text-secondary);font-weight:500;font-size:.85rem;text-transform:uppercase}.lineage-table td{color:var(--text-primary)}.lineage-table tr:last-child td{border-bottom:none}.lineage-table tr:hover td{background:var(--bg-tertiary)}.lineage-table a{color:#3b82f6;text-decoration:none}.lineage-table a:hover{text-decoration:underline}.table-name{font-family:monospace;font-size:.85rem;color:var(--text-secondary)}.dep-count{font-size:.85rem;color:var(--text-primary)}.no-deps-badge{font-size:.75rem;padding:2px 8px;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:10px}.lineage-legend{margin-top:24px;padding:16px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.lineage-legend h4{margin:0 0 12px;font-size:.9rem;color:var(--text-secondary)}.legend-items{display:flex;flex-wrap:wrap;gap:20px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-primary)}.legend-color{width:16px;height:16px;border-radius:4px}.legend-color.bronze{background:#d97706}.legend-color.silver{background:#6b7280}.legend-color.gold{background:#eab308}.loading-state,.error-state{text-align:center;padding:60px 20px;color:var(--text-secondary)}.error-state{color:#ef4444}@media (max-width: 1200px){.flow-details-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);right:auto;max-height:80vh;overflow-y:auto}}@media (max-width: 768px){.layers-container{flex-direction:column}.layer-column{max-width:none}.layer-arrow{transform:rotate(90deg);padding:0;justify-content:center}}*{box-sizing:border-box;margin:0;padding:0}html,body{margin:0;padding:0;width:100%;height:100%}:root{--background: 0 0% 100%;--foreground: 222.2 84% 4.9%;--card: 0 0% 100%;--card-foreground: 222.2 84% 4.9%;--popover: 0 0% 100%;--popover-foreground: 222.2 84% 4.9%;--primary: 221.2 83.2% 53.3%;--primary-foreground: 210 40% 98%;--secondary: 210 40% 96.1%;--secondary-foreground: 222.2 47.4% 11.2%;--muted: 210 40% 96.1%;--muted-foreground: 215.4 16.3% 46.9%;--accent: 210 40% 96.1%;--accent-foreground: 222.2 47.4% 11.2%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 210 40% 98%;--border: 214.3 31.8% 91.4%;--input: 214.3 31.8% 91.4%;--ring: 221.2 83.2% 53.3%;--radius: .5rem}[data-theme=dark]{--background: 222.2 84% 4.9%;--foreground: 210 40% 98%;--card: 222.2 84% 4.9%;--card-foreground: 210 40% 98%;--popover: 222.2 84% 4.9%;--popover-foreground: 210 40% 98%;--primary: 217.2 91.2% 59.8%;--primary-foreground: 222.2 47.4% 11.2%;--secondary: 217.2 32.6% 17.5%;--secondary-foreground: 210 40% 98%;--muted: 217.2 32.6% 17.5%;--muted-foreground: 215 20.2% 65.1%;--accent: 217.2 32.6% 17.5%;--accent-foreground: 210 40% 98%;--destructive: 0 62.8% 30.6%;--destructive-foreground: 210 40% 98%;--border: 217.2 32.6% 17.5%;--input: 217.2 32.6% 17.5%;--ring: 224.3 76.3% 48%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:hsl(var(--background));color:hsl(var(--foreground));transition:background-color .2s,color .2s}#root,.App{min-height:100vh;width:100%;margin:0;padding:0}[data-theme=dark] .pipeline-info-section,[data-theme=dark] .config-table-section,[data-theme=dark] .dependencies-section,[data-theme=dark] .section-content,[data-theme=dark] .progress-steps,[data-theme=dark] .step-content,[data-theme=dark] .model-card,[data-theme=dark] .field-item-wrapper,[data-theme=dark] .review-section,[data-theme=dark] .loader,[data-theme=dark] .source-card,[data-theme=dark] .source-config-form,[data-theme=dark] .source-summary,[data-theme=dark] .available-fields-panel,[data-theme=dark] .selected-fields-panel,[data-theme=dark] .info-card,[data-theme=dark] .detail-header,[data-theme=dark] .additional-info,[data-theme=dark] .error-box,[data-theme=dark] .logs-section,[data-theme=dark] .field-tag,[data-theme=dark] .field-row,[data-theme=dark] .quality-field-item,[data-theme=dark] .quality-pill,[data-theme=dark] .search-input,[data-theme=dark] .stack-trace pre{background:hsl(var(--card))!important;border-color:hsl(var(--border))!important}[data-theme=dark] .pipeline-title-row h1,[data-theme=dark] .config-table-section h2,[data-theme=dark] .dependencies-header h2,[data-theme=dark] .step-content h2,[data-theme=dark] .model-name,[data-theme=dark] .field-name,[data-theme=dark] .source-info h3,[data-theme=dark] .source-name-text,[data-theme=dark] .source-name-input,[data-theme=dark] .panel-header h3,[data-theme=dark] .review-section h3,[data-theme=dark] .field-category h3,[data-theme=dark] .card-header h1,[data-theme=dark] .logs-header h2,[data-theme=dark] .edit-input-title,[data-theme=dark] .config-val,[data-theme=dark] .stat-num,[data-theme=dark] .palette-title,[data-theme=dark] .template-card h3,[data-theme=dark] .summary-item strong,[data-theme=dark] .info-card strong,[data-theme=dark] .node-config-preview strong,[data-theme=dark] .form-group label{color:hsl(var(--foreground))!important}[data-theme=dark] .pipeline-desc,[data-theme=dark] .config-key,[data-theme=dark] .stat-name,[data-theme=dark] .step-description,[data-theme=dark] .model-technical,[data-theme=dark] .field-technical,[data-theme=dark] .field-type,[data-theme=dark] .field-help,[data-theme=dark] .source-type,[data-theme=dark] .config-preview,[data-theme=dark] .summary-item,[data-theme=dark] .info-card li,[data-theme=dark] .help-text,[data-theme=dark] .loading-deps,[data-theme=dark] .no-dependencies,[data-theme=dark] .no-fields,[data-theme=dark] .empty-runs,[data-theme=dark] .log-count,[data-theme=dark] .log-phase,[data-theme=dark] .log-timestamp,[data-theme=dark] .pill-label,[data-theme=dark] .bar-label,[data-theme=dark] .search-results-info,[data-theme=dark] .bar-value{color:hsl(var(--muted-foreground))!important}[data-theme=dark] .form-input,[data-theme=dark] .form-select,[data-theme=dark] .form-textarea,[data-theme=dark] .edit-input,[data-theme=dark] .edit-input-title,[data-theme=dark] .edit-textarea-desc,[data-theme=dark] .add-field-input,[data-theme=dark] .sort-select,[data-theme=dark] .mode-select,[data-theme=dark] .search-input{background:hsl(var(--background))!important;color:hsl(var(--foreground))!important;border-color:hsl(var(--border))!important}[data-theme=dark] .btn-back,[data-theme=dark] .btn-edit-outline,[data-theme=dark] .btn-cancel-small,[data-theme=dark] .btn-secondary,[data-theme=dark] .btn-field-action-small,[data-theme=dark] .btn-toggle-view,[data-theme=dark] .filter-btn,[data-theme=dark] .type-btn,[data-theme=dark] .section-tab,[data-theme=dark] .expand-btn,[data-theme=dark] .select-all-btn,[data-theme=dark] .btn-expand-small,[data-theme=dark] .btn-clear-all{background:hsl(var(--card))!important;color:hsl(var(--foreground))!important;border-color:hsl(var(--border))!important}[data-theme=dark] .fields-scroll-container,[data-theme=dark] .fields-container,[data-theme=dark] .fields-list,[data-theme=dark] .selected-fields-list{background:hsl(var(--muted) / .3)!important}[data-theme=dark] .config-val code,[data-theme=dark] .info-item code,[data-theme=dark] .summary-item code,[data-theme=dark] .run-id,[data-theme=dark] .field-technical{background:hsl(var(--muted))!important;color:hsl(var(--primary))!important}[data-theme=dark] .status-pill.status-active{background:#16a24926!important;color:#1fe066!important}[data-theme=dark] .status-pill.status-inactive{background:hsl(var(--destructive) / .15)!important;color:hsl(var(--destructive))!important}[data-theme=dark] .status-pill.status-archived{background:hsl(var(--muted))!important;color:hsl(var(--muted-foreground))!important}[data-theme=dark] .node-body,[data-theme=dark] .panel-header,[data-theme=dark] .quality-summary-header,[data-theme=dark] .fields-scroll-container,[data-theme=dark] .review-section,[data-theme=dark] .source-summary,[data-theme=dark] .config-preview,[data-theme=dark] .source-config-form,[data-theme=dark] .modal-actions,[data-theme=dark] .config-header,[data-theme=dark] .stat-box{background:hsl(var(--muted) / .3)!important}[data-theme=dark] .model-card:hover,[data-theme=dark] .field-item:hover,[data-theme=dark] .field-row:hover,[data-theme=dark] .quality-field-item:hover,[data-theme=dark] .dependency-item:hover,[data-theme=dark] .source-card:hover,[data-theme=dark] .template-card:hover,[data-theme=dark] .tab:hover:not(:disabled),[data-theme=dark] .palette-node:hover,[data-theme=dark] .related-field-label:hover{background:hsl(var(--accent))!important;border-color:hsl(var(--primary) / .3)!important}[data-theme=dark] .runs-table tbody tr.row-running,[data-theme=dark] .related-fields{background:#f59f0a1a!important}[data-theme=dark] .quality-field-item.selected,[data-theme=dark] .model-card.selected,[data-theme=dark] .selected-field-item{background:hsl(var(--primary) / .15)!important;border-color:hsl(var(--primary))!important}
