*,*:before,*:after{box-sizing:border-box}:root{--color-primary: #6366f1;--color-primary-hover: #4f46e5;--color-primary-light: #eef2ff;--color-primary-ring: rgba(99, 102, 241, .25);--color-danger: #ef4444;--color-danger-hover: #dc2626;--color-danger-light: #fef2f2;--color-success: #10b981;--color-success-light: #ecfdf5;--color-warning: #f59e0b;--color-warning-light: #fffbeb;--color-info: #3b82f6;--color-info-light: #eff6ff;--color-pending: #6b7280;--color-processing: #3b82f6;--color-completed: #10b981;--color-failed: #ef4444;--color-suspended: #f59e0b;--color-bg: #f8fafc;--color-surface: #ffffff;--color-surface-hover: #f8fafc;--color-border: #e2e8f0;--color-border-light: #f1f5f9;--color-text: #0f172a;--color-text-secondary: #64748b;--color-text-muted: #94a3b8;--radius-sm: 6px;--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .04);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 8px 10px -6px rgba(0, 0, 0, .04);--transition-fast: .15s ease;--transition: .2s ease}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover);text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:500;border:none;border-radius:var(--radius);padding:.5rem 1rem;transition:all var(--transition-fast);line-height:1.4}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;font-weight:500;letter-spacing:.01em}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 1px 2px #6366f14d}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:0 2px 8px #6366f159;transform:translateY(-1px)}.btn-danger{background:var(--color-danger);color:#fff;box-shadow:0 1px 2px #ef44444d}.btn-danger:hover{background:var(--color-danger-hover);box-shadow:0 2px 8px #ef444459;transform:translateY(-1px)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);box-shadow:var(--shadow-xs)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:#cbd5e1;box-shadow:var(--shadow-sm)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover{background:#059669}.btn-warning{background:var(--color-warning);color:#fff}.btn-warning:hover{background:#d97706}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn:active:not(:disabled){transform:translateY(0)}input,select,textarea{font-family:inherit;font-size:.875rem;border:1px solid var(--color-border);border-radius:var(--radius);padding:.5rem .75rem;width:100%;background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-ring)}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}label{display:block;margin-bottom:.375rem;font-size:.8125rem;font-weight:600;color:var(--color-text);letter-spacing:.01em}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition),transform var(--transition)}.card:hover{box-shadow:var(--shadow)}.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--color-border-light);font-weight:600;font-size:.9375rem}.card-body{padding:1.25rem}table{width:100%;border-collapse:separate;border-spacing:0;font-size:.875rem}.table-wrapper{overflow-x:auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.table-wrapper table{min-width:600px}.table-wrapper thead tr{background:var(--color-bg)}.table-wrapper thead th{padding:.75rem 1rem;font-weight:600;font-size:.75rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;text-align:left;border-bottom:1px solid var(--color-border);white-space:nowrap}.table-wrapper tbody tr{transition:background var(--transition-fast)}.table-wrapper tbody tr:hover{background:var(--color-surface-hover)}.table-wrapper tbody td{padding:.75rem 1rem;border-bottom:1px solid var(--color-border-light);vertical-align:middle}.table-wrapper tbody tr:last-child td{border-bottom:none}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-bottom:1.5rem}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.25rem;text-align:center;box-shadow:var(--shadow-xs);transition:box-shadow var(--transition),transform var(--transition)}.stat-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.stat-card .stat-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:.375rem}.stat-card .stat-value{font-size:1.5rem;font-weight:700;line-height:1.2}.page{animation:fadeIn .2s ease}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}.page-header h1{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.page-header .count-badge{font-weight:400;font-size:.875rem;color:var(--color-text-secondary);margin-left:.5rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.empty-state{text-align:center;padding:4rem 2rem;color:var(--color-text-secondary);background:var(--color-surface);border-radius:var(--radius-lg);border:2px dashed var(--color-border)}.empty-state h3{margin:0 0 .5rem;font-size:1.125rem;color:var(--color-text)}.empty-state p{margin:0 0 1.25rem;font-size:.9375rem}.filter-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.filter-bar select{width:auto;min-width:160px;font-size:.8125rem;padding:.4375rem .75rem}.filter-bar label{margin:0;font-size:.8125rem;font-weight:500;color:var(--color-text-secondary)}.progress-bar{display:flex;align-items:center;gap:.5rem;min-width:100px}.progress-bar .track{flex:1;height:6px;background:var(--color-border-light);border-radius:var(--radius-full);overflow:hidden}.progress-bar .fill{height:100%;border-radius:var(--radius-full);transition:width .4s ease}.progress-bar .label{font-size:.75rem;font-weight:500;color:var(--color-text-secondary);white-space:nowrap;min-width:36px;text-align:right}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-nav{display:flex;align-items:center;gap:.5rem;padding:0 1.5rem;height:60px;background:linear-gradient(135deg,#1e1b4b,#312e81,#3730a3);border-bottom:none;box-shadow:0 2px 12px #1e1b4b4d;position:sticky;top:0;z-index:100}.nav-brand .brand-link{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.9375rem;color:#fff;white-space:nowrap;letter-spacing:-.01em}.nav-brand .brand-link:hover{text-decoration:none;color:#c7d2fe}.nav-brand .brand-icon{font-size:1.25rem}.nav-brand .brand-text{font-weight:700}.nav-divider{width:1px;height:28px;background:#ffffff26;margin:0 .375rem;flex-shrink:0}.nav-links{display:flex;list-style:none;margin:0;padding:0;gap:.25rem;flex:1;overflow-x:auto}.nav-link{display:flex;align-items:center;gap:.375rem;padding:.4375rem .75rem;border-radius:var(--radius);font-size:.8125rem;font-weight:500;color:#ffffffb3;white-space:nowrap;transition:all var(--transition-fast)}.nav-link:hover{background:#ffffff1a;color:#fff;text-decoration:none}.nav-link--active{background:#ffffff2e;color:#fff!important;box-shadow:0 1px 4px #00000026;font-weight:600}.nav-link--active:hover{background:#ffffff38;color:#fff!important}.nav-link-icon{font-size:.875rem;line-height:1}.nav-logout{background:#ffffff14;color:#ffffffb3;font-size:.8125rem;font-weight:500;padding:.4375rem .75rem;white-space:nowrap;border-radius:var(--radius);transition:all var(--transition-fast);border:1px solid rgba(255,255,255,.1)}.nav-logout:hover{color:#fca5a5;background:#ef444426;border-color:#ef44444d}.app-main{flex:1;padding:1.5rem;max-width:1320px;width:100%;margin:0 auto}.auth-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--color-text-secondary);font-size:1rem}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#eef2ff,#f8fafc,#ecfdf5);padding:1rem}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-md)}.auth-card h1{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;text-align:center;letter-spacing:-.02em}.auth-card .auth-subtitle{text-align:center;color:var(--color-text-secondary);font-size:.875rem;margin:0 0 1.75rem}.auth-card .form-group{margin-bottom:1.125rem}.auth-card .error-banner{padding:.75rem 1rem;margin-bottom:1.25rem;border-radius:var(--radius);background:var(--color-danger-light);color:var(--color-danger);border:1px solid #fecaca;font-size:.8125rem;font-weight:500}.auth-card .auth-footer{margin-top:1.5rem;text-align:center;font-size:.875rem;color:var(--color-text-secondary)}.status-badge{display:inline-block;padding:.125rem .5rem;font-size:.75rem;font-weight:600;border-radius:var(--radius-full);text-transform:capitalize;letter-spacing:.01em}.status-badge--pending{background:#f3f4f6;color:#6b7280;border:1px solid #d1d5db}.status-badge--processing{background:#dbeafe;color:#1d4ed8;border:1px solid #93c5fd}.status-badge--completed{background:#dcfce7;color:#15803d;border:1px solid #86efac}.status-badge--failed{background:#fee2e2;color:#b91c1c;border:1px solid #fca5a5}.status-badge--suspended{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.field-error{color:var(--color-danger);font-size:.8rem;margin-top:.25rem}.tag{display:inline-block;padding:.0625rem .375rem;font-size:.75rem;font-weight:500;border-radius:4px;background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary);text-transform:capitalize}.toast-container{position:fixed;top:1rem;right:1rem;z-index:10000;display:flex;flex-direction:column;gap:.5rem}.toast{padding:.75rem 1rem;border-radius:var(--radius);font-size:.875rem;display:flex;align-items:center;gap:.5rem;box-shadow:var(--shadow);min-width:250px;animation:fadeIn .2s ease}.toast--success{background:var(--color-success-light);color:#15803d;border:1px solid #86efac}.toast--error{background:var(--color-danger-light);color:#b91c1c;border:1px solid #fca5a5}.toast--info{background:var(--color-info-light);color:#1d4ed8;border:1px solid #93c5fd}.toast-dismiss{background:none;border:none;color:inherit;cursor:pointer;padding:0 .25rem;font-size:1rem;line-height:1;opacity:.7}.toast-dismiss:hover{opacity:1}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9000;animation:overlayIn .15s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal-card{width:90%;max-width:560px;max-height:85vh;overflow:auto;box-shadow:var(--shadow-lg)}.modal-close{background:none;border:none;font-size:1.25rem;color:var(--color-text-secondary);padding:.25rem;line-height:1;border-radius:var(--radius-sm)}.modal-close:hover{color:var(--color-text);background:var(--color-surface-hover)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item .detail-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.detail-item .detail-value{font-size:.9375rem;font-weight:500;color:var(--color-text);word-break:break-word}.step-indicator{display:flex;gap:.25rem;margin-bottom:1.5rem}.step-indicator .step{flex:1;text-align:center;padding:.5rem .25rem;font-size:.6875rem;font-weight:600;border-radius:var(--radius);background:var(--color-border-light);color:var(--color-text-muted);transition:all var(--transition)}.step-indicator .step.completed{background:var(--color-success-light);color:var(--color-success)}.step-indicator .step.current{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.step-pipeline{display:flex;align-items:flex-start;gap:0;margin-bottom:1.5rem;overflow-x:auto;padding:.5rem 0}.pipeline-step{display:flex;flex-direction:column;align-items:center;flex:1;min-width:80px;position:relative;text-align:center}.pipeline-step-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.125rem;background:var(--color-border-light);border:2px solid var(--color-border);margin-bottom:.375rem;transition:all var(--transition)}.pipeline-step--done .pipeline-step-icon{background:var(--color-success-light);border-color:var(--color-success)}.pipeline-step--active .pipeline-step-icon{background:var(--color-primary-light);border-color:var(--color-primary);box-shadow:0 0 0 4px var(--color-primary-ring);animation:pulse 2s infinite}.pipeline-step-label{font-size:.75rem;font-weight:700;color:var(--color-text-muted)}.pipeline-step--done .pipeline-step-label{color:var(--color-success)}.pipeline-step--active .pipeline-step-label{color:var(--color-primary)}.pipeline-step-desc{font-size:.625rem;color:var(--color-text-muted);margin-top:.125rem}.pipeline-step--done .pipeline-step-desc{color:var(--color-success)}.pipeline-step--active .pipeline-step-desc{color:var(--color-primary)}.pipeline-connector{position:absolute;top:20px;left:calc(50% + 24px);width:calc(100% - 48px);height:2px;background:var(--color-border)}.pipeline-step--done .pipeline-connector{background:var(--color-success)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:1rem}.tab{padding:.625rem 1.25rem;font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all var(--transition-fast);border-radius:0}.tab:hover{color:var(--color-text);background:var(--color-surface-hover)}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.log-viewer{background:#1e293b;color:#e2e8f0;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:.75rem;line-height:1.7;padding:1rem;border-radius:var(--radius-lg);overflow:auto;max-height:70vh;white-space:pre-wrap;word-break:break-all}.action-group{display:inline-flex;gap:.375rem;flex-wrap:wrap}.action-group .btn{padding:.25rem .625rem;font-size:.75rem}.pagination{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.pagination-btn{padding:.375rem .75rem;font-size:.8125rem}.pagination-btn--active{background:var(--color-primary);color:#fff;border:1px solid var(--color-primary);box-shadow:0 1px 2px #6366f14d}.pagination-btn--active:hover{background:var(--color-primary-hover)}.pagination-ellipsis{padding:0 .25rem;color:var(--color-text-muted)}.file-dropzone{border:2px dashed var(--color-border);border-radius:var(--radius);padding:1.5rem;text-align:center;cursor:pointer;background:var(--color-surface-hover);transition:all var(--transition-fast)}.file-dropzone:hover,.file-dropzone--active{border-color:var(--color-primary);background:var(--color-primary-light)}.file-dropzone p{margin:0;color:var(--color-text-secondary);font-size:.875rem}.file-preview{position:relative;width:80px;height:80px;border-radius:var(--radius-sm);border:1px solid var(--color-border);overflow:hidden;background:var(--color-bg);display:flex;align-items:center;justify-content:center;font-size:.625rem;color:var(--color-text-secondary)}.file-preview img{width:100%;height:100%;object-fit:cover}.file-preview-remove{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;background:#0009;color:#fff;border:none;font-size:.7rem;line-height:1;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center}.error-box{padding:.625rem .75rem;background:var(--color-danger-light);color:#b91c1c;border-radius:var(--radius);font-size:.875rem;border:1px solid #fca5a5}.media-asset-card{padding:.625rem .75rem;background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius);transition:box-shadow var(--transition-fast)}.media-asset-card:hover{box-shadow:var(--shadow-xs)}.toggle-switch{position:relative;width:40px;height:22px;border-radius:11px;border:none;cursor:pointer;padding:0;transition:background var(--transition-fast);flex-shrink:0}.toggle-switch--on{background:var(--color-success)}.toggle-switch--off{background:#d1d5db}.toggle-switch .toggle-knob{position:absolute;top:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:left var(--transition-fast)}.toggle-switch--on .toggle-knob{left:20px}.toggle-switch--off .toggle-knob{left:2px}@media(max-width:768px){body{font-size:14px}.app-nav{flex-wrap:wrap;height:auto;padding:.75rem 1rem;gap:.5rem}.nav-links{order:3;width:100%}.nav-divider{display:none}.app-main{padding:1rem}button,.btn{min-height:40px;padding:.5rem .875rem;font-size:.8125rem}.overlay>div{width:95%!important;max-width:100%!important;max-height:90vh!important;margin:.5rem;padding:1.25rem!important}.toast-container{left:1rem;right:1rem}.page-header h1{font-size:1.25rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.detail-grid{grid-template-columns:1fr}}@media(max-width:480px){.app-nav{padding:.5rem .75rem;gap:.375rem}.nav-brand .brand-link{font-size:.8125rem}.nav-brand .brand-text{display:none}.nav-links{gap:.125rem}.nav-link{padding:.375rem .5rem;font-size:.75rem}.nav-link-icon{display:none}.app-main{padding:.75rem}button,.btn{min-height:44px;font-size:.8125rem}.page-header h1{font-size:1.125rem}.overlay>div{width:100%!important;max-height:95vh!important;border-radius:var(--radius-lg) var(--radius-lg) 0 0!important;margin:auto 0 0!important}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}}@media print{.app-nav,.toast-container,.overlay{display:none!important}.app-main{padding:0;max-width:100%}}
