:root{--tesco: #00539F;--dunnes: #00573F;--supervalu: #E31837;--aldi: #00358E;--bg: #f5f6f8;--bg-card: #ffffff;--bg-elevated: #ffffff;--bg-sidebar: #ffffff;--bg-input: #f0f1f4;--text: #1a1a2e;--text-secondary: #64748b;--text-muted: #94a3b8;--border: #e2e8f0;--border-hover: #cbd5e1;--accent: #6366f1;--accent-soft: #e0e7ff;--accent-hover: #4f46e5;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 1px 4px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .08);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .12);--radius: 14px;--radius-sm: 10px;--radius-xs: 6px;--green: #10b981;--green-soft: #d1fae5;--red: #ef4444;--orange: #f59e0b;--sidebar-w: 280px;--topbar-h: 56px;--tabs-h: 42px}[data-theme=dark]{--bg: #0a0a14;--bg-card: #12121e;--bg-elevated: #181828;--bg-sidebar: #0e0e1a;--bg-input: #1a1a2e;--text: #e8e8f0;--text-secondary: #9ca3af;--text-muted: #6b7280;--border: #1e1e32;--border-hover: #2d2d48;--accent: #818cf8;--accent-soft: rgba(99, 102, 241, .15);--accent-hover: #6366f1;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow: 0 1px 4px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .5);--green-soft: rgba(16, 185, 129, .15)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;-webkit-font-smoothing:antialiased;scroll-behavior:smooth}body{background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;transition:background .3s,color .3s}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.topbar{position:sticky;top:0;z-index:100;background:var(--bg-sidebar);border-bottom:1px solid var(--border);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);height:var(--topbar-h)}.topbar-inner{display:flex;align-items:center;gap:12px;max-width:1600px;margin:0 auto;padding:0 16px;height:100%}.topbar-brand{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--text);flex-shrink:0}.topbar-flag{font-size:1.4rem}.topbar-title{font-weight:800;font-size:1.1rem;letter-spacing:-.02em}.topbar-title .accent{color:var(--accent)}.topbar-search{flex:1;position:relative;max-width:560px}.topbar-search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.topbar-search input{width:100%;padding:9px 14px 9px 40px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.875rem;font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s}.topbar-search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.topbar-search input::placeholder{color:var(--text-muted)}.autocomplete-dropdown{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);max-height:350px;overflow-y:auto;z-index:200}.autocomplete-dropdown.show{display:block}.autocomplete-item{padding:10px 14px;cursor:pointer;font-size:.85rem;display:flex;align-items:center;gap:10px;transition:background .15s;border-bottom:1px solid var(--border)}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover,.autocomplete-item.active{background:var(--accent-soft)}.autocomplete-item .ac-store{font-size:.7rem;font-weight:600;padding:2px 6px;border-radius:4px;color:#fff;flex-shrink:0}.autocomplete-item .ac-price{margin-left:auto;font-weight:600;color:var(--green);flex-shrink:0}.ac-highlight{font-weight:700;color:var(--accent)}.topbar-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.topbar-btn{position:relative;display:flex;align-items:center;justify-content:center;width:38px;height:38px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all .2s}.topbar-btn:hover{background:var(--accent-soft);color:var(--accent)}.topbar-badge{position:absolute;top:2px;right:2px;min-width:18px;height:18px;padding:0 5px;background:var(--accent);color:#fff;font-size:.65rem;font-weight:700;border-radius:9px;display:flex;align-items:center;justify-content:center}[data-theme=dark] .icon-sun{display:none}[data-theme=dark] .icon-moon,[data-theme=light] .icon-sun{display:block}[data-theme=light] .icon-moon,.filter-toggle-btn{display:none}@media(max-width:768px){.filter-toggle-btn{display:flex}.topbar-actions #nav-list,.topbar-actions #nav-insights{display:none}}.view-tabs{display:flex;background:var(--bg-sidebar);border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none;position:sticky;top:var(--topbar-h);z-index:90}.view-tabs::-webkit-scrollbar{display:none}.view-tab{display:flex;align-items:center;gap:6px;padding:10px 20px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.825rem;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;transition:all .2s}.view-tab:hover{color:var(--text);background:var(--accent-soft)}.view-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-badge{background:var(--accent);color:#fff;font-size:.65rem;padding:1px 6px;border-radius:8px;font-weight:700}@media(max-width:768px){.view-tabs{display:none}}.app-layout{display:grid;grid-template-columns:var(--sidebar-w) 1fr;align-items:start}@media(max-width:768px){.app-layout{grid-template-columns:1fr}body{padding-bottom:72px}}.sidebar{grid-column:1;grid-row:1;position:sticky;top:calc(var(--topbar-h) + var(--tabs-h));max-height:calc(100vh - var(--topbar-h) - var(--tabs-h));overflow-y:auto;background:var(--bg-sidebar);border-right:1px solid var(--border);scrollbar-width:thin;z-index:10}.sidebar-inner{padding:16px}.filter-group{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.filter-group:last-of-type{border-bottom:none}.filter-group-title{display:flex;align-items:center;gap:8px;font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.store-checks{display:flex;flex-direction:column;gap:6px}.store-check{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--radius-xs);cursor:pointer;font-size:.85rem;font-weight:500;transition:background .15s}.store-check:hover{background:var(--accent-soft)}.store-check input{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.store-check-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.store-check-name{flex:1}.store-check-count{font-size:.7rem;color:var(--text-muted);font-weight:400}.filter-select{width:100%;padding:8px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:.85rem;font-family:inherit;cursor:pointer;outline:none;transition:border-color .2s}.filter-select:focus{border-color:var(--accent)}.search-filters-group{animation:fadeSlideIn .2s ease-out}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.search-facet{margin-bottom:12px}.facet-label{display:block;font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.facet-pills{display:flex;flex-wrap:wrap;gap:5px}.facet-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--bg-input);border:1px solid var(--border);border-radius:999px;color:var(--text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap;font-family:inherit}.facet-pill:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--text)}.facet-pill.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.facet-pill .facet-count{font-size:.65rem;opacity:.7;font-weight:400}.facet-pill.active .facet-count{opacity:.9}.clear-search-filters-btn{display:block;width:100%;padding:6px 12px;margin-top:8px;background:transparent;border:1px dashed var(--border);border-radius:var(--radius-xs);color:var(--text-muted);font-size:.75rem;font-family:inherit;cursor:pointer;transition:all .15s}.clear-search-filters-btn:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.toggle-check{display:flex;align-items:center;gap:10px;padding:5px 0;cursor:pointer;font-size:.85rem;color:var(--text-secondary)}.toggle-check input{display:none}.toggle-slider{width:36px;height:20px;background:var(--bg-input);border:1px solid var(--border);border-radius:10px;position:relative;transition:all .25s;flex-shrink:0}.toggle-slider:after{content:"";width:14px;height:14px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .25s;box-shadow:var(--shadow-sm)}.toggle-check input:checked+.toggle-slider{background:var(--accent);border-color:var(--accent)}.toggle-check input:checked+.toggle-slider:after{transform:translate(16px)}.price-range-inputs{display:flex;align-items:center;gap:8px}.price-input-wrap{flex:1;position:relative}.price-input-prefix{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:.8rem;font-weight:600}.price-input-wrap input{width:100%;padding:7px 10px 7px 26px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:.8rem;font-family:inherit;outline:none}.price-input-wrap input:focus{border-color:var(--accent)}.price-range-sep{color:var(--text-muted);font-size:.85rem}.sidebar-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:16px}.stat-item{text-align:center;padding:10px 4px;background:var(--bg-input);border-radius:var(--radius-xs)}.stat-value{display:block;font-size:1.1rem;font-weight:800;color:var(--accent)}.stat-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}@media(max-width:768px){.sidebar{position:fixed;top:0;left:0;bottom:0;width:300px;z-index:200;transform:translate(-100%);transition:transform .3s ease;height:100vh}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:190;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sidebar-overlay.show{display:block}}.content{grid-column:2;grid-row:1;min-height:calc(100vh - var(--topbar-h) - var(--tabs-h));min-width:0;overflow-x:hidden}.view{display:none}.view.active{display:block}.hero{text-align:center;padding:48px 20px 32px;max-width:700px;margin:0 auto}.hero-title{font-size:clamp(1.5rem,4vw,2.2rem);font-weight:800;line-height:1.2;letter-spacing:-.03em;margin-bottom:12px}.gradient-text{background:linear-gradient(135deg,var(--tesco),var(--supervalu),var(--dunnes),var(--aldi));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-sub{font-size:1rem;color:var(--text-secondary);margin-bottom:28px}.hero-cats{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}.hero-cat-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;color:var(--text);font-size:.825rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}.hero-cat-btn:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px)}.hero-cat-btn .cat-emoji{font-size:1.1rem}.breadcrumb-bar{background:var(--bg-card);border-bottom:1px solid var(--border);padding:10px 16px}.breadcrumb-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;gap:8px;font-size:.825rem;overflow-x:auto;white-space:nowrap}.crumb{color:var(--text-secondary);cursor:pointer;transition:color .15s}.crumb:hover{color:var(--accent)}.crumb:last-child{color:var(--text);font-weight:600;cursor:default}.crumb-sep{color:var(--text-muted);font-size:.75rem}.subcategory-bar{background:var(--bg-card);border-bottom:1px solid var(--border);padding:8px 16px;overflow-x:auto;scrollbar-width:none}.subcategory-bar::-webkit-scrollbar{display:none}.subcategory-pills{display:flex;gap:6px;max-width:1400px;margin:0 auto}.sub-pill{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:100px;color:var(--text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;font-family:inherit}.sub-pill:hover{border-color:var(--accent);color:var(--accent)}.sub-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.sub-pill .sub-count{font-size:.65rem;opacity:.7}.results-bar{padding:10px 16px;background:var(--bg);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.results-count{font-size:.9rem;font-weight:600;color:var(--text)}.results-count span{color:var(--accent);font-weight:800}.results-bar-spacer{flex:1}.results-view-toggle{display:flex;gap:2px}.view-mode-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-muted);cursor:pointer;transition:all .15s}.view-mode-btn:hover{color:var(--accent);border-color:var(--accent)}.view-mode-btn.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.results-grid{padding:16px;display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media(min-width:600px){.results-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1000px){.results-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1400px){.results-grid{grid-template-columns:repeat(4,1fr)}}.results-grid.list-mode{grid-template-columns:1fr;gap:8px}.results-grid.list-mode .product-card{flex-direction:row;align-items:center}.results-grid.list-mode .card-image{width:80px;height:80px;min-height:auto}.results-grid.list-mode .card-body{flex:1}.product-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .25s;display:flex;flex-direction:column}.product-card:hover{border-color:var(--accent);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-image{width:100%;min-height:140px;max-height:180px;object-fit:contain;background:var(--bg-input);padding:12px}.card-body{padding:14px;flex:1;display:flex;flex-direction:column}.card-header{margin-bottom:10px}.card-category{font-size:.7rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.03em;margin-bottom:4px}.card-name{font-size:.9rem;font-weight:600;line-height:1.35;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-prices{display:flex;flex-direction:column;gap:4px;margin-bottom:10px;flex:1}.price-tile{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:var(--radius-xs);background:var(--bg-input);transition:all .15s;position:relative}.price-tile.cheapest{background:var(--green-soft);border:1px solid var(--green)}.price-tile .store-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.price-tile .store-name{font-size:.8rem;font-weight:600;color:var(--text);min-width:65px}.price-tile .unit-price{font-size:.65rem;color:var(--text-muted);flex:1}.price-tile .price-val{font-size:.9rem;font-weight:700;color:var(--text)}.price-tile.cheapest .price-val{color:var(--green)}.price-tile .best-badge{position:absolute;top:-6px;right:6px;font-size:.55rem;font-weight:700;background:var(--green);color:#fff;padding:1px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.price-tile .offer-tag{font-size:.6rem;font-weight:600;color:var(--orange)}.card-savings{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;background:var(--green-soft);border:1px solid var(--green);border-radius:var(--radius-xs);font-size:.8rem;font-weight:700;color:var(--green);margin-bottom:8px}.card-actions{padding:0 14px 14px}.card-action-btn{width:100%;padding:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.8rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}.card-action-btn:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.card-action-btn.added{background:var(--green-soft);border-color:var(--green);color:var(--green)}.card-single .price-tile{background:transparent;padding:4px 0}.sb-header{padding:24px 16px 16px}.sb-header h2{font-size:1.3rem;font-weight:800}.sb-subtitle{color:var(--text-secondary);font-size:.9rem;margin-top:4px}.sb-controls{margin-top:12px}.sb-search{width:100%;max-width:400px;padding:8px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.85rem;font-family:inherit;outline:none}.sb-search:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.store-brand-grid{padding:0 16px 16px;display:grid;grid-template-columns:repeat(1,1fr);gap:12px}@media(min-width:600px){.store-brand-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1000px){.store-brand-grid{grid-template-columns:repeat(3,1fr)}}.sb-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .2s;display:flex;flex-direction:column}.sb-card:hover{border-color:var(--accent);box-shadow:var(--shadow-lg)}.sb-card-img{width:100%;height:120px;object-fit:contain;background:var(--bg-input);padding:10px}.sb-card-body{padding:12px}.sb-card-name{font-weight:600;font-size:.9rem;margin-bottom:8px}.sb-card-prices{display:flex;flex-direction:column;gap:4px}.sb-price-item{display:flex;align-items:center;gap:6px;font-size:.8rem}.sb-price-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sb-savings{margin-top:8px;font-size:.8rem;font-weight:700;color:var(--green)}.pagination-bar{display:flex;justify-content:center;align-items:center;gap:4px;padding:16px}.page-btn{min-width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:.85rem;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.page-btn:hover{border-color:var(--accent);color:var(--accent)}.page-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.page-btn:disabled{opacity:.4;cursor:default}.page-dots{padding:0 8px;color:var(--text-muted)}.list-section{max-width:900px;margin:0 auto;padding:24px 16px}.section-title{font-size:1.3rem;font-weight:800;margin-bottom:4px}.section-subtitle{color:var(--text-secondary);margin-bottom:20px}.empty-state{color:var(--text-muted);font-size:.9rem;padding:24px 0}.list-content{margin-bottom:24px}.list-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px}.list-item-name{flex:1;font-weight:500;font-size:.9rem}.list-item-price{font-weight:700;color:var(--green)}.list-item-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.2rem;padding:4px}.list-item-remove:hover{color:var(--red)}.list-panels{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:600px){.list-panels{grid-template-columns:1fr}}.glass-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.glass-card h3{font-size:1rem;font-weight:700;margin-bottom:12px}.smart-subtitle{font-size:.8rem;color:var(--text-muted);margin-bottom:12px}.cost-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.cost-bar-label{min-width:70px;font-size:.8rem;font-weight:600}.cost-bar-track{flex:1;height:24px;background:var(--bg-input);border-radius:var(--radius-xs);overflow:hidden}.cost-bar-fill{height:100%;border-radius:var(--radius-xs);display:flex;align-items:center;padding-left:8px;font-size:.75rem;font-weight:700;color:#fff;transition:width .5s ease}.cost-bar-value{min-width:50px;text-align:right;font-size:.85rem;font-weight:700}.insights-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:1200px;margin:0 auto;padding:16px}@media(max-width:768px){.insights-grid{grid-template-columns:1fr}}.insight-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.insight-bar-label{min-width:100px;font-size:.8rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.insight-bar-track{flex:1;height:20px;background:var(--bg-input);border-radius:var(--radius-xs);overflow:hidden}.insight-bar-fill{height:100%;border-radius:var(--radius-xs);transition:width .5s ease}.insight-bar-value{min-width:50px;text-align:right;font-size:.8rem;font-weight:600}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-sidebar);border-top:1px solid var(--border);z-index:100;padding-bottom:env(safe-area-inset-bottom,0px)}@media(max-width:768px){.mobile-nav{display:flex}}.mobile-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 0;background:none;border:none;color:var(--text-muted);font-size:.65rem;font-weight:500;cursor:pointer;transition:color .15s;font-family:inherit;position:relative}.mobile-nav-btn.active{color:var(--accent)}.mobile-badge{position:absolute;top:2px;right:calc(50% - 18px);min-width:16px;height:16px;padding:0 4px;background:var(--accent);color:#fff;font-size:.6rem;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center}.no-results{text-align:center;padding:48px 16px;grid-column:1 / -1}.no-results h3{font-size:1.1rem;margin-bottom:8px}.no-results p{color:var(--text-muted)}.loading-spinner{text-align:center;padding:60px 16px;color:var(--text-muted);font-size:1rem;grid-column:1 / -1}.toast-container{position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:999;display:flex;flex-direction:column;gap:8px;align-items:center}.toast{padding:10px 20px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);font-size:.85rem;font-weight:500;animation:toastIn .3s ease,toastOut .3s ease 2.7s}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0;transform:translateY(-10px)}}@media(max-width:768px){.app-layout{grid-template-columns:1fr}.content{grid-column:1}.view-tabs{overflow-x:auto;scrollbar-width:none}.view-tabs::-webkit-scrollbar{display:none}.sidebar-close-btn{display:flex;align-items:center;justify-content:center;position:absolute;top:12px;right:12px;width:32px;height:32px;background:var(--bg-input);border:1px solid var(--border);border-radius:50%;color:var(--text-secondary);font-size:1.1rem;cursor:pointer;z-index:10;transition:all .15s}.sidebar-close-btn:hover{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.sidebar-inner{position:relative;padding-top:48px}}@media(max-width:600px){:root{--topbar-h: 48px}.topbar-inner{padding:0 8px;gap:6px}.topbar-brand{gap:4px}.topbar-flag,.topbar-title{font-size:.9rem}.topbar-search input{font-size:.8rem;padding:6px 10px 6px 32px;height:34px}.topbar-search svg{left:8px;width:16px;height:16px}.topbar-btn{width:32px;height:32px}.results-grid{grid-template-columns:repeat(2,1fr)!important;padding:8px;gap:8px}.product-card{border-radius:var(--radius-sm)}.product-card:hover{transform:none}.card-image{min-height:80px;max-height:100px;padding:6px}.card-body{padding:8px}.card-header{margin-bottom:6px}.card-category{font-size:.55rem;margin-bottom:2px}.card-name{font-size:.72rem;line-height:1.25;-webkit-line-clamp:2;line-clamp:2}.price-tile{padding:3px 6px;gap:4px;border-radius:4px}.price-tile .store-dot{width:6px;height:6px}.price-tile .store-name{font-size:.65rem}.price-tile .unit-price{font-size:.55rem}.price-tile .offer-tag{font-size:.5rem;padding:1px 3px}.price-tile .price{font-size:.72rem}.price-tile .best-badge{font-size:.45rem;padding:1px 3px}.card-prices{gap:2px;margin-bottom:6px}.savings-bar{padding:4px 8px;font-size:.65rem;border-radius:4px}.add-to-list-btn{padding:5px 8px;font-size:.68rem}.results-bar{padding:6px 10px}.results-count{font-size:.8rem}.breadcrumb-inner{font-size:.75rem;padding:6px 10px}.hero{padding:24px 16px 20px}.hero-title{font-size:1.2rem}.hero-subtitle{font-size:.8rem}.content{padding-bottom:60px}.sidebar{width:260px!important}.dept-grid{grid-template-columns:repeat(2,1fr);gap:8px;padding:8px}.dept-card{padding:10px;font-size:.75rem}.results-grid.list-mode{grid-template-columns:1fr!important}.results-grid.list-mode .card-image{width:60px;height:60px}}
