.product-input-wrapper{flex-direction:column;gap:6px;display:flex}.product-input{width:100%;color:var(--text-primary);background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);outline:none;padding:14px 16px;font-family:inherit;font-size:16px;transition:border-color .15s,box-shadow .15s}.product-input::placeholder{color:var(--text-muted)}.product-input:focus{border-color:var(--green);box-shadow:0 0 0 3px #1d9e751f}.product-input:disabled{opacity:.6;cursor:not-allowed}.product-input-hint{color:var(--text-muted);font-size:13px}.skin-type-selector{flex-direction:column;gap:10px;display:flex}.skin-type-label{color:var(--text-secondary);letter-spacing:.02em;text-transform:uppercase;font-size:14px;font-weight:500}.skin-type-pills{flex-wrap:wrap;gap:8px;display:flex}.pill{border:1.5px solid var(--border);background:var(--bg);color:var(--text-secondary);white-space:nowrap;border-radius:999px;padding:9px 20px;font-size:14px;font-weight:500;transition:all .18s;position:relative}.pill:hover{border-color:var(--green);color:var(--green);background:var(--green-light)}.pill.selected{background:var(--green);border-color:var(--green);color:#fff}.pill.selected:hover{color:#fff;background:#18896a;border-color:#18896a}.pill.selected.auto{background:var(--green);border-color:var(--green);color:#fff;padding-right:36px}.auto-badge{background:var(--green-dark);color:#fff;letter-spacing:.05em;text-transform:uppercase;pointer-events:none;border-radius:4px;padding:2px 5px;font-size:9px;font-weight:700;line-height:1.3;position:absolute;top:-7px;right:6px}.inference-hint{color:var(--green-dark);background:var(--green-light);border-radius:var(--radius-sm);padding:8px 12px;font-size:13px;line-height:1.5;animation:.2s slide-down}.inference-reason{color:var(--text-secondary);font-size:13px}@keyframes slide-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.home-container{background:var(--bg-secondary);flex-direction:column;align-items:center;min-height:100vh;padding:40px 16px 32px;display:flex}.home-header{text-align:center;flex-direction:column;align-items:center;gap:6px;width:100%;max-width:520px;margin-bottom:32px;display:flex}.header-top-row{justify-content:space-between;align-items:center;width:100%;display:flex}.auth-link{color:var(--text-secondary);border:1px solid var(--border);border-radius:999px;padding:5px 14px;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s}.auth-link:hover{border-color:var(--green);color:var(--green-dark);background:var(--green-light);text-decoration:none}.logo{color:var(--text-primary);letter-spacing:-1px;font-size:36px;font-weight:700;line-height:1}.tagline{color:var(--text-secondary);margin-top:2px;font-size:15px}.nova-badge{letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);background:var(--bg);border:1px solid var(--border);border-radius:999px;align-items:center;gap:4px;margin-top:4px;padding:4px 12px;font-size:11px;font-weight:600;display:inline-flex}.home-main{width:100%;max-width:520px}.form-card{background:var(--bg);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);flex-direction:column;gap:24px;padding:28px 24px;display:flex}.form-section{flex-direction:column;gap:10px;display:flex}.section-label{color:var(--text-primary);font-size:14px;font-weight:600;display:block}.section-label.secondary{color:var(--text-secondary);font-weight:400}.demo-chips{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.demo-chip{color:var(--text-secondary);background:var(--bg);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:999px;padding:5px 12px;font-size:12px;font-weight:500;transition:all .2s}.demo-chip:hover{border-color:var(--green);color:var(--green-dark);background:var(--green-light)}.upload-label-row{align-items:center;gap:8px;display:flex}.optional-badge{letter-spacing:.06em;color:var(--text-muted);border:1px solid var(--border);text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700}.drop-zone{border:1.5px dashed var(--border);border-radius:var(--radius-sm);text-align:center;cursor:pointer;background:var(--bg-secondary);color:var(--text-muted);padding:20px;font-size:14px;transition:all .25s}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--green);background:var(--green-light);color:var(--green-dark)}.drop-zone.has-file{border-style:solid;border-color:var(--green);background:var(--green-light)}.upload-prompt{flex-direction:column;align-items:center;gap:4px;display:flex}.upload-icon{margin-bottom:4px;font-size:24px}.upload-types{color:var(--text-muted);letter-spacing:.04em;font-size:12px}.upload-preview{color:var(--green-dark);justify-content:center;align-items:center;gap:10px;font-weight:500;display:flex}.upload-check{color:var(--green);font-size:18px}.remove-image{color:var(--text-muted);background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:14px}.remove-image:hover{background:#0000000f}.upload-hint{color:var(--green-dark);background:var(--green-light);border-radius:var(--radius-sm);padding:8px 12px;font-size:13px}.upload-privacy{color:var(--text-muted);margin:0;font-size:12px}.compatibility-toggle-row{justify-content:space-between;align-items:center;display:flex}.toggle-label{color:var(--text-primary);cursor:pointer;font-size:14px;font-weight:500}.toggle-switch{border:none;border-radius:999px;flex-shrink:0;width:44px;height:24px;padding:2px;transition:background .2s;position:relative}.toggle-switch.on{background:var(--green)}.toggle-switch.off{background:#d1d5db}.toggle-thumb{background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .2s;display:block;box-shadow:0 1px 3px #0003}.toggle-switch.on .toggle-thumb{transform:translate(20px)}.toggle-switch.off .toggle-thumb{transform:translate(0)}.second-product-wrapper{flex-direction:column;gap:8px;animation:.18s slide-down;display:flex}.analyze-btn{border-radius:var(--radius-sm);border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:15px;font-size:16px;font-weight:600;transition:all .25s;display:flex}.analyze-btn:not(.disabled):not(.loading){background:var(--green);color:#fff}.analyze-btn:not(.disabled):not(.loading):hover{background:#18896a}.analyze-btn:not(.disabled):not(.loading):active{transform:scale(.98)}.analyze-btn.disabled{color:var(--text-muted);cursor:not-allowed;background:#e5e7eb}.analyze-btn.loading{background:var(--green);color:#fff;opacity:.8;cursor:wait}.spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}.home-footer{text-align:center;max-width:520px;margin-top:24px}.home-footer p{color:var(--text-muted);font-size:12px;line-height:1.5}@keyframes spin{to{transform:rotate(360deg)}}.upload-actions{gap:8px;margin-top:4px;display:flex}.upload-action-btn{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-secondary);cursor:pointer;flex:1;padding:8px;font-size:13px;font-weight:500;transition:all .2s}.upload-action-btn:hover{border-color:var(--green);color:var(--green-dark);background:var(--green-light)}.camera-preview-wrap{border-radius:var(--radius-sm);aspect-ratio:16/9;background:#000;position:relative;overflow:hidden}.camera-preview-wrap video{object-fit:cover;width:100%;height:100%}.camera-controls{gap:8px;margin-top:8px;display:flex}.capture-btn{background:var(--green);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;flex:1;padding:10px;font-size:14px;font-weight:600}.cancel-camera-btn{color:var(--text-muted);border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:10px 16px;font-size:14px;font-weight:500}.scanning-label{color:var(--green-dark);align-items:center;gap:6px;margin:0;font-size:13px;display:flex}.detection-banner{background:var(--green-light);border-radius:var(--radius-sm);color:var(--green-dark);border:1px solid #1d9e7540;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.detection-icon{font-size:15px}.follow-up-section{animation:.18s slide-down}.follow-up-pills{flex-wrap:wrap;gap:8px;display:flex}.follow-up-pill{border:1.5px solid var(--border);background:var(--bg);color:var(--text-secondary);cursor:pointer;border-radius:999px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .15s}.follow-up-pill:hover{border-color:var(--green);color:var(--green-dark)}.follow-up-pill.selected{background:var(--green);border-color:var(--green);color:#fff}.follow-up-pill.follow-up-skip{color:var(--text-muted);background:0 0;border-color:#0000;padding:6px 10px;font-size:13px;font-weight:400}.follow-up-pill.follow-up-skip:hover{color:var(--text-secondary);border-color:#0000;text-decoration:underline}.photo-grid{flex-wrap:wrap;gap:10px;display:flex}.photo-thumb{border-radius:var(--radius-sm);flex-shrink:0;width:80px;height:80px;position:relative;overflow:visible}.photo-thumb-img{object-fit:cover;border-radius:var(--radius-sm);border:1.5px solid var(--green);width:80px;height:80px;display:block}.photo-remove-btn{color:#fff;cursor:pointer;z-index:1;background:#ef4444;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;padding:0;font-size:10px;font-weight:700;line-height:1;display:flex;position:absolute;top:-6px;right:-6px}.photo-remove-btn:hover{background:#dc2626}.photo-num{color:#fff;background:#0000008c;border-radius:3px;padding:1px 4px;font-size:10px;font-weight:700;line-height:1.4;position:absolute;bottom:4px;left:4px}@media (width<=540px){.home-container{padding:24px 12px}.form-card{gap:20px;padding:20px 16px}.logo{font-size:28px}.upload-actions{flex-direction:column}.upload-action-btn{width:100%}.follow-up-pills,.demo-chips{gap:6px}.demo-chip{padding:4px 10px;font-size:11px}}.ingredient-card{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);flex-direction:column;gap:6px;padding:12px 14px;transition:border-color .2s;display:flex}.ingredient-card:hover{border-color:var(--green)}.ingredient-card.caution-card:hover{border-color:var(--amber)}.ingredient-card.avoid-card:hover{border-color:var(--red)}.ingredient-card.flagged{background:#fff8f8;border-color:#fecaca}.ingredient-top{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.ingredient-name{color:var(--text-primary);flex:1;font-size:13px;font-weight:600;line-height:1.3}.cat-badge{color:#fff;text-transform:capitalize;letter-spacing:.2px;border-radius:10px;flex-shrink:0;padding:2px 8px;font-size:10px;font-weight:600}.ingredient-desc{color:var(--text-secondary);margin:0;font-size:12px;line-height:1.5}.ingredient-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:2px;display:flex}.irritant-pill{text-transform:capitalize;font-size:11px;font-weight:600}.comed-wrapper{align-items:center;gap:4px;display:flex}.comed-label{color:var(--text-muted);font-size:11px}.comed-dots{gap:3px;display:flex}.comed-dot{background:#e5e7eb;border-radius:50%;width:8px;height:8px;transition:background .15s}.comed-dot.filled{background:#ba7517}.safe-chip{text-transform:capitalize;letter-spacing:.3px;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700}.ingredient-flag-note{color:var(--red);margin:0;font-size:12px;font-weight:500}.red-flag-card{border-radius:var(--radius-sm);border-left:4px solid;flex-direction:column;gap:4px;padding:12px 16px;transition:box-shadow .2s;display:flex}.red-flag-card.sev-high{border-color:var(--red);background:#fff3f3}.red-flag-card.sev-medium{border-color:var(--amber);background:#fffbf2}.red-flag-card.sev-low{background:#f9fafb;border-color:#9ca3af}.flag-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.flag-name{color:var(--text-primary);font-size:14px;font-weight:600}.sev-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:10px;flex-shrink:0;padding:2px 8px;font-size:10px;font-weight:700}.sev-badge.sev-high{color:#991b1b;background:#fee2e2}.sev-badge.sev-medium{color:#92400e;background:#fef3c7}.sev-badge.sev-low{color:#374151;background:#f3f4f6}.flag-reason{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.5}.alt-loading{color:var(--text-secondary);align-items:center;gap:10px;padding:8px 0;font-size:14px;display:flex}.alt-spinner{border:2px solid var(--green-light);border-top-color:var(--green);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.8s linear infinite spin}.alt-empty{color:var(--text-muted);font-size:14px;font-style:italic}.alt-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.alt-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:6px;padding:14px;transition:border-color .2s;display:flex;position:relative}.alt-card:hover{border-color:var(--green)}.alt-match-badge{background:var(--green-light);color:var(--green-dark);border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700;position:absolute;top:10px;right:10px}.alt-brand{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0;padding-right:60px;font-size:11px;font-weight:600}.alt-name{color:var(--text-primary);margin:0;font-size:13px;font-weight:600;line-height:1.4}.alt-shared{color:var(--green-dark);margin:0;font-size:11px;font-weight:500}.alt-similar-badge{color:var(--text-secondary);background:#f3f4f6}.alt-ingredients{flex-wrap:wrap;gap:4px;margin-top:2px;display:flex}.alt-ing-pill{color:var(--green-dark);background:#e1f5ee;border-radius:8px;padding:2px 7px;font-size:10px;font-weight:500}.alt-why{color:var(--text-secondary);flex:1;margin:2px 0 0;font-size:12px;line-height:1.5}.alt-amazon-btn{color:var(--green);border-radius:var(--radius-sm);margin-top:auto;padding:6px 10px;font-size:12px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-block}.alt-amazon-btn:hover{color:var(--green-dark);background:var(--green-light);text-decoration:none}@media (width<=600px){.alt-grid{grid-template-columns:1fr}}.compat-loading{color:var(--text-secondary);align-items:center;gap:10px;padding:4px 0;font-size:14px;display:flex}.compat-spinner{border:2px solid var(--green-light);border-top-color:var(--green);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.8s linear infinite spin}.compat-wrapper{flex-direction:column;gap:12px;display:flex}.compat-products{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.compat-product-chip{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:220px;padding:5px 12px;font-size:13px;font-weight:600;overflow:hidden}.compat-plus{color:var(--text-muted);flex-shrink:0;font-size:16px;font-weight:700}.compat-verdict{border-radius:var(--radius-sm);border:1px solid;align-items:flex-start;gap:12px;padding:14px 16px;display:flex}.compat-verdict.safe{background:var(--green-light);border-color:#a7f3d0}.compat-verdict.conflict{background:#fff3cd;border-color:#f59e0b}.compat-verdict-icon{flex-shrink:0;font-size:20px}.compat-verdict-text{color:var(--text-primary);margin:0 0 4px;font-size:15px;font-weight:700}.compat-recommendation{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.5}.compat-conflicts{flex-direction:column;gap:8px;display:flex}.compat-conflict-card{border-radius:var(--radius-sm);border:1px solid;padding:12px 14px}.conflict-top{justify-content:space-between;align-items:center;gap:8px;margin-bottom:5px;display:flex}.conflict-pair{color:var(--text-primary);text-transform:capitalize;font-size:13px;font-weight:600}.conflict-sev-badge{text-transform:uppercase;letter-spacing:.4px;border-radius:10px;flex-shrink:0;padding:2px 8px;font-size:10px;font-weight:700}.conflict-reason{margin:0;font-size:13px;line-height:1.5}.results-page{background:var(--bg-secondary);flex-direction:column;min-height:100vh;display:flex}.results-header{background:var(--bg);border-bottom:1px solid var(--border);z-index:10;align-items:center;gap:16px;padding:14px 24px;display:flex;position:sticky;top:0}.back-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);background:0 0;padding:6px 14px;font-size:14px;transition:border-color .15s,color .15s}.back-btn:hover{border-color:var(--green);color:var(--green)}.logo-text{color:var(--text-primary);letter-spacing:-.3px;flex:1;font-size:18px;font-weight:700}.logo-green{color:var(--green)}.header-actions{align-items:center;gap:8px;display:flex}.header-action-btn{color:var(--text-secondary);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;align-items:center;gap:4px;padding:5px 12px;font-size:12px;font-weight:500;transition:all .2s;display:inline-flex}.header-action-btn:hover{border-color:var(--green);color:var(--green-dark)}.header-action-btn.saved{border-color:var(--green);color:var(--green);background:var(--green-light);cursor:default}.toast{background:var(--green);color:#fff;border-radius:var(--radius-sm);z-index:100;padding:10px 20px;font-size:14px;font-weight:500;animation:.3s toast-in,.3s 1.7s forwards toast-out;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #1d9e754d}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toast-out{0%{opacity:1}to{opacity:0}}.state-center{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:60px 24px;display:flex}.skeleton-layout{flex-direction:column;gap:20px;width:100%;max-width:760px;margin:0 auto;padding:24px 16px 60px;display:flex}.skeleton-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:24px;overflow:hidden}.skeleton-line{background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0) 0 0/200% 100%;border-radius:6px;height:14px;animation:1.5s ease-in-out infinite shimmer}.skeleton-line.lg{width:60%;height:20px;margin-bottom:12px}.skeleton-line.md{width:80%;height:14px;margin-bottom:8px}.skeleton-line.sm{width:45%;height:12px;margin-bottom:6px}.skeleton-circle{background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0) 0 0/200% 100%;border-radius:50%;flex-shrink:0;width:120px;height:120px;animation:1.5s ease-in-out infinite shimmer}.skeleton-row{align-items:center;gap:24px;display:flex}.skeleton-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.skeleton-grid-item{border-radius:var(--radius-sm);background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0) 0 0/200% 100%;height:80px;animation:1.5s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-steps{flex-direction:column;gap:10px;width:100%;max-width:760px;margin:0 auto;padding:0 24px;display:flex}.loading-step-item{color:var(--text-muted);align-items:center;gap:10px;font-size:14px;transition:color .3s,opacity .3s;display:flex}.loading-step-item.active{color:var(--green-dark);font-weight:500}.loading-step-item.done{color:var(--green)}.step-indicator{background:var(--bg-secondary);border:1.5px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;transition:all .3s;display:flex}.loading-step-item.active .step-indicator{background:var(--green-light);border-color:var(--green)}.loading-step-item.done .step-indicator{background:var(--green);border-color:var(--green);color:#fff}.spinner{border:3px solid var(--green-light);border-top-color:var(--green);border-radius:50%;width:44px;height:44px;margin-bottom:8px;animation:.9s linear infinite spin}.loading-product{color:var(--text-primary);font-size:17px;font-weight:600}.loading-step{color:var(--text-secondary);min-height:20px;font-size:14px}.state-icon{font-size:40px}.error-title{color:var(--text-primary);font-size:18px;font-weight:600}.error-detail{color:var(--text-secondary);max-width:340px;font-size:14px}.btn-primary{background:var(--green);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;padding:12px 28px;font-size:15px;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.btn-primary:hover{background:var(--green-dark)}.btn-primary:active{transform:scale(.97)}.inference-banner{background:var(--green-light);border-radius:var(--radius);border:1px solid #a7f3d0;flex-direction:column;gap:12px;padding:16px 20px;display:flex}.inference-banner-text{align-items:flex-start;gap:10px;display:flex}.inference-icon{flex-shrink:0;font-size:18px}.inference-banner-text p{color:var(--green-dark);margin:0;font-size:14px;line-height:1.5}.inference-banner-text strong{font-weight:700}.inference-sub{color:var(--text-secondary);font-size:13px;margin-top:2px!important}.inference-pills{flex-wrap:wrap;gap:8px;display:flex}.inf-pill{background:var(--bg);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:20px;padding:5px 14px;font-size:13px;font-weight:500;transition:border-color .15s,color .15s,background .15s}.inf-pill:hover:not(:disabled){border-color:var(--green);color:var(--green)}.inf-pill.active{background:var(--green);border-color:var(--green);color:#fff}.inf-pill:disabled{opacity:.5;cursor:not-allowed}.results-content{flex-direction:column;gap:20px;width:100%;max-width:760px;margin:0 auto;padding:24px 16px 60px;display:flex}.product-header{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 24px}.product-header-top{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.product-title{color:var(--text-primary);font-size:20px;font-weight:700;line-height:1.3}.cached-badge{background:var(--green-light);color:var(--green-dark);white-space:nowrap;border-radius:20px;flex-shrink:0;padding:3px 10px;font-size:11px;font-weight:600}.product-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.skin-type-pill{background:var(--green-light);color:var(--green-dark);border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:13px;font-weight:500;display:inline-flex}.auto-tag{background:var(--green);color:#fff;letter-spacing:.3px;text-transform:uppercase;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:700}.price-pill{color:#92400e;background:#fef3c7;border-radius:20px;padding:4px 12px;font-size:13px;font-weight:500}.score-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:28px;padding:24px;display:flex}.score-circle-wrapper{flex-shrink:0;position:relative}.score-svg{display:block}.score-inner{flex-direction:column;justify-content:center;align-items:center;line-height:1;display:flex;position:absolute;inset:0}.score-number{letter-spacing:-1px;font-size:30px;font-weight:800}.score-denom{color:var(--text-muted);font-size:12px;font-weight:500}.score-info{flex:1}.score-label-text{margin-bottom:8px;font-size:20px;font-weight:700}.score-summary{color:var(--text-secondary);font-size:14px;line-height:1.7}.r-section{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:14px;padding:24px;display:flex}.section-title{color:var(--text-primary);margin:0;font-size:16px;font-weight:700}.section-subtitle{color:var(--text-secondary);margin:-6px 0 0;font-size:13px}.note-text{color:var(--text-secondary);border-radius:var(--radius-sm);background:#fffbeb;border:1px solid #fde68a;margin:0;padding:10px 14px;font-size:13px}.r-section+.r-section{margin-top:4px}.red-flags-list{flex-direction:column;gap:10px;display:flex}.ingredients-grid-wrapper{position:relative}.ingredients-grid-wrapper.collapsed:after{content:"";background:linear-gradient(transparent, var(--bg));pointer-events:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);height:60px;position:absolute;bottom:0;left:0;right:0}.ingredients-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;display:grid}.btn-show-more{border:1px dashed var(--border);border-radius:var(--radius-sm);width:100%;color:var(--green);cursor:pointer;background:0 0;justify-content:center;align-items:center;padding:10px;font-size:13px;font-weight:600;transition:border-color .15s,background .15s;display:flex}.btn-show-more:hover{border-color:var(--green);background:var(--green-light)}.info-box{border-radius:var(--radius-sm);color:var(--text-secondary);padding:14px 16px;font-size:14px;line-height:1.7}.brand-box{background:#f0f9ff;border:1px solid #bae6fd}.reality-box{background:var(--green-light);border:1px solid #a7f3d0}.box-label{letter-spacing:.6px;text-transform:uppercase;color:var(--text-secondary);margin-bottom:6px;font-size:11px;font-weight:700;display:block}.correction-banner{border-radius:var(--radius-sm);color:#92400e;background:#fffbeb;border:1px solid #fcd34d;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;display:flex}.source-banner{border-radius:var(--radius-sm);align-items:flex-start;gap:8px;padding:10px 14px;font-size:13px;display:flex}.web-research-banner{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe}.estimated-banner{color:#9a3412;background:#fff7ed;border:1px solid #fdba74}.not-found-banner{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.not-found-banner p{margin:0 0 8px}.btn-upload-prompt{background:var(--green);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s;display:inline-flex}.btn-upload-prompt:hover{background:var(--green-dark)}.analyse-another{justify-content:center;padding-top:8px;display:flex}@keyframes fade-in-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.ingredient-stagger{animation:.3s both fade-in-up}@media (width<=768px){.ingredients-grid,.skeleton-grid{grid-template-columns:1fr}}@media (width<=600px){.score-card{text-align:center;flex-direction:column;align-items:center;gap:16px}.product-header,.r-section{padding:16px}.results-content{padding:16px 12px 48px}.results-header{padding:12px 16px}.header-action-btn span:not(:first-child){display:none}.skeleton-row{flex-direction:column}}.auth-container{background:var(--bg-secondary);flex-direction:column;align-items:center;min-height:100vh;padding:48px 16px 32px;display:flex}.auth-header{text-align:center;margin-bottom:28px}.auth-logo{color:var(--text-primary);letter-spacing:-1px;cursor:pointer;font-size:32px;font-weight:700}.auth-tagline{color:var(--text-secondary);margin-top:6px;font-size:14px}.auth-card{background:var(--bg);border-radius:var(--radius);width:100%;max-width:420px;box-shadow:var(--shadow);border:1px solid var(--border);flex-direction:column;gap:20px;padding:28px 24px;display:flex}.auth-tabs{border-radius:var(--radius-sm);border:1px solid var(--border);display:flex;overflow:hidden}.auth-tab{background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;border:none;flex:1;padding:10px;font-size:14px;font-weight:600;transition:all .2s}.auth-tab.active{background:var(--green);color:#fff}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-field{flex-direction:column;gap:5px;display:flex}.auth-field label{color:var(--text-primary);font-size:13px;font-weight:600}.auth-field input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-primary);outline:none;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .2s}.auth-field input:focus{border-color:var(--green)}.auth-error{color:var(--red);border-radius:var(--radius-sm);background:#e24b4a14;margin:0;padding:8px 12px;font-size:13px}.auth-confirm{color:var(--green-dark);background:var(--green-light);border-radius:var(--radius-sm);padding:10px 12px;font-size:13px}.auth-submit{border-radius:var(--radius-sm);background:var(--green);color:#fff;cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-size:15px;font-weight:600;transition:background .2s;display:flex}.auth-submit:hover:not(:disabled){background:#18896a}.auth-submit:disabled{opacity:.7;cursor:wait}.auth-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite auth-spin;display:inline-block}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-divider{align-items:center;gap:12px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-divider span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:12px}.auth-google{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text-primary);cursor:pointer;justify-content:center;align-items:center;gap:10px;padding:10px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.auth-google:hover{border-color:var(--green);background:var(--green-light)}.google-icon{flex-shrink:0}.auth-footer-text{color:var(--text-muted);text-align:center;margin:0;font-size:11px}.auth-back{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;margin-top:16px;font-size:13px}.auth-back:hover{color:var(--green)}@media (width<=540px){.auth-container{padding:24px 12px}.auth-card{padding:20px 16px}.auth-logo{font-size:28px}}.dash-container{background:var(--bg-secondary);flex-direction:column;align-items:center;min-height:100vh;padding:32px 16px;display:flex}.dash-header{justify-content:space-between;align-items:center;width:100%;max-width:680px;margin-bottom:24px;display:flex}.dash-logo{color:var(--text-primary);letter-spacing:-1px;cursor:pointer;font-size:28px;font-weight:700}.dash-header-right{align-items:center;gap:12px;display:flex}.dash-email{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:13px;overflow:hidden}.dash-signout{color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:5px 12px;font-size:13px;font-weight:500;transition:all .2s}.dash-signout:hover{color:var(--red);border-color:var(--red)}.dash-tabs{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);gap:4px;width:100%;max-width:680px;margin-bottom:20px;padding:4px;display:flex}.dash-tab{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;border:none;flex:1;padding:10px 8px;font-size:13px;font-weight:600;transition:all .2s}.dash-tab.active{background:var(--green);color:#fff;box-shadow:0 1px 4px #1d9e7540}.dash-tab:not(.active):hover{background:var(--bg-secondary)}.dash-content{flex:1;width:100%;max-width:680px}.dash-section{animation:.2s dash-fade-in}@keyframes dash-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.dash-section-title{color:var(--text-primary);margin-bottom:16px;font-size:20px;font-weight:700}.dash-empty{color:var(--text-muted);font-size:14px}.dash-empty-state{text-align:center;background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);padding:40px 20px}.empty-icon{margin-bottom:12px;font-size:36px;display:block}.dash-empty-state p{color:var(--text-secondary);margin-bottom:4px;font-size:15px}.empty-sub{color:var(--text-muted);font-size:13px}.dash-cta{border-radius:var(--radius-sm);background:var(--green);color:#fff;cursor:pointer;border:none;margin-top:12px;padding:10px 20px;font-size:14px;font-weight:600;transition:background .2s}.dash-cta:hover{background:#18896a}.dash-cards{flex-direction:column;gap:10px;display:flex}.dash-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:16px 18px;transition:all .2s}.dash-card:hover{border-color:var(--green);box-shadow:var(--shadow);transform:translateY(-2px)}.dash-card-top{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.dash-card-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:15px;font-weight:600;overflow:hidden}.dash-card-score{border-radius:6px;flex-shrink:0;padding:3px 10px;font-size:13px;font-weight:700}.dash-card-bottom{justify-content:space-between;align-items:center;gap:8px;display:flex}.dash-card-skin{color:var(--text-muted);background:var(--bg-secondary);border-radius:4px;padding:2px 8px;font-size:12px}.dash-card-date{color:var(--text-muted);font-size:12px}.dash-card-actions{align-items:center;gap:10px;display:flex}.dash-unsave-btn{color:var(--red);cursor:pointer;background:0 0;border:1px solid #e24b4a4d;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500;transition:all .2s}.dash-unsave-btn:hover{border-color:var(--red);background:#e24b4a14}.dash-profile-form{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:24px;padding:24px;display:flex}.profile-field{flex-direction:column;gap:8px;display:flex}.profile-label{color:var(--text-primary);font-size:14px;font-weight:600}.profile-pills{flex-wrap:wrap;gap:8px;display:flex}.profile-pill{border:1.5px solid var(--border);background:var(--bg);color:var(--text-secondary);cursor:pointer;border-radius:999px;padding:7px 16px;font-size:13px;font-weight:500;transition:all .15s}.profile-pill:hover{border-color:var(--green);color:var(--green-dark)}.profile-pill.selected{background:var(--green);border-color:var(--green);color:#fff}.profile-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-primary);outline:none;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .2s}.profile-input:focus{border-color:var(--green)}.profile-hint{color:var(--text-muted);font-size:12px}.profile-save{border-radius:var(--radius-sm);background:var(--green);color:#fff;cursor:pointer;border:none;align-self:flex-start;padding:10px 24px;font-size:14px;font-weight:600;transition:background .2s}.profile-save:hover{background:#18896a}.profile-success{color:var(--green-dark);background:var(--green-light);border-radius:var(--radius-sm);margin:0;padding:8px 12px;font-size:13px;animation:.2s dash-fade-in}.dash-footer-cta{margin-top:24px}@media (width<=540px){.dash-container{padding:20px 12px}.dash-header{flex-direction:column;align-items:flex-start;gap:8px}.dash-header-right{justify-content:space-between;width:100%}.dash-tab{padding:8px 4px;font-size:12px}.dash-profile-form{padding:16px}.dash-card{padding:14px}}:root{--green:#1d9e75;--green-light:#e1f5ee;--green-dark:#085041;--amber:#ba7517;--red:#e24b4a;--bg:#fff;--bg-secondary:#f9fafb;--border:#0000001f;--text-primary:#1a1a1a;--text-secondary:#6b7280;--text-muted:#9ca3af;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px #00000014, 0 4px 16px #0000000f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:16px}body{background:var(--bg-secondary);color:var(--text-primary);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5}#root{min-height:100vh}a{color:var(--green);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}
