/* CartWatch App v10.19 — Clean Blyyss-style UI */
#cwa-app-root{all:initial;display:block;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;font-size:15px;color:#0f172a;line-height:1.5}
#cwa-app-root *{box-sizing:border-box}

/* ── App section wrapper ── */
#cwa-app-section{background:#fff;border-radius:20px;border:1px solid #e2e8f0;box-shadow:0 8px 40px rgba(15,23,42,.08),0 2px 8px rgba(15,23,42,.04);overflow:hidden;position:relative}
#cwa-app-section::before{content:'';display:block;height:4px;background:linear-gradient(90deg,#16a34a,#22c55e,#4ade80)}
#cwa-app-section #cwa-app-root{padding:24px 24px 0}

/* ── Nav tabs ── */
#cwa-app-root #cw-nav{display:flex;gap:0;border-bottom:2px solid #f1f5f9;margin-bottom:20px}
#cwa-app-section #cwa-app-root #cw-nav{display:none!important}
#cwa-app-root .cw-nav-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:600;border:none;background:transparent;color:#94a3b8;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;white-space:nowrap}
#cwa-app-root .cw-nav-btn.on{color:#16a34a;border-bottom-color:#16a34a}
#cwa-app-root .cw-ai-banner{display:none;align-items:flex-start;gap:8px;background:#fefce8;border:1.5px solid #fde047;border-radius:10px;padding:10px 14px;margin-top:8px;font-size:13px;color:#854d0e;line-height:1.5}
#cwa-app-root .cw-ai-banner.active{display:flex!important}
#cwa-app-root .cw-ai-banner svg{flex-shrink:0;margin-top:1px;color:#ca8a04}
#cwa-app-root .cw-ai-banner-off{background:none;border:none;padding:0;font-size:13px;color:#16a34a;font-weight:600;cursor:pointer;text-decoration:underline;font-family:inherit}
#cwa-app-root .cw-ai-banner-off:hover{color:#15803d}
@media(max-width:600px){#cwa-app-root .cw-ai-banner{font-size:12px;padding:9px 12px}}
#cwa-app-root .cw-nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:#16a34a;color:#fff;border-radius:20px;font-size:10px;font-weight:700;margin-left:2px}

/* ── Compare view layout ── */
.cw-compare-view{display:flex;flex-direction:column;gap:12px;padding-bottom:0}

/* ── Location bar ── */
#cwa-app-root .cw-loc-bar{font-size:13px;color:#64748b;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;padding:9px 14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
#cwa-app-root .cw-loc-ok-bar{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac;color:#15803d;font-weight:500}
#cwa-app-root .cw-loc-btn{background:none;border:none;cursor:pointer;color:#16a34a;font-weight:600;font-size:13px;padding:0;text-decoration:underline}
#cwa-app-root .cw-loc-tip{font-size:12px;color:#94a3b8}
#cwa-app-root .cw-loc-ok{display:flex;align-items:center;gap:6px}

/* ── AI toggle ── */
#cwa-app-root .cw-ai-toggle{display:flex;align-items:center;gap:8px;flex-wrap:nowrap;font-size:13px;margin-bottom:8px}
#cwa-app-root .cw-ai-toggle .cw-ai-label{display:inline-flex;align-items:center;gap:6px;cursor:pointer;flex-shrink:0;font-size:13px;font-weight:700;color:#16a34a;text-transform:uppercase;letter-spacing:.06em}
#cwa-app-root .cw-ai-label-text{line-height:1}
#cwa-app-root .cw-ai-tip{font-size:12px;color:#9ca3af;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1}
#cwa-app-root .cw-ai-toggle input[type=checkbox]{width:15px;height:15px;accent-color:#16a34a;cursor:pointer;flex-shrink:0;margin:0}

/* ── Search bar ── */
#cwa-app-root .cw-search-wrap{position:relative;display:flex;align-items:center}
#cwa-app-root .cw-search-icon{position:absolute;left:16px;color:#94a3b8;pointer-events:none;flex-shrink:0}
#cwa-app-root #cw-search{width:100%;height:52px;padding:0 48px 0 48px;font-size:15px;border:1.5px solid #e2e8f0;border-radius:12px;outline:none;color:#0f172a;background:#f8fafc;transition:border .15s,box-shadow .15s;-webkit-appearance:none}
#cwa-app-root #cw-search::placeholder{color:#94a3b8}
#cwa-app-root #cw-search:focus{border-color:#16a34a;box-shadow:0 0 0 3px rgba(22,163,74,.1);background:#fff}
#cwa-app-root .cw-search-x{position:absolute;right:14px;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;color:#94a3b8;cursor:pointer;border-radius:6px;font-size:16px;padding:0}
#cwa-app-root .cw-search-x:hover{background:#f1f5f9;color:#64748b}

/* ── Category pills ── */
#cwa-app-root .cw-pills{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px;scrollbar-width:none}
#cwa-app-root .cw-pills::-webkit-scrollbar{display:none}
#cwa-app-root .cw-pill{flex-shrink:0;padding:6px 14px;font-size:12px;font-weight:600;border:1.5px solid #e2e8f0;border-radius:20px;background:#fff;color:#64748b;cursor:pointer;transition:all .15s;white-space:nowrap}
#cwa-app-root .cw-pill:hover{border-color:#16a34a;color:#16a34a}
#cwa-app-root .cw-pill.on{background:#16a34a;color:#fff;border-color:#16a34a}

/* ── Basket card ── */
#cwa-app-root .cw-basket-card{border:1.5px solid #e2e8f0;border-radius:14px;overflow:hidden;background:#fff;box-shadow:0 1px 4px rgba(15,23,42,.04)}
#cwa-app-root .cw-basket-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;cursor:pointer;user-select:none}
#cwa-app-root .cw-basket-left{display:flex;align-items:center;gap:10px}
#cwa-app-root .cw-basket-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#f0fdf4;border-radius:10px;color:#16a34a;flex-shrink:0}
#cwa-app-root .cw-basket-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 4px;background:#16a34a;color:#fff;border-radius:20px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}
#cwa-app-root .cw-basket-title{font-size:14px;font-weight:600;color:#0f172a}
#cwa-app-root .cw-basket-right{display:flex;align-items:center;gap:8px}
#cwa-app-root .cw-basket-del{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;color:#94a3b8;cursor:pointer;border-radius:6px;padding:0}
#cwa-app-root .cw-basket-del:hover{background:#fef2f2;color:#ef4444}
#cwa-app-root .cw-basket-chips{display:flex;flex-wrap:wrap;gap:6px;padding:0 16px 14px}
#cwa-app-root .cw-basket-items{border-top:1px solid #f1f5f9;padding:0 16px}

/* ── Basket item rows ── */
#cwa-app-root .cw-bitem{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid #f8fafc}
#cwa-app-root .cw-bitem:last-child{border-bottom:none}
#cwa-app-root .cw-bitem-info{flex:1;min-width:0}
#cwa-app-root .cw-bitem-name{display:block;font-size:13px;font-weight:600;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#cwa-app-root .cw-bitem-price{display:block;font-size:11px;color:#16a34a;font-weight:600;margin-top:2px}
#cwa-app-root .cw-bitem-qty{display:flex;align-items:center;gap:6px;flex-shrink:0}
#cwa-app-root .cw-qbtn{width:26px;height:26px;border-radius:8px;border:1.5px solid #e2e8f0;background:#fff;color:#64748b;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;line-height:1}
#cwa-app-root .cw-qbtn:hover{background:#f0fdf4;border-color:#16a34a;color:#16a34a}
#cwa-app-root .cw-qnum{font-size:13px;font-weight:700;color:#0f172a;min-width:18px;text-align:center}
#cwa-app-root .cw-rmbtn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;background:none;cursor:pointer;color:#cbd5e1;border-radius:6px;font-size:15px;padding:0}
#cwa-app-root .cw-rmbtn:hover{background:#fef2f2;color:#ef4444}

/* ── Chips ── */
#cwa-app-root .cw-chip{display:inline-block;padding:3px 10px;font-size:11px;font-weight:500;border-radius:20px;background:#f1f5f9;color:#475569;white-space:nowrap}
#cwa-app-root .cw-chip--more{background:#e2e8f0;color:#64748b}

/* ── Results area ── */
#cwa-app-root .cw-results-area{flex:1}
#cwa-app-root .cw-hint{text-align:center;padding:32px 16px;color:#94a3b8}
#cwa-app-root .cw-hint p{font-size:15px;font-weight:500;color:#475569;margin:8px 0 4px}
#cwa-app-root .cw-hint span{font-size:13px}
#cwa-app-root .cw-nores{color:#94a3b8;font-size:13px;text-align:center;padding:20px 0}
#cwa-app-root .cw-ai-thinking{display:flex;align-items:center;gap:10px;color:#64748b;font-size:14px;padding:20px 0}

/* ── Result rows (Blyyss-style) ── */
#cwa-app-root .cw-rlist{display:flex;flex-direction:column}
#cwa-app-root .cw-rrow{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1.5px solid #f1f5f9;border-radius:12px;margin-bottom:6px;cursor:pointer;transition:all .15s;background:#fff}
#cwa-app-root .cw-rrow:hover{border-color:#16a34a;background:#f0fdf4}
#cwa-app-root .cw-rrow.selected{border-color:#16a34a;background:#f0fdf4}
#cwa-app-root .cw-rcheck{width:28px;height:28px;border-radius:50%;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;background:#fff}
#cwa-app-root .cw-rrow.selected .cw-rcheck{background:#16a34a;border-color:#16a34a}
#cwa-app-root .cw-rinfo{flex:1;min-width:0}
#cwa-app-root .cw-rname{display:block;font-size:14px;font-weight:600;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#cwa-app-root .cw-rmeta{display:block;font-size:12px;color:#94a3b8;margin-top:2px}
#cwa-app-root .cw-rprice{font-size:13px;font-weight:700;color:#64748b;flex-shrink:0}
#cwa-app-root .cw-rrow.selected .cw-rprice{color:#16a34a}
#cwa-app-root .cw-sale{color:#dc2626;font-weight:700;font-size:11px}

/* ── Action bar (bottom of compare) ── */
#cwa-app-root .cw-action-bar{position:sticky;bottom:0;background:#fff;border-top:1.5px solid #f1f5f9;padding:14px 0 20px;display:flex;flex-direction:column;gap:10px;z-index:10;margin:0 -24px;padding-left:24px;padding-right:24px}
#cwa-app-root .cw-compare-btn{width:100%;height:52px;background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 16px rgba(22,163,74,.35);transition:all .2s;letter-spacing:.02em}
#cwa-app-root .cw-compare-btn:disabled{background:#e2e8f0;color:#94a3b8;box-shadow:none;cursor:not-allowed}
#cwa-app-root .cw-compare-btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(22,163,74,.4)}
#cwa-app-root .cw-upgrade-pill{display:block;text-align:center;padding:9px 16px;font-size:12px;font-weight:600;color:#15803d;background:#f0fdf4;border:1.5px solid #86efac;border-radius:10px;text-decoration:none;transition:all .15s}
#cwa-app-root .cw-upgrade-pill:hover{background:#dcfce7}

/* ── Results view ── */
#cwa-app-root .cw-res-wrap{padding:0 0 24px}
#cwa-app-root .cw-res-header{display:flex;align-items:center;gap:12px;padding:16px 0;border-bottom:2px solid #f1f5f9;margin-bottom:20px}
#cwa-app-root .cw-back-btn{display:flex;align-items:center;gap:4px;padding:7px 12px;font-size:13px;font-weight:600;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;color:#64748b;cursor:pointer;flex-shrink:0}
#cwa-app-root .cw-back-btn:hover{border-color:#16a34a;color:#16a34a}
#cwa-app-root .cw-res-title{flex:1;font-size:16px;font-weight:700;color:#0f172a}
#cwa-app-root .cw-res-count{font-size:12px;color:#94a3b8;white-space:nowrap}

/* ── Store totals grid ── */
#cwa-app-root .cw-totals-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
#cwa-app-root .cw-total-card{border:1.5px solid #e2e8f0;border-radius:14px;padding:14px;position:relative;background:#fff}
#cwa-app-root .cw-total-card.best{border-color:#16a34a;background:#f0fdf4}
#cwa-app-root .cw-best-badge{font-size:10px;font-weight:700;color:#16a34a;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
#cwa-app-root .cw-total-store{font-size:12px;font-weight:700;margin-bottom:4px}
#cwa-app-root .cw-total-amt{font-size:22px;font-weight:800;color:#0f172a;margin-bottom:2px}
#cwa-app-root .cw-total-vs{font-size:11px;color:#94a3b8;margin-bottom:8px}
#cwa-app-root .cw-stinfo{margin-top:8px;padding-top:8px;border-top:1px solid #f1f5f9}
#cwa-app-root .cw-stn{display:block;font-size:11px;font-weight:600;color:#374151}
#cwa-app-root .cw-sta{display:block;font-size:10px;color:#94a3b8;margin-top:1px}
#cwa-app-root .cw-sth{display:block;font-size:10px;color:#94a3b8}
#cwa-app-root .cw-stp{display:block;font-size:10px;color:#94a3b8}
#cwa-app-root .cw-mapbtn{display:inline-flex;align-items:center;gap:4px;margin-top:6px;font-size:10px;font-weight:600;color:#16a34a;text-decoration:none;padding:4px 8px;border:1px solid #86efac;border-radius:6px;background:#f0fdf4}

/* ── Split card ── */
#cwa-app-root .cw-split-card{border:1.5px solid #bfdbfe;border-radius:14px;padding:16px;margin-bottom:16px;background:linear-gradient(135deg,#eff6ff,#dbeafe)}
#cwa-app-root .cw-split-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
#cwa-app-root .cw-split-title{font-size:14px;font-weight:700;color:#1e40af}
#cwa-app-root .cw-split-save{font-size:13px;font-weight:700;color:#16a34a;background:#f0fdf4;border:1px solid #86efac;padding:3px 10px;border-radius:20px}
#cwa-app-root .cw-split-desc{font-size:13px;color:#374151;margin:0 0 10px}
#cwa-app-root .cw-split-stores{display:flex;gap:8px;flex-wrap:wrap}
#cwa-app-root .cw-split-chip{font-size:12px;font-weight:600;padding:4px 12px;border:1.5px solid;border-radius:20px}

/* ── Item breakdown ── */
#cwa-app-root .cw-breakdown{border:1.5px solid #f1f5f9;border-radius:14px;overflow:hidden;margin-bottom:16px}
#cwa-app-root .cw-breakdown-title{font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;padding:12px 16px;border-bottom:1px solid #f1f5f9;background:#f8fafc}
#cwa-app-root .cw-brow{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;border-bottom:1px solid #f8fafc}
#cwa-app-root .cw-brow:last-child{border-bottom:none}
#cwa-app-root .cw-brow-name{font-size:13px;font-weight:600;color:#0f172a;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#cwa-app-root .cw-brow-prices{display:flex;gap:10px;flex-shrink:0}
#cwa-app-root .cw-brow-p{display:flex;flex-direction:column;align-items:center;font-size:12px;font-weight:600;color:#94a3b8}
#cwa-app-root .cw-brow-p small{font-size:9px;font-weight:600;text-transform:uppercase;color:#cbd5e1;margin-bottom:1px}
#cwa-app-root .cw-brow-p.b small{color:inherit;opacity:.7}

/* ── Results actions ── */
#cwa-app-root .cw-res-actions{display:flex;gap:10px}
#cwa-app-root .cw-res-btn{flex:1;height:46px;border-radius:10px;font-size:13px;font-weight:700;border:1.5px solid #e2e8f0;background:#fff;color:#374151;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s}
#cwa-app-root .cw-res-btn:hover{border-color:#16a34a;color:#16a34a}
#cwa-app-root .cw-res-btn--primary{background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;border-color:transparent;box-shadow:0 2px 8px rgba(22,163,74,.25)}
#cwa-app-root .cw-res-btn--primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(22,163,74,.35);color:#fff}

/* ── Shopping list ── */
#cwa-app-root .cw-shop-wrap{padding:0 0 24px}
#cwa-app-root .cw-shop-store{border-radius:12px;border:1.5px solid #e2e8f0;overflow:hidden;margin-bottom:12px}
#cwa-app-root .cw-shop-store-name{font-size:13px;font-weight:700;padding:12px 16px;background:#f8fafc;border-bottom:1px solid #f1f5f9}
#cwa-app-root .cw-shop-item{display:flex;align-items:center;gap:10px;padding:11px 16px;border-bottom:1px solid #f8fafc}
#cwa-app-root .cw-shop-item:last-child{border-bottom:none}
#cwa-app-root .cw-shop-chk{display:flex;align-items:center;cursor:pointer}
#cwa-app-root .cw-shop-chk input{display:none}
#cwa-app-root .cw-shop-chk span{width:20px;height:20px;border:2px solid #e2e8f0;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
#cwa-app-root .cw-shop-chk input:checked+span{background:#16a34a;border-color:#16a34a}
#cwa-app-root .cw-shop-chk input:checked+span::after{content:'✓';color:#fff;font-size:11px;font-weight:700}
#cwa-app-root .cw-shop-item-name{flex:1;font-size:13px;font-weight:500;color:#0f172a}
#cwa-app-root .cw-shop-item-price{font-size:13px;font-weight:700;color:#64748b}
#cwa-app-root .cw-shop-sub{font-size:12px;font-weight:600;color:#64748b;text-align:right;padding:10px 16px;border-top:1px solid #f1f5f9;background:#f8fafc}
#cwa-app-root .cw-shop-total{border:1.5px solid #e2e8f0;border-radius:12px;overflow:hidden}
#cwa-app-root .cw-shop-total-row{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid #f8fafc;font-size:14px;color:#374151}
#cwa-app-root .cw-shop-total-row:last-child{border-bottom:none}
#cwa-app-root .cw-shop-total-row.bold{font-size:16px;font-weight:800;color:#0f172a;background:#f8fafc}

/* ── Lists view ── */
#cwa-app-root .cw-lists-wrap{padding:0 0 24px}
#cwa-app-root .cw-lists-empty{font-size:14px;color:#94a3b8;text-align:center;padding:24px 0;font-style:italic}
#cwa-app-root .cw-list-card{border:1.5px solid #e2e8f0;border-radius:14px;padding:16px;margin-bottom:10px;background:#fff}
#cwa-app-root .cw-list-card-hd{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}
#cwa-app-root .cw-list-card-name{font-size:14px;font-weight:700;color:#0f172a}
#cwa-app-root .cw-list-card-date{font-size:11px;color:#94a3b8}
#cwa-app-root .cw-list-chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}
#cwa-app-root .cw-list-card-acts{display:flex;gap:8px;flex-wrap:wrap}
#cwa-app-root .cw-list-btn{padding:8px 14px;font-size:12px;font-weight:600;border-radius:8px;border:1.5px solid #e2e8f0;background:#fff;color:#374151;cursor:pointer;transition:all .15s}
#cwa-app-root .cw-list-btn--primary{background:#16a34a;color:#fff;border-color:#16a34a}
#cwa-app-root .cw-list-btn--outline{border-color:#16a34a;color:#16a34a}
#cwa-app-root .cw-list-btn--danger{border-color:#fecaca;color:#ef4444}
#cwa-app-root .cw-list-btn:hover{opacity:.85}

/* ── Upgrade card ── */
#cwa-app-root .cw-upgrade-card{display:flex;flex-direction:column;gap:6px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1.5px solid #86efac;border-radius:14px;padding:18px 20px;margin-top:8px}
#cwa-app-root .cw-upgrade-card strong{font-size:15px;color:#15803d}
#cwa-app-root .cw-upgrade-card span{font-size:13px;color:#475569}

/* ── Recipes ── */
#cwa-app-root .cw-recipe-hd{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
#cwa-app-root .cw-recipe-title{font-size:17px;font-weight:800;color:#0f172a}
#cwa-app-root .cw-recipe-sub{font-size:12px;color:#94a3b8;margin-top:2px}
#cwa-app-root .cw-generate-btn{display:flex;align-items:center;gap:6px;padding:10px 18px;font-size:13px;font-weight:700;border:none;border-radius:10px;background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;cursor:pointer;box-shadow:0 2px 8px rgba(22,163,74,.25);flex-shrink:0}
#cwa-app-root .cw-form-grp{margin-bottom:16px}
#cwa-app-root .cw-form-lbl{display:block;font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
#cwa-app-root .cw-recipe-sel{width:100%;height:44px;padding:0 14px;font-size:14px;border:1.5px solid #e2e8f0;border-radius:10px;background:#f8fafc;color:#374151;outline:none;cursor:pointer}
#cwa-app-root .cw-recipe-card{border:1.5px solid #e2e8f0;border-radius:14px;overflow:hidden;margin-bottom:10px}
#cwa-app-root .cw-recipe-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;cursor:pointer;background:#f8fafc}
#cwa-app-root .cw-recipe-head:hover{background:#f1f5f9}
#cwa-app-root .cw-recipe-body{display:none;padding:0 16px 16px}
#cwa-app-root .cw-recipe-card.open .cw-recipe-body{display:block}
#cwa-app-root .cw-recipe-card.open .cw-recipe-chevron{display:inline-block;transform:rotate(180deg)}
#cwa-app-root .cw-recipe-name{display:block;font-size:14px;font-weight:700;color:#0f172a;margin-bottom:6px}
#cwa-app-root .cw-recipe-meta{display:flex;gap:6px;flex-wrap:wrap}
#cwa-app-root .cw-rpill{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;display:inline-block}
#cwa-app-root .cw-rpill.time{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}
#cwa-app-root .cw-rpill.diff{background:#f5f3ff;color:#7c3aed;border:1px solid #ddd6fe}
#cwa-app-root .cw-recipe-section{margin-top:14px}
#cwa-app-root .cw-recipe-stitle{display:block;font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
#cwa-app-root .cw-recipe-ing{font-size:13px;color:#374151;padding:4px 0;border-bottom:1px solid #f8fafc}
#cwa-app-root .cw-recipe-step{display:flex;gap:10px;margin-bottom:8px}
#cwa-app-root .cw-recipe-stepnum{width:22px;height:22px;border-radius:50%;background:#f0fdf4;color:#16a34a;border:1.5px solid #86efac;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
#cwa-app-root .cw-recipe-steptext{font-size:13px;color:#374151;line-height:1.5}

/* ── Family ── */
#cwa-app-root .cw-family-title{font-size:17px;font-weight:800;color:#0f172a;margin-bottom:12px}
#cwa-app-root .cw-family-desc{font-size:13px;color:#64748b;line-height:1.6;margin-bottom:14px}
#cwa-app-root .cw-family-row{display:flex;gap:10px;margin-bottom:10px}
#cwa-app-root .cw-family-input{flex:1;height:44px;padding:0 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;color:#0f172a;outline:none;background:#f8fafc}
#cwa-app-root .cw-family-input:focus{border-color:#16a34a}
#cwa-app-root .cw-family-status{border-radius:12px;padding:16px;margin-bottom:4px;display:flex;align-items:center;gap:12px}
#cwa-app-root .cw-family-status.pending{background:#fffbeb;border:1.5px solid #fde68a}
#cwa-app-root .cw-family-status.pending strong{display:block;color:#92400e;margin-bottom:4px}
#cwa-app-root .cw-family-status.pending p{font-size:13px;color:#78350f;margin:0}
#cwa-app-root .cw-family-status.active{background:#f0fdf4;border:1.5px solid #bbf7d0}
#cwa-app-root .cw-family-status.active strong{display:block;color:#15803d;margin-bottom:4px}
#cwa-app-root .cw-family-status.active p{font-size:13px;color:#374151;margin:0}
#cwa-app-root .cw-family-avatar{width:36px;height:36px;border-radius:50%;background:#16a34a;color:#fff;font-size:15px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* ── Auth prompt ── */
#cwa-app-root .cw-auth-prompt{text-align:center;padding:40px 20px;max-width:420px;margin:0 auto}
#cwa-app-root .cw-auth-prompt h2{font-size:20px;font-weight:700;color:#0f172a;margin:0 0 8px}
#cwa-app-root .cw-auth-prompt p{font-size:14px;color:#64748b;margin-bottom:24px;line-height:1.6}
#cwa-app-root .cw-btn-primary{display:flex;align-items:center;justify-content:center;padding:13px;font-size:15px;font-weight:600;border-radius:10px;background:#16a34a;color:#fff;text-decoration:none;border:none;cursor:pointer;transition:all .15s;width:100%;margin-bottom:10px}
#cwa-app-root .cw-btn-secondary{display:flex;align-items:center;justify-content:center;padding:13px;font-size:14px;font-weight:500;border-radius:10px;border:1.5px solid #e2e8f0;color:#1e293b;text-decoration:none;background:#fff;width:100%}

/* ── Spinner ── */
#cwa-app-root .cw-spinner{width:18px;height:18px;border:2.5px solid #e2e8f0;border-top-color:#16a34a;border-radius:50%;animation:cwSpin .7s linear infinite;flex-shrink:0}
@keyframes cwSpin{to{transform:rotate(360deg)}}

/* ── Toast ── */
.cw-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:#0f172a;color:#fff;font-size:13px;font-weight:600;padding:10px 20px;border-radius:24px;opacity:0;transition:all .25s;pointer-events:none;z-index:99999;white-space:nowrap}
.cw-toast.on{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── Account page styles (outside app root) ── */
.cwa-account{max-width:1200px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif}
.cwa-account__profile{background:linear-gradient(135deg,#0a1a0f,#0f2d1a);border-radius:14px;padding:20px 24px;display:flex;align-items:center;gap:16px;margin-bottom:16px;color:#fff}
.cwa-account__avatar{width:48px;height:48px;border-radius:50%;background:#16a34a;color:#fff;font-size:20px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cwa-account__name{font-size:16px;font-weight:700;color:#f1f5f9;margin-bottom:4px}
.cwa-account__email{font-size:13px;color:#94a3b8}
.cw-badge--green{background:#16a34a;color:#fff;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700}
.cw-badge--slate{background:rgba(255,255,255,.1);color:#94a3b8;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700}
.cwa-upgrade-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1.5px solid #86efac;border-radius:14px;padding:16px 20px;flex-wrap:wrap;margin-bottom:16px}
.cwa-upgrade-banner strong{display:block;color:#15803d;font-size:15px;font-weight:700}
.cwa-upgrade-banner span{font-size:13px;color:#475569}
.cw-btn--primary{background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;border:none;border-radius:10px;padding:9px 18px;font-size:13px;font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;box-shadow:0 2px 8px rgba(22,163,74,.25);transition:all .15s}
.cw-btn--sm{padding:7px 14px;font-size:12px}
.cwa-account__actions{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-bottom:16px}
.cwa-action-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:18px 12px;border:1.5px solid #e2e8f0;border-radius:14px;background:#fff;text-decoration:none;color:#374151;cursor:pointer;transition:all .15s;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:12px;font-weight:600;text-align:center}
.cwa-action-card:hover{border-color:#16a34a;color:#16a34a;background:#f0fdf4;transform:translateY(-1px)}
.cwa-action-card__icon{font-size:22px}
.cwa-action-card__count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:#16a34a;color:#fff;border-radius:20px;font-size:10px;font-weight:700;margin-left:3px}
.cwa-action-card--muted{color:#94a3b8}
.cwa-action-card--muted:hover{border-color:#fecaca;color:#ef4444;background:#fef2f2}
.cwa-account__section{background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;padding:20px 24px;margin-bottom:16px}
.cwa-account__section-header{margin-bottom:16px}
.cwa-account__section-header h2{font-size:16px;font-weight:700;color:#0f172a;margin:0}
.cwa-list-card{border:1.5px solid #e2e8f0;border-radius:12px;padding:16px;margin-bottom:10px;background:#fff}
.cwa-item-chip{font-size:11px;padding:3px 9px;border-radius:20px;background:#f1f5f9;color:#64748b;display:inline-block;font-weight:500}

/* ── Auth forms ── */
.cwa-auth-wrap{max-width:420px;margin:0 auto;padding:24px}
.cwa-register-form{display:flex;flex-direction:column;gap:14px}
.cwa-form-row--2col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cwa-form-group{display:flex;flex-direction:column;gap:6px}
.cwa-form-group label{font-size:13px;font-weight:600;color:#374151}
.cwa-form-group input{height:46px;padding:0 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;color:#0f172a;outline:none;background:#f8fafc}
.cwa-form-group input:focus{border-color:#16a34a;box-shadow:0 0 0 3px rgba(22,163,74,.1)}
.cwa-form-note{font-size:12px;color:#94a3b8;margin:0}
.cwa-form-terms{font-size:11px;color:#94a3b8;text-align:center;margin:0}
.cwa-auth-register{text-align:center;font-size:13px;color:#64748b}
.cwa-auth-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 14px;font-size:13px;color:#991b1b;margin-bottom:8px}
.cwa-auth-success{background:#f0fdf4;border:1px solid #86efac;border-radius:8px;padding:10px 14px;font-size:13px;color:#15803d}
.cwa-auth-divider{display:flex;align-items:center;gap:12px;color:#94a3b8;font-size:12px;margin:8px 0}
.cwa-auth-divider::before,.cwa-auth-divider::after{content:'';flex:1;border-top:1px solid #e2e8f0}
.cw-btn--block{width:100%;justify-content:center}

/* ── Back button ── */
#cwa-app-root .cw-backbtn{display:inline-flex;align-items:center;gap:6px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:8px;cursor:pointer;color:#64748b;font-size:13px;font-weight:600;padding:7px 14px;margin-bottom:20px;transition:all .15s}
#cwa-app-root .cw-backbtn:hover{border-color:#94a3b8;color:#374151;background:#f1f5f9}

/* ── Verdict card ── */
#cwa-app-root .cw-verdict{border-radius:16px;padding:24px 28px;margin-bottom:20px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1.5px solid #86efac}
#cwa-app-root .cw-vbadge{display:inline-flex;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;padding:4px 12px;border-radius:20px}
#cwa-app-root .cw-vbadge.split{color:#15803d;background:#fff;border:1.5px solid #86efac;box-shadow:0 1px 4px rgba(22,163,74,.15)}
#cwa-app-root .cw-vbadge.one{color:#1d4ed8;background:#fff;border:1.5px solid #93c5fd;box-shadow:0 1px 4px rgba(59,130,246,.15)}
#cwa-app-root .cw-vhl{font-size:21px;font-weight:800;color:#0f172a;margin-bottom:4px;display:block;letter-spacing:-.02em}
#cwa-app-root .cw-vsub{font-size:13px;color:#475569;margin-bottom:16px;display:block}
#cwa-app-root .cw-vnums{display:flex;align-items:baseline;gap:12px;margin-bottom:10px;flex-wrap:wrap}
#cwa-app-root .cw-vnum{display:flex;flex-direction:column}
#cwa-app-root .cw-vamt{font-size:36px;font-weight:900;letter-spacing:-.04em;color:#0f172a;line-height:1;display:block}
#cwa-app-root .cw-vlbl{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.06em;margin-top:4px;display:block}

/* ── Tax note ── */
#cwa-app-root .cw-tax-note{font-size:12px;color:#64748b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:9px 14px;margin-bottom:20px}

/* ── Totals bar ── */
#cwa-app-root .cw-totals-label{font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;display:block}
#cwa-app-root .cw-totals-bar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:0}
#cwa-app-root .cw-total-card{border:1.5px solid #e2e8f0;border-radius:12px 12px 0 0;padding:18px 16px 14px;text-align:center;background:#fff;border-bottom:none}
#cwa-app-root .cw-total-card.winner{border:2px solid #16a34a;border-bottom:none;background:linear-gradient(135deg,#f0fdf4,#fff)}
#cwa-app-root .cw-total-chain{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;margin-bottom:6px;display:block}
#cwa-app-root .cw-total-amount{font-size:24px;font-weight:900;letter-spacing:-.03em;color:#0f172a;display:block;margin-bottom:2px}
#cwa-app-root .cw-total-card.winner .cw-total-amount{color:#15803d}
#cwa-app-root .cw-total-badge{display:inline-block;font-size:10px;font-weight:700;color:#15803d;background:#dcfce7;border:1px solid #86efac;padding:3px 10px;border-radius:20px;margin-top:6px;margin-bottom:2px}
#cwa-app-root .cw-total-tax{font-size:11px;color:#94a3b8;display:block;margin-top:2px}

/* ── Store split cards ── */
#cwa-app-root .cw-sgrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:24px}
#cwa-app-root .cw-sc{border:1.5px solid #e2e8f0;border-radius:0 0 12px 12px;overflow:hidden;border-top:none}
#cwa-app-root .cw-sc.dim{opacity:.35}
#cwa-app-root .cw-sc.winner-col{border-color:#16a34a;border-top:none}
#cwa-app-root .cw-sch{padding:12px 14px;display:flex;justify-content:space-between;align-items:flex-start;gap:6px}
#cwa-app-root .cw-sch.sobeys{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-bottom:1px solid #86efac}
#cwa-app-root .cw-sch.superstore{background:linear-gradient(135deg,#fff1f2,#ffe4e6);border-bottom:1px solid #fecdd3}
#cwa-app-root .cw-sch.walmart{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-bottom:1px solid #bfdbfe}
#cwa-app-root .cw-scn{font-size:12px;font-weight:700;color:#0f172a;display:block}
#cwa-app-root .cw-scc{font-size:10px;color:#64748b;margin-top:2px;display:block;font-weight:500}
#cwa-app-root .cw-sct{font-size:17px;font-weight:800;color:#0f172a;text-align:right;flex-shrink:0;letter-spacing:-.02em}
#cwa-app-root .cw-scb{padding:12px 14px;background:#fff}
#cwa-app-root .cw-scr{display:flex;justify-content:space-between;align-items:baseline;padding:4px 0;border-bottom:1px solid #f8fafc;font-size:11px;color:#64748b;gap:6px}
#cwa-app-root .cw-scr:last-of-type{border-bottom:none}
#cwa-app-root .cw-sci{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}
#cwa-app-root .cw-scp{font-weight:700;color:#0f172a;flex-shrink:0;white-space:nowrap}
#cwa-app-root .cw-scbdg{font-size:10px;font-weight:700;color:#15803d;background:#f0fdf4;border:1px solid #86efac;padding:2px 8px;border-radius:6px;margin-top:8px;display:inline-block}

/* ── Store info card ── */
#cwa-app-root .cw-stinfo{border:1.5px solid #f1f5f9;border-radius:10px;padding:10px 14px;background:#f8fafc;margin-top:12px}
#cwa-app-root .cw-stn{font-size:13px;font-weight:700;color:#0f172a;display:block}
#cwa-app-root .cw-sta{font-size:12px;color:#64748b;display:block}
#cwa-app-root .cw-sth{font-size:11px;color:#94a3b8;margin-top:2px;display:block}
#cwa-app-root .cw-stp{font-size:11px;color:#94a3b8;display:block}
#cwa-app-root .cw-mapbtn{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:#15803d;background:#f0fdf4;border:1.5px solid #86efac;border-radius:8px;padding:6px 14px;text-decoration:none;margin-top:10px;transition:all .15s}
#cwa-app-root .cw-mapbtn:hover{background:#dcfce7}

/* ── Tax summary ── */
#cwa-app-root .cw-tax-summary{border-top:1.5px solid #f1f5f9;margin-top:8px;padding-top:8px}
#cwa-app-root .cw-tax-row{display:flex;justify-content:space-between;font-size:13px;color:#64748b;padding:5px 0;border-bottom:1px solid #f8fafc}
#cwa-app-root .cw-gtotal{display:flex;justify-content:space-between;align-items:center;padding:12px 0;font-size:16px;font-weight:800;color:#0f172a}
#cwa-app-root .cw-footnote{font-size:11px;color:#cbd5e1;display:block;margin-top:16px;text-align:center}

/* ── Trip choice ── */
#cwa-app-root .cw-trip-choice{margin:8px 0 24px}
#cwa-app-root .cw-trip-choice__label{font-size:16px;font-weight:800;color:#0f172a;margin-bottom:14px;letter-spacing:-.02em}
#cwa-app-root .cw-trip-choice__options{display:flex;flex-direction:column;gap:10px}
#cwa-app-root .cw-trip-btn{display:flex;align-items:center;gap:16px;padding:18px 20px;border-radius:14px;border:2px solid #e2e8f0;background:#fff;cursor:pointer;text-align:left;transition:all .15s;width:100%;box-shadow:0 1px 4px rgba(15,23,42,.04)}
#cwa-app-root .cw-trip-btn:hover{border-color:#16a34a;background:#f0fdf4;box-shadow:0 4px 16px rgba(22,163,74,.12);transform:translateY(-1px)}
#cwa-app-root .cw-trip-btn--recommended{border-color:#16a34a;background:linear-gradient(135deg,#f0fdf4,#fff);box-shadow:0 4px 16px rgba(22,163,74,.15)}
#cwa-app-root .cw-trip-btn--split:hover{border-color:#8b5cf6;background:#faf5ff;box-shadow:0 4px 16px rgba(139,92,246,.12)}
#cwa-app-root .cw-trip-btn__icon{font-size:2rem;flex-shrink:0}
#cwa-app-root .cw-trip-btn__title{display:block;font-size:15px;font-weight:700;color:#0f172a;margin-bottom:3px}
#cwa-app-root .cw-trip-btn__sub{display:block;font-size:13px;color:#64748b}

/* ── Shopping list ── */
#cwa-app-root .cw-shop-header{padding:20px 22px 18px;border-radius:16px;margin-bottom:20px;color:#fff}
#cwa-app-root .cw-shop-header--sobeys{background:linear-gradient(135deg,#16a34a,#166534)}
#cwa-app-root .cw-shop-header--superstore{background:linear-gradient(135deg,#dc2626,#9f1239)}
#cwa-app-root .cw-shop-header--walmart{background:linear-gradient(135deg,#2563eb,#1e40af)}
#cwa-app-root .cw-shop-header--split{background:linear-gradient(135deg,#0f172a,#1e293b)}
#cwa-app-root .cw-shop-header__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
#cwa-app-root .cw-shop-back{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.35);border-radius:8px;color:#fff;font-size:12px;font-weight:600;padding:6px 14px;cursor:pointer;transition:all .15s}
#cwa-app-root .cw-shop-back:hover{background:rgba(255,255,255,.3)}
#cwa-app-root .cw-shop-saved-badge{font-size:11px;font-weight:700;background:rgba(255,255,255,.2);padding:4px 12px;border-radius:20px;color:#fff}
#cwa-app-root .cw-shop-header__store{font-size:24px;font-weight:900;margin-bottom:4px;letter-spacing:-.03em}
#cwa-app-root .cw-shop-header__addr{font-size:12px;opacity:.75;margin-bottom:4px}
#cwa-app-root .cw-shop-header__meta{font-size:13px;opacity:.85;margin-bottom:12px}
#cwa-app-root .cw-shop-maps-btn{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.35);border-radius:8px;color:#fff;font-size:12px;font-weight:600;padding:7px 14px;text-decoration:none;transition:all .15s}
#cwa-app-root .cw-shop-maps-btn:hover{background:rgba(255,255,255,.3)}
#cwa-app-root .cw-shop-flyer-btn{background:rgba(255,255,255,.15);margin-left:8px}
#cwa-app-root .cw-shop-flyer-btn:hover{background:rgba(255,255,255,.28)}

/* Progress bar */
#cwa-app-root .cw-shop-progress{margin-bottom:20px}
#cwa-app-root .cw-shop-progress__bar{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin-bottom:8px}
#cwa-app-root .cw-shop-progress__fill{height:100%;background:linear-gradient(90deg,#16a34a,#22c55e);border-radius:4px;transition:width .4s ease}
#cwa-app-root .cw-shop-progress__text{font-size:12px;color:#64748b;font-weight:600}

/* Store section (split) */
#cwa-app-root .cw-shop-store-section{border:1.5px solid #e2e8f0;border-radius:14px;overflow:hidden;margin-bottom:16px;transition:opacity .3s;box-shadow:0 1px 4px rgba(15,23,42,.04)}
#cwa-app-root .cw-shop-store-section.done-store{opacity:.45}
#cwa-app-root .cw-shop-store-header{padding:16px 18px;display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
#cwa-app-root .cw-shop-store-header--sobeys{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-bottom:1px solid #86efac}
#cwa-app-root .cw-shop-store-header--superstore{background:linear-gradient(135deg,#fff1f2,#ffe4e6);border-bottom:1px solid #fecdd3}
#cwa-app-root .cw-shop-store-header--walmart{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-bottom:1px solid #bfdbfe}
#cwa-app-root .cw-shop-store-name{display:block;font-size:15px;font-weight:700;color:#0f172a}
#cwa-app-root .cw-shop-store-addr{display:block;font-size:11px;color:#64748b;margin-top:2px}
#cwa-app-root .cw-shop-store-total{display:block;font-size:20px;font-weight:900;color:#0f172a;text-align:right;letter-spacing:-.02em}
#cwa-app-root .cw-shop-store-left{display:block;font-size:11px;color:#64748b;margin-top:2px;text-align:right;font-weight:500}

/* Shopping items */
#cwa-app-root .cw-shop-items-list{padding:4px 0}
#cwa-app-root .cw-shop-item{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid #f8fafc;cursor:pointer;transition:background .1s;user-select:none;-webkit-user-select:none}
#cwa-app-root .cw-shop-item:last-child{border-bottom:none}
#cwa-app-root .cw-shop-item:active{background:#f0fdf4}
#cwa-app-root .cw-shop-check{width:28px;height:28px;border-radius:10px;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;background:#fff}
#cwa-app-root .cw-shop-check svg{opacity:0;color:#fff;transition:opacity .2s}
#cwa-app-root .cw-shop-item.done .cw-shop-check{background:#16a34a;border-color:#16a34a;box-shadow:0 2px 8px rgba(22,163,74,.3)}
#cwa-app-root .cw-shop-item.done .cw-shop-check svg{opacity:1}
#cwa-app-root .cw-shop-item.done .cw-shop-item-name{text-decoration:line-through;color:#94a3b8}
#cwa-app-root .cw-shop-item.done .cw-shop-item-price{color:#94a3b8}
#cwa-app-root .cw-shop-item-info{flex:1;min-width:0}
#cwa-app-root .cw-shop-item-name{display:block;font-size:15px;font-weight:500;color:#0f172a;transition:all .2s}
#cwa-app-root .cw-shop-item-cat{display:block;font-size:11px;color:#94a3b8;margin-top:2px}
#cwa-app-root .cw-shop-qty{color:#94a3b8;font-weight:400}
#cwa-app-root .cw-shop-item-price{font-size:15px;font-weight:700;color:#0f172a;flex-shrink:0;transition:all .2s}
#cwa-app-root .cw-shop-totals{border-top:2px solid #f1f5f9;margin-top:16px;padding-top:8px}

/* ── Saved lists card ── */
.cwa-list-card{border:1.5px solid #e2e8f0;border-radius:12px;padding:18px;background:#fff;box-shadow:0 1px 4px rgba(15,23,42,.04)}
.cwa-item-chip{font-size:11px;padding:3px 9px;border-radius:20px;background:#f1f5f9;color:#64748b;display:inline-block;font-weight:500}

/* ── Upgrade banner ── */
.cwa-upgrade-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1.5px solid #86efac;border-radius:14px;padding:16px 20px;flex-wrap:wrap}
.cwa-upgrade-banner strong{display:block;color:#15803d;font-size:15px;font-weight:700}
.cwa-upgrade-banner span{font-size:13px;color:#475569}
.cw-btn--primary{background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;border:none;border-radius:10px;padding:9px 18px;font-size:13px;font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;box-shadow:0 2px 8px rgba(22,163,74,.25);transition:all .15s}
.cw-btn--primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(22,163,74,.35)}
.cw-btn--sm{padding:7px 14px;font-size:12px}

/* ── Recipes ── */
#cwa-app-root .cw-recipe-thinking{display:flex;align-items:center;gap:10px;color:#64748b;font-size:14px;padding:24px 0}
#cwa-app-root .cw-recipe-spinner{width:20px;height:20px;border:2.5px solid #e2e8f0;border-top-color:#16a34a;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
#cwa-app-root .cw-recipe-card{border:1.5px solid #e2e8f0;border-radius:14px;overflow:hidden;margin-bottom:12px;box-shadow:0 1px 4px rgba(15,23,42,.04);transition:box-shadow .15s}
#cwa-app-root .cw-recipe-card:hover{box-shadow:0 4px 16px rgba(15,23,42,.08)}
#cwa-app-root .cw-recipe-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:16px 18px;cursor:pointer;background:#f8fafc;transition:background .15s}
#cwa-app-root .cw-recipe-head:hover{background:#f1f5f9}
#cwa-app-root .cw-recipe-body{display:none;padding:0 18px 18px}
#cwa-app-root .cw-recipe-card.open .cw-recipe-body{display:block}
#cwa-app-root .cw-recipe-card.open .cw-recipe-chevron{transform:rotate(180deg)}
#cwa-app-root .cw-recipe-name{font-size:15px;font-weight:700;color:#0f172a;display:block;margin-bottom:6px}
#cwa-app-root .cw-recipe-meta{display:flex;gap:6px;flex-wrap:wrap}
#cwa-app-root .cw-recipe-chevron{font-size:18px;color:#94a3b8;transition:transform .2s;flex-shrink:0}
#cwa-app-root .cw-rpill{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;display:inline-block}
#cwa-app-root .cw-rpill.time{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}
#cwa-app-root .cw-rpill.diff{background:#f5f3ff;color:#7c3aed;border:1px solid #ddd6fe}
#cwa-app-root .cw-recipe-section{margin-top:16px}
#cwa-app-root .cw-recipe-stitle{font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;display:block;margin-bottom:10px}
#cwa-app-root .cw-recipe-step{display:flex;gap:12px;margin-bottom:10px}
#cwa-app-root .cw-recipe-stepnum{width:24px;height:24px;border-radius:50%;background:#f0fdf4;color:#16a34a;border:1.5px solid #86efac;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}

/* ── Mobile ── */
@media(max-width:640px){
  #cwa-app-section #cwa-app-root{padding:16px 16px 0}
  #cwa-app-root .cw-action-bar{margin:0 -16px;padding-left:16px;padding-right:16px}
  #cwa-app-root .cw-basket-hd{padding:12px 14px}
  #cwa-app-root .cw-basket-chips{padding:0 14px 12px}

  /* Results view actions — stack vertically, full width */
  #cwa-app-root .cw-res-actions{flex-direction:column;gap:10px}
  #cwa-app-root .cw-res-btn{width:100%;height:50px;font-size:15px}

  /* Store totals — single column */
  #cwa-app-root .cw-totals-bar{grid-template-columns:1fr}
  #cwa-app-root .cw-sgrid{grid-template-columns:1fr}
  #cwa-app-root .cw-sc.dim{display:none}

  /* Trip buttons */
  #cwa-app-root .cw-trip-btn{padding:14px 16px}

  /* Shopping list */
  #cwa-app-root .cw-shop-header{border-radius:12px}
  #cwa-app-root .cw-shop-item{padding:12px 14px}
  #cwa-app-root .cw-shop-item-name{font-size:14px}

  /* Results/shopping views */
  #cw-view-results,#cw-view-shopping,#cw-view-lists,#cw-view-recipes,#cw-view-family{
    padding:0;max-height:none;overflow-y:visible;
  }

  /* Auth forms */
  .cwa-form-row--2col{grid-template-columns:1fr}
  #cwa-app-section{border-radius:12px}
}

/* ── Product images ─────────────────────────────────────────── */
.cw-rrow { align-items: center; }
.cw-rimg { flex-shrink: 0; width: 44px; height: 44px; border-radius: 8px; overflow: hidden; background: #f1f5f9; display: flex; align-items: center; justify-content: center; margin-right: 10px; }
.cw-rimg img { width: 100%; height: 100%; object-fit: contain; }
.cw-rimg-ph { width: 100%; height: 100%; background: #f1f5f9; display:flex;align-items:center;justify-content:center; }
.cw-rimg-ph::after{content:"🛒";font-size:18px}
.cw-scr { display: flex; align-items: center; gap: 8px; }
.cw-scr-img { flex-shrink: 0; width: 36px; height: 36px; border-radius: 6px; object-fit: contain; background: #f8fafc; }
.cw-scr-img-ph { flex-shrink: 0; width: 36px; height: 36px; border-radius: 6px; background: #f1f5f9; display:flex;align-items:center;justify-content:center; }
.cw-scr-img-ph::after{content:"🛒";font-size:14px}
