@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600&display=swap";: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-50:#ecfdf5;--accent-100:#d1fae5;--accent-200:#a7f3d0;--accent-300:#6ee7b7;--accent-400:#34d399;--accent-500:#10b981;--accent-600:#059669;--accent-700:#047857;--warm-50:#fffbeb;--warm-100:#fef3c7;--warm-200:#fde68a;--warm-300:#fcd34d;--warm-400:#fbbf24;--warm-500:#f59e0b;--danger-50:#fff1f2;--danger-100:#ffe4e6;--danger-200:#fecdd3;--danger-400:#fb7185;--danger-500:#f43f5e;--danger-600:#e11d48;--neutral-50:#f8fafc;--neutral-100:#f1f5f9;--neutral-200:#e2e8f0;--neutral-300:#cbd5e1;--neutral-400:#94a3b8;--neutral-500:#64748b;--neutral-600:#475569;--neutral-700:#334155;--neutral-800:#1e293b;--neutral-900:#0f172a;--neutral-950:#020617;--surface-glass:#ffffffb8;--surface-glass-border:#fff3;--surface-card:#fff;--surface-elevated:#fff;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--shadow-glow-primary:0 0 20px #6366f126;--shadow-glow-accent:0 0 20px #10b98126;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--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);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--neutral-100);color:var(--neutral-800);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(80% 50% at 20% 0,#6366f10f 0%,#0000 60%),radial-gradient(60% 40% at 80% 100%,#10b9810d 0%,#0000 60%);position:fixed;inset:0}#root{z-index:1;position:relative}.app-header{background:linear-gradient(135deg, var(--neutral-950) 0%, var(--neutral-900) 50%, #1a1a3e 100%);color:#fff;z-index:100;border-bottom:1px solid #6366f133;justify-content:space-between;align-items:center;height:64px;padding:0 1.5rem;display:flex;position:sticky;top:0;box-shadow:0 4px 30px #0003}.header-brand{align-items:center;gap:.75rem;display:flex}.header-logo{background:linear-gradient(135deg, var(--primary-500), var(--accent-500));border-radius:var(--radius-md);width:36px;height:36px;box-shadow:var(--shadow-glow-primary);justify-content:center;align-items:center;font-size:1.1rem;animation:3s ease-in-out infinite logoPulse;display:flex}@keyframes logoPulse{0%,to{box-shadow:0 0 10px #6366f14d}50%{box-shadow:0 0 20px #6366f180,0 0 40px #10b98133}}.header-title{letter-spacing:-.02em;background:linear-gradient(90deg, #fff 30%, var(--primary-300));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.15rem;font-weight:700}.header-subtitle{color:var(--neutral-400);letter-spacing:.08em;text-transform:uppercase;font-size:.7rem;font-weight:500}.header-actions{align-items:center;gap:.5rem;display:flex}.header-btn{color:var(--neutral-300);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);background:#ffffff0f;border:1px solid #ffffff1a;align-items:center;gap:.4rem;padding:.45rem .85rem;font-family:inherit;font-size:.78rem;font-weight:500;display:flex}.header-btn:hover{color:#fff;background:#ffffff1f;border-color:#fff3;transform:translateY(-1px)}.app-main{flex-direction:column;gap:1.5rem;max-width:1280px;margin:0 auto;padding:1.5rem;display:flex}.card{background:var(--surface-card);border-radius:var(--radius-lg);border:1px solid var(--neutral-200);box-shadow:var(--shadow-md);transition:box-shadow var(--transition-base), transform var(--transition-base);animation:cardSlideUp .5s var(--transition-spring) backwards;overflow:hidden}.card:hover{box-shadow:var(--shadow-lg)}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.card:nth-child(2){animation-delay:50ms}.card:nth-child(3){animation-delay:.1s}.card:nth-child(4){animation-delay:.15s}.card-header{border-bottom:1px solid var(--neutral-100);justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem;display:flex}.card-header-title{color:var(--neutral-900);align-items:center;gap:.5rem;font-size:1rem;font-weight:700;display:flex}.card-body{padding:1.5rem}.card-footer{background:var(--neutral-50);border-top:1px solid var(--neutral-100);color:var(--neutral-500);padding:.875rem 1.5rem;font-size:.75rem}.step-badge{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--primary-500), var(--primary-600));color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;font-weight:700;display:flex}.status-alert{border-radius:var(--radius-md);animation:alertSlideIn .35s var(--transition-spring);align-items:flex-start;gap:.75rem;padding:.875rem 1.25rem;font-size:.875rem;font-weight:500;line-height:1.5;display:flex}@keyframes alertSlideIn{0%{opacity:0;transform:translateY(-8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.status-alert.error{background:var(--danger-50);color:var(--danger-600);border:1px solid var(--danger-200)}.status-alert.success{background:var(--accent-50);color:var(--accent-700);border:1px solid var(--accent-200)}.status-alert.info{background:var(--primary-50);color:var(--primary-700);border:1px solid var(--primary-200)}.status-alert svg{flex-shrink:0;margin-top:2px}.form-group{flex-direction:column;gap:.35rem;display:flex}.form-label{color:var(--neutral-600);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:.35rem;font-size:.78rem;font-weight:600;display:flex}.form-input,.form-select{border:1.5px solid var(--neutral-200);border-radius:var(--radius-sm);width:100%;color:var(--neutral-800);transition:all var(--transition-fast);background:#fff;outline:none;padding:.625rem .875rem;font-family:inherit;font-size:.875rem;font-weight:500}.form-input:focus,.form-select:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #6366f11a}.form-input::placeholder{color:var(--neutral-400);font-weight:400}.form-input.mono{font-family:JetBrains Mono,monospace;font-size:.8rem}.date-preview{align-items:center;gap:.35rem;margin-top:.25rem;font-size:.75rem;display:inline-flex}.date-preview-value{color:var(--primary-600);background:var(--primary-50);border-radius:var(--radius-sm);border:1px solid var(--primary-100);padding:.15rem .5rem;font-family:JetBrains Mono,monospace;font-size:.78rem;font-weight:600}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-family:inherit;font-size:.85rem;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";pointer-events:none;background:linear-gradient(#ffffff1a 0%,#0000 100%);position:absolute;inset:0}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg, var(--primary-500), var(--primary-600));color:#fff;box-shadow:var(--shadow-sm), inset 0 1px 0 #ffffff1a}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg, var(--primary-600), var(--primary-700));box-shadow:var(--shadow-md), var(--shadow-glow-primary);transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg, var(--accent-500), var(--accent-600));color:#fff;box-shadow:var(--shadow-sm), inset 0 1px 0 #ffffff1a}.btn-success:hover:not(:disabled){background:linear-gradient(135deg, var(--accent-600), var(--accent-700));box-shadow:var(--shadow-md), var(--shadow-glow-accent);transform:translateY(-1px)}.btn-outline{color:var(--neutral-700);border:1.5px solid var(--neutral-200);box-shadow:var(--shadow-sm);background:#fff}.btn-outline:hover:not(:disabled){background:var(--neutral-50);border-color:var(--neutral-300);transform:translateY(-1px)}.btn-ghost{color:var(--neutral-500);border-radius:var(--radius-sm);background:0 0;padding:.4rem}.btn-ghost:hover{background:var(--neutral-100);color:var(--danger-500)}.btn-upload{background:linear-gradient(135deg, var(--primary-50), var(--primary-100));color:var(--primary-700);border:2px dashed var(--primary-300);border-radius:var(--radius-md);cursor:pointer;padding:.75rem 1.5rem}.btn-upload:hover{background:linear-gradient(135deg, var(--primary-100), var(--primary-200));border-color:var(--primary-400);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-camera{background:linear-gradient(135deg, var(--accent-50), var(--accent-100));color:var(--accent-700);border:2px dashed var(--accent-300);border-radius:var(--radius-md);cursor:pointer;padding:.75rem 1.5rem}.btn-camera:hover{background:linear-gradient(135deg, var(--accent-100), var(--accent-200));border-color:var(--accent-400);box-shadow:var(--shadow-md);transform:translateY(-1px)}.upload-zone{border:2px dashed var(--neutral-300);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:all var(--transition-base);background:var(--neutral-50);padding:2.5rem;position:relative}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--primary-400);background:var(--primary-50);box-shadow:var(--shadow-glow-primary)}.upload-zone.drag-over{transform:scale(1.01)}.upload-zone-icon{background:linear-gradient(135deg, var(--primary-100), var(--primary-200));border-radius:var(--radius-lg);width:56px;height:56px;color:var(--primary-500);justify-content:center;align-items:center;margin:0 auto 1rem;display:flex}.upload-zone-text{color:var(--neutral-700);margin-bottom:.25rem;font-size:.95rem;font-weight:600}.upload-zone-hint{color:var(--neutral-400);font-size:.8rem}.upload-actions{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-top:1.25rem;display:flex}.image-previews{flex-wrap:wrap;gap:.75rem;margin-top:1.25rem;display:flex}.image-preview-item{border-radius:var(--radius-md);border:2px solid var(--neutral-200);transition:all var(--transition-base);animation:imagePopIn .3s var(--transition-spring);position:relative;overflow:hidden}@keyframes imagePopIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.image-preview-item:hover{border-color:var(--primary-300);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.image-preview-item img{object-fit:cover;width:auto;max-width:140px;height:80px;display:block}.image-preview-remove{background:var(--danger-500);color:#fff;border-radius:var(--radius-full);cursor:pointer;opacity:0;width:22px;height:22px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);border:none;justify-content:center;align-items:center;font-size:.7rem;display:flex;position:absolute;top:4px;right:4px}.image-preview-item:hover .image-preview-remove{opacity:1}.setup-grid{grid-template-columns:1fr 2fr;gap:2rem;display:grid}@media (width<=768px){.setup-grid{grid-template-columns:1fr}}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{border-collapse:separate;border-spacing:0;width:100%;font-size:.8rem}.data-table thead{z-index:10;position:sticky;top:0}.data-table th{background:linear-gradient(180deg, var(--neutral-100), var(--neutral-50));color:var(--neutral-500);text-transform:uppercase;letter-spacing:.06em;text-align:left;white-space:nowrap;border-bottom:2px solid var(--neutral-200);padding:.75rem .65rem;font-size:.68rem;font-weight:700}.data-table td{border-bottom:1px solid var(--neutral-100);vertical-align:middle;padding:.5rem .65rem}.data-table tbody tr{transition:all var(--transition-fast);animation:.3s backwards rowSlideIn}@keyframes rowSlideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.data-table tbody tr:first-child{animation-delay:20ms}.data-table tbody tr:nth-child(2){animation-delay:40ms}.data-table tbody tr:nth-child(3){animation-delay:60ms}.data-table tbody tr:nth-child(4){animation-delay:80ms}.data-table tbody tr:nth-child(5){animation-delay:.1s}.data-table tbody tr:nth-child(n+6){animation-delay:.12s}.data-table tbody tr:hover{background:var(--primary-50)}.data-table tbody tr.row-gap{background:var(--neutral-50);opacity:.55}.data-table tbody tr.row-gap:hover{opacity:.75}.data-table tbody tr.row-low-confidence{background:var(--warm-50)}.cell-input{border:1.5px solid var(--neutral-200);border-radius:var(--radius-sm);width:100%;color:var(--neutral-800);transition:all var(--transition-fast);background:#fff;outline:none;padding:.35rem .5rem;font-family:JetBrains Mono,monospace;font-size:.8rem;font-weight:500}.cell-input:focus{border-color:var(--primary-400);box-shadow:0 0 0 2px #6366f11a}.cell-input:disabled{background:var(--neutral-50);color:var(--neutral-400);border-color:#0000}.cell-input.machine-input{text-align:center;width:52px;color:var(--primary-700);font-weight:700}.cell-select{border:1.5px solid var(--neutral-200);border-radius:var(--radius-sm);width:100%;color:var(--neutral-800);transition:all var(--transition-fast);cursor:pointer;background:#fff;outline:none;padding:.35rem .4rem;font-family:inherit;font-size:.78rem;font-weight:600}.cell-select:focus{border-color:var(--primary-400);box-shadow:0 0 0 2px #6366f11a}.status-badge{justify-content:center;align-items:center;min-width:24px;display:inline-flex}.badge-gap{text-transform:uppercase;letter-spacing:.06em;background:var(--neutral-200);color:var(--neutral-500);border-radius:var(--radius-full);padding:.15rem .5rem;font-size:.6rem;font-weight:800}.badge-ok{color:var(--accent-500)}.badge-warn{color:var(--warm-500)}.row-count{background:var(--primary-100);color:var(--primary-700);border-radius:var(--radius-full);padding:.2rem .6rem;font-size:.7rem;font-weight:700}.table-actions{align-items:center;gap:.5rem;display:flex}.help-panel{background:linear-gradient(135deg, var(--warm-50), #fffdf5);border:1px solid var(--warm-200);border-radius:var(--radius-lg);animation:cardSlideUp .4s var(--transition-spring);padding:1.25rem 1.5rem}.help-title{color:var(--warm-500);align-items:center;gap:.4rem;margin-bottom:.75rem;font-size:.9rem;font-weight:700;display:flex}.help-list{flex-direction:column;gap:.5rem;list-style:none;display:flex}.help-list li{color:var(--neutral-600);align-items:flex-start;gap:.5rem;font-size:.8rem;line-height:1.5;display:flex}.help-list li:before{content:"→";color:var(--warm-400);flex-shrink:0;font-weight:700}.help-list strong{color:var(--neutral-800)}.config-panel{animation:cardSlideUp .35s var(--transition-spring)}.config-grid{flex-direction:column;gap:1rem;display:flex}.spinner{border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin}.spinner-dark{border-color:#6366f133;border-top-color:var(--primary-500)}@keyframes spin{to{transform:rotate(360deg)}}.processing-shimmer{position:relative;overflow:hidden}.processing-shimmer:after{content:"";background:linear-gradient(90deg,#0000,#6366f10d,#0000);width:100%;height:100%;animation:1.5s ease-in-out infinite shimmer;position:absolute;top:0;left:-100%}@keyframes shimmer{to{left:100%}}@media (width<=640px){.app-header{height:56px;padding:0 1rem}.header-title{font-size:.95rem}.header-subtitle{display:none}.app-main{gap:1rem;padding:1rem}.card-body{padding:1rem}.setup-grid{grid-template-columns:1fr;gap:1.25rem}.upload-zone{padding:1.5rem}.data-table{font-size:.75rem}.data-table th,.data-table td{padding:.4rem .45rem}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--neutral-100)}::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}.text-center{text-align:center}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:.5rem}.gap-md{gap:.75rem}.gap-lg{gap:1rem}.mt-sm{margin-top:.5rem}.mt-md{margin-top:.75rem}.hidden{display:none}
