:root{--sidebar-width: 240px;--color-bg: #0b0e18;--color-surface: #12162a;--color-surface-raised: #181d34;--color-surface-hover: #1e2440;--color-border: #232b48;--color-border-subtle: #1a2139;--color-text: #e4e8f1;--color-text-secondary: #7b83a0;--color-text-tertiary: #525a75;--color-primary: #6366f1;--color-primary-hover: #818cf8;--color-primary-muted: rgba(99, 102, 241, .1);--color-primary-glow: rgba(99, 102, 241, .2);--color-success: #10b981;--color-success-muted: rgba(16, 185, 129, .1);--color-danger: #ef4444;--color-danger-muted: rgba(239, 68, 68, .08);--color-warning: #f59e0b;--color-warning-muted: rgba(245, 158, 11, .08);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .25), 0 1px 3px rgba(0, 0, 0, .15);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .5);--shadow-glow: 0 0 24px var(--color-primary-glow);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-pill: 100px;--transition: .15s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.6;font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{background:var(--color-primary);color:#fff}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border-subtle);position:fixed;top:0;left:0;bottom:0;overflow-y:auto;display:flex;flex-direction:column;z-index:100}.sidebar h1{font-size:1.15rem;font-weight:700;padding:1.5rem 1.5rem 1.25rem;border-bottom:1px solid var(--color-border-subtle);margin-bottom:.75rem;letter-spacing:-.01em;background:linear-gradient(135deg,#818cf8,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar nav{flex:1;padding:0 .5rem}.sidebar nav a{display:flex;align-items:center;gap:.65rem;padding:.6rem 1rem;color:var(--color-text-secondary);text-decoration:none;font-size:.88rem;font-weight:500;border-radius:var(--radius-sm);transition:all var(--transition);margin-bottom:2px}.sidebar nav a:hover{background:var(--color-surface-hover);color:var(--color-text)}.sidebar nav a.active{background:var(--color-primary-muted);color:var(--color-primary-hover);font-weight:600}.main-content{margin-left:var(--sidebar-width);flex:1;padding:2rem 2.5rem;max-width:1280px;min-height:100vh}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h2{font-size:1.5rem;font-weight:700;letter-spacing:-.02em}button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface-raised);color:var(--color-text);cursor:pointer;font-size:.85rem;font-weight:500;line-height:1.4;transition:all var(--transition);white-space:nowrap}button:hover{background:var(--color-surface-hover);border-color:var(--color-text-tertiary)}button:active{transform:scale(.98)}button:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-primary{background:var(--color-primary);border-color:transparent;color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:0 4px 16px #6366f166}.btn-success{background:var(--color-success);border-color:transparent;color:#fff;box-shadow:0 2px 8px #10b9814d}.btn-danger{background:var(--color-danger);border-color:transparent;color:#fff;box-shadow:0 2px 8px #ef44444d}input,select,textarea{padding:.55rem .85rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);font-size:.9rem;font-family:inherit;transition:border-color var(--transition),box-shadow var(--transition)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-muted)}label{display:block;margin-bottom:.4rem;font-size:.78rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.form-group{margin-bottom:1.25rem}table{width:100%;border-collapse:separate;border-spacing:0}th,td{padding:.75rem 1rem;text-align:left}th{font-size:.72rem;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--color-border)}td{border-bottom:1px solid var(--color-border-subtle);font-size:.88rem}tbody tr{transition:background var(--transition)}tbody tr:hover{background:var(--color-primary-muted)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.5rem;box-shadow:var(--shadow-sm)}.grid-3{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.badge{display:inline-flex;align-items:center;padding:.2rem .65rem;border-radius:var(--radius-pill);font-size:.7rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.badge-pending{background:var(--color-warning-muted);color:var(--color-warning)}.badge-approved,.badge-completed,.badge-active{background:var(--color-success-muted);color:var(--color-success)}.badge-rejected,.badge-failed{background:var(--color-danger-muted);color:var(--color-danger)}.badge-running{background:var(--color-primary-muted);color:var(--color-primary-hover)}.kbd{display:inline-block;padding:.15rem .45rem;border-radius:4px;border:1px solid var(--color-border);background:var(--color-surface-raised);font-family:SF Mono,Fira Code,monospace;font-size:.72rem;color:var(--color-text-secondary)}.mono{font-family:SF Mono,Fira Code,ui-monospace,monospace;font-size:.82rem;letter-spacing:.03em}.image-preview{max-width:100%;max-height:500px;object-fit:contain;border-radius:var(--radius-sm);background:#000}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.image-grid img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius-sm);border:2px solid transparent;cursor:pointer;transition:border-color var(--transition),transform var(--transition)}.image-grid img:hover{border-color:var(--color-primary);transform:translateY(-1px)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.page-loading{padding:3rem;text-align:center;color:var(--color-text-secondary);font-size:.9rem}.error-banner{padding:.85rem 1.15rem;border-radius:var(--radius-sm);background:var(--color-danger-muted);border:1px solid rgba(239,68,68,.25);color:var(--color-danger);margin:.75rem 0;font-size:.88rem;font-weight:500}.warning-text{color:var(--color-warning);font-size:.85rem}.info-text{font-size:.85rem;color:var(--color-text-secondary);margin-top:.5rem}.data-table{margin-top:.75rem}.thumb{height:36px;border-radius:4px;object-fit:contain;background:#0b0e18}.stats-page h2,.csv-upload-page h2,.vin-decode-page h2{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1.5rem}.stats-page h3,.csv-upload-page h3,.vin-decode-page h3{font-size:1.05rem;font-weight:600;margin:1.75rem 0 .85rem;color:var(--color-text)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.35rem;box-shadow:var(--shadow-sm);transition:transform var(--transition),box-shadow var(--transition)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-value{font-size:1.85rem;font-weight:700;color:var(--color-primary-hover);letter-spacing:-.03em;line-height:1.2}.stat-label{font-size:.72rem;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em}.brand-coverage{display:flex;flex-direction:column;gap:.5rem}.brand-row{display:grid;grid-template-columns:140px 1fr 48px 72px;align-items:center;gap:.75rem;font-size:.85rem;padding:.25rem 0}.brand-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.brand-bar-track{height:8px;background:var(--color-surface-hover);border-radius:var(--radius-pill);overflow:hidden}.brand-bar-fill{height:100%;border-radius:var(--radius-pill);transition:width .5s ease}.brand-bar-fill.high{background:linear-gradient(90deg,#059669,#34d399)}.brand-bar-fill.med{background:linear-gradient(90deg,#d97706,#fbbf24)}.brand-bar-fill.low{background:linear-gradient(90deg,#dc2626,#f87171)}.brand-pct{text-align:right;font-weight:600;font-size:.85rem}.brand-count{text-align:right;color:var(--color-text-secondary);font-size:.8rem}.drop-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:3rem 1.5rem;text-align:center;cursor:pointer;transition:all .2s ease;color:var(--color-text-secondary);margin-bottom:1.25rem;background:var(--color-surface)}.drop-zone.active,.drop-zone:hover{border-color:var(--color-primary);background:var(--color-primary-muted);box-shadow:var(--shadow-glow);color:var(--color-primary-hover)}.drop-zone.has-file{border-color:var(--color-success);color:var(--color-text);background:var(--color-success-muted)}.csv-options{display:flex;gap:1.25rem;flex-wrap:wrap;margin-bottom:1.25rem}.csv-options label{display:flex;flex-direction:column;gap:.35rem;min-width:140px}.csv-result{margin-top:1.75rem}.csv-result .btn{display:inline-block;margin-top:.75rem;text-decoration:none}.csv-result-actions{display:flex;gap:.85rem;margin-top:.85rem;flex-wrap:wrap}.tab-bar{display:inline-flex;gap:0;margin-bottom:1.25rem;background:var(--color-surface);border-radius:var(--radius-sm);border:1px solid var(--color-border);padding:3px}.tab-bar button{border-radius:6px;border:none;padding:.45rem 1.25rem;font-weight:500;background:transparent;color:var(--color-text-secondary)}.tab-bar button:first-child{border-radius:6px}.tab-bar button:last-child{border-radius:6px}.tab-bar button:hover{color:var(--color-text);background:var(--color-surface-hover)}.tab-bar button.active{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.input-row{display:flex;gap:.5rem;margin-bottom:1.25rem}.input-row input{flex:1;font-family:SF Mono,Fira Code,ui-monospace,monospace;letter-spacing:.1em;font-size:.95rem}.vin-result-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.5rem;display:flex;gap:1.75rem;flex-wrap:wrap;box-shadow:var(--shadow-sm)}.vin-info{flex:1;min-width:200px}.vin-info h3{font-size:1.15rem;font-weight:600;margin-bottom:.6rem}.vin-info p{font-size:.9rem;margin-bottom:.3rem;color:var(--color-text-secondary)}.vin-info p strong{color:var(--color-text)}.vin-image{flex:1;min-width:250px;max-width:400px}.vin-image img{width:100%;border-radius:var(--radius-sm);object-fit:contain;background:#080a12}.vin-batch textarea{width:100%;padding:.85rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);font-family:SF Mono,Fira Code,ui-monospace,monospace;font-size:.88rem;resize:vertical;margin-bottom:.85rem;min-height:120px}.vin-batch textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-muted)}.sidebar-bottom{margin-top:auto;border-top:1px solid var(--color-border-subtle);padding:.5rem}.sidebar-bottom a{display:flex;align-items:center;gap:.6rem;padding:.6rem 1rem;color:var(--color-text-secondary);text-decoration:none;font-size:.88rem;font-weight:500;border-radius:var(--radius-sm);transition:all var(--transition)}.sidebar-bottom a:hover{background:var(--color-surface-hover);color:var(--color-text)}.sidebar-bottom a.active{background:var(--color-primary-muted);color:var(--color-primary-hover)}.sidebar-user{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;font-size:.82rem;color:var(--color-text-secondary);border-top:1px solid var(--color-border-subtle);margin-top:.25rem}.sidebar-user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:130px;font-weight:500}.sidebar-logout-btn{background:transparent;border:1px solid var(--color-border);color:var(--color-text-tertiary);border-radius:6px;padding:.25rem .6rem;font-size:.75rem;cursor:pointer;transition:all var(--transition)}.sidebar-logout-btn:hover{color:var(--color-danger);border-color:var(--color-danger);background:var(--color-danger-muted)}.setup-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--color-bg)}.setup-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2.5rem 3rem;max-width:700px;width:100%;box-shadow:var(--shadow-lg)}.setup-card h1{font-size:1.6rem;margin-bottom:.3rem;font-weight:700;letter-spacing:-.02em}.setup-subtitle{color:var(--color-text-secondary);margin-bottom:2rem;font-size:.95rem}.setup-progress{display:flex;gap:0;justify-content:center;margin-bottom:2.5rem}.setup-progress-step{display:flex;align-items:center;cursor:pointer}.setup-progress-step:after{content:"";width:36px;height:2px;background:var(--color-border);transition:background var(--transition)}.setup-progress-step:last-child:after{display:none}.setup-progress-step.active:after{background:var(--color-primary)}.step-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;background:var(--color-bg);border:2px solid var(--color-border);color:var(--color-text-tertiary);transition:all .2s ease}.setup-progress-step.active .step-dot{border-color:var(--color-primary);color:var(--color-primary-hover)}.setup-progress-step.current .step-dot{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 0 12px var(--color-primary-glow)}.setup-step-content{min-height:280px}.step-section h2{font-size:1.15rem;margin-bottom:.4rem;font-weight:600}.step-desc{color:var(--color-text-secondary);font-size:.9rem;margin-bottom:1.5rem;line-height:1.6}.step-section label{margin-top:.85rem;margin-bottom:.4rem;display:block;font-size:.8rem;color:var(--color-text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.step-section input{width:100%;padding:.6rem .85rem}.field-hint{font-size:.8rem;color:var(--color-text-tertiary);margin-top:.4rem}.field-hint code{background:var(--color-bg);padding:.15rem .4rem;border-radius:4px;font-size:.78rem;color:var(--color-text-secondary)}.option-cards{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}.option-cards.small{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.option-card{background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-md);padding:1.15rem;cursor:pointer;transition:all .2s ease}.option-card:hover{border-color:var(--color-text-tertiary);background:var(--color-surface-hover)}.option-card.selected{border-color:var(--color-primary);background:var(--color-primary-muted);box-shadow:0 0 16px var(--color-primary-glow)}.option-card h3{font-size:.95rem;margin-bottom:.35rem;font-weight:600}.option-card p{font-size:.82rem;color:var(--color-text-secondary);line-height:1.45}.input-with-button{display:flex;gap:.5rem}.input-with-button input{flex:1}.input-with-button .btn-secondary{white-space:nowrap;background:var(--color-surface-raised);border:1px solid var(--color-border)}.key-display{margin-top:.85rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.85rem}.key-display code{font-size:.82rem;word-break:break-all;color:var(--color-success);font-family:SF Mono,Fira Code,ui-monospace,monospace}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.form-row input{width:100%}.info-banner{background:var(--color-primary-muted);border:1px solid rgba(99,102,241,.25);border-radius:var(--radius-sm);padding:.75rem 1.15rem;font-size:.88rem;color:var(--color-primary-hover);margin-bottom:1.25rem}.info-banner code{background:var(--color-bg);padding:.15rem .4rem;border-radius:4px;font-size:.82rem}.review-table{margin-top:.5rem}.review-table td{padding:.6rem .85rem}.review-table td:first-child{font-weight:600;color:var(--color-text-secondary);width:150px;font-size:.82rem;text-transform:uppercase;letter-spacing:.03em}.review-table code{font-size:.82rem;color:var(--color-primary-hover)}.setup-nav{display:flex;gap:.85rem;margin-top:2.25rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.setup-error{padding:.85rem 1.15rem;border-radius:var(--radius-sm);background:var(--color-danger-muted);border:1px solid rgba(239,68,68,.25);color:var(--color-danger);margin-bottom:1.25rem;font-size:.88rem;font-weight:500}.setup-success{text-align:center;padding:2.5rem 1rem}.setup-success p{font-size:1.1rem;color:var(--color-success);margin-bottom:.5rem;font-weight:600}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:modal-fade-in .2s ease}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem 2.25rem;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modal-slide-up .25s ease}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.modal-header h3{font-size:1.15rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.3rem;color:var(--color-text-tertiary);cursor:pointer;padding:.25rem;border-radius:6px;line-height:1;transition:all var(--transition)}.modal-close:hover{color:var(--color-text);background:var(--color-surface-hover)}.modal-form{margin-top:1rem}.modal-form .form-group{margin-bottom:1rem}.modal-form label{font-size:.78rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:.35rem}.modal-form input{width:100%;padding:.55rem .85rem}.modal-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--color-border-subtle)}.modal-done{text-align:center;padding:2rem 0}.modal-done-icon{width:56px;height:56px;margin:0 auto 1rem;border-radius:50%;background:var(--color-success-muted);border:2px solid var(--color-success);display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--color-success)}.modal-done h3{font-size:1.15rem;margin-bottom:.4rem;font-weight:600}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}
