:root{--primary-50: #eef2ff;--primary-100: #e0e7ff;--primary-200: #c7d2fe;--primary-300: #a5b4fc;--primary-400: #818cf8;--primary-500: #6366f1;--primary-600: #4f46e5;--primary-700: #4338ca;--primary-800: #3730a3;--primary-900: #312e81;--accent-400: #2dd4bf;--accent-500: #14b8a6;--accent-600: #0d9488;--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-tertiary: #1e2538;--bg-card: rgba(30, 37, 56, .7);--bg-card-hover: rgba(40, 50, 72, .8);--bg-glass: rgba(17, 24, 39, .6);--bg-input: rgba(30, 37, 56, .5);--border-primary: rgba(99, 102, 241, .15);--border-subtle: rgba(255, 255, 255, .06);--border-focus: rgba(99, 102, 241, .5);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-inverse: #0f172a;--status-submitted: #3b82f6;--status-approved: #8b5cf6;--status-in-progress: #f59e0b;--status-review: #06b6d4;--status-testing: #ec4899;--status-live: #10b981;--status-rejected: #ef4444;--status-clarification: #f97316;--gradient-primary: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a78bfa 100%);--gradient-accent: linear-gradient(135deg, #06b6d4 0%, #14b8a6 100%);--gradient-warm: linear-gradient(135deg, #f59e0b 0%, #ef4444 100%);--gradient-surface: linear-gradient(135deg, rgba(99, 102, 241, .1) 0%, rgba(139, 92, 246, .05) 100%);--gradient-hero: linear-gradient(135deg, #0a0e1a 0%, #1a1040 40%, #0a0e1a 100%);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(99, 102, 241, .3);--shadow-glow-accent: 0 0 20px rgba(20, 184, 166, .2);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 260px;--sidebar-collapsed: 72px;--header-height: 64px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}a{color:var(--primary-400);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-300)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.bg-pattern{position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse 600px 600px at 20% 10%,rgba(99,102,241,.08) 0%,transparent 70%),radial-gradient(ellipse 400px 400px at 80% 80%,rgba(139,92,246,.06) 0%,transparent 70%),radial-gradient(ellipse 300px 300px at 50% 50%,rgba(20,184,166,.04) 0%,transparent 70%);pointer-events:none;z-index:0}.app-layout{display:flex;min-height:100vh;position:relative;z-index:1}.main-content{flex:1;margin-left:var(--sidebar-width);padding-top:var(--header-height);min-height:100vh;transition:margin-left var(--transition-base)}.page-container{padding:var(--space-xl);max-width:1400px;margin:0 auto;animation:fadeInUp .4s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-header{margin-bottom:var(--space-xl)}.page-header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-xs)}.page-header p{color:var(--text-secondary);font-size:.9rem}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-base)}.card:hover{background:var(--bg-card-hover);border-color:var(--border-primary)}.card-glass{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}.kpi-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:relative;overflow:hidden;transition:all var(--transition-base)}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.kpi-card.blue:before{background:var(--gradient-primary)}.kpi-card.teal:before{background:var(--gradient-accent)}.kpi-card.warm:before{background:var(--gradient-warm)}.kpi-card.purple:before{background:linear-gradient(135deg,#8b5cf6,#a78bfa)}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-primary)}.kpi-card .kpi-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-md)}.kpi-card.blue .kpi-icon{background:#6366f126;color:var(--primary-400)}.kpi-card.teal .kpi-icon{background:#14b8a626;color:var(--accent-400)}.kpi-card.warm .kpi-icon{background:#f59e0b26;color:#f59e0b}.kpi-card.purple .kpi-icon{background:#8b5cf626;color:#a78bfa}.kpi-card .kpi-value{font-size:1.75rem;font-weight:800;letter-spacing:-.03em;line-height:1;margin-bottom:var(--space-xs)}.kpi-card .kpi-label{color:var(--text-secondary);font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.kpi-card .kpi-change{display:flex;align-items:center;gap:var(--space-xs);margin-top:var(--space-sm);font-size:.8rem;font-weight:500}.kpi-change.positive{color:#10b981}.kpi-change.negative{color:#ef4444}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 20px;border:none;border-radius:var(--radius-md);font-family:inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-primary:hover{box-shadow:var(--shadow-lg),0 0 30px #6366f166;transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-subtle)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-primary)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:8px 12px}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-success:hover{box-shadow:0 0 20px #10b9814d}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-danger:hover{box-shadow:0 0 20px #ef44444d}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-md)}.form-group{margin-bottom:var(--space-lg)}.form-label{display:block;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-sm);letter-spacing:.01em}.form-label .required{color:var(--status-rejected);margin-left:2px}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:.9rem;transition:all var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #6366f11a;background:#1e2538cc}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-tertiary)}input[type=date],input[type=time],input[type=datetime-local]{position:relative}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;border-radius:4px;padding:4px;margin-right:-8px}input[type=date]::-webkit-calendar-picker-indicator:hover{background-color:#6366f133}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-textarea{resize:vertical;min-height:100px}.form-hint{font-size:.78rem;color:var(--text-tertiary);margin-top:var(--space-xs)}.form-error{font-size:.78rem;color:var(--status-rejected);margin-top:var(--space-xs)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-lg)}.checkbox-group,.radio-group{display:flex;flex-wrap:wrap;gap:var(--space-md)}.checkbox-item,.radio-item{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;padding:8px 16px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-input);transition:all var(--transition-fast);font-size:.875rem}.checkbox-item:hover,.radio-item:hover{border-color:var(--border-primary);background:var(--bg-tertiary)}.checkbox-item.active,.radio-item.active{border-color:var(--primary-500);background:#6366f11a;color:var(--primary-300)}.checkbox-item input,.radio-item input{display:none}.check-indicator{width:18px;height:18px;border-radius:4px;border:2px solid var(--text-tertiary);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.active .check-indicator{background:var(--primary-500);border-color:var(--primary-500)}.radio-indicator{width:18px;height:18px;border-radius:50%;border:2px solid var(--text-tertiary);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.active .radio-indicator{border-color:var(--primary-500)}.active .radio-indicator:after{content:"";width:8px;height:8px;border-radius:50%;background:var(--primary-500)}.file-upload-zone{border:2px dashed var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;cursor:pointer;transition:all var(--transition-base)}.file-upload-zone:hover{border-color:var(--primary-500);background:#6366f10d}.file-upload-zone .upload-icon{color:var(--text-tertiary);margin-bottom:var(--space-md)}.file-upload-zone p{color:var(--text-secondary);font-size:.875rem}.file-upload-zone .upload-hint{color:var(--text-tertiary);font-size:.78rem;margin-top:var(--space-xs)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.status-badge:before{content:"";width:6px;height:6px;border-radius:50%;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.status-badge.submitted{background:#3b82f626;color:#60a5fa}.status-badge.submitted:before{background:#3b82f6}.status-badge.approved{background:#8b5cf626;color:#a78bfa}.status-badge.approved:before{background:#8b5cf6}.status-badge.in-progress{background:#f59e0b26;color:#fbbf24}.status-badge.in-progress:before{background:#f59e0b}.status-badge.ba-review{background:#06b6d426;color:#22d3ee}.status-badge.ba-review:before{background:#06b6d4}.status-badge.mapping-finalized{background:#06b6d426;color:#22d3ee}.status-badge.mapping-finalized:before{background:#06b6d4}.status-badge.development{background:#f59e0b26;color:#fbbf24}.status-badge.development:before{background:#f59e0b}.status-badge.unit-testing{background:#ec489926;color:#f472b6}.status-badge.unit-testing:before{background:#ec4899}.status-badge.uat{background:#ec489926;color:#f472b6}.status-badge.uat:before{background:#ec4899}.status-badge.uat-completed{background:#10b98126;color:#34d399}.status-badge.uat-completed:before{background:#10b981}.status-badge.ready-for-production{background:#10b98126;color:#34d399}.status-badge.ready-for-production:before{background:#10b981}.status-badge.live{background:#10b98126;color:#34d399}.status-badge.live:before{background:#10b981;animation-duration:1s}.status-badge.rejected{background:#ef444426;color:#f87171}.status-badge.rejected:before{background:#ef4444;animation:none}.status-badge.clarification{background:#f9731626;color:#fb923c}.status-badge.clarification:before{background:#f97316}.data-table{width:100%;border-collapse:separate;border-spacing:0}.data-table thead th{padding:12px 16px;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;background:var(--bg-secondary);z-index:1}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-tertiary)}.data-table tbody td{padding:14px 16px;font-size:.875rem;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary)}.data-table tbody td:first-child{color:var(--text-primary);font-weight:500}.table-container{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.table-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border-subtle)}.table-header h3{font-size:1rem;font-weight:600}.table-actions{display:flex;align-items:center;gap:var(--space-sm)}.tabs{display:flex;gap:2px;background:var(--bg-tertiary);border-radius:var(--radius-md);padding:3px;margin-bottom:var(--space-lg)}.tab{padding:8px 20px;border:none;background:transparent;color:var(--text-secondary);font-family:inherit;font-size:.85rem;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.tab:hover{color:var(--text-primary)}.tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}.progress-steps{display:flex;align-items:center;margin-bottom:var(--space-xl)}.progress-step{display:flex;align-items:center;gap:var(--space-sm);flex:1;position:relative}.progress-step:not(:last-child):after{content:"";flex:1;height:2px;background:var(--border-subtle);margin:0 var(--space-md)}.progress-step.completed:not(:last-child):after{background:var(--primary-500)}.progress-step .step-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0;transition:all var(--transition-base)}.progress-step.pending .step-dot{background:var(--bg-tertiary);border:2px solid var(--border-subtle);color:var(--text-tertiary)}.progress-step.active .step-dot{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow)}.progress-step.completed .step-dot{background:var(--primary-600);color:#fff}.step-label{font-size:.78rem;font-weight:500;color:var(--text-tertiary);white-space:nowrap}.progress-step.active .step-label{color:var(--primary-400)}.progress-step.completed .step-label{color:var(--text-secondary)}.wizard-progress{display:flex;align-items:center;padding:var(--space-lg) var(--space-xl);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:var(--space-xl);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow-x:auto}.wizard-step{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.wizard-step:not(:last-child){margin-right:var(--space-lg)}.wizard-step:not(:last-child):after{content:"";width:40px;height:2px;background:var(--border-subtle);margin-left:var(--space-lg)}.wizard-step.completed:not(:last-child):after{background:var(--primary-500)}.wizard-step .step-number{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.wizard-step.pending .step-number{background:var(--bg-tertiary);border:2px solid var(--border-subtle);color:var(--text-tertiary)}.wizard-step.active .step-number{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow)}.wizard-step.completed .step-number{background:var(--primary-600);color:#fff}.wizard-step .step-info .step-title{font-size:.8rem;font-weight:600;color:var(--text-tertiary)}.wizard-step.active .step-info .step-title{color:var(--text-primary)}.wizard-step.completed .step-info .step-title{color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);width:90%;max-width:540px;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:modalSlide .3s ease-out}@keyframes modalSlide{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border-subtle)}.modal-header h3{font-size:1.1rem;font-weight:600}.modal-body{padding:var(--space-lg)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-lg);border-top:1px solid var(--border-subtle)}.toast-container{position:fixed;top:var(--space-lg);right:var(--space-lg);z-index:2000;display:flex;flex-direction:column;gap:var(--space-sm)}.toast{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);display:flex;align-items:center;gap:var(--space-md);box-shadow:var(--shadow-lg);animation:toastSlide .3s ease-out;min-width:320px;max-width:440px}@keyframes toastSlide{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.toast.success{border-left:3px solid #10b981}.toast.error{border-left:3px solid #ef4444}.toast.warning{border-left:3px solid #f59e0b}.toast.info{border-left:3px solid #3b82f6}.toast .toast-icon{flex-shrink:0}.toast.success .toast-icon{color:#10b981}.toast.error .toast-icon{color:#ef4444}.toast.warning .toast-icon{color:#f59e0b}.toast.info .toast-icon{color:#3b82f6}.toast-content h4{font-size:.85rem;font-weight:600;margin-bottom:2px}.toast-content p{font-size:.8rem;color:var(--text-secondary)}.priority-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-full);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.priority-badge.high{background:#ef444426;color:#f87171}.priority-badge.medium{background:#f59e0b26;color:#fbbf24}.priority-badge.low{background:#10b98126;color:#34d399}.avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.avatar.sm{width:24px;height:24px;font-size:.65rem}.avatar.lg{width:40px;height:40px;font-size:.85rem}.avatar.xl{width:56px;height:56px;font-size:1.1rem}.avatar.blue{background:#6366f133;color:var(--primary-400)}.avatar.teal{background:#14b8a633;color:var(--accent-400)}.avatar.purple{background:#8b5cf633;color:#a78bfa}.avatar.pink{background:#ec489933;color:#f472b6}.avatar.orange{background:#f9731633;color:#fb923c}.search-box{position:relative;width:100%;max-width:320px}.search-box .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary)}.search-box input{width:100%;padding:8px 12px 8px 36px;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:.85rem;transition:all var(--transition-fast)}.search-box input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #6366f11a}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-xl);color:var(--text-tertiary)}.empty-state .empty-icon{margin-bottom:var(--space-lg);opacity:.5}.empty-state h3{font-size:1.1rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-sm)}.empty-state p{font-size:.875rem;max-width:400px;margin:0 auto var(--space-lg)}.notification-panel{position:fixed;right:0;top:0;bottom:0;width:400px;background:var(--bg-secondary);border-left:1px solid var(--border-subtle);z-index:900;transform:translate(100%);transition:transform var(--transition-base);display:flex;flex-direction:column}.notification-panel.open{transform:translate(0)}.notification-panel .panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border-subtle)}.notification-panel .panel-body{flex:1;overflow-y:auto;padding:var(--space-md)}.notification-item{display:flex;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:pointer}.notification-item:hover{background:var(--bg-tertiary)}.notification-item.unread{background:#6366f10d}.notification-item .notif-dot{width:8px;height:8px;border-radius:50%;background:var(--primary-500);flex-shrink:0;margin-top:6px}.notification-item .notif-content h4{font-size:.85rem;font-weight:500;margin-bottom:4px}.notification-item .notif-content p{font-size:.78rem;color:var(--text-tertiary)}.notification-item .notif-time{font-size:.72rem;color:var(--text-tertiary);white-space:nowrap;flex-shrink:0}.timeline{position:relative;padding-left:var(--space-xl)}.timeline:before{content:"";position:absolute;left:11px;top:0;bottom:0;width:2px;background:var(--border-subtle)}.timeline-item{position:relative;padding-bottom:var(--space-lg)}.timeline-item:before{content:"";position:absolute;left:-21px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--primary-500);border:2px solid var(--bg-secondary)}.timeline-item .timeline-date{font-size:.75rem;color:var(--text-tertiary);margin-bottom:4px}.timeline-item .timeline-text{font-size:.85rem;color:var(--text-secondary)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-hero);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse 600px 600px at 30% 20%,rgba(99,102,241,.12) 0%,transparent 70%),radial-gradient(ellipse 500px 500px at 70% 70%,rgba(139,92,246,.08) 0%,transparent 70%),radial-gradient(ellipse 400px 400px at 50% 40%,rgba(20,184,166,.06) 0%,transparent 70%);animation:loginBg 20s ease-in-out infinite}@keyframes loginBg{0%,to{transform:translate(0)}33%{transform:translate(30px,-30px)}66%{transform:translate(-20px,20px)}}.login-card{width:100%;max-width:420px;background:var(--bg-glass);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-2xl);position:relative;z-index:1;box-shadow:var(--shadow-xl)}.login-logo{text-align:center;margin-bottom:var(--space-xl)}.login-logo .logo-icon{width:56px;height:56px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--space-md);box-shadow:var(--shadow-glow)}.login-logo h1{font-size:1.3rem;font-weight:700;letter-spacing:-.02em}.login-logo p{color:var(--text-secondary);font-size:.85rem;margin-top:var(--space-xs)}.role-selector{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm);margin-bottom:var(--space-lg)}.role-option{display:flex;align-items:center;gap:var(--space-sm);padding:12px 14px;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-input);cursor:pointer;transition:all var(--transition-fast);font-size:.85rem;color:var(--text-secondary)}.role-option:hover{border-color:var(--border-primary);color:var(--text-primary)}.role-option.selected{border-color:var(--primary-500);background:#6366f11a;color:var(--primary-300)}.role-option .role-icon{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;z-index:100;transition:width var(--transition-base)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);border-bottom:1px solid var(--border-subtle)}.sidebar-logo .logo-mark{width:36px;height:36px;background:var(--gradient-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-logo .logo-text h2{font-size:.9rem;font-weight:700;letter-spacing:-.01em;line-height:1.2}.sidebar-logo .logo-text span{font-size:.7rem;color:var(--text-tertiary);font-weight:500}.sidebar-nav{flex:1;padding:var(--space-md);overflow-y:auto}.nav-section{margin-bottom:var(--space-lg)}.nav-section-title{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);padding:0 var(--space-md);margin-bottom:var(--space-sm)}.nav-item{display:flex;align-items:center;gap:var(--space-md);padding:10px var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;position:relative}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:#6366f11a;color:var(--primary-400)}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--primary-500);border-radius:0 var(--radius-full) var(--radius-full) 0}.nav-item .nav-badge{margin-left:auto;background:var(--primary-600);color:#fff;font-size:.7rem;font-weight:700;padding:1px 7px;border-radius:var(--radius-full)}.sidebar-footer{padding:var(--space-md);border-top:1px solid var(--border-subtle)}.user-info{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.user-info:hover{background:var(--bg-tertiary)}.user-info .user-details .user-name{font-size:.85rem;font-weight:600}.user-info .user-details .user-role{font-size:.72rem;color:var(--text-tertiary)}.app-header{position:fixed;top:0;left:var(--sidebar-width);right:0;height:var(--header-height);background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-xl);z-index:50;transition:left var(--transition-base)}.header-left{display:flex;align-items:center;gap:var(--space-lg)}.header-right{display:flex;align-items:center;gap:var(--space-md)}.header-right .notif-btn{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.header-right .notif-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.header-right .notif-btn .notif-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--status-rejected);border:2px solid var(--bg-secondary)}.progress-bar-container{width:100%;height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;border-radius:var(--radius-full);background:var(--gradient-primary);transition:width var(--transition-slow)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-secondary)}.text-right{text-align:right}.font-semibold{font-weight:600}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 1280px){.form-row-3{grid-template-columns:1fr 1fr}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.main-content{margin-left:0}.app-header{left:0}.form-row,.form-row-3,.kpi-grid,.role-selector{grid-template-columns:1fr}}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--bg-tertiary: #e2e8f0;--bg-card: rgba(255, 255, 255, .9);--bg-card-hover: rgba(255, 255, 255, 1);--bg-glass: rgba(248, 250, 252, .85);--bg-input: rgba(255, 255, 255, .9);--border-primary: rgba(99, 102, 241, .25);--border-subtle: rgba(0, 0, 0, .08);--border-focus: rgba(99, 102, 241, .5);--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-inverse: #f1f5f9;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .12);--shadow-glow: 0 0 20px rgba(99, 102, 241, .15);--gradient-surface: linear-gradient(135deg, rgba(99, 102, 241, .06) 0%, rgba(139, 92, 246, .03) 100%);--gradient-hero: linear-gradient(135deg, #f8fafc 0%, #ede9fe 40%, #f8fafc 100%)}[data-theme=light] .sidebar{background:#fff;border-right:1px solid rgba(0,0,0,.08)}[data-theme=light] .sidebar-logo h2{color:#4f46e5}[data-theme=light] .nav-item{color:#475569}[data-theme=light] .nav-item:hover{background:#6366f114;color:#4f46e5}[data-theme=light] .nav-item.active{background:#6366f11f;color:#4f46e5}[data-theme=light] .nav-section-title{color:#94a3b8}[data-theme=light] .app-header{background:#f8fafcf2;border-bottom:1px solid rgba(0,0,0,.08)}[data-theme=light] .card{background:#fff;border:1px solid rgba(0,0,0,.08);box-shadow:0 2px 8px #0000000f}[data-theme=light] .form-input,[data-theme=light] .form-select,[data-theme=light] .form-textarea{background:#fff;border:1px solid #cbd5e1;color:#0f172a}[data-theme=light] .form-input:focus,[data-theme=light] .form-select:focus{border-color:#6366f1}[data-theme=light] .modal{background:#fff;border:1px solid rgba(0,0,0,.1)}[data-theme=light] .modal-header{border-bottom:1px solid rgba(0,0,0,.08)}[data-theme=light] .modal-footer{border-top:1px solid rgba(0,0,0,.08)}[data-theme=light] .status-badge{filter:none}[data-theme=light] body{background:#f8fafc;color:#0f172a}
