:root{--teal-600: #0d9488;--teal-700: #0f766e;--teal-50: #f0fdfa;--red-500: #ef4444;--red-50: #fef2f2;--amber-500: #f59e0b;--amber-50: #fffbeb;--green-500: #22c55e;--green-50: #f0fdf4;--slate-900: #0f172a;--slate-700: #334155;--slate-500: #64748b;--slate-200: #e2e8f0;--slate-100: #f1f5f9;--white: #ffffff;--radius: 12px;--shadow: 0 4px 24px rgba(15, 23, 42, .08);--safe-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:DM Sans,system-ui,-apple-system,sans-serif;background:var(--slate-100);color:var(--slate-900);line-height:1.5;min-height:100dvh}.app{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;background:var(--white);box-shadow:var(--shadow)}.app-header{background:linear-gradient(135deg,var(--teal-600),var(--teal-700));color:var(--white);padding:1.25rem 1rem 1rem}.brand{display:flex;align-items:center;gap:.75rem}.brand--button{background:none;border:none;padding:0;margin:0;color:inherit;font:inherit;text-align:left;cursor:pointer;width:100%}.brand-icon{width:2.5rem;height:2.5rem;flex-shrink:0;color:var(--white)}.brand h1{margin:0;font-size:1.35rem;font-weight:700;letter-spacing:-.02em}.tagline{margin:.1rem 0 0;font-size:.85rem;opacity:.9}.app-main{flex:1;padding:1rem;padding-bottom:calc(1rem + var(--safe-bottom));overflow-y:auto}.app-main:has(+.tab-bar){padding-bottom:calc(5rem + var(--safe-bottom))}.panel{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.panel-header h2{margin:0 0 .25rem;font-size:1.15rem;font-weight:700}.panel-header p{margin:0 0 1rem;color:var(--slate-500);font-size:.9rem}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.85rem}.field span{font-size:.8rem;font-weight:600;color:var(--slate-700)}.field input,.field textarea{font:inherit;padding:.65rem .75rem;border:1.5px solid var(--slate-200);border-radius:8px;background:var(--white);transition:border-color .15s}.field input:focus,.field textarea:focus{outline:none;border-color:var(--teal-600);box-shadow:0 0 0 3px #0d948826}.field textarea{resize:vertical;min-height:100px}.btn{font:inherit;font-weight:600;padding:.7rem 1.1rem;border-radius:8px;border:none;cursor:pointer;transition:background .15s,opacity .15s}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--teal-600);color:var(--white);width:100%}.btn-primary:not(:disabled):hover{background:var(--teal-700)}.btn-secondary{background:var(--slate-900);color:var(--white);width:100%}.btn-secondary:not(:disabled):hover{background:var(--slate-700)}.btn-ghost{background:transparent;color:var(--slate-500);border:1.5px solid var(--slate-200)}.suggestions{margin:1.25rem 0}.suggestions-label{font-size:.8rem;font-weight:600;color:var(--slate-500);display:block;margin-bottom:.5rem}.chip-row{display:flex;flex-wrap:wrap;gap:.4rem}.chip{font:inherit;font-size:.78rem;padding:.35rem .65rem;border-radius:999px;border:1.5px solid var(--slate-200);background:var(--white);color:var(--slate-700);cursor:pointer}.chip:hover{border-color:var(--teal-600);color:var(--teal-700);background:var(--teal-50)}.allergen-list{list-style:none;margin:0;padding:0}.allergen-item{border:1.5px solid var(--slate-200);border-radius:var(--radius);margin-bottom:.5rem;overflow:hidden}.allergen-item-main{display:flex;align-items:center;padding:.65rem .75rem;gap:.5rem}.allergen-name{flex:1;font-weight:600}.btn-icon{background:none;border:none;font-size:1rem;cursor:pointer;color:var(--slate-500);padding:.25rem .4rem;line-height:1}.btn-remove{color:var(--red-500)}.alias-preview{margin:0;padding:.5rem .75rem .65rem;font-size:.78rem;color:var(--slate-500);background:var(--slate-100);border-top:1px solid var(--slate-200)}.empty-state{text-align:center;color:var(--slate-500);padding:2rem 1rem;font-size:.9rem}.camera-zone{margin-bottom:1rem}.camera-viewport{position:relative;width:100%;aspect-ratio:4 / 3;border-radius:var(--radius);background:var(--slate-900);overflow:hidden;margin-bottom:.75rem}.camera-preview{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;pointer-events:none}.camera-viewport--live .camera-preview{opacity:1}.camera-viewport--review .camera-preview{opacity:0}.camera-viewport--live .camera-placeholder,.camera-viewport--review .camera-placeholder{display:none}.capture-preview{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;background:var(--slate-900)}.capture-review-badge{position:absolute;top:.5rem;left:50%;transform:translate(-50%);font-size:.68rem;font-weight:600;color:var(--white);background:#0d9488d9;padding:.25rem .55rem;border-radius:999px;pointer-events:none}.camera-viewport--live .camera-placeholder{display:none}.camera-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--slate-500);font-size:.85rem;background:var(--slate-900)}.camera-placeholder-icon{font-size:2rem;opacity:.6}.camera-viewfinder{position:absolute;top:12%;right:12%;bottom:12%;left:12%;border:2px dashed rgba(255,255,255,.75);border-radius:8px;box-shadow:0 0 0 9999px #00000040;pointer-events:none;display:flex;align-items:flex-end;justify-content:center;padding-bottom:.5rem}.viewfinder-hint{font-size:.72rem;font-weight:600;color:var(--white);background:#0f172aa6;padding:.25rem .5rem;border-radius:999px}.hidden-canvas{display:none}.camera-actions{display:flex;flex-direction:column;gap:.5rem}.camera-viewfinder--barcode{top:34%;right:8%;bottom:34%;left:8%;z-index:2}.warn-banner{background:var(--amber-50);border:1.5px solid var(--amber-500);color:#92400e;padding:.65rem .75rem;border-radius:8px;font-size:.85rem;margin-bottom:1rem}.error-msg{color:var(--red-500);font-size:.85rem;margin:.5rem 0}.source-note{font-size:.75rem;color:var(--slate-500);margin-top:1rem}.tab-bar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;background:var(--white);border-top:1.5px solid var(--slate-200);padding-bottom:var(--safe-bottom);z-index:100}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.55rem .25rem;background:none;border:none;font:inherit;font-size:.68rem;font-weight:600;color:var(--slate-500);cursor:pointer;position:relative}.tab-btn.active{color:var(--teal-600)}.tab-icon{font-size:1.1rem}.tab-badge{position:absolute;top:.25rem;right:calc(50% - 1.5rem);background:var(--teal-600);color:var(--white);font-size:.6rem;min-width:1rem;height:1rem;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 .25rem}.app-footer{text-align:center;padding:.5rem;font-size:.75rem;padding-bottom:calc(4.5rem + var(--safe-bottom))}.app-footer a,.footer-link{color:var(--slate-500)}.footer-link{background:none;border:none;padding:0;font:inherit;font-size:inherit;cursor:pointer;text-decoration:underline}.welcome-screen{animation:fadeIn .25s ease}.welcome-hero{text-align:center;margin-bottom:1.5rem}.welcome-symbol{width:4.5rem;height:4.5rem;color:var(--teal-600);margin:0 auto 1rem;display:block}.welcome-hero h2{margin:0 0 .75rem;font-size:1.25rem;font-weight:700;line-height:1.3;letter-spacing:-.02em}.welcome-lead{margin:0;font-size:.92rem;color:var(--slate-700);line-height:1.55}.welcome-steps,.welcome-features,.welcome-faq{margin-bottom:1.25rem}.welcome-steps h3,.welcome-features h3,.welcome-faq h3{margin:0 0 .5rem;font-size:.95rem;font-weight:700;color:var(--slate-900)}.welcome-steps ol{margin:0;padding-left:1.2rem;font-size:.88rem;color:var(--slate-700)}.welcome-steps li{margin-bottom:.5rem}.welcome-features ul{margin:0;padding-left:1.1rem;font-size:.88rem;color:var(--slate-700)}.welcome-features li{margin-bottom:.35rem}.welcome-faq details{margin-bottom:.5rem;font-size:.85rem;color:var(--slate-700);border:1.5px solid var(--slate-200);border-radius:8px;padding:.5rem .65rem}.welcome-faq summary{font-weight:600;cursor:pointer;color:var(--slate-900)}.welcome-faq p{margin:.5rem 0 0;line-height:1.5}.welcome-cta{margin-bottom:.75rem}.welcome-disclaimer{margin:0;font-size:.72rem;color:var(--slate-500);text-align:center;line-height:1.45}.results-panel{border-radius:var(--radius);overflow:hidden}.results-safe{border:2px solid var(--green-500)}.results-alert{border:2px solid var(--red-500)}.results-unknown{border:2px solid var(--amber-500)}.product-name{margin:0;padding:0 1rem .5rem;font-size:1.05rem;font-weight:700}.verdict-unknown{background:var(--amber-50)}.matched-tags-summary{margin:0;padding:0 1rem .75rem;font-size:.82rem;color:var(--slate-700)}.tag-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.35rem}.tag-item{font-size:.75rem;padding:.25rem .5rem;border-radius:999px;background:var(--slate-100);color:var(--slate-700);border:1px solid var(--slate-200)}.tag-item--hit{background:#fecaca;color:#991b1b;border-color:var(--red-500);font-weight:600}.verdict{display:flex;gap:.75rem;padding:1rem;align-items:flex-start}.verdict-safe{background:var(--green-50)}.verdict-alert{background:var(--red-50)}.verdict-icon{font-size:1.75rem;line-height:1}.verdict strong{display:block;font-size:1.05rem}.verdict p{margin:.15rem 0 0;font-size:.85rem;color:var(--slate-700)}.product-thumb{display:block;max-height:120px;margin:0 auto .5rem;border-radius:8px}.result-source{font-size:.78rem;color:var(--slate-500);padding:0 1rem;margin:0 0 .75rem}.free-from-warnings{background:var(--amber-50);border-top:1.5px solid var(--amber-500);border-bottom:1.5px solid var(--amber-500);padding:.75rem 1rem}.free-from-warnings h3{margin:0 0 .35rem;font-size:.9rem;color:#92400e}.free-from-warnings ul{margin:0;padding-left:1.1rem;font-size:.82rem;color:#92400e}.match-list{list-style:none;margin:0;padding:.75rem 1rem;display:flex;flex-direction:column;gap:.35rem}.match-list li{display:flex;gap:.5rem;font-size:.85rem}.match-allergen{font-weight:700;color:var(--red-500);min-width:5rem}.match-term{color:var(--slate-700)}.ingredients-block{padding:.75rem 1rem;border-top:1.5px solid var(--slate-200)}.ingredients-block h3{margin:0 0 .5rem;font-size:.85rem;color:var(--slate-500)}.ingredients-plain,.ingredients-highlighted{font-size:.85rem;line-height:1.6;margin:0;white-space:pre-wrap;word-break:break-word}.allergen-hit{background:#fecaca;color:#991b1b;padding:.05rem .15rem;border-radius:3px;font-weight:600}.results-actions{display:flex;gap:.5rem;padding:.75rem 1rem}.results-actions .btn{flex:1}.disclaimer{font-size:.72rem;color:var(--slate-500);padding:0 1rem 1rem;margin:0;text-align:center}@media (min-width: 481px){body{padding:1rem 0;background:linear-gradient(160deg,var(--teal-50),var(--slate-100))}}
