*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;min-height:100vh;padding:20px}.app{margin:0 auto;max-width:900px}.app-header{color:#fff;margin-bottom:40px;padding:20px;text-align:center}.app-header h1{font-size:2.5rem;margin-bottom:10px}.app-header p{font-size:1.1rem;opacity:.9}.app-main{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px}.error-message{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;margin:20px 0;padding:15px}.vehicle-section{margin-top:30px}.tabs{border-bottom:2px solid #eee;display:flex;gap:10px;margin-bottom:20px}.tab{background:none;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:1rem;padding:12px 20px;transition:all .3s ease}.tab.active,.tab:hover{color:#667eea}.tab.active{border-bottom-color:#667eea}.tab-content{padding:20px 0}.garage-toggle{background:#fff3;border:1px solid #fff6;border-radius:20px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;margin-top:12px;padding:8px 20px;transition:all .3s}.garage-toggle:hover{background:#ffffff4d}.garage-panel{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;margin-bottom:20px;padding:20px}.garage-panel h3{color:#333;margin:0 0 15px}.garage-list{display:flex;flex-direction:column;gap:10px}.garage-card{background:#f9f9f9;border-left:4px solid #667eea;border-radius:8px;cursor:pointer;padding:14px 16px;transition:all .2s}.garage-card:hover{background:#f0f0ff;box-shadow:0 2px 8px #667eea26}.garage-card-main{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.garage-card-main strong{color:#333;font-size:1rem}.garage-nickname{color:#667eea;font-size:.85rem;font-style:italic}.garage-card-sub{align-items:center;display:flex;justify-content:space-between}.garage-vin{color:#999;font-family:monospace;font-size:.8rem}.garage-remove{background:none;border:none;color:#c33;cursor:pointer;font-size:.8rem;padding:2px 8px}.garage-remove:hover{text-decoration:underline}.vehicle-actions{display:flex;justify-content:flex-end;margin-bottom:10px}.save-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:8px 18px;transition:opacity .3s}.save-btn:hover{opacity:.9}.saved-badge{background:#e8f5e9;border-radius:6px;color:#2e7d32;font-size:.85rem;font-weight:600;padding:8px 18px}.install-banner{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:12px;box-shadow:0 4px 20px #00000026;display:flex;gap:12px;margin-bottom:20px;padding:14px 20px}.install-banner span{color:#333;flex:1 1;font-size:.9rem}.install-banner button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:8px 18px}.install-banner button.dismiss{background:#eee;color:#666;padding:8px 12px}@media (max-width:768px){.app-main{padding:20px}.app-header h1{font-size:2rem}.tabs{flex-wrap:wrap}.tab{font-size:.9rem;padding:10px 15px}}.barcode-overlay{align-items:center;background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.barcode-modal{background:#1a1a1a;border-radius:16px;max-height:90vh;max-width:480px;overflow-x:hidden;overflow-y:auto;width:100%}.barcode-header{align-items:center;background:#222;display:flex;justify-content:space-between;padding:16px 20px}.barcode-header h3{color:#fff;font-size:1.1rem;margin:0}.close-btn{background:#444;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:.9rem;font-weight:700;height:32px;width:32px}.close-btn:hover{background:#666}.barcode-video-container{aspect-ratio:4/3;background:#000;position:relative;width:100%}.barcode-video{height:100%;object-fit:cover;width:100%}.scan-guide{border:2px solid #667eeacc;border-radius:8px;height:30%;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:80%}.scan-line{animation:scanMove 2s ease-in-out infinite;background:#667eea;height:2px;left:0;position:absolute;right:0;top:0}@keyframes scanMove{0%,to{top:0}50%{top:100%}}.scan-hint{color:#aaa;font-size:.9rem;margin:0;padding:12px;text-align:center}.capture-btn{background:#667eeacc;border:4px solid #fff;border-radius:50%;bottom:50px;cursor:pointer;height:64px;left:50%;position:absolute;transform:translateX(-50%);transition:all .2s;width:64px}.capture-btn:active{background:#667eea;transform:translateX(-50%) scale(.9)}.capture-review{position:relative;width:100%}.preview-image{background:#000;display:block;max-height:50vh;object-fit:contain;width:100%}.processing-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;flex-direction:column;gap:16px;justify-content:center;left:0;position:absolute;right:0;top:0}.processing-overlay p{color:#fff;font-size:1rem}.spinner{animation:spin .8s linear infinite;border:3px solid #fff3;border-radius:50%;border-top-color:#667eea;height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.ocr-result{padding:20px;text-align:center}.vin-found{color:#4caf50;font-size:.9rem;margin:0 0 8px}.vin-value{background:#333;border-radius:8px;color:#fff;font-family:monospace;font-size:1.4rem;font-weight:700;letter-spacing:2px;margin:0 0 20px;padding:12px}.vin-not-found{color:#ff6b6b;font-size:1rem;margin:0 0 8px}.raw-text{color:#888;font-size:.8rem;margin:0 0 16px;word-break:break-all}.alt-matches{margin-bottom:16px}.alt-label{color:#888;font-size:.8rem;margin:0 0 8px}.alt-vin{background:#333;border:1px solid #555;border-radius:4px;color:#aaa;cursor:pointer;font-family:monospace;font-size:.85rem;margin:4px;padding:6px 12px}.alt-vin:hover{border-color:#667eea;color:#fff}.result-actions{display:flex;gap:12px;justify-content:center}.use-btn{background:linear-gradient(135deg,#667eea,#764ba2);font-weight:600}.retake-btn,.use-btn{border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:12px 28px}.retake-btn{background:#444}.barcode-error{color:#ff6b6b;padding:40px 20px;text-align:center}.barcode-error button{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;margin-top:16px;padding:10px 24px}.vin-scanner{margin-bottom:30px}.scanner-form{display:flex;flex-direction:column;gap:15px}.input-group{display:flex;gap:10px}.vin-input{border:2px solid #ddd;border-radius:8px;flex:1 1;font-family:monospace;font-size:1.1rem;font-weight:700;letter-spacing:1px;padding:15px;transition:border-color .3s}.vin-input:focus{border-color:#667eea;outline:none}.vin-input:disabled{background:#f5f5f5;cursor:not-allowed}.camera-button{align-items:center;background:#f0f0f0;border:2px solid #ddd;border-radius:8px;color:#667eea;cursor:pointer;display:flex;justify-content:center;padding:12px 14px;transition:all .3s}.camera-button:hover:not(:disabled){background:#667eea;border-color:#667eea;color:#fff}.camera-button:disabled{cursor:not-allowed;opacity:.5}.scan-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:15px 30px;transition:opacity .3s,transform .2s}.scan-button:hover:not(:disabled){opacity:.9;transform:translateY(-2px)}.scan-button:active:not(:disabled){transform:translateY(0)}.scan-button:disabled{cursor:not-allowed;opacity:.5}.input-hint{color:#999;font-size:.9rem;text-align:center}.example{background:#f9f9f9;border-radius:6px;padding:12px;text-align:center}.example p{color:#666;font-size:.9rem;margin:0}.example code{background:#e8e8e8;border-radius:3px;color:#333;font-family:monospace;font-weight:700;padding:2px 6px}@media (max-width:600px){.input-group{flex-direction:column}.scan-button{width:100%}}.vehicle-details{animation:slideIn .3s ease}.vehicle-header{border-bottom:2px solid #eee;margin-bottom:30px;padding-bottom:20px}.vehicle-header h2{color:#333;font-size:2rem;margin-bottom:8px}.vin-display{color:#666;font-family:monospace;font-size:.95rem;font-weight:700;letter-spacing:.5px}.details-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:20px}.detail-card{background:#f9f9f9;border-left:4px solid #667eea;border-radius:8px;padding:15px}.detail-card label{color:#999;display:block;font-size:.85rem;font-weight:700;margin-bottom:5px;text-transform:uppercase}.detail-card value{color:#333;display:block;font-size:1.2rem;font-weight:600}.decoded-info{border-top:1px solid #eee;color:#999;font-size:.9rem;padding-top:10px;text-align:center}@media (max-width:600px){.vehicle-header h2{font-size:1.5rem}.details-grid{grid-template-columns:1fr}}.detail-card.full-width{grid-column:1/-1}.list-container{animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.empty-state{color:#999;padding:40px 20px;text-align:center}.empty-state p{font-size:1.1rem;margin:0}.list-count{color:#666;font-size:.95rem;font-weight:500;margin:0 0 20px}.items-list{display:flex;flex-direction:column;gap:15px}.list-item{background:#f9f9f9;border-left:4px solid #667eea;border-radius:8px;padding:18px;transition:all .3s ease}.list-item:hover{background:#f5f5f5;box-shadow:0 2px 8px #667eea1a}.recall-item{border-left-color:#e74c3c}.complaint-item{border-left-color:#f39c12}.item-header{align-items:flex-start;display:flex;gap:10px;justify-content:space-between;margin-bottom:10px}.item-header h3{color:#333;font-size:1.1rem;margin:0}.item-date{background:#eee;border-radius:4px;color:#666;font-size:.85rem;font-weight:500;padding:4px 10px;white-space:nowrap}.item-summary{color:#555;line-height:1.5;margin:10px 0}.item-detail{border-top:1px solid #ddd;color:#666;font-size:.95rem;margin-top:10px;padding-top:10px}.item-detail strong{color:#333}.item-manufacturer{color:#999;font-size:.9rem;margin:10px 0 0}.list-toolbar{align-items:center;display:flex;gap:15px;justify-content:space-between;margin-bottom:20px}.filter-input{border:1px solid #ddd;border-radius:6px;font-size:.9rem;padding:8px 14px;width:200px}.filter-input:focus{border-color:#667eea;outline:none}.category-group{margin-bottom:20px}.category-header{border-bottom:1px solid #eee;color:#667eea;font-size:1rem;margin:0 0 10px;padding-bottom:6px}.part-item{border-left-color:#27ae60}.part-item h4{color:#333;font-size:1rem;margin:0}.part-price{color:#27ae60;font-size:1.1rem;font-weight:700;white-space:nowrap}.part-details{color:#888;display:flex;font-size:.85rem;gap:12px;margin-top:6px}.part-brand{color:#555;font-weight:500}.part-link{color:#667eea;display:inline-block;font-size:.85rem;margin-top:8px;text-decoration:none}.part-link:hover{text-decoration:underline}.video-item{border-left-color:#e74c3c}.video-content{display:flex;gap:16px}.video-thumbnail{border-radius:6px;flex-shrink:0;height:90px;object-fit:cover;width:120px}.video-info{flex:1 1}.video-info h3{font-size:1rem}.video-info a{color:#333;text-decoration:none}.video-info a:hover{color:#667eea}.video-channel{color:#888;font-size:.85rem;margin:4px 0}@media (max-width:600px){.item-header{align-items:flex-start;flex-direction:column}.item-date{align-self:flex-start}.item-header h3{font-size:1rem}.list-toolbar{align-items:stretch;flex-direction:column}.filter-input{width:100%}.video-content{flex-direction:column}.video-thumbnail{height:auto;width:100%}}
/*# sourceMappingURL=main.88677d1d.css.map*/