.demo-page{min-height:100vh;background:#f1f5f9;padding:32px 28px;color:#0f172a;box-sizing:border-box}.demo-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px;margin-bottom:36px}.demo-title{font-size:26px;font-weight:800;margin:0 0 6px;color:#0f172a;display:flex;align-items:center;gap:12px}.demo-live-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:20px;background:#fff7ed;border:1px solid #fed7aa;color:#ea580c;letter-spacing:.3px}.demo-live-dot{width:7px;height:7px;border-radius:50%;background:#ea580c;animation:livePulse 1.4s ease-in-out infinite}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.demo-sub{font-size:13px;color:#64748b;margin:0}.demo-controls{display:flex;gap:10px;align-items:center}.demo-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;color:#374151;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s,border-color .2s,box-shadow .2s;box-shadow:0 1px 3px #0000000f}.demo-btn:hover{background:#f8fafc;border-color:#cbd5e1;box-shadow:0 2px 6px #00000017}.demo-btn--refresh{font-variant-numeric:tabular-nums;min-width:80px;justify-content:center}.demo-btn__spin{font-size:16px;display:inline-block}.demo-btn--refresh:hover .demo-btn__spin{animation:spin .5s linear}.demo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.demo-empty{text-align:center;color:#94a3b8;padding:100px 0;font-size:15px}@keyframes cardIn{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.dc{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:0;display:flex;flex-direction:column;animation:cardIn .4s cubic-bezier(.16,1,.3,1) both;transition:box-shadow .25s,transform .2s;box-shadow:0 2px 8px #0000000f;overflow:hidden}.dc:hover{box-shadow:0 10px 32px #0000001f;transform:translateY(-3px)}.dc:before{content:"";display:block;height:4px;background:var(--clr, #94a3b8);flex-shrink:0}@keyframes activePulse{0%,to{box-shadow:0 2px 8px #0000000f,0 0 #f973161f}50%{box-shadow:0 6px 20px #0000001a,0 0 0 4px #f9731624}}.dc--active{animation:cardIn .4s cubic-bezier(.16,1,.3,1) both,activePulse 2.8s ease-in-out infinite}.dc__head,.dc__track,.dc__stats,.dc__foot,.dc__report{padding-left:20px;padding-right:20px}.dc__head{padding-top:18px;padding-bottom:0}.dc__track{padding-top:14px}.dc__stats{padding-top:12px}.dc__foot{padding-top:10px;padding-bottom:16px}.dc__report{padding-bottom:16px}.dc__head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.dc__airline{display:flex;align-items:center;gap:13px;min-width:0}.dc__logo{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;letter-spacing:.5px;flex-shrink:0;box-shadow:0 3px 8px #0000002e}.dc__airline-name{font-size:15px;font-weight:700;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.2px}.dc__rid{font-size:11px;color:#94a3b8;font-family:Courier New,monospace;margin-top:3px}.dc__status{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:700;padding:5px 11px;border-radius:20px;border:1.5px solid;white-space:nowrap;letter-spacing:.4px;flex-shrink:0;background:#ffffffb3}.dc__dot{width:6px;height:6px;border-radius:50%;animation:livePulse 1.2s ease-in-out infinite}.dc__track{height:6px;background:#f1f5f9;border-radius:99px;overflow:hidden;position:relative}.dc__fill{height:100%;border-radius:99px;transition:width 1.2s cubic-bezier(.4,0,.2,1);position:relative}@keyframes shine{0%{left:-60%}to{left:120%}}.dc__fill--shine:after{content:"";position:absolute;top:0;left:-60%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);animation:shine 2s linear infinite}.dc__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.dc__stats:has(>:nth-child(4)){grid-template-columns:repeat(4,1fr)}.dc__stat{background:#f8fafc;border:1px solid #f1f5f9;border-radius:12px;padding:12px 6px 10px;display:flex;flex-direction:column;align-items:center;gap:5px}.dc__val{font-size:20px;font-weight:800;font-variant-numeric:tabular-nums;color:#0f172a;line-height:1}@keyframes countBounce{0%{transform:translateY(5px);opacity:.5}60%{transform:translateY(-2px)}to{transform:translateY(0);opacity:1}}.dc__val--live{animation:countBounce .35s ease}.dc__lbl{font-size:9px;color:#94a3b8;text-transform:uppercase;letter-spacing:.7px;font-weight:700}.dc__foot{display:flex;justify-content:space-between;align-items:center;border-top:1px solid #f1f5f9;margin-top:4px}.dc__date{font-size:11px;color:#94a3b8}.dc__pct{font-size:14px;font-weight:800;font-variant-numeric:tabular-nums}.dc__report{display:flex;flex-direction:column;gap:6px;padding-top:10px;border-top:1px solid #f1f5f9;margin-top:2px}.dc__report-btn{width:100%;padding:7px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid;transition:opacity .15s;white-space:nowrap}.dc__report-btn:disabled{opacity:.55;cursor:not-allowed}.dc__report-btn--gen{background:#f8fafc;border-color:#cbd5e1;color:#374151}.dc__report-btn--gen:hover:not(:disabled){background:#f1f5f9}.dc__report-btn--dl{background:linear-gradient(135deg,#67e8f9,#93c5fd);border-color:transparent;color:#0f172a;box-shadow:0 2px 8px #93c5fd73}.dc__report-btn--dl:hover:not(:disabled){background:linear-gradient(135deg,#38bdf8,#60a5fa);box-shadow:0 4px 12px #60a5fa73}.dc__report-msg{font-size:11px;font-weight:500}.dc__dropdown-wrap{position:relative}.dc__dropdown{position:absolute;bottom:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 16px #0000001f;overflow:hidden;z-index:50}.dc__dropdown-item{display:block;width:100%;padding:9px 14px;text-align:left;background:none;border:none;border-bottom:1px solid #f1f5f9;cursor:pointer;font-size:12px;color:#374151}.dc__dropdown-item:last-child{border-bottom:none}.dc__dropdown-item:hover{background:#f8fafc}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.dm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}.dm{background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:28px;width:100%;max-width:460px;box-shadow:0 20px 50px #00000026;animation:modalIn .25s ease}.dm__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}.dm__head h2{font-size:17px;font-weight:700;color:#0f172a;margin:0}.dm__close{background:none;border:1px solid #e2e8f0;border-radius:8px;color:#94a3b8;font-size:16px;cursor:pointer;padding:4px 8px;line-height:1;transition:all .15s}.dm__close:hover{background:#f1f5f9;color:#0f172a}.dm__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.ac{display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;cursor:pointer;color:#374151;font-size:12px;font-weight:500;text-align:center;position:relative;transition:background .2s,border-color .2s,transform .15s,box-shadow .2s}.ac:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 3px 10px #00000012}.ac--sel{background:#eff6ff;border-color:#3b82f6;color:#1d4ed8}.ac__logo{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;letter-spacing:.5px}.ac__check{position:absolute;top:8px;right:10px;font-size:13px;font-weight:800;color:#3b82f6}@media (max-width: 600px){.demo-page{padding:20px 16px}.demo-grid{grid-template-columns:1fr}.demo-title{font-size:20px}.dm__grid{grid-template-columns:repeat(2,1fr)}}@keyframes rdmIn{0%{opacity:0;transform:scale(.96) translateY(-12px)}to{opacity:1;transform:scale(1) translateY(0)}}.rdm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:300;display:flex;align-items:center;justify-content:center;padding:20px}.rdm{background:#fff;border:1px solid #e2e8f0;border-radius:20px;width:100%;max-width:660px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 64px #0f172a2e;animation:rdmIn .28s cubic-bezier(.16,1,.3,1)}@keyframes topbarIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.rdm__topbar{animation:topbarIn .35s ease both .05s;display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:2px solid;gap:12px;flex-shrink:0;background:#f8fafc;flex-wrap:wrap}.rdm__topbar-left{display:flex;align-items:center;gap:14px;min-width:0}@keyframes logoPop{0%{transform:scale(.4) rotate(-8deg);opacity:0}70%{transform:scale(1.12) rotate(3deg)}to{transform:scale(1) rotate(0);opacity:1}}.rdm__logo{width:50px;height:50px;border-radius:12px;animation:logoPop .5s cubic-bezier(.16,1,.3,1) both .1s;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;letter-spacing:.5px;flex-shrink:0}.rdm__airline{font-size:17px;font-weight:700;color:#0f172a}.rdm__rid{font-size:12px;color:#1e293b;font-family:Courier New,monospace;margin-top:3px}.rdm__topbar-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.rdm__started{text-align:right}.rdm__started-val{font-size:13px;font-weight:600;color:#0f172a}.rdm__started-lbl{font-size:10px;color:#1e293b;text-transform:uppercase;letter-spacing:.5px;font-weight:600;margin-top:2px}@keyframes badgeBounce{0%{transform:scale(.6);opacity:0}70%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.rdm__status{animation:badgeBounce .4s cubic-bezier(.16,1,.3,1) both .2s;display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;padding:5px 12px;border-radius:20px;border:1px solid;letter-spacing:.4px;white-space:nowrap}.rdm__dot{width:7px;height:7px;border-radius:50%;animation:rdmPulse 1.3s ease-in-out infinite}@keyframes rdmPulse{0%,to{opacity:1}50%{opacity:.3}}.rdm__close{background:none;border:1px solid #e2e8f0;border-radius:8px;color:#475569;font-size:16px;cursor:pointer;padding:5px 10px;line-height:1;transition:all .15s}.rdm__close:hover{background:#f1f5f9;color:#0f172a}.rdm__loading{display:flex;align-items:center;justify-content:center;padding:60px 20px;color:#1e293b;font-size:14px}.rdm__spinner{width:36px;height:36px;border:3px solid #e2e8f0;border-top:3px solid;border-radius:50%;animation:rdmSpin .7s linear infinite}@keyframes rdmSpin{to{transform:rotate(360deg)}}@keyframes bodyIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.rdm__body{animation:bodyIn .4s ease both .15s;overflow-y:auto;padding:24px;position:relative;display:flex;flex-direction:column;gap:22px}.rdm__section{display:flex;flex-direction:column;gap:10px}.rdm__track{height:10px;background:#f1f5f9;border-radius:99px;overflow:hidden;position:relative}.rdm__fill{height:100%;border-radius:99px;transition:width 1.6s cubic-bezier(.4,0,.2,1);position:relative}@keyframes rdmShine{0%{left:-60%}to{left:120%}}.rdm__fill--shine:after{content:"";position:absolute;top:0;left:-60%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);animation:rdmShine 2s linear infinite}.rdm__pct-row{display:flex;justify-content:space-between;align-items:center}.rdm__pct-label{font-size:13px;color:#1e293b;font-weight:500}.rdm__pct-val{font-size:16px;font-weight:800;font-variant-numeric:tabular-nums}.rdm__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@keyframes statIn{0%{opacity:0;transform:translateY(16px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}.rdm__stat{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:18px 12px;display:flex;flex-direction:column;align-items:center;gap:6px;animation:statIn .45s cubic-bezier(.16,1,.3,1) both}.rdm__stat:nth-child(1){animation-delay:.22s}.rdm__stat:nth-child(2){animation-delay:.3s}.rdm__stat:nth-child(3){animation-delay:.38s}@keyframes breathe{0%,to{box-shadow:0 0 #16a34a1f}50%{box-shadow:0 0 0 6px #16a34a2e}}.rdm__stat--highlight{background:#f0fdf4;border-color:#86efac;animation:statIn .45s cubic-bezier(.16,1,.3,1) both .3s,breathe 2.5s ease-in-out infinite 1s}.rdm__stat-val{font-size:28px;font-weight:800;font-variant-numeric:tabular-nums;color:#0f172a;text-align:center;line-height:1.1}@keyframes countUp{0%{opacity:0;transform:translateY(12px) scale(.85)}60%{transform:translateY(-3px) scale(1.05)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes countGlow{0%{text-shadow:0 0 0px rgba(22,163,74,0)}40%{text-shadow:0 0 12px rgba(22,163,74,.5)}to{text-shadow:0 0 0px rgba(22,163,74,0)}}.rdm__stat-val--animated{animation:countUp .6s cubic-bezier(.16,1,.3,1) both,countGlow 1.5s ease .4s}.rdm__stat-lbl{font-size:11px;color:#1e293b;text-transform:uppercase;letter-spacing:.7px;font-weight:700;text-align:center}.rdm__error{background:#fef2f2;border:1px solid #fecaca;border-radius:12px;padding:16px 18px;display:flex;flex-direction:column;gap:6px}.rdm__error-code{font-size:13px;font-weight:700;color:#dc2626}.rdm__error-msg{font-size:13px;color:#991b1b;line-height:1.5}.rdm__stats-wrap{position:relative}@keyframes pFlyX{0%{transform:translate(0);opacity:0}8%{opacity:1}90%{opacity:1}to{transform:translate(210px);opacity:0}}@keyframes pFlyY{0%{transform:translateY(0)}50%{transform:translateY(-52px)}to{transform:translateY(0)}}.rdm__p-outer{position:absolute;top:50%;left:14%;pointer-events:none;z-index:20;animation:pFlyX .95s cubic-bezier(.4,0,.6,1) both}.rdm__p-inner{font-size:13px;font-weight:800;color:#16a34a;background:#dcfce7;border:1px solid #86efac;border-radius:99px;padding:2px 7px;white-space:nowrap;transform:translateY(var(--y-off, 0px));animation:pFlyY .95s ease-in-out both}@keyframes flashIn{0%{opacity:.18}to{opacity:0}}.rdm__flash{position:absolute;top:0;right:0;bottom:0;left:0;background:#dcfce7;border-radius:14px;pointer-events:none;animation:flashIn .55s ease forwards;z-index:1}@keyframes barPulse{0%{filter:brightness(1)}40%{filter:brightness(1.4)}to{filter:brightness(1)}}.rdm__fill--pulse{animation:barPulse .5s ease}@keyframes pctPop{0%{transform:scale(1)}40%{transform:scale(1.25)}to{transform:scale(1)}}.rdm__pct-val--pop{display:inline-block;animation:pctPop .4s cubic-bezier(.16,1,.3,1)}@media (max-width: 540px){.rdm__stats{grid-template-columns:repeat(2,1fr)}.rdm__topbar{flex-wrap:wrap}.rdm__started{display:none}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #f5f7fa;--color-surface: #ffffff;--color-border: #e2e8f0;--color-text: #1a202c;--color-text-muted: #718096;--color-primary: #4f46e5;--color-primary-hover: #4338ca;--color-danger: #e53e3e;--color-success: #38a169;--color-warning: #d69e2e;--color-info: #3182ce;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;background:var(--color-bg);color:var(--color-text);font-size:14px;line-height:1.5}.navbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);height:56px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow);position:sticky;top:0;z-index:100}.navbar-brand a{font-size:18px;font-weight:700;color:var(--color-primary);text-decoration:none;letter-spacing:-.3px}.navbar-right{display:flex;align-items:center;gap:12px}.navbar-user{display:flex;align-items:center;gap:8px;color:var(--color-text-muted);font-size:13px}.role-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.role-admin{background:#ebf4ff;color:#2b6cb0}.role-user{background:#f0fff4;color:#276749}.status-badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}.status-pending{background:#ebf8ff;color:#2b6cb0}.status-in-progress{background:#fffbeb;color:#b7791f}.status-completed{background:#f0fff4;color:#276749}.status-failed{background:#fff5f5;color:#c53030}.status-in-queue{background:#f0f9ff;color:#0369a1}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:var(--radius);border:1px solid transparent;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,opacity .15s;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg)}.btn-ghost{background:transparent;color:var(--color-text-muted)}.btn-ghost:hover:not(:disabled){background:var(--color-bg);color:var(--color-text)}.btn-full{width:100%;justify-content:center}.link-btn{background:none;border:none;padding:0;color:var(--color-primary);font-size:13px;cursor:pointer;text-decoration:underline}.link-btn:hover{color:var(--color-primary-hover)}.link-btn.small{font-size:11px}.alert{padding:10px 14px;border-radius:var(--radius);font-size:13px;margin-bottom:16px}.alert-error{background:#fff5f5;color:#c53030;border:1px solid #fed7d7}.auth-container{min-height:calc(100vh - 56px);display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:36px 32px;width:100%;max-width:400px;box-shadow:var(--shadow-md)}.auth-title{font-size:22px;font-weight:700;color:var(--color-text);margin-bottom:4px}.auth-subtitle{color:var(--color-text-muted);font-size:13px;margin-bottom:24px}.auth-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:13px;font-weight:500;color:var(--color-text)}.form-group input{padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;color:var(--color-text);background:var(--color-surface);outline:none;transition:border-color .15s,box-shadow .15s}.form-group input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e51f}.auth-switch{text-align:center;margin-top:18px;font-size:13px;color:var(--color-text-muted)}.page-container{max-width:1280px;margin:0 auto;padding:28px 24px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}.page-header h1{font-size:22px;font-weight:700;color:var(--color-text)}.page-subtitle{font-size:13px;color:var(--color-text-muted);margin-top:2px}.table-wrapper{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table thead tr{background:#f8fafc;border-bottom:1px solid var(--color-border)}.data-table th{padding:10px 14px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);white-space:nowrap}.data-table td{padding:12px 14px;border-bottom:1px solid var(--color-border);vertical-align:middle;color:var(--color-text)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:#fafbff}.batch-id{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:12px;color:var(--color-text-muted);white-space:nowrap}.numeric{text-align:right;font-variant-numeric:tabular-nums}.date-cell{font-size:12px;color:var(--color-text-muted);white-space:nowrap}.error-cell{display:flex;flex-direction:column;gap:3px}.error-code{font-size:11px;font-weight:600;color:#c53030;background:#fff5f5;padding:1px 6px;border-radius:4px;display:inline-block}.error-msg{font-size:11px;color:#c53030;max-width:280px;line-height:1.4}.no-error{color:var(--color-text-muted)}.processed-pct,.airline-code{font-size:11px;color:var(--color-text-muted)}.not-found-cell{color:var(--color-danger)}.running-count{font-weight:600;color:#b7791f}@media (max-width: 768px){.table-wrapper{border:none;background:transparent;box-shadow:none;overflow:visible}.data-table thead{display:none}.data-table,.data-table tbody,.data-table tr,.data-table td{display:block;width:100%}.data-table tbody tr{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:12px;padding:4px 0}.data-table tbody tr:last-child td{border-bottom:1px solid var(--color-border)}.data-table tbody tr:last-child td:last-child{border-bottom:none}.data-table tbody tr:hover{background:var(--color-surface)}.data-table td{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:9px 14px;border-bottom:1px solid #f1f5f9;text-align:right}.data-table td:before{content:attr(data-label);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-muted);white-space:nowrap;flex-shrink:0;text-align:left}.data-table td:last-child{border-bottom:none}.numeric{text-align:right}.date-cell{white-space:normal}.error-msg{max-width:200px}}.batch-id-btn{background:none;border:none;padding:0;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:12px;color:var(--color-primary);cursor:pointer;text-decoration:underline dotted;text-underline-offset:3px}.batch-id-btn:hover{color:var(--color-primary-hover)}.count-btn{background:none;border:none;padding:0;font-size:13px;font-variant-numeric:tabular-nums;color:var(--color-primary);cursor:pointer;text-decoration:underline dotted;text-underline-offset:3px}.count-btn:hover{color:var(--color-primary-hover)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:200;padding:16px}.modal-box{background:var(--color-surface);border-radius:12px;box-shadow:0 20px 60px #0003;width:100%;max-width:560px;max-height:85vh;overflow-y:auto;display:flex;flex-direction:column}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--color-border);position:sticky;top:0;background:var(--color-surface);z-index:1}.modal-title{font-size:16px;font-weight:700;color:var(--color-text);margin-bottom:2px}.modal-batch-id{font-family:SF Mono,Fira Code,monospace;font-size:12px;color:var(--color-text-muted)}.modal-close{background:none;border:none;font-size:16px;color:var(--color-text-muted);cursor:pointer;padding:2px 6px;border-radius:4px;line-height:1}.modal-close:hover{background:var(--color-bg);color:var(--color-text)}.modal-loading{display:flex;justify-content:center;padding:40px}.modal-error,.modal-empty{padding:16px 24px;font-size:13px;color:var(--color-text-muted)}.modal-section{padding:16px 24px;border-bottom:1px solid var(--color-border)}.modal-section:last-child{border-bottom:none}.modal-section-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:12px}.modal-count{font-weight:400}.detail-grid{display:grid;grid-template-columns:110px 1fr;gap:6px 12px;font-size:13px}.detail-grid dt{color:var(--color-text-muted);font-weight:500}.detail-grid dd{color:var(--color-text);word-break:break-word}.worker-list{display:flex;flex-direction:column;gap:6px}.worker-chip{display:flex;align-items:center;gap:10px;padding:7px 12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius)}.worker-seq{font-size:11px;color:var(--color-text-muted);width:24px;flex-shrink:0}.worker-name{font-family:SF Mono,Fira Code,monospace;font-size:12px;flex:1;color:var(--color-text)}.worker-status{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;padding:2px 8px;border-radius:999px}.worker-idle{background:#f1f5f9;color:#64748b}.worker-running{background:#fffbeb;color:#b7791f}.worker-failed{background:#fff5f5;color:#c53030}.worker-completed{background:#f0fff4;color:#276749}.cb-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px 24px}.cb-form{display:flex;flex-direction:column;gap:20px}.cb-select{padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;color:var(--color-text);background:var(--color-surface);outline:none;transition:border-color .15s,box-shadow .15s;cursor:pointer}.cb-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e51f}.cb-hint{font-size:11px;color:var(--color-text-muted)}.cb-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:28px 20px;border:2px dashed var(--color-border);border-radius:var(--radius);cursor:pointer;text-align:center;transition:border-color .15s,background .15s;position:relative}.cb-dropzone:hover{border-color:var(--color-primary);background:#f5f3ff}.cb-dropzone--has-file{flex-direction:row;justify-content:flex-start;padding:16px 20px;border-style:solid;border-color:var(--color-primary);background:#f5f3ff;gap:12px}.cb-upload-icon{font-size:28px}.cb-dropzone-text{font-size:14px;font-weight:500;color:var(--color-text)}.cb-file-icon{font-size:28px;flex-shrink:0}.cb-file-name{font-size:14px;font-weight:500;color:var(--color-text);word-break:break-all}.cb-file-size{font-size:12px;color:var(--color-text-muted)}.cb-remove-file{position:absolute;top:8px;right:10px;background:none;border:none;font-size:14px;color:var(--color-text-muted);cursor:pointer;line-height:1}.cb-remove-file:hover{color:var(--color-danger)}.cb-progress-wrap{display:flex;flex-direction:column;gap:6px}.cb-progress-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--color-text-muted)}.cb-progress-bar{height:6px;background:var(--color-border);border-radius:999px;overflow:hidden}.cb-progress-fill{height:100%;background:var(--color-primary);border-radius:999px;transition:width .2s ease}.cb-airline-btn{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.cb-airline-btn:hover:not(:disabled){border-color:var(--color-primary);background:#f5f3ff}.cb-airline-btn:disabled{opacity:.6;cursor:not-allowed}.cb-airline-logo{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;letter-spacing:.5px;flex-shrink:0}.cb-airline-name{flex:1;font-size:14px;font-weight:600;color:var(--color-text)}.cb-airline-placeholder{font-size:14px;color:var(--color-text-muted)}.cb-airline-change{font-size:12px;color:var(--color-primary);font-weight:600}.cb-advanced-toggle{background:none;border:none;color:var(--color-primary);font-size:12px;font-weight:600;cursor:pointer;padding:4px 0;margin-top:6px;display:inline-block;letter-spacing:.2px}.cb-advanced-toggle:hover{text-decoration:underline}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;gap:12px;color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:28px;height:28px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}
