*{box-sizing:border-box;margin:0;padding:0}
body{font-family:system-ui,sans-serif;background:#0d0f14;color:#d1d5db;min-height:100vh}
.layout{max-width:1100px;margin:0 auto;padding:24px}
.stitle{font-size:22px;font-weight:600;color:#fff;margin-bottom:6px}
.ssub{font-size:13px;color:#6b7280;margin-bottom:20px;line-height:1.5}
.creo-history-badge{font-size:12px;color:#93c5fd;background:#1e293b;border:1px solid #334155;border-radius:8px;padding:8px 12px;margin:-8px 0 14px;display:inline-block}
.creo-help{font-size:11px;color:#6b7280;margin-bottom:10px;line-height:1.45}
.card{background:#12151e;border:1px solid #1f2333;border-radius:12px;padding:20px;margin-bottom:18px}
.card h3{font-size:14px;color:#fff;margin-bottom:12px}
.row3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:900px){.row3{grid-template-columns:1fr}}
.dropzone{border:2px dashed #2a2d3e;border-radius:12px;padding:28px;text-align:center;color:#6b7280;cursor:pointer;margin-bottom:8px}
.dropzone.small{padding:18px;font-size:12px}
.dropzone.drag{border-color:#4f8ef7;background:#141929}
.field label{display:block;font-size:12px;color:#6b7280;margin-bottom:6px}
.field select,.field textarea{width:100%;background:#0d0f14;border:1px solid #2a2d3e;border-radius:8px;padding:10px;color:#e5e7eb;font-size:13px}
.hint{font-size:11px;color:#4b5563;margin-top:8px}
.creo-ready-download-line{font-size:13px;color:#9ca3af;margin-top:12px}
.creo-ready-download-line strong{color:#fbbf24}
.creo-btn-download-ready{order:0}
.actions{display:flex;align-items:center;gap:12px;margin-top:14px;flex-wrap:wrap}
.bprim{background:#4f8ef7;color:#fff;border:none;border-radius:8px;padding:11px 22px;font-size:14px;font-weight:500;cursor:pointer}
.bprim:disabled{opacity:.45;cursor:not-allowed}
.bsec{background:transparent;color:#9ca3af;border:1px solid #2a2d3e;border-radius:8px;padding:9px 16px;font-size:13px;cursor:pointer}
.bsec:disabled{opacity:.4;cursor:not-allowed}
.banner{font-size:13px;padding:10px 14px;border-radius:8px;background:#1e293b;margin-top:12px}
.creo-parse-status{font-size:13px;margin-top:10px;padding:8px 12px;border-radius:8px}
.creo-parse-status.ok{background:#14532d;color:#86efac}
.creo-parse-status.warn{background:#422006;color:#fdba74}
.creo-preview-cards{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.creo-preview-card{display:flex;gap:14px;padding:12px;background:#0d0f14;border:1px solid #1f2333;border-radius:10px;align-items:flex-start}
.creo-preview-card .thumb{width:120px;height:90px;flex-shrink:0;border-radius:6px;object-fit:cover;background:#1a1d2a;border:1px solid #2a2d3e}
.creo-preview-card .thumb-missing{width:120px;height:90px;flex-shrink:0;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;color:#f87171;background:#1a1d2a;border:1px dashed #450a0a;text-align:center;padding:6px}
.creo-preview-card .body{min-width:0;flex:1}
.creo-preview-card .vin-id{font-size:11px;color:#6b7280;margin-bottom:4px;font-weight:500}
.creo-tile .vin-id-label{font-size:12px;color:#fbbf24;font-weight:600;margin-bottom:4px}
.creo-tile .vehicle{font-size:11px;color:#9ca3af;margin-bottom:4px}
.creo-grid-toolbar{margin-bottom:10px}
.creo-legacy-banner{font-size:12px;color:#fde68a;background:#422006;border:1px solid #854d0e;border-radius:8px;padding:10px 12px;margin-bottom:10px}
.creo-state-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.creo-state-chips button{font-size:12px;padding:6px 10px;border-radius:999px;border:1px solid #2a2d3e;background:#12151e;color:#d1d5db;cursor:pointer}
.creo-state-chips button:hover{border-color:#4f8ef7;color:#fff}
.creo-state-chips button.active{background:#1e3a5f;border-color:#4f8ef7;color:#e0f2fe}
.creo-bulk-toolbar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.creo-vin-filter{width:100%;max-width:280px;background:#0d0f14;border:1px solid #2a2d3e;border-radius:8px;padding:8px 10px;color:#e5e7eb;font-size:13px}
.creo-modal-actions-split{flex-wrap:wrap;justify-content:flex-end}
.creo-modal-card.creo-sample-card{max-width:560px}
.creo-sample-image-wrap{margin:12px 0;text-align:center;background:#0a0c10;border-radius:8px;padding:12px}
.creo-sample-img{max-width:100%;max-height:480px;border-radius:6px}
.creo-sample-meta{font-size:14px;line-height:1.6;color:#d1d5db;margin-bottom:8px}
.creo-sample-actions{flex-wrap:wrap}
.creo-skipped-section{margin-top:20px;padding-top:16px;border-top:1px solid #1f2333}
.creo-skipped-section h4{font-size:13px;color:#9ca3af;margin-bottom:10px}
.creo-skipped-table{width:100%;border-collapse:collapse;font-size:12px}
.creo-skipped-table th,.creo-skipped-table td{padding:8px 10px;text-align:left;border-bottom:1px solid #1f2333}
.creo-skipped-table th{color:#6b7280;font-weight:500}
.creo-skipped-hint{color:#fbbf24;font-size:12px;margin-top:8px}
.confirm-skipped-wrap{margin:12px 0;padding:10px 12px;background:#422006;border-radius:8px;border:1px solid #854d0e}
.confirm-skipped-warn{color:#fde68a;font-size:13px;margin:0}
.confirm-skipped-list{margin:8px 0 0 16px;font-size:12px;color:#fcd34d;max-height:120px;overflow-y:auto}
.confirm-no-ready{color:#f87171;font-size:13px;margin-bottom:12px}
.creo-preview-card .vehicle-copy{margin:2px 0 8px}
.creo-preview-card .vehicle-line1{font-size:14px;color:#fff;font-weight:600;margin-bottom:2px;line-height:1.3}
.creo-preview-card .vehicle-line2{font-size:13px;color:#cbd5e1;margin-bottom:4px;line-height:1.3}
.creo-preview-card .vehicle-price{font-size:13px;color:#fbbf24;margin-bottom:6px;font-weight:500}
.vehicle-meta-compact{font-size:10px;color:#9ca3af;line-height:1.35;margin-bottom:4px}
.reused-card .vehicle-line1{font-size:12px;font-weight:600;color:#e5e7eb}
.reused-card .vehicle-line2{font-size:11px;color:#cbd5e1}
.reused-card .vehicle-price{font-size:11px;color:#fbbf24;margin-bottom:4px}
.creo-tile .vehicle{font-weight:600;color:#e5e7eb;margin-bottom:2px;line-height:1.25;font-size:11px}
.creo-preview-card .badge{display:inline-block;font-size:10px;padding:3px 8px;border-radius:99px;background:#1e293b;color:#93c5fd}
.creo-preview-card .badge.upload{color:#86efac;background:#14532d}
.creo-preview-card .badge.missing{color:#fca5a5;background:#450a0a}
.creo-show-all{margin-top:8px}
.creo-match-status{font-size:13px;padding:12px 14px;border-radius:8px;background:#0d0f14;border:1px solid #2a2d3e;margin-bottom:14px;line-height:1.6}
.creo-match-status ul{margin:6px 0 0 18px;font-size:12px;color:#94a3b8}
.creo-match-missing{margin-top:8px;font-size:12px;color:#f87171}
.creo-match-missing summary{cursor:pointer;color:#fca5a5}
.creo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
.creo-tile{border:1px solid #1f2333;border-radius:8px;padding:8px;background:#0d0f14;font-size:11px}
.creo-tile-img-wrap{position:relative;margin-top:6px}
.creo-tile-img-wrap .creo-out-img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px;display:none}
.creo-tile-regen{position:absolute;top:6px;right:6px;z-index:3;width:30px;height:30px;border-radius:50%;border:none;cursor:pointer;font-size:16px;line-height:1;padding:0;background:rgba(15,18,28,.45);color:#e5e7eb;box-shadow:0 1px 4px rgba(0,0,0,.4)}
.creo-tile-regen:hover:not(:disabled){background:rgba(15,18,28,.92)}
.creo-tile-regen:disabled{opacity:.55;cursor:wait}
.creo-tile-spinner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.35);border-radius:6px;z-index:2}
.creo-tile-spinner::after{content:"";width:26px;height:26px;border:3px solid #4b5563;border-top-color:#fbbf24;border-radius:50%;animation:creo-tile-spin .75s linear infinite}
.creo-version-badge{position:absolute;bottom:6px;left:6px;z-index:3;font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;background:rgba(0,0,0,.55);color:#fbbf24}
@keyframes creo-tile-spin{to{transform:rotate(360deg)}}
.creo-tile .st-ok{color:#4ade80}
.creo-tile .st-fail{color:#f87171}
.creo-tile .st-run{color:#fbbf24}
.creo-test-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:12px;font-size:12px;color:#9ca3af}
.creo-test-input{width:64px;background:#0d0f14;border:1px solid #2a2d3e;border-radius:6px;padding:6px 8px;color:#e5e7eb}
.creo-live-progress{margin-top:16px;padding:14px;background:#0d0f14;border:1px solid #1f2333;border-radius:10px}
.creo-pbar-wrap{height:10px;background:#1f2333;border-radius:5px;overflow:hidden;margin-bottom:10px}
.creo-pbar{height:100%;width:0;background:#4f8ef7;border-radius:5px;transition:width .3s}
.creo-progress-text{font-size:14px;color:#fff;margin-bottom:6px}
.creo-progress-stats{font-size:12px;color:#94a3b8;margin-bottom:4px}
.creo-done-strip-wrap{margin-top:12px}
.creo-done-strip-label{font-size:11px;color:#6b7280;margin-bottom:8px}
.creo-done-strip{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.creo-done-strip::-webkit-scrollbar{height:6px}
.creo-done-strip::-webkit-scrollbar-thumb{background:#2a2d3e;border-radius:3px}
.creo-done-strip-item{flex:0 0 72px;scroll-snap-align:start}
.creo-done-strip-item img{width:72px;height:72px;object-fit:cover;border-radius:6px;border:1px solid #2a2d3e;display:block;background:#1a1d2a}
.creo-done-strip-vin{font-size:9px;color:#9ca3af;text-align:center;margin-top:4px;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.creo-progress-eta{font-size:11px;color:#4b5563;margin-top:4px}
.creo-errors-panel{margin-top:10px;font-size:12px}
.creo-errors-panel ul{margin:8px 0 0 16px;color:#f87171;max-height:160px;overflow-y:auto}
.creo-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px}
.creo-modal[hidden]{display:none!important}
.creo-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65)}
.creo-modal-card{position:relative;background:#12151e;border:1px solid #1f2333;border-radius:12px;padding:24px;max-width:440px;width:100%;box-shadow:0 12px 40px rgba(0,0,0,.45)}
.creo-modal-title{font-size:18px;font-weight:600;color:#fff;margin-bottom:12px}
.creo-modal-body{font-size:14px;line-height:1.6;margin-bottom:18px;color:#d1d5db}
.creo-modal-body strong{color:#fbbf24;font-weight:600}
.creo-modal-actions{display:flex;gap:10px;justify-content:flex-end}
.creo-batch-footer{position:fixed;bottom:0;left:0;right:0;z-index:9000;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px;background:#0d0f14;border-top:2px solid #b8860b;box-shadow:0 -4px 24px rgba(0,0,0,.5)}
.creo-batch-footer[hidden]{display:none!important}
.creo-batch-footer .footer-left{display:flex;flex-wrap:wrap;gap:14px;font-size:14px;color:#e5e7eb}
.creo-batch-footer .footer-left span{color:#9ca3af}
.creo-batch-footer #footer-progress{color:#fff;font-weight:600}
.creo-batch-footer #footer-percent{color:#fbbf24}
.creo-batch-footer #footer-credits{color:#93c5fd;font-size:13px}
.btn-danger{color:#fecaca;border-color:#7f1d1d;background:#450a0a}
.btn-danger:hover:not(:disabled){background:#7f1d1d;color:#fff}
.btn-danger:disabled{opacity:.55;cursor:not-allowed}
.creo-retry-row{margin-top:12px}
.creo-tile .st-cancelled{color:#9ca3af}
.creo-tile .pill-cancelled{display:inline-block;margin-top:4px;padding:2px 8px;border-radius:99px;font-size:10px;background:#374151;color:#d1d5db}
.creo-reusable-banner{margin-top:12px}
.info-banner{display:flex;flex-wrap:wrap;align-items:center;gap:10px 14px;padding:12px 14px;background:linear-gradient(90deg,#1e1b4b,#12151e);border:1px solid #4338ca;border-radius:10px;font-size:13px;color:#e0e7ff}
.info-banner .icon{font-size:18px}
.info-banner b{color:#c4b5fd}
.creo-reused-section{position:sticky;top:12px;z-index:5;border-color:#312e81}
.creo-reused-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px;align-items:center}
.creo-reused-filter{flex:1;min-width:160px;max-width:280px;background:#0d0f14;border:1px solid #3730a3;border-radius:8px;padding:8px 10px;color:#e5e7eb;font-size:13px}
.creo-reused-grid{margin-top:4px}
.reused-card{border:1px solid #6366f1;border-radius:10px;padding:10px;background:#0d0f14;font-size:11px;position:relative;box-shadow:0 0 0 1px rgba(99,102,241,.25)}
.reused-card img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;margin-bottom:8px;display:block;background:#1a1d2a}
.reused-card .meta{color:#9ca3af;margin:4px 0;font-size:11px}
.reused-card .vin-line{font-weight:600;color:#fbbf24;margin-bottom:2px}
.badge-reused{display:inline-block;font-size:9px;padding:2px 6px;border-radius:4px;background:#312e81;color:#c4b5fd;margin-top:6px}
.reused-card .regen-btn{margin-top:8px;width:100%;font-size:12px;padding:6px 8px;border-radius:6px;border:1px solid #4338ca;background:#1e1b4b;color:#e0e7ff;cursor:pointer}
.reused-card .regen-btn:hover{border-color:#818cf8;color:#fff}
.creo-tile-reused-badge{position:absolute;top:6px;left:6px;z-index:4;font-size:11px;padding:2px 6px;border-radius:4px;background:rgba(49,46,129,.92);color:#c4b5fd;font-weight:600;pointer-events:none}
.creo-logo-block .creo-logo-controls{margin-top:10px;max-width:320px}
.creo-logo-block .creo-logo-controls label{display:block;font-size:12px;color:#6b7280;margin-bottom:6px}
.creo-logo-block select,.creo-logo-block input[type=range]{width:100%}
.confirm-mode-label{margin:0 0 8px;font-size:12px;color:#93c5fd}
.confirm-breakdown{display:inline-block;margin:8px 0 0;font-size:12px;color:#94a3b8;line-height:1.55}
