.scanner-page{background:var(--background-primary);min-height:100vh;padding:1rem 0 2rem}.scanner-container{max-width:800px;margin:0 auto;padding:0 1.25rem}.scanner-header{text-align:center;padding:1.5rem 0 1rem}.scanner-header h1{color:var(--text-primary);letter-spacing:-.5px;margin:0 0 .25rem;font-size:1.75rem;font-weight:700}.scanner-subtitle{color:var(--text-secondary);margin:0;font-size:.95rem;font-weight:400}.loading-state{text-align:center;padding:3rem 1rem}.loading-spinner{border:3px solid var(--border-light);border-top:3px solid var(--brand-copper);border-radius:50%;width:2.5rem;height:2.5rem;margin:0 auto 1rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{color:var(--text-secondary);margin:0;font-size:.95rem}.scanner-input-grid{grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem;display:grid}.input-card{background:var(--background-primary);border:1.5px solid var(--border-light);cursor:pointer;text-align:left;font-family:inherit;font-size:inherit;color:inherit;border-radius:12px;align-items:center;gap:1rem;padding:1.25rem;transition:all .2s;display:flex}.input-card:hover{border-color:var(--brand-copper);box-shadow:var(--shadow-md)}.input-card:active{transform:scale(.98)}.input-card:disabled{opacity:.5;cursor:not-allowed}.input-card-icon{background:var(--background-accent);width:48px;height:48px;color:var(--brand-copper);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.input-card-text h3{color:var(--text-primary);margin:0 0 2px;font-size:1rem;font-weight:600}.input-card-text p{color:var(--text-secondary);margin:0;font-size:.8125rem}.camera-container{margin-bottom:1rem}.camera-viewport{background:#000;border-radius:12px;margin-bottom:.75rem;position:relative;overflow:hidden}.camera-video{object-fit:contain;width:100%;max-height:20rem;display:block}.camera-overlay{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.scan-frame{border:2px dashed #fff9;border-radius:10px;justify-content:center;align-items:center;width:16rem;height:10rem;display:flex}.scan-hint{color:#ffffffb3;text-shadow:0 1px 3px #00000080;font-size:.8125rem;font-weight:500}.camera-controls{justify-content:center;gap:.5rem;display:flex}.preview-section{margin-bottom:1rem}.preview-row{align-items:flex-start;gap:1rem;display:flex}.image-preview{object-fit:contain;border:1px solid var(--border-light);border-radius:10px;max-width:200px;max-height:200px}.preview-actions{flex-direction:column;gap:.5rem;padding-top:.25rem;display:flex}.progress-section{margin-bottom:1rem}.progress-bar{background:var(--border-light);border-radius:3px;width:100%;height:6px;margin-bottom:.5rem;overflow:hidden}.progress-fill{background:var(--brand-copper);border-radius:3px;height:100%;transition:width .3s}.progress-text{color:var(--text-secondary);text-align:center;margin:0;font-size:.8125rem}.error-message{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem;display:flex}.error-icon{color:#fff;background:#dc2626;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:.75rem;font-weight:700;display:flex}.detection-result{background:var(--background-accent);border-radius:8px;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem 1rem;display:flex}.detection-label{color:var(--text-secondary);font-size:.8125rem;font-weight:600}.detection-details{flex-wrap:wrap;gap:.375rem;display:flex}.detection-tag{background:var(--background-primary);border:1px solid var(--border-light);color:var(--text-primary);border-radius:100px;padding:.25rem .625rem;font-size:.8125rem;font-weight:500}.best-match-card{background:var(--background-primary);border:1px solid var(--border-light);cursor:pointer;box-shadow:var(--shadow-sm);border-radius:12px;margin-bottom:1rem;transition:all .2s;overflow:hidden}.best-match-card:hover{border-color:var(--brand-copper);box-shadow:var(--shadow-md);transform:translateY(-1px)}.best-match-label{background:var(--background-accent);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:.625rem 1rem;display:flex}.best-match-text{text-transform:uppercase;letter-spacing:.05em;color:var(--brand-sage);font-size:.75rem;font-weight:600}.match-score-pill{color:#fff;background:var(--brand-sage);border-radius:100px;padding:.125rem .5rem;font-size:.75rem;font-weight:700}.best-match-content{align-items:center;gap:1.25rem;padding:1rem;display:flex}.match-image{background:var(--background-accent);border-radius:8px;flex-shrink:0;width:100px;height:100px;overflow:hidden}.match-image img{object-fit:cover;width:100%;height:100%}.match-details{flex:1;min-width:0}.match-details h3{color:var(--text-primary);margin:0 0 .125rem;font-size:1.05rem;font-weight:700;line-height:1.3}.match-maker{color:var(--maker-color);margin:0 0 .375rem;font-size:.8125rem;font-weight:500}.match-meta{color:var(--text-secondary);gap:.75rem;margin-bottom:.375rem;font-size:.8125rem;display:flex}.match-meta span{align-items:center;display:flex}.match-rating{align-items:center;gap:.375rem;display:flex}.match-rating .stars{color:var(--star-color);letter-spacing:-1px;font-size:.875rem}.match-rating .rating-text{color:var(--text-secondary);font-size:.75rem}.other-matches{margin-bottom:1rem}.other-matches-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem;font-size:.875rem;font-weight:600}.other-matches .chocolate-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;display:grid}.match-confidence-badge{color:#fff;z-index:10;border-radius:100px;padding:2px 8px;font-size:.6875rem;font-weight:700;position:absolute;top:8px;right:8px}.fallback-actions{flex-wrap:wrap;align-items:center;gap:.75rem;padding:.75rem 0;display:flex}.fallback-actions>span{color:var(--text-secondary);font-size:.8125rem}.no-matches-card{text-align:center;background:var(--background-accent);border-radius:12px;margin-bottom:1rem;padding:2rem 1.5rem}.no-matches-card h3{color:var(--text-primary);margin:0 0 .5rem;font-size:1.25rem;font-weight:700}.no-matches-card p{color:var(--text-secondary);margin:0 0 1.25rem;font-size:.9rem;line-height:1.5}.no-matches-actions{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:inherit;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--brand-copper);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--background-accent);color:var(--text-primary);border:1px solid var(--border-light)}.btn-secondary:hover{border-color:var(--brand-copper);color:var(--brand-copper);background:var(--background-primary)}.btn-small{padding:.375rem .75rem;font-size:.8125rem}@media (max-width:600px){.scanner-input-grid{grid-template-columns:1fr}.scanner-header h1{font-size:1.5rem}.best-match-content{flex-direction:column;align-items:flex-start}.match-image{width:100%;height:160px}.preview-row{flex-direction:column}.image-preview{max-width:100%}.fallback-actions{flex-direction:column;align-items:flex-start}.scan-frame{width:12rem;height:8rem}}
