/* ── BASE RESET & LAYOUT ── */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
body{font-family:-apple-system,'Segoe UI',sans-serif;background:#f5f7f5;color:#1a2e1a;min-height:100vh;max-width:480px;margin:0 auto}
.screen{display:none;flex-direction:column;min-height:100vh;padding-bottom:80px}
.screen.active{display:flex}
.cam-screen{display:none;flex-direction:column;height:100vh;position:relative;background:#000;overflow:hidden}
.cam-screen.active{display:flex}

/* ── BOTTOM NAV ── */
.bnav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;background:#fff;border-top:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-around;padding:8px 0 20px;z-index:50}
.bnav-btn{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;font-family:inherit;padding:4px 10px;color:#9ca3af;transition:color .15s;min-width:52px}
.bnav-btn.active{color:#16a34a}
.bnav-btn span{font-size:10px;font-weight:600}
.bnav-icon{font-size:19px;line-height:1}
.bnav-scan{width:52px;height:52px;border-radius:50%;background:#22c55e;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 2px 12px rgba(34,197,94,.4);margin-top:-16px;transition:transform .15s}
.bnav-scan:active{transform:scale(.92)}

/* ── COMMON COMPONENTS ── */
.hdr{padding:52px 20px 14px;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:9px}
.logo-icon{width:34px;height:34px;background:#22c55e;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px}
.logo-text{font-size:19px;font-weight:700;color:#1a2e1a}
.logo-text span{color:#16a34a}
.back{background:none;border:none;color:#6b7280;font-size:14px;cursor:pointer;font-family:inherit;padding:0}
.pad{padding:0 20px 24px;flex:1}
.scr-title{font-size:20px;font-weight:700;letter-spacing:-.3px;margin-bottom:5px;color:#1a2e1a}
.scr-sub{font-size:13px;color:#6b7280;margin-bottom:18px;line-height:1.6}
.abtn{background:#22c55e;border:none;border-radius:9px;padding:14px;color:#fff;font-family:inherit;font-size:15px;font-weight:700;cursor:pointer;width:100%;box-shadow:0 2px 8px rgba(34,197,94,.25)}
.abtn:active{transform:scale(.98)}
.empty-state{text-align:center;padding:48px 20px;color:#9ca3af}
.empty-icon{font-size:40px;margin-bottom:12px}
.empty-title{font-size:16px;font-weight:600;color:#6b7280;margin-bottom:6px}
.empty-sub{font-size:13px;line-height:1.6}
.opt{background:#fff;border:1.5px solid #e5e7eb;border-radius:14px;padding:15px 16px;cursor:pointer;display:flex;align-items:center;gap:13px;width:100%;text-align:left;margin-bottom:9px;color:#1a2e1a;font-family:inherit;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.opt:active{transform:scale(.98);background:#f9fafb}
.opt.primary{background:#22c55e;border-color:#22c55e;box-shadow:0 2px 8px rgba(34,197,94,.3)}
.opt.primary .ot,.opt.primary .od{color:#fff}
.opt.primary .od{color:rgba(255,255,255,.8)}
.opt-icon{width:42px;height:42px;border-radius:10px;background:#f0fdf4;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.opt.primary .opt-icon{background:rgba(255,255,255,.2)}
.ot{font-size:14px;font-weight:700;margin-bottom:1px;color:#1a2e1a}
.od{font-size:11px;color:#6b7280}
.choice-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:14px;padding:18px;cursor:pointer;display:flex;gap:14px;align-items:flex-start;margin-bottom:10px;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.choice-card:active{transform:scale(.98)}
.choice-card.rec{border-color:#86efac}
.rec-pill{font-size:10px;font-weight:700;color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;padding:2px 8px;border-radius:99px;display:inline-block;margin-bottom:5px}
.ch-title{font-size:15px;font-weight:700;margin-bottom:4px;color:#1a2e1a}
.ch-desc{font-size:12px;color:#6b7280;line-height:1.5}

/* ── CAMERA ── */
#cam-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
#quagga-container{position:absolute;inset:0;width:100%;height:100%;display:none}
#quagga-container video{width:100%!important;height:100%!important;object-fit:cover!important;position:absolute;inset:0}
#quagga-container canvas{display:none!important}
.cam-top{position:absolute;top:0;left:0;right:0;padding:44px 16px 12px;display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.93);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.06);z-index:10}
.cam-top-btn{background:#f3f4f6;border:none;border-radius:99px;color:#374151;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;padding:7px 14px}
.cam-switch{background:#22c55e;border:none;border-radius:99px;color:#fff;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;padding:7px 14px}
.cam-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:5;pointer-events:none}
.label-guide{width:88%;height:60%;border:2px solid #22c55e;border-radius:14px;box-shadow:0 0 0 4000px rgba(0,0,0,.5)}
.barcode-guide{width:82%;height:26%;border:2px solid #22c55e;border-radius:8px;box-shadow:0 0 0 4000px rgba(0,0,0,.5);position:relative;overflow:hidden}
.scan-line{position:absolute;left:0;right:0;height:2px;background:linear-gradient(to right,transparent,#22c55e,transparent);animation:sl 1.6s ease-in-out infinite}
@keyframes sl{0%,100%{top:5%;opacity:.3}50%{top:90%;opacity:1}}
.cam-hint-pill{position:absolute;bottom:158px;left:50%;transform:translateX(-50%);font-size:13px;color:#1a2e1a;background:rgba(255,255,255,.93);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:7px 18px;border-radius:99px;z-index:10;font-weight:500;box-shadow:0 1px 6px rgba(0,0,0,.12);max-width:90%;text-align:center;white-space:nowrap}
.cam-detect-pill{position:absolute;bottom:210px;left:50%;transform:translateX(-50%);font-size:12px;font-weight:700;padding:6px 16px;border-radius:99px;z-index:10;white-space:nowrap;display:none;background:#22c55e;color:#fff;box-shadow:0 2px 8px rgba(34,197,94,.4)}
.cam-bottom{position:absolute;bottom:0;left:0;right:0;padding:14px 20px 44px;display:flex;flex-direction:column;align-items:center;gap:12px;background:rgba(255,255,255,.93);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid rgba(0,0,0,.06);z-index:10}
.capture-btn{width:66px;height:66px;border-radius:50%;background:#22c55e;border:4px solid rgba(34,197,94,.25);cursor:pointer;font-size:22px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px rgba(34,197,94,.35)}
.capture-btn:active{transform:scale(.92)}
.cam-sub-btns{display:flex;gap:10px}
.cam-sub-btn{background:#f0fdf4;border:1.5px solid #86efac;border-radius:99px;padding:8px 18px;color:#15803d;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer}
.cam-torch-btn{background:#fef9c3;border:1.5px solid #fde68a;border-radius:99px;padding:8px 18px;color:#854d0e;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;display:none}

/* ── FORMS & INPUTS ── */
.upload-area{border:2px dashed #d1fae5;border-radius:14px;padding:26px 18px;text-align:center;cursor:pointer;margin-bottom:14px;background:#f0fdf4}
.ing-row{display:flex;gap:9px;margin-bottom:11px}
.ing-in{flex:1;background:#fff;border:1.5px solid #e5e7eb;border-radius:9px;padding:11px 14px;color:#1a2e1a;font-family:inherit;font-size:14px;outline:none}
.ing-in:focus{border-color:#22c55e}
.ing-in::placeholder{color:#9ca3af}
.add-btn{width:44px;height:44px;background:#22c55e;border:none;border-radius:9px;font-size:22px;color:#fff;cursor:pointer;flex-shrink:0}
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px;min-height:14px}
.chip{background:#fff;border:1.5px solid #e5e7eb;border-radius:99px;padding:5px 11px;font-size:12px;display:flex;align-items:center;gap:6px;color:#1a2e1a}
.chip-x{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:15px;padding:0;line-height:1}
.empty-msg{font-size:12px;color:#9ca3af;font-style:italic}
.flbl{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#9ca3af;margin-bottom:7px;display:block}
.ta{background:#fff;border:1.5px solid #e5e7eb;border-radius:9px;padding:11px 14px;color:#1a2e1a;font-family:inherit;font-size:13px;line-height:1.6;resize:none;width:100%;height:78px;outline:none;margin-bottom:14px;display:block}
.ta:focus{border-color:#22c55e}
.ta::placeholder,.ni::placeholder{color:#9ca3af}
.ni{background:#fff;border:1.5px solid #e5e7eb;border-radius:9px;padding:11px 14px;color:#1a2e1a;font-family:inherit;font-size:14px;width:100%;outline:none;margin-bottom:18px;display:block}
.ni:focus{border-color:#22c55e}

/* ── ANALYZING ── */
.analyzing-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}
.pulse{width:80px;height:80px;border-radius:50%;background:#f0fdf4;border:2px solid #86efac;display:flex;align-items:center;justify-content:center;font-size:32px;margin-bottom:20px;animation:pp 1.6s ease-in-out infinite}
@keyframes pp{0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(34,197,94,.2)}50%{transform:scale(1.06);box-shadow:0 0 0 14px rgba(34,197,94,0)}}
.an-steps{margin-top:16px;display:flex;flex-direction:column;gap:7px;width:100%;max-width:240px}
.an-step{font-size:12px;color:#d1d5db;display:flex;align-items:center;gap:8px;transition:color .3s}
.an-step.active{color:#16a34a}
.an-step.done{color:#6b7280}
.step-dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}

/* ── RESULTS ── */
.res-scroll{flex:1;overflow-y:auto;padding-bottom:16px}
.product-hero{background:#fff;margin:0 20px 14px;border-radius:16px;padding:16px;display:flex;gap:14px;align-items:center;border:1.5px solid #e5e7eb;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.product-img{width:64px;height:64px;border-radius:10px;background:#f5f7f5;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0;overflow:hidden;border:1px solid #e5e7eb}
.product-img img{width:100%;height:100%;object-fit:cover}
.score-big{font-size:30px;font-weight:800;font-family:monospace;line-height:1}
.fav-btn{margin-left:auto;background:none;border:1.5px solid #e5e7eb;border-radius:8px;padding:6px 10px;color:#9ca3af;cursor:pointer;font-size:16px;font-family:inherit}
.fav-btn.active{color:#ef4444;border-color:#fca5a5}
.sec-hdr{font-size:10px;font-weight:700;letter-spacing:.1em;color:#9ca3af;text-transform:uppercase;padding:0 20px;margin:14px 0 8px}
.score-bar-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;margin:0 20px 10px;padding:14px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.score-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.score-bar-row:last-child{margin-bottom:0}
.sbl{font-size:12px;color:#6b7280;width:110px;flex-shrink:0}
.sb-track{flex:1;height:5px;background:#f3f4f6;border-radius:99px;overflow:hidden}
.sb-fill{height:100%;border-radius:99px;transition:width .8s ease}
.sbv{font-size:11px;color:#9ca3af;width:32px;text-align:right;flex-shrink:0}
.section-cards{padding:0 20px;display:flex;flex-direction:column;gap:8px;margin-bottom:4px}
.wcard{border-radius:12px;padding:13px 15px;border:1.5px solid;cursor:pointer;margin-bottom:8px;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.pos-card{background:#fff;border:1.5px solid #bbf7d0;border-radius:11px;padding:12px 14px;margin-bottom:8px;display:flex;align-items:center;gap:12px}
.ing-card{border-radius:12px;padding:13px 15px;border:1.5px solid;margin-bottom:7px;cursor:pointer;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.ipill{font-size:9px;padding:2px 6px;border-radius:99px;font-weight:700}
.green-summary{background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:12px;padding:12px 15px;margin-bottom:10px;display:flex;align-items:center;gap:10px;cursor:pointer}
.qty-meter{margin-top:10px}
.qty-meter-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}
.qty-meter-name{font-size:11px;color:#6b7280}
.qty-meter-val{font-size:11px;font-family:monospace;font-weight:700}
.qty-track{height:6px;background:#f3f4f6;border-radius:99px;overflow:hidden}
.qty-fill{height:100%;border-radius:99px}
.qty-ticks{display:flex;justify-content:space-between;margin-top:3px}
.qty-tick{font-size:9px;color:#9ca3af}
.rescan-bar{margin:0 20px 12px;background:#fffbeb;border:1.5px solid #fde68a;border-radius:10px;padding:11px 13px;display:flex;gap:10px;align-items:center}
.rescan-btn{background:#f59e0b;border:none;border-radius:7px;padding:6px 10px;color:#fff;font-family:inherit;font-size:11px;font-weight:700;cursor:pointer;flex-shrink:0}
.eu-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 8px;border-radius:99px;background:#fef2f2;color:#dc2626;border:1px solid #fca5a5;margin-top:5px}
.diet-badges{display:flex;gap:6px;padding:0 20px 10px;flex-wrap:wrap}
.recipe-banner{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1.5px solid #86efac;border-radius:14px;padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;margin:0 20px 14px}
.recipe-banner:active{transform:scale(.98)}

/* ── HISTORY & LISTS ── */
.hist-item{background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;padding:13px 15px;display:flex;align-items:center;gap:12px;margin-bottom:8px;box-shadow:0 1px 3px rgba(0,0,0,.04);cursor:pointer}
.hist-item:active{transform:scale(.98);background:#f9fafb}
.hist-score{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;font-family:monospace;border:2.5px solid;flex-shrink:0}
.recipe-stat{flex:1;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;padding:10px;text-align:center}
.recipe-stat-val{font-size:15px;font-weight:700;color:#1a2e1a;margin-bottom:2px}
.recipe-stat-lbl{font-size:10px;color:#9ca3af;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.saved-recipe-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:14px;padding:16px;margin-bottom:10px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.saved-recipe-actions{display:flex;gap:8px;margin-top:12px}
.recipe-cook-btn{flex:1;background:#22c55e;border:none;border-radius:9px;padding:10px;color:#fff;font-family:inherit;font-size:13px;font-weight:700;cursor:pointer}
.recipe-list-btn{flex:1;background:#f0fdf4;border:1.5px solid #86efac;border-radius:9px;padding:10px;color:#15803d;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer}

/* ── GROCERY ── */
.grocery-group{margin-bottom:20px}
.grocery-group-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.grocery-group-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#16a34a}
.grocery-group-remove{font-size:11px;color:#9ca3af;background:none;border:none;cursor:pointer;font-family:inherit;text-decoration:underline;padding:0}
.grocery-item{background:#fff;border:1.5px solid #e5e7eb;border-radius:11px;padding:12px 15px;display:flex;align-items:center;gap:12px;margin-bottom:7px;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.grocery-item:active{transform:scale(.98)}
.grocery-item.done{background:#f9fafb}
.grocery-check{width:22px;height:22px;border-radius:50%;border:2px solid #d1d5db;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px;color:transparent}
.grocery-item.done .grocery-check{background:#22c55e;border-color:#22c55e;color:#fff}
.grocery-amount{font-size:12px;font-weight:600;color:#16a34a;margin-bottom:1px}
.grocery-name{font-size:14px;color:#1a2e1a;font-weight:500}
.grocery-item.done .grocery-name{text-decoration:line-through;color:#9ca3af}
.grocery-item.done .grocery-amount{color:#9ca3af}

/* ── SEARCH ── */
.search-bar{display:flex;gap:10px;margin-bottom:18px}
.search-in{flex:1;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;padding:11px 14px;color:#1a2e1a;font-family:inherit;font-size:14px;outline:none}
.search-in:focus{border-color:#22c55e}
.search-in::placeholder{color:#9ca3af}

/* ── MODALS ── */
.mbg{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:flex;align-items:flex-end;justify-content:center}
.modal{background:#fff;border-radius:20px 20px 0 0;padding:20px;width:100%;max-width:480px;max-height:88vh;overflow-y:auto;box-shadow:0 -4px 20px rgba(0,0,0,.1)}
.mhandle{width:32px;height:4px;background:#e5e7eb;border-radius:99px;margin:0 auto 16px}
.mclose{width:100%;background:#f3f4f6;border:none;border-radius:9px;padding:13px;color:#374151;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;margin-top:8px}
.msec-hdr{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#9ca3af;margin-bottom:6px}
.r-action-btn{width:100%;border-radius:9px;padding:14px;font-family:inherit;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:8px;border:none}
.r-action-green{background:#22c55e;color:#fff;box-shadow:0 2px 8px rgba(34,197,94,.25)}
.r-action-outline{background:#f0fdf4;border:1.5px solid #86efac;color:#15803d}
.report-btn{display:flex;align-items:center;gap:6px;background:none;border:none;color:#9ca3af;font-family:inherit;font-size:12px;cursor:pointer;padding:0;margin:16px auto 0;text-decoration:underline}
.disclaimer{padding:8px 20px 0;font-size:10px;color:#9ca3af;line-height:1.6;text-align:center}

/* ── ONBOARDING ── */
.ob-screen{display:none;flex-direction:column;min-height:100vh;background:#fff}
.ob-screen.active{display:flex}
.ob-progress{display:flex;gap:5px;padding:56px 24px 0}
.ob-prog-dot{flex:1;height:4px;border-radius:99px;background:#e5e7eb;transition:background .3s}
.ob-prog-dot.done{background:#22c55e}
.ob-content{flex:1;padding:28px 24px 0;display:flex;flex-direction:column}
.ob-emoji{font-size:52px;margin-bottom:18px}
.ob-title{font-size:24px;font-weight:800;letter-spacing:-.4px;color:#1a2e1a;margin-bottom:8px;line-height:1.2}
.ob-sub{font-size:14px;color:#6b7280;line-height:1.6;margin-bottom:28px}
.ob-options{display:flex;flex-direction:column;gap:9px;margin-bottom:24px}
.ob-opt{background:#fff;border:2px solid #e5e7eb;border-radius:13px;padding:14px 16px;cursor:pointer;display:flex;align-items:center;gap:12px;text-align:left;font-family:inherit;transition:all .15s;-webkit-user-select:none;user-select:none}
.ob-opt:active{transform:scale(.98)}
.ob-opt.selected{border-color:#22c55e;background:#f0fdf4}
.ob-opt-icon{font-size:22px;flex-shrink:0;width:36px;text-align:center}
.ob-opt-text{font-size:14px;font-weight:600;color:#1a2e1a}
.ob-opt-sub{font-size:11px;color:#6b7280;margin-top:1px}
.ob-check{width:22px;height:22px;border-radius:50%;border:2px solid #d1d5db;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-left:auto;font-size:12px;color:transparent;transition:all .15s}
.ob-opt.selected .ob-check{background:#22c55e;border-color:#22c55e;color:#fff}
.ob-tag-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.ob-tag{background:#f3f4f6;border:2px solid #e5e7eb;border-radius:99px;padding:9px 16px;cursor:pointer;font-size:13px;font-weight:600;color:#374151;font-family:inherit;transition:all .15s;-webkit-user-select:none;user-select:none}
.ob-tag:active{transform:scale(.95)}
.ob-tag.selected{background:#f0fdf4;border-color:#22c55e;color:#15803d}
.ob-footer{padding:20px 24px 44px;display:flex;flex-direction:column;gap:10px}
.ob-btn{background:#22c55e;border:none;border-radius:12px;padding:16px;color:#fff;font-family:inherit;font-size:16px;font-weight:700;cursor:pointer;width:100%;box-shadow:0 2px 10px rgba(34,197,94,.3);transition:transform .1s}
.ob-btn:active{transform:scale(.98)}
.ob-btn-ghost{background:none;border:none;color:#9ca3af;font-family:inherit;font-size:14px;cursor:pointer;padding:4px}
.ob-input{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:14px 16px;color:#1a2e1a;font-family:inherit;font-size:16px;width:100%;outline:none;margin-bottom:14px;transition:border-color .2s}
.ob-input:focus{border-color:#22c55e}
.ob-input::placeholder{color:#9ca3af}

/* ── SETTINGS ── */
.settings-section{margin-bottom:22px}
.settings-section-title{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#9ca3af;margin-bottom:10px;padding:0 20px}
.settings-row{background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;margin:0 20px 8px;padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.settings-row:active{background:#f9fafb}
.settings-row-icon{font-size:20px;flex-shrink:0;width:32px;text-align:center}
.settings-row-text{flex:1}
.settings-row-label{font-size:14px;font-weight:600;color:#1a2e1a}
.settings-row-sub{font-size:12px;color:#6b7280;margin-top:1px}
.settings-row-arrow{color:#d1d5db;font-size:14px}
.settings-toggle{width:44px;height:24px;border-radius:99px;background:#e5e7eb;border:none;cursor:pointer;position:relative;flex-shrink:0;transition:background .2s}
.settings-toggle.on{background:#22c55e}
.settings-toggle::after{content:'';position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.settings-toggle.on::after{transform:translateX(20px)}

/* ── PROFILES ── */
.profile-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:14px;margin:0 20px 10px;padding:15px 16px;display:flex;align-items:center;gap:14px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.profile-avatar{width:46px;height:46px;border-radius:50%;background:#f0fdf4;border:2px solid #86efac;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.profile-avatar.active-profile{border-color:#22c55e;background:#dcfce7;box-shadow:0 0 0 3px rgba(34,197,94,.2)}
.profile-name{font-size:14px;font-weight:700;color:#1a2e1a}
.profile-tags{font-size:11px;color:#6b7280;margin-top:2px}
.profile-active-badge{font-size:10px;font-weight:700;color:#16a34a;background:#f0fdf4;border:1px solid #86efac;padding:2px 8px;border-radius:99px;margin-left:auto;flex-shrink:0}

/* ── ALLERGEN WARNING ── */
.allergen-warn{display:flex;gap:8px;align-items:flex-start;background:#fff;border:1px solid #e5e7eb;border-left:3px solid #f59e0b;border-radius:8px;padding:8px 12px;margin-top:8px}
.allergen-warn-icon{font-size:13px;flex-shrink:0;margin-top:1px}
.allergen-warn-text{font-size:11px;color:#6b7280;line-height:1.5}

/* ── PAYWALL ── */
.paywall-screen{display:none;flex-direction:column;min-height:100vh;background:#fff}
.paywall-screen.active{display:flex}
.paywall-hero{background:linear-gradient(135deg,#f0fdf4,#dcfce7);padding:48px 24px 32px;text-align:center}
.paywall-badge{display:inline-flex;align-items:center;gap:6px;background:#22c55e;color:#fff;font-size:11px;font-weight:700;padding:5px 14px;border-radius:99px;margin-bottom:16px}
.paywall-title{font-size:26px;font-weight:800;letter-spacing:-.4px;color:#1a2e1a;margin-bottom:8px;line-height:1.2}
.paywall-sub{font-size:14px;color:#4b5563;line-height:1.6}
.paywall-features{padding:24px;display:flex;flex-direction:column;gap:12px}
.paywall-feature{display:flex;align-items:flex-start;gap:12px}
.paywall-feature-icon{font-size:20px;flex-shrink:0;margin-top:1px}
.paywall-feature-text{font-size:14px;color:#374151;line-height:1.5}
.paywall-feature-text strong{color:#1a2e1a;font-weight:700}
.paywall-cta{padding:0 24px 44px}
.paywall-price-card{background:#f0fdf4;border:2px solid #22c55e;border-radius:16px;padding:20px;text-align:center;margin-bottom:14px}
.paywall-price{font-size:34px;font-weight:800;color:#1a2e1a}
.paywall-price span{font-size:16px;font-weight:500;color:#6b7280}
.paywall-price-sub{font-size:13px;color:#16a34a;font-weight:600;margin-top:2px}

/* ── REVIEW PROMPT ── */
.review-prompt{position:fixed;bottom:88px;left:50%;transform:translateX(-50%);width:calc(100% - 40px);max-width:440px;background:#fff;border:1.5px solid #e5e7eb;border-radius:16px;padding:18px;box-shadow:0 4px 24px rgba(0,0,0,.12);z-index:150;display:none}
