*{margin:0;padding:0;box-sizing:border-box}html{-webkit-tap-highlight-color:transparent;touch-action:manipulation}:focus-visible{outline:3px solid #667eea;outline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;background:#667eea;color:#fff;padding:8px 16px;z-index:10000;text-decoration:none;font-weight:600;border-radius:0 0 8px 0}.skip-link:focus{top:0}@media (prefers-reduced-motion:reduce){*,::after,::before{animation-duration:0s!important;animation-iteration-count:1!important;transition-duration:0s!important}.spinner{animation:none;border:3px solid #667eea}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:root,html.theme-light{--bg-primary:#ffffff;--bg-secondary:#f9f9f9;--bg-card:#f9f9f9;--text-primary:#333333;--text-secondary:#666666;--text-muted:#888888;--border-color:#e0e0e0;--shadow-color:rgba(0, 0, 0, 0.1);--accent:#667eea;--accent-hover:#5a6fd6}html.theme-dark{--bg-primary:#1a1a2e;--bg-secondary:#16213e;--bg-card:#1f2940;--text-primary:#e8e8e8;--text-secondary:#b0b0b0;--text-muted:#808080;--border-color:#2d3a4f;--shadow-color:rgba(0, 0, 0, 0.3)}html.theme-dark body{background:linear-gradient(135deg,#1a1a2e 0,#16213e 100%)}html.theme-dark .donation-banner,html.theme-dark .feedback-banner,html.theme-dark .filter-box,html.theme-dark .results,html.theme-dark .search-box{background:var(--bg-primary)}html.theme-dark .search-input{background:#2a3a52;color:#fff;border-color:#3d5070}html.theme-dark .search-input::placeholder{color:#9aa5b8}html.theme-dark .filter-group input,html.theme-dark .filter-group select{background:#2a3a52;color:#fff;border-color:#3d5070}html.theme-dark .product-card{background:var(--bg-card);border-color:var(--border-color)}html.theme-dark .product-name{color:var(--text-primary)}html.theme-dark .category-stats{background:var(--bg-primary)}html.theme-dark .custom-select-options,html.theme-dark .custom-select-trigger{background:#2a3a52;color:#fff;border-color:#3d5070}html.theme-dark .custom-select-option{color:#fff}html.theme-dark .custom-select-option:hover{background:#3d5070}html.theme-dark .filter-group>label,html.theme-dark .filter-group>span{color:#b8c5d6}html.theme-dark .results-header h2{color:#e8ecf2}html.theme-dark .results-header{border-bottom-color:#3d5070}html.theme-dark .results-count{color:#9aa5b8}@media (prefers-color-scheme:dark){html:not(.theme-light):not(.theme-dark){--bg-primary:#1a1a2e;--bg-secondary:#16213e;--bg-card:#1f2940;--text-primary:#e8e8e8;--text-secondary:#b0b0b0;--text-muted:#808080;--border-color:#2d3a4f;--shadow-color:rgba(0, 0, 0, 0.3)}body{background:linear-gradient(135deg,#1a1a2e 0,#16213e 100%)}.donation-banner,.feedback-banner,.filter-box,.results,.search-box{background:var(--bg-primary)}.search-input{background:#2a3a52;color:#fff;border-color:#3d5070}.search-input::placeholder{color:#9aa5b8}.filter-group input,.filter-group select{background:#2a3a52;color:#fff;border-color:#3d5070}.product-card{background:var(--bg-card);border-color:var(--border-color)}.product-name{color:var(--text-primary)}.results-header h2{color:var(--text-primary)}.filter-group>label,.filter-group>span{color:var(--text-secondary)}.results-header{border-bottom-color:var(--border-color)}.results-count{color:var(--text-muted)}.unit-price{background:var(--bg-secondary);color:var(--text-muted)}.donation-banner h3{color:var(--text-primary)}.donation-banner p{color:var(--text-secondary)}html:not(.theme-light) .custom-select-options,html:not(.theme-light) .custom-select-trigger{background:#2a3a52;color:#fff;border-color:#3d5070}html:not(.theme-light) .custom-select-option:hover{background:#3d5070}@media (max-width:480px){.header{background:linear-gradient(135deg,#1a1a2e 0,#16213e 100%)}}}body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);min-height:100vh;padding:20px;padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));padding-bottom:max(20px,env(safe-area-inset-bottom))}.container{max-width:1200px;margin:0 auto}.header{display:flex;flex-direction:column;color:#fff;transition:all .3s ease;position:sticky;top:0;z-index:100;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);padding:16px 20px 0 20px;margin:0 -20px 40px -20px}.header-row-brand{text-align:center;padding-bottom:8px;transition:opacity .2s;cursor:pointer;position:relative}.header-row-brand:hover{opacity:.85}.header h1,.header-row-brand .site-title{font-size:1.6em;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.2);transition:font-size .3s ease;display:inline}.header-tagline{font-size:.85em;opacity:.7;margin-left:.5em}.retailer-count-tooltip{border-bottom:1px dotted rgba(255,255,255,.5);cursor:default}.retailer-count-tooltip::after{content:"Albert Heijn · Aldi · DekaMarkt · Dirk · Ekoplaza · Hoogvliet · Jumbo · Lidl · PLUS · Vomar";position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%);background:rgba(30,30,60,.95);color:#fff;padding:8px 14px;border-radius:8px;font-size:.75em;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s ease;box-shadow:0 4px 12px rgba(0,0,0,.3);z-index:1000}.retailer-count-tooltip:hover::after{opacity:1}.header-reset{display:flex;align-items:center;gap:4px;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 16px;border-radius:20px;cursor:pointer;font-size:.9em;transition:background .2s,transform .2s,opacity .2s,visibility .2s;white-space:nowrap;visibility:hidden;opacity:0;pointer-events:none}.header-reset:hover{background:rgba(255,255,255,.3);transform:scale(1.02)}.header-reset:active{transform:scale(.98)}.header--filtered .header-row-brand{text-align:left}.header--filtered h1{font-size:1.4em}.header--filtered .header-tagline{display:none}.header--filtered .header-reset{visibility:visible;opacity:1;pointer-events:auto}.header--filtered .header-row-nav{display:none}.header-row-nav{display:none}@media (min-width:768px){.header-row-nav{display:flex;justify-content:space-between;align-items:center;padding:8px 0}}.header-nav{display:flex;gap:8px}.header-nav-link{color:#fff;text-decoration:none;font-weight:500;padding:6px 14px;border-radius:16px;background:rgba(255,255,255,.15);transition:background .2s;font-size:.85em}.header-nav-link:hover{background:rgba(255,255,255,.25)}.header-nav-link.active{background:rgba(255,255,255,.95);color:#667eea}.header-actions{display:flex;align-items:center;gap:8px}.list-toggle{position:relative;background:rgba(255,255,255,.2);border:none;color:#fff;padding:6px;border-radius:50%;cursor:pointer;font-size:1em;transition:background .2s,transform .2s;width:34px;height:34px;display:flex;align-items:center;justify-content:center}.list-toggle:hover{background:rgba(255,255,255,.35);transform:scale(1.05)}.list-toggle-badge{position:absolute;top:-4px;right:-4px;background:#e91e63;color:#fff;font-size:.6em;font-weight:700;min-width:16px;height:16px;padding:0 4px;border-radius:8px;display:flex;align-items:center;justify-content:center}.settings-toggle{background:rgba(255,255,255,.2);border:none;color:#fff;padding:6px;border-radius:50%;cursor:pointer;font-size:1em;transition:background .2s;width:34px;height:34px;min-width:34px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.settings-toggle:hover{background:rgba(255,255,255,.35)}.settings-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:9999;display:none;align-items:center;justify-content:center;padding:20px}.settings-overlay.active{display:flex}.settings-modal{position:relative;display:flex;flex-direction:column;background:var(--bg-primary,#fff);border-radius:16px;max-width:420px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color,#e0e0e0)}.settings-header h2{margin:0;font-size:1.2em;color:var(--text-primary,#333)}.settings-close{background:0 0;border:none;font-size:1.5em;cursor:pointer;padding:4px 8px;color:var(--text-muted,#888);border-radius:8px}.settings-close:hover{background:var(--bg-secondary,#f0f0f0)}.theme-options{display:flex;gap:8px}.theme-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:var(--bg-secondary,#f5f5f5);border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s}.theme-option:hover{background:var(--bg-card,#e8e8e8)}.theme-option[aria-pressed=true]{border-color:var(--accent,#667eea);background:rgba(102,126,234,.1)}.theme-option-icon{font-size:1.5em}.theme-option-label{font-size:.85em;color:var(--text-primary,#333)}html.theme-dark .theme-option{background:var(--bg-secondary,#2a3a52)}html.theme-dark .theme-option:hover{background:var(--bg-card,#3a4a62)}html.theme-dark .theme-option[aria-pressed=true]{background:rgba(102,126,234,.2)}.settings-body{padding:20px;padding-bottom:20px;flex:1}.settings-section{margin-bottom:28px;padding-bottom:28px;border-bottom:1px solid var(--border-color,#e0e0e0)}.settings-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.settings-label{font-weight:600;margin-bottom:8px;color:var(--text-primary,#333);display:block}.settings-section-desc{font-size:.9em;color:var(--text-muted,#888);margin-bottom:16px;line-height:1.5}.settings-sublabel{font-weight:400;font-size:.85em;color:var(--text-muted,#888)}.category-chips{display:flex;flex-wrap:wrap;gap:8px}.category-chip{padding:8px 14px;border:2px solid var(--border-color,#e0e0e0);border-radius:20px;background:var(--bg-secondary,#f9f9f9);color:var(--text-primary,#333);cursor:pointer;font-size:.9em;transition:all .2s}.category-chip:hover{border-color:var(--accent,#667eea)}.category-chip.selected{background:var(--accent,#667eea);border-color:var(--accent,#667eea);color:#fff}.category-chip.disabled{opacity:.5;cursor:not-allowed}.category-chip.disabled:hover{border-color:var(--border-color,#e0e0e0)}.retailer-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:2px solid var(--border-color,#e0e0e0);border-radius:20px;background:var(--bg-secondary,#f9f9f9);color:var(--text-primary,#333);cursor:pointer;font-size:.9em;transition:all .2s}.retailer-chip:hover{border-color:var(--accent,#667eea)}.retailer-chip.selected{background:var(--accent,#667eea);border-color:var(--accent,#667eea);color:#fff}.retailer-chip-logo{width:20px;height:20px;object-fit:contain;border-radius:4px}.settings-toggle-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0}.settings-toggle-row:first-child{padding-top:0}.settings-toggle-info{flex:1}.settings-toggle-title{font-weight:600;color:var(--text-primary,#333);margin-bottom:4px}.settings-toggle-desc{font-size:.85em;color:var(--text-muted,#888)}.toggle-switch{position:relative;width:50px;height:28px;flex-shrink:0;margin-left:12px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border-color,#ccc);transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.2)}.toggle-switch input:checked+.toggle-slider{background-color:var(--accent,#667eea)}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(22px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.notification-status{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:.85em}.notification-status.success{color:#27ae60}.notification-status.warning{color:#f39c12}.notification-status.error{color:#e74c3c}.settings-install-tip{color:#b0b0b0;font-size:.85em;margin:4px 0 12px 0;word-wrap:break-word;white-space:normal;background:0 0}.btn-test-notification{background:var(--accent,#667eea);color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.9em;margin-top:12px;transition:background .2s}.btn-test-notification:hover{background:var(--accent-hover,#5a6fd6)}.btn-test-notification:disabled{opacity:.5;cursor:not-allowed}.settings-divider{border-top:1px solid var(--card-border,#e5e7eb);margin:16px 0}.email-subscription-form{margin-top:12px}.email-input-row{display:flex;gap:8px}.email-input{flex:1;padding:10px 12px;border:1px solid var(--card-border,#e5e7eb);border-radius:6px;font-size:.95em;background:var(--bg-primary,#fff);color:var(--text-primary,#333)}.email-input:focus{outline:0;border-color:var(--accent,#667eea)}.btn-email-subscribe{background:var(--accent,#667eea);color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-size:.9em;white-space:nowrap;transition:background .2s}.btn-email-subscribe:hover{background:var(--accent-hover,#5a6fd6)}.btn-email-subscribe:disabled{opacity:.5;cursor:not-allowed}.email-status{margin-top:8px;padding:8px 12px;border-radius:6px;font-size:.85em}.email-status.success{background:#dcfce7;color:#166534}.email-status.error{background:#fee2e2;color:#dc2626}.email-verified-row{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#dcfce7;border-radius:6px;color:#166534}.email-verified-icon{font-size:1.1em}#emailVerifiedText{flex:1}.btn-email-unsubscribe{background:0 0;color:#666;border:1px solid #ccc;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:.85em}.btn-email-unsubscribe:hover{background:#f5f5f5}.btn-gdpr{padding:10px 16px;border-radius:8px;font-weight:500;font-size:.85em;cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s;border:none;display:inline-flex;align-items:center}.btn-gdpr:hover{transform:translateY(-2px)}.btn-gdpr-export{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#1a1a2e}.btn-gdpr-export:hover{box-shadow:0 4px 15px rgba(79,172,254,.4)}.btn-gdpr-delete{background:rgba(239,68,68,.15);color:#ef4444;border:1px solid rgba(239,68,68,.3)}.btn-gdpr-delete:hover{background:rgba(239,68,68,.25);box-shadow:0 4px 15px rgba(239,68,68,.2)}.list-panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:9998;display:none;opacity:0;transition:opacity .3s ease}.list-panel-overlay.active{display:block;opacity:1}.list-panel{position:fixed;bottom:0;left:0;right:0;background:var(--bg-primary,#fff);border-radius:20px 20px 0 0;max-height:70vh;z-index:9999;transform:translateY(100%);transition:transform .3s ease;display:flex;flex-direction:column;box-shadow:0 -10px 40px rgba(0,0,0,.2)}.list-panel.active{transform:translateY(0)}.list-panel-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color,#e0e0e0);flex-shrink:0}.list-panel-header h2{margin:0;font-size:1.1em;color:var(--text-primary,#333);display:flex;align-items:center;gap:8px}.list-panel-count{background:var(--bg-secondary,#f0f0f0);color:var(--text-muted,#666);font-size:.8em;padding:2px 8px;border-radius:12px}.list-panel-close{background:0 0;border:none;font-size:1.5em;cursor:pointer;padding:4px 8px;color:var(--text-muted,#888);border-radius:8px}.list-panel-close:hover{background:var(--bg-secondary,#f0f0f0)}.list-panel-content{flex:1;overflow-y:auto;padding:0}.list-empty{text-align:center;padding:40px 20px;color:var(--text-muted,#888)}.list-empty-icon{font-size:3em;margin-bottom:12px}.list-item{display:flex;align-items:center;padding:12px 20px;border-bottom:1px solid var(--border-color,#f0f0f0);gap:12px}.list-item.checked{opacity:.5}.list-item.checked .list-item-name{text-decoration:line-through}.list-item-checkbox{width:24px;height:24px;border:2px solid var(--border-color,#ccc);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.list-item-checkbox:hover{border-color:#667eea}.list-item.checked .list-item-checkbox{background:#4caf50;border-color:#4caf50;color:#fff}.list-item-image{width:40px;height:40px;border-radius:8px;object-fit:contain;background:var(--bg-secondary,#f5f5f5);flex-shrink:0}.list-item-info{flex:1;min-width:0}.list-item-name{font-weight:500;color:var(--text-primary,#333);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-item-meta{font-size:.85em;color:var(--text-muted,#888);display:flex;align-items:center;gap:8px}.list-item-quantity{display:flex;align-items:center;gap:8px;flex-shrink:0}.list-item-qty-btn{width:28px;height:28px;border:1px solid var(--border-color,#ddd);background:var(--bg-secondary,#f5f5f5);border-radius:6px;cursor:pointer;font-size:1.1em;display:flex;align-items:center;justify-content:center;color:var(--text-primary,#333)}.list-item-qty-btn:hover{background:var(--border-color,#e0e0e0)}.list-item-qty{min-width:20px;text-align:center;font-weight:600;color:var(--text-primary,#333)}.list-item-delete{width:32px;height:32px;border:none;background:0 0;cursor:pointer;color:#e53935;font-size:1.2em;border-radius:8px;display:flex;align-items:center;justify-content:center;opacity:.6;flex-shrink:0}.list-item-delete:hover{opacity:1;background:rgba(229,57,53,.1)}.list-item-img{width:48px;height:48px;border-radius:8px;object-fit:contain;background:var(--bg-secondary,#f5f5f5);flex-shrink:0}.list-item-img-placeholder{width:48px;height:48px;border-radius:8px;background:var(--bg-secondary,#f5f5f5);display:flex;align-items:center;justify-content:center;font-size:1.5em;flex-shrink:0}.list-item-retailer-logo{width:20px;height:20px;object-fit:contain;border-radius:3px}.list-item-remove{width:32px;height:32px;border:none;background:0 0;cursor:pointer;font-size:1.1em;border-radius:8px;display:flex;align-items:center;justify-content:center;opacity:.6;flex-shrink:0}.list-item-remove:hover{opacity:1;background:rgba(229,57,53,.1)}.list-item-clickable{cursor:pointer}.list-item-clickable:hover{background:var(--bg-secondary,#f5f5f5)}.list-item-link{color:var(--accent,#667eea);font-size:.85em}.list-item-price{font-weight:600;color:var(--accent,#667eea)}.list-btn-clear.confirm-pending{background:#ff9800;color:#fff;border-color:#ff9800}.list-panel-footer{padding:12px 20px;border-top:1px solid var(--border-color,#e0e0e0);display:flex;flex-direction:column;gap:12px;flex-shrink:0;padding-bottom:max(12px,env(safe-area-inset-bottom))}.list-total{display:flex;justify-content:space-between;align-items:center;font-size:1.1em;font-weight:600;padding:8px 0}.list-total-amount{color:var(--primary-color,#4caf50);font-size:1.2em}.list-footer-buttons{display:flex;gap:12px}.list-footer-buttons button{flex:1;padding:12px 16px;border-radius:10px;font-weight:600;cursor:pointer;font-size:.95em}.list-btn-clear{background:var(--bg-secondary,#f0f0f0);border:1px solid var(--border-color,#ddd);color:var(--text-primary,#333)}.list-btn-clear:hover{background:var(--border-color,#e0e0e0)}.list-btn-clear:disabled{opacity:.5;cursor:not-allowed}.list-btn-share{background:var(--accent,#667eea);border:1px solid var(--accent,#667eea);color:#fff}.list-btn-share:hover{opacity:.9}.list-btn-share:disabled{opacity:.5;cursor:not-allowed}.settings-toast{position:sticky;bottom:0;left:0;right:0;padding:14px 20px;font-size:.9em;text-align:center;border-radius:0 0 16px 16px;z-index:10;margin-top:auto}.settings-toast.info{background:#fff3cd;color:#856404;border-top:1px solid #ffc107}.settings-toast.success{background:#d4edda;color:#155724;border-top:1px solid #28a745}html.theme-dark .settings-toast.info{background:#3d3200;color:#ffc107;border-top-color:#ffc107}html.theme-dark .settings-toast.success{background:#1b3d2f;color:#81c784;border-top-color:#81c784}.toast-notification{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(100px);background:rgba(33,33,33,.95);color:#fff;padding:12px 24px;border-radius:8px;font-size:.9em;z-index:10000;opacity:0;transition:transform .3s ease,opacity .3s ease;box-shadow:0 4px 12px rgba(0,0,0,.3);max-width:90%;text-align:center}.toast-notification.show{transform:translateX(-50%) translateY(0);opacity:1}@media (max-width:480px){.toast-notification{bottom:90px}}.category-group{margin-bottom:16px}.category-group:last-child{margin-bottom:0}.category-group-header{font-size:.8em;font-weight:600;color:var(--text-muted,#888);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid var(--border-color,#e0e0e0)}.search-box{background:#fff;border-radius:15px;padding:20px;box-shadow:0 10px 30px rgba(0,0,0,.3);margin-bottom:12px}.search-input-wrapper{position:relative;display:flex;align-items:stretch}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #e0e0e0;border-top:none;border-radius:0 0 10px 10px;box-shadow:0 4px 12px rgba(0,0,0,.15);z-index:1000;max-height:300px;overflow-y:auto;display:none}.search-suggestions.active{display:block}.suggestion-section{padding:8px 0;border-bottom:1px solid #f0f0f0}.suggestion-section:last-child{border-bottom:none}.suggestion-section-title{font-size:.75em;color:#888;text-transform:uppercase;padding:4px 16px;font-weight:600}.suggestion-item{padding:10px 16px;cursor:pointer;display:flex;align-items:center;gap:10px;color:#333}.suggestion-item.selected,.suggestion-item:hover{background:#f5f5f5}.suggestion-item .icon{font-size:.9em;opacity:.5}.suggestion-item .text{flex:1}.suggestion-item .hint{font-size:.85em;color:#888}.suggestion-clear{font-size:.8em;color:#667eea;cursor:pointer;padding:4px 16px;text-align:right}.suggestion-clear:hover{text-decoration:underline}.voice-search-btn{position:absolute;right:100px;top:50%;transform:translateY(-50%);background:0 0;border:none;font-size:1.2em;cursor:pointer;padding:8px;border-radius:50%;transition:background .2s,transform .2s;z-index:1}.voice-search-btn:hover{background:rgba(0,0,0,.05)}.voice-search-btn.listening{background:#ffebee;animation:voice-pulse 1s ease-in-out infinite}.voice-search-btn.listening::after{content:'';position:absolute;inset:-4px;border:2px solid #c62828;border-radius:50%;animation:voice-ring 1s ease-out infinite}@keyframes voice-pulse{0%,100%{transform:translateY(-50%) scale(1)}50%{transform:translateY(-50%) scale(1.1)}}@keyframes voice-ring{0%{transform:scale(1);opacity:1}100%{transform:scale(1.3);opacity:0}}.voice-search-btn:disabled{opacity:.3;cursor:not-allowed}@media (max-width:480px){.voice-search-btn{right:70px;padding:6px;font-size:1.1em}}@media (prefers-color-scheme:dark){.voice-search-btn{filter:brightness(1.2)}.voice-search-btn:hover{background:rgba(255,255,255,.15)}.voice-search-btn.listening{background:rgba(198,40,40,.4);filter:brightness(1.3)}}@media (prefers-color-scheme:dark){.search-suggestions{background:var(--bg-card);border-color:var(--border-color)}.suggestion-item{color:var(--text-primary)}.suggestion-item.selected,.suggestion-item:hover{background:rgba(255,255,255,.1)}.suggestion-section{border-color:var(--border-color)}.suggestion-section-title{color:var(--text-secondary)}.suggestion-item .hint{color:var(--text-secondary)}.suggestion-clear{color:#8fa4d4}}.filter-box{background:#fff;border-radius:15px;padding:20px;box-shadow:0 10px 30px rgba(0,0,0,.3);margin-bottom:20px}.filter-box.inactive{display:none}.search-input{width:100%;padding:15px 50px 15px 20px;font-size:1.1em;border:2px solid #e0e0e0;border-radius:10px;outline:0;transition:border-color .3s;background:#fff;color:#333}.search-input::placeholder{color:#999}.search-input:focus{border-color:#667eea}.search-btn{position:absolute;right:5px;top:5px;bottom:5px;padding:0 25px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1em;transition:opacity .3s}.search-btn:hover{opacity:.9}.filters{display:flex;gap:15px;flex-wrap:wrap;align-items:center}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group>label,.filter-group>span{font-size:.9em;color:#666;font-weight:500}.dietary-filter-group{min-width:280px}.dietary-chips{display:flex;flex-wrap:wrap;gap:6px}.new-feature-badge{display:inline-block;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;font-size:.65em;font-weight:700;padding:2px 6px;border-radius:4px;margin-left:6px;text-transform:uppercase;letter-spacing:.5px;animation:pulse-badge 2s ease-in-out infinite;vertical-align:middle}@keyframes pulse-badge{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.05)}}html.theme-dark .new-feature-badge{background:linear-gradient(135deg,#7c3aed 0,#a855f7 100%)}.dietary-chip{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:var(--color-surface,#f5f5f5);border:1px solid var(--color-border,#ddd);border-radius:20px;color:#333;cursor:pointer;font-size:.85em;transition:all .2s ease;user-select:none}.dietary-chip:hover{background:#e8e8e8;border-color:#ccc}.dietary-chip:has(input:checked){background:var(--primary-color,#0077be);color:#fff;border-color:var(--primary-color,#0077be)}.dietary-chip input{display:none}.dietary-chip .chip-count{font-size:.8em;opacity:.7}.dietary-chip:has(input:checked) .chip-count{opacity:.9}html.theme-dark .dietary-chip{background:#2a3a52;border-color:#3d5070;color:#fff}html.theme-dark .dietary-chip:hover{background:#354a66;border-color:#4a6088}html.theme-dark .dietary-chip:has(input:checked){background:var(--primary-color,#0077be);border-color:var(--primary-color,#0077be)}@media (prefers-color-scheme:dark){html:not(.theme-light) .dietary-chip{background:#2a3a52;border-color:#3d5070;color:#fff}html:not(.theme-light) .dietary-chip:hover{background:#354a66;border-color:#4a6088}html:not(.theme-light) .dietary-chip:has(input:checked){background:var(--primary-color,#0077be);border-color:var(--primary-color,#0077be)}}.dietary-disclaimer{display:block;margin-top:6px;font-size:.75em;color:#888;font-style:italic}html.theme-dark .dietary-disclaimer{color:#999}.product-detail-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:10000;display:none;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px)}.product-detail-overlay.active{display:flex}.product-detail-modal{position:relative;display:flex;flex-direction:column;background:var(--bg-primary,#fff);border-radius:20px;max-width:480px;width:100%;max-height:90vh;overflow:hidden;box-shadow:0 25px 80px rgba(0,0,0,.4);animation:modalSlideUp .25s ease-out}@keyframes modalSlideUp{from{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.product-detail-close{position:absolute;top:12px;right:12px;width:36px;height:36px;background:rgba(0,0,0,.5);border:none;border-radius:50%;cursor:pointer;color:#fff;font-size:1.4em;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .2s}.product-detail-close:hover{background:rgba(0,0,0,.7)}.product-detail-image-container{position:relative;width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,#f8f9fa 0,#e9ecef 100%);overflow:hidden}html.theme-dark .product-detail-image-container{background:linear-gradient(135deg,#2a2a3e 0,#1a1a2e 100%)}.product-detail-image-container img{width:100%;height:100%;object-fit:contain;padding:20px}.product-detail-savings-badge{position:absolute;top:16px;left:16px;background:linear-gradient(135deg,#10b981 0,#059669 100%);color:#fff;padding:8px 14px;border-radius:20px;font-weight:700;font-size:1.1em;box-shadow:0 4px 12px rgba(16,185,129,.3)}.product-detail-content{padding:20px;overflow-y:auto}.product-detail-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.product-detail-retailer-logo{width:48px;height:48px;border-radius:12px;object-fit:contain;background:#f5f5f5;padding:4px;flex-shrink:0}html.theme-dark .product-detail-retailer-logo{background:#2a2a3e}.product-detail-title-block{flex:1;min-width:0}.product-detail-name{font-size:1.3em;font-weight:700;color:var(--text-primary,#333);margin:0 0 4px 0;line-height:1.3}.product-detail-brand{font-size:.95em;color:var(--text-muted,#666)}.product-detail-pricing{display:flex;align-items:baseline;gap:12px;margin-bottom:16px;flex-wrap:wrap}.product-detail-price{font-size:2em;font-weight:800;color:var(--primary-color,#0077be)}.product-detail-original-price{font-size:1.2em;color:var(--text-muted,#888);text-decoration:line-through}.product-detail-discount-amount{font-size:1em;color:#10b981;font-weight:500}.product-detail-quantity-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.product-detail-unit-price{font-size:.95em;color:var(--text-muted,#666);background:var(--bg-secondary,#f5f5f5);padding:4px 10px;border-radius:12px}.product-detail-quantity{font-size:1em;color:var(--text-muted,#666)}.product-detail-section{margin-bottom:16px}.product-detail-section-title{font-size:.85em;font-weight:600;color:var(--text-muted,#888);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.product-detail-dietary-tags{display:flex;flex-wrap:wrap;gap:8px}.product-detail-dietary-tag{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:linear-gradient(135deg,#e8f5e9 0,#c8e6c9 100%);color:#2e7d32;border-radius:20px;font-size:.9em;font-weight:600}html.theme-dark .product-detail-dietary-tag{background:linear-gradient(135deg,#1b5e20 0,#2e7d32 100%);color:#a5d6a7}.product-detail-promo{display:inline-block;padding:6px 12px;background:#ff6b6b;color:#fff;border-radius:6px;font-size:1em;font-weight:600}html.theme-dark .product-detail-promo{background:#ff6b6b;color:#fff}.product-detail-validity{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg-secondary,#f5f5f5);border-radius:12px;color:var(--text-muted,#666);font-size:.95em}.product-detail-validity.upcoming{background:linear-gradient(135deg,#e3f2fd 0,#bbdefb 100%);color:#1565c0}html.theme-dark .product-detail-validity{background:var(--bg-secondary,#2a2a3e)}html.theme-dark .product-detail-validity.upcoming{background:linear-gradient(135deg,#0d47a1 0,#1565c0 100%);color:#90caf9}.product-detail-actions{display:flex;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color,#e0e0e0)}.product-detail-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border:none;border-radius:12px;font-size:1em;font-weight:600;cursor:pointer;transition:all .2s}.product-detail-btn-primary{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff}.product-detail-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(102,126,234,.4)}.product-detail-btn-secondary{background:var(--bg-secondary,#f5f5f5);color:var(--text-primary,#333)}.product-detail-btn-secondary:hover{background:#4facfe;color:#fff}html.theme-dark .product-detail-btn-secondary{background:#2a2a3e;color:#e0e0e0}html.theme-dark .product-detail-btn-secondary:hover{background:#4facfe;color:#fff}.product-detail-btn svg{width:20px;height:20px}@media (max-width:480px){.product-detail-modal{max-height:95vh;border-radius:16px 16px 0 0;margin-top:auto}.product-detail-image-container{aspect-ratio:3/2}.product-detail-content{padding:16px}.product-detail-name{font-size:1.15em}.product-detail-price{font-size:1.7em}.product-detail-actions{flex-direction:column}}.filter-group input,.filter-group select{padding:8px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:.95em;outline:0;background:#fff;color:#333}.filter-group input:focus,.filter-group select:focus{border-color:#667eea}#categoryFilter{min-width:220px}.custom-select{position:relative;min-width:280px;width:280px}.custom-select-trigger{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;color:#333;cursor:pointer;font-size:.95em;transition:border-color .2s}.custom-select.open .custom-select-trigger,.custom-select:focus .custom-select-trigger{border-color:#667eea;outline:0}.custom-select-value{display:flex;align-items:center;gap:8px}.custom-select-value img{height:18px;width:auto}.custom-select-arrow{width:20px;height:20px;color:#666;transition:transform .2s}.custom-select.open .custom-select-arrow{transform:rotate(180deg)}.custom-select-options{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #667eea;border-radius:8px;margin-top:4px;box-shadow:0 4px 12px rgba(0,0,0,.15);z-index:1000;display:none;overflow:hidden}.custom-select.open .custom-select-options{display:block}.custom-select-option{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .15s;color:#333}.custom-select-option:hover{background:#f0f0ff}.custom-select-option.selected{background:#e8e0f0}.retailer-option-logo{height:20px;width:auto}.option-count{margin-left:auto;color:#667eea;font-weight:600;font-size:.9em}@media (prefers-color-scheme:dark){html:not(.theme-light) .custom-select-trigger{background:#2a3a52;color:#fff;border-color:#3d5070}html:not(.theme-light) .custom-select-options{background:#2a3a52;border-color:#667eea}html:not(.theme-light) .custom-select-option:hover{background:#3d5070}html:not(.theme-light) .custom-select-option.selected{background:#4a5a72}}html.theme-light .custom-select-trigger{background:#fff;color:#333;border-color:#e0e0e0}html.theme-light .custom-select-options{background:#fff;border-color:#667eea}html.theme-light .custom-select-option{color:#333}html.theme-light .custom-select-option:hover{background:#f0f0ff}html.theme-light .custom-select-option.selected{background:#e8e0f0}@media (max-width:768px){.custom-select-trigger{min-height:44px;font-size:16px}.custom-select-option{min-height:44px}}.results{background:#fff;border-radius:15px;padding:30px;box-shadow:0 10px 30px rgba(0,0,0,.3);min-height:200px}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid #e0e0e0}.results-header h2{color:#333;font-size:1.5em}.results-count{color:#666;font-size:.95em}.results-bar{display:none;justify-content:space-between;align-items:center;padding:12px 20px;background:#fff;border-radius:10px;box-shadow:0 4px 15px rgba(0,0,0,.1);margin-bottom:15px;gap:12px}.results-bar.visible{display:flex}.results-bar-count{font-size:.95em;color:#333;font-weight:500}.results-bar-sort{display:flex;align-items:center;gap:8px}.results-bar-sort label{font-size:.9em;color:#666;white-space:nowrap}.results-bar-sort select{padding:6px 10px;border:2px solid #e0e0e0;border-radius:8px;font-size:.9em;outline:0;cursor:pointer;background:#fff;color:#333;min-width:140px}.results-bar-sort select:focus{border-color:#667eea}html.theme-dark .results-bar{background:var(--card-bg);box-shadow:0 4px 15px rgba(0,0,0,.3)}html.theme-dark .results-bar-count{color:var(--text-primary)}html.theme-dark .results-bar-sort label{color:var(--text-secondary)}html.theme-dark .results-bar-sort select{background:var(--input-bg);border-color:var(--border-color);color:var(--text-primary)}.filter-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.filter-badge{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;padding:6px 12px;border-radius:20px;font-size:.85em;animation:fadeIn .2s ease}.filter-badge-label{opacity:.8;font-size:.9em}.filter-badge-remove{background:rgba(255,255,255,.2);border:none;color:#fff;width:24px;height:24px;min-width:24px;min-height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8em;padding:0;transition:background .2s}.filter-badge-remove:hover{background:rgba(255,255,255,.4)}@keyframes fadeIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.category-group{margin-bottom:30px;padding:20px;border-radius:15px}.category-group-header{font-size:1.3em;font-weight:600;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid rgba(255,255,255,.3)}.category-group-vers{background:linear-gradient(135deg,#e8f5e9 0,#c8e6c9 100%)}.category-group-vers .category-group-header,.category-group-vers .category-group-label{color:#2e7d32}.category-group-houdbaar{background:linear-gradient(135deg,#fff3e0 0,#ffe0b2 100%)}.category-group-houdbaar .category-group-header,.category-group-houdbaar .category-group-label{color:#e65100}.category-group-dranken{background:linear-gradient(135deg,#e3f2fd 0,#bbdefb 100%)}.category-group-dranken .category-group-header,.category-group-dranken .category-group-label{color:#1565c0}.category-group-overig{background:linear-gradient(135deg,#f5f5f5 0,#eee 100%)}.category-group-overig .category-group-header,.category-group-overig .category-group-label{color:#616161}html.theme-dark .category-group-vers{background:linear-gradient(135deg,#1b3d1f 0,#2e5932 100%)}html.theme-dark .category-group-vers .category-group-header,html.theme-dark .category-group-vers .category-group-label{color:#81c784}html.theme-dark .category-group-houdbaar{background:linear-gradient(135deg,#3d2914 0,#5d3f1f 100%)}html.theme-dark .category-group-houdbaar .category-group-header,html.theme-dark .category-group-houdbaar .category-group-label{color:#ffb74d}html.theme-dark .category-group-dranken{background:linear-gradient(135deg,#0d2340 0,#1a3a5c 100%)}html.theme-dark .category-group-dranken .category-group-header,html.theme-dark .category-group-dranken .category-group-label{color:#64b5f6}html.theme-dark .category-group-overig{background:linear-gradient(135deg,#2a2a2a 0,#3a3a3a 100%)}html.theme-dark .category-group-overig .category-group-header,html.theme-dark .category-group-overig .category-group-label{color:#bdbdbd}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin:32px 0;padding:16px}.pagination-btn{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1em;font-weight:500;cursor:pointer;transition:opacity .2s,transform .1s}.pagination-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.pagination-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.pagination-info{font-size:1em;color:#666;font-weight:500}.product-card{background:#f9f9f9;border:2px solid #e0e0e0;border-radius:12px;padding:20px;transition:transform .2s,box-shadow .2s;cursor:pointer;position:relative}.product-image-wrapper{width:100%;height:120px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;background:#fff;border-radius:8px;overflow:hidden;position:relative}.savings-badge{position:absolute;bottom:6px;right:6px;background:linear-gradient(135deg,#10b981 0,#059669 100%);color:#fff;font-size:.75em;font-weight:700;padding:3px 8px;border-radius:4px;box-shadow:0 2px 4px rgba(0,0,0,.15);z-index:1}.product-image{max-width:100%;max-height:100%;object-fit:contain}.product-image-placeholder{width:60px;height:60px;opacity:.3}.external-link-corner{position:absolute;top:10px;right:10px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);border-radius:8px;color:#fff;cursor:pointer;transition:background .2s,transform .2s,box-shadow .2s;border:none;padding:0;z-index:20;box-shadow:0 2px 8px rgba(0,0,0,.2)}.external-link-corner:hover{background:linear-gradient(135deg,#5a6fd6 0,#6a4092 100%);transform:scale(1.1);box-shadow:0 4px 12px rgba(102,126,234,.4)}.external-link-corner svg{width:18px;height:18px}html.theme-dark .external-link-corner{box-shadow:0 2px 8px rgba(0,0,0,.4)}.product-card:hover{transform:translateY(-5px);box-shadow:0 5px 15px rgba(0,0,0,.1);border-color:#667eea}.lowest-price-tag{display:inline-block;background:linear-gradient(135deg,#10b981 0,#059669 100%);color:#fff;font-size:.7em;font-weight:700;padding:2px 8px;border-radius:4px;margin-bottom:4px}.product-name{font-size:1.1em;font-weight:600;color:#333;margin-bottom:10px;line-height:1.4;padding-right:40px}.product-info{display:flex;justify-content:flex-start;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}.product-price{font-size:1.5em;font-weight:700;color:#667eea}.product-quantity{font-size:.9em;color:#666}.product-meta{display:flex;justify-content:flex-start;align-items:center;gap:10px;margin-top:10px}.badge{padding:4px 10px;border-radius:6px;font-size:.8em;font-weight:600;text-transform:uppercase}.retailer-logo{height:24px;width:auto;display:inline-block;vertical-align:middle}.retailer-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:.75em;font-weight:700;vertical-align:middle;background:#e0e0e0;color:#333}.retailer-jumbo{background:#ffd300;color:#000}.retailer-aldi{background:#fff200;color:#e31e24;border:2px solid #1e4a8d}.retailer-lidl{background:#0050aa;color:#fff200}.badge-score{background:#f3e5f5;color:#7b1fa2}.badge-upcoming{background:#fff3e0;color:#e65100;border:1px solid #ffb74d}.badge-active{background:#e8f5e9;color:#2e7d32}.badge-category{background:#f3e5f5;color:#7b1fa2;font-size:.7em;text-transform:none}.card-compare-link{display:block;text-align:center;font-size:.75em;color:var(--accent-color,#2196f3);text-decoration:none;padding:6px 0 2px;margin-top:4px;border-top:1px solid rgba(0,0,0,.06)}.category-stats{background:#fff;border-radius:15px;padding:20px 25px;box-shadow:0 10px 30px rgba(0,0,0,.3);margin-bottom:20px;min-height:350px}.category-stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.category-stats-header h2,.category-stats-header h3{color:#333;font-size:1.1em;margin:0}.category-stats-total{color:#667eea;font-weight:600;font-size:.95em}.category-stats-grid{display:flex;flex-wrap:wrap;gap:8px}.category-stat-chip{display:inline-flex;align-items:center;gap:4px;background:#f5f5f5;padding:6px 12px;border-radius:20px;font-size:.85em;color:#555;cursor:pointer;transition:all .2s;border:2px solid transparent}.category-stat-chip:hover{background:#e8e0f0;border-color:#667eea;transform:translateY(-1px)}.category-stat-chip .count{color:#3949ab;font-weight:600}.category-stats-loading{color:#888;text-align:center;padding:10px;display:flex;align-items:center;justify-content:center;min-height:inherit}.category-browse-group{padding:12px 15px;border-radius:12px;margin-bottom:10px}.category-browse-group:last-child{margin-bottom:0}.category-group-label{font-weight:600;font-size:.9em;margin-bottom:10px;padding-left:2px}html.theme-dark .category-browse-group .category-stat-chip{background:rgba(255,255,255,.1);color:#e0e0e0}html.theme-dark .category-browse-group .category-stat-chip:hover{background:rgba(255,255,255,.2)}html.theme-dark .category-stat-chip .count{color:#90caf9}.category-tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.category-tile{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;background:#f5f5f5;border-radius:12px;text-decoration:none;color:#333;transition:transform .15s,box-shadow .15s;text-align:center;cursor:pointer}.category-tile:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.category-tile-icon{font-size:1.6em}.category-tile-name{font-size:.8em;font-weight:600;line-height:1.2}.category-tile-count{font-size:.7em;color:#667eea;font-weight:600}html.theme-dark .category-tile{background:rgba(255,255,255,.1);color:#e0e0e0}html.theme-dark .category-tile:hover{background:rgba(255,255,255,.15)}@media (prefers-color-scheme:dark){html:not(.theme-light) .category-tile{background:rgba(255,255,255,.1);color:#e0e0e0}html:not(.theme-light) .category-tile:hover{background:rgba(255,255,255,.15)}}@media (max-width:480px){.category-tile-grid{grid-template-columns:repeat(3,1fr);gap:8px}.category-tile{padding:10px 6px}.category-tile-icon{font-size:1.4em}}.top-deals-section{margin-bottom:20px}.top-deals-carousel{background:#fff;border-radius:15px;padding:16px 20px;box-shadow:0 10px 30px rgba(0,0,0,.3);margin-bottom:16px}.deals-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.deals-header h2,.deals-header h3{color:#333;font-size:1.05em;margin:0}.section-heading{font-size:1.05em;font-weight:600}.deals-settings-link{background:0 0;border:none;color:#4facfe;font-size:.85em;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s}.deals-settings-link:hover{background:rgba(79,172,254,.1)}html.theme-dark .deals-settings-link{color:#90caf9}html.theme-dark .deals-settings-link:hover{background:rgba(144,202,249,.1)}.deals-scroll-container{display:flex;overflow-x:auto;gap:12px;padding:4px 0;scrollbar-width:none;min-height:180px;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.deals-scroll-container::-webkit-scrollbar{display:none}.deal-card{flex-shrink:0;width:140px;background:#f9f9f9;border:2px solid #e0e0e0;border-radius:12px;padding:12px;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;position:relative}.deal-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px rgba(0,0,0,.12);border-color:#667eea}.deal-badge{position:absolute;top:-8px;left:10px;background:linear-gradient(135deg,#ff6b6b 0,#ee5a24 100%);color:#fff;font-size:.75em;font-weight:700;padding:4px 8px;border-radius:10px;box-shadow:0 2px 4px rgba(238,90,36,.3)}.deal-badge.amount{background:linear-gradient(135deg,#10b981 0,#059669 100%);box-shadow:0 2px 4px rgba(16,185,129,.3)}.deal-image{width:100%;height:80px;object-fit:contain;margin-bottom:8px;border-radius:6px}.deal-image-placeholder{width:100%;height:80px;background:#e8e8e8;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:2em;color:#bbb;margin-bottom:8px}.deal-brand{font-size:.85em;font-weight:600;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.deal-promo-type{font-size:.7em;color:#667eea;font-weight:500;margin-bottom:4px}.deal-variant-count{font-size:.7em;color:#888}.deal-retailer-logo{position:absolute;bottom:8px;right:8px;width:24px;height:24px;border-radius:4px;object-fit:contain}.deal-card{text-decoration:none;color:inherit}.deal-price-row{display:flex;align-items:baseline;gap:4px;margin-top:2px}.deal-price{font-size:.85em;font-weight:700;color:#667eea}.deal-original-price{font-size:.7em;color:#999;text-decoration:line-through}.lowest-price-badge{position:absolute;top:-8px;right:10px;background:linear-gradient(135deg,#10b981 0,#059669 100%);color:#fff;font-size:.6em;font-weight:700;padding:3px 6px;border-radius:8px;white-space:nowrap}.hero-stats-banner{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;text-align:center;padding:10px 16px;border-radius:10px;font-size:.85em;margin-bottom:12px}.hero-stats-banner strong{font-weight:700}.deals-loading{color:#888;text-align:center;padding:20px;width:100%;align-self:center}.deals-empty{color:#888;text-align:center;padding:16px;font-size:.9em}html.theme-dark .top-deals-carousel{background:var(--bg-primary)}html.theme-dark .deals-header h2,html.theme-dark .deals-header h3{color:var(--text-primary)}html.theme-dark .deal-card{background:var(--bg-card);border-color:var(--border-color)}html.theme-dark .deal-brand{color:var(--text-primary)}html.theme-dark .deal-image-placeholder{background:var(--border-color)}@media (prefers-color-scheme:dark){html:not(.theme-light):not(.theme-dark) .top-deals-carousel{background:var(--bg-primary)}html:not(.theme-light):not(.theme-dark) .deal-card{background:var(--bg-card);border-color:var(--border-color)}html:not(.theme-light):not(.theme-dark) .deals-header h2,html:not(.theme-light):not(.theme-dark) .deals-header h3{color:var(--text-primary)}html:not(.theme-light):not(.theme-dark) .deal-brand{color:var(--text-primary)}}@media (max-width:480px){.top-deals-carousel{padding:12px 16px;border-radius:12px}.deal-card{width:120px;padding:10px}.deals-scroll-container{min-height:148px}.deal-image,.deal-image-placeholder{height:60px}.deal-badge{font-size:.7em;padding:3px 6px}}@media (prefers-color-scheme:dark){.category-stats{background:var(--bg-primary)}.category-stats-header h2,.category-stats-header h3{color:var(--text-primary)}.category-stat-chip{background:var(--bg-card);color:var(--text-secondary)}.category-stat-chip:hover{background:#2a3a52}.category-stat-chip .count{color:#90caf9}}@media (max-width:480px){.category-stats{padding:16px;min-height:420px}.category-stats-grid{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:4px;margin-right:-15px;padding-right:15px}.category-stats-grid::-webkit-scrollbar{display:none}.category-stat-chip{flex-shrink:0;font-size:.85em;padding:6px 10px;white-space:nowrap}}.mobile-category-chips{display:none}@media (max-width:480px){.mobile-category-chips{display:flex;overflow-x:auto;gap:8px;padding:4px 0;margin-top:10px;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.mobile-category-chips::-webkit-scrollbar{display:none}.mobile-category-chip{flex-shrink:0;display:flex;align-items:center;gap:4px;padding:8px 12px;background:#f0f4ff;border:1px solid #dde4f0;border-radius:20px;font-size:.85em;color:#333;cursor:pointer;transition:all .2s;white-space:nowrap}.mobile-category-chip .chip-count{font-size:.85em;color:#888}.mobile-category-chip.active .chip-count{color:rgba(255,255,255,.8)}.mobile-category-chip:active,.mobile-category-chip:hover{background:#e0e8ff;border-color:#667eea}.mobile-category-chip.active{background:#667eea;color:#fff;border-color:#667eea}.mobile-category-chip .chip-icon{font-size:1em}.filter-group:has(#categoryFilter){display:none}}@media (prefers-color-scheme:dark){.mobile-category-chip{background:var(--bg-card);border-color:#3a4a62;color:var(--text-primary)}.mobile-category-chip:active,.mobile-category-chip:hover{background:#2a3a52}.mobile-category-chip.active{background:#667eea;color:#fff}}.price-original{text-decoration:line-through;color:#999;font-size:.85em;margin-left:6px}.discount-amount{font-size:.85em;color:#10b981;font-weight:500;margin-left:4px}.product-info-secondary{display:flex;align-items:center;gap:8px;margin-top:4px}.unit-price{color:#888;font-size:.85em;background:#f0f0f0;padding:2px 6px;border-radius:4px;margin-left:auto}.vanaf-date{font-size:.8em;color:#e65100;font-weight:500}.promo-keywords{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px}.promo-keyword{background:#ff6b6b;color:#fff;padding:4px 10px;border-radius:4px;font-size:.75em;font-weight:600;white-space:nowrap;display:inline-block;line-height:1.4}.promo-keyword-albert_heijn{background:#ee8131}.promo-keyword-no-discount{background:#9ca3af;color:#fff}.promo-keyword-aldi{background:#fff200;color:#e31e24}.promo-keyword-jumbo{background:#d62e1f}.loading{text-align:center;padding:40px;color:#666}.spinner{border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 15px}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;padding:20px 0}.skeleton-card{background:#f9f9f9;border:2px solid #e0e0e0;border-radius:12px;padding:20px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-image{width:100%;height:120px;background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0 50%,#e0e0e0 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:8px;margin-bottom:12px}.skeleton-text{height:16px;background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0 50%,#e0e0e0 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:4px;margin-bottom:8px}.skeleton-text.short{width:60%}.skeleton-text.medium{width:80%}.skeleton-text.price{width:40%;height:24px}@keyframes skeleton-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}@keyframes skeleton-pulse{0%,100%{opacity:1}50%{opacity:.7}}@media (prefers-color-scheme:dark){.skeleton-card{background:var(--bg-card);border-color:var(--border-color)}.skeleton-image,.skeleton-text{background:linear-gradient(90deg,#2a3a52 25%,#3d5070 50%,#2a3a52 75%);background-size:200% 100%}}@media (max-width:480px){.skeleton-grid{grid-template-columns:1fr}}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.empty-state{text-align:center;padding:40px 20px;color:#666}.empty-state-icon{font-size:4em;margin-bottom:16px;opacity:.4}.empty-state h3{font-size:1.4em;margin-bottom:8px;color:#333}.empty-state p{margin-bottom:20px;color:#666}.empty-state-suggestions{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:16px}.empty-state-suggestion{background:#f0f4ff;border:1px solid #dde4f0;color:#667eea;padding:8px 16px;border-radius:20px;font-size:.9em;cursor:pointer;transition:all .2s}.empty-state-suggestion:hover{background:#667eea;color:#fff;border-color:#667eea}.empty-state-tip{margin-top:20px;padding:12px 16px;background:#fff8e1;border-radius:8px;font-size:.9em;color:#f57c00}.error-message{background:#ffebee;color:#c62828;padding:15px;border-radius:8px;margin-bottom:20px;border-left:4px solid #c62828}.maintenance-message{background:#e3f2fd;color:#1565c0;padding:20px;border-radius:12px;margin-bottom:20px;border-left:4px solid #1976d2;text-align:center}.maintenance-message h3{margin:0 0 10px 0;font-size:1.1rem}.maintenance-message p{margin:0;opacity:.9}.maintenance-spinner{display:inline-block;width:20px;height:20px;border:2px solid #1976d2;border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite;margin-right:10px;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.maintenance-retry-btn{margin-top:15px;padding:8px 20px;background:#1976d2;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem}.maintenance-retry-btn:hover{background:#1565c0}.footer{text-align:center;color:#fff;margin-top:40px;padding:20px;opacity:.9;font-size:.9em}.footer p{margin:5px 0}.footer-links{margin-bottom:20px}.footer-link{display:inline-flex;align-items:center;gap:8px;color:#333;text-decoration:none;padding:12px 24px;background:linear-gradient(135deg,#ff4500 0,#ff5722 100%);color:#fff;border-radius:25px;font-size:1em;font-weight:600;transition:all .3s;box-shadow:0 4px 15px rgba(255,69,0,.3)}.footer-link:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,69,0,.4)}.footer-link svg{width:18px;height:18px;fill:currentColor}.announcement-banner{background:linear-gradient(135deg,rgba(102,126,234,.12) 0,rgba(118,75,162,.12) 100%);border:1px solid rgba(102,126,234,.3);border-radius:12px;padding:12px 16px;margin-bottom:16px;display:flex;align-items:center;gap:8px;animation:announcementSlideIn .4s ease-out}@keyframes announcementSlideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.announcement-content{display:flex;align-items:center;gap:10px;flex:1;color:inherit;text-decoration:none;min-width:0}.announcement-content:hover{opacity:.85}.announcement-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.7em;font-weight:700;padding:3px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.announcement-text{font-size:.9em;color:#333}.announcement-arrow{font-size:1.1em;opacity:.5;flex-shrink:0}.announcement-close{background:0 0;border:none;color:#999;font-size:1em;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .2s;flex-shrink:0}.announcement-close:hover{background:rgba(0,0,0,.08);color:#666}html.theme-dark .announcement-banner{background:linear-gradient(135deg,rgba(102,126,234,.15) 0,rgba(118,75,162,.15) 100%);border-color:rgba(102,126,234,.25)}html.theme-dark .announcement-text{color:var(--text-primary)}html.theme-dark .announcement-close{color:var(--text-secondary)}.feedback-banner{background:rgba(255,255,255,.95);border-radius:12px;padding:16px 20px;box-shadow:0 4px 15px rgba(0,0,0,.2);margin-top:40px;margin-bottom:0;text-align:center}.feedback-banner .footer-links{margin-bottom:0}.donation-banner{background:rgba(255,255,255,.95);border-radius:12px;padding:20px;box-shadow:0 4px 15px rgba(0,0,0,.2);margin-top:16px;margin-bottom:25px;text-align:center}.donation-banner h3{color:#333;font-size:1.1em;margin-bottom:8px}.donation-banner p{color:#666;margin:6px 0;line-height:1.5;font-size:.9em}.btn-donate{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#fd0 0,#ffc800 100%);color:#333;padding:10px 20px;border-radius:8px;text-decoration:none;font-weight:600;font-size:.95em;margin-top:12px;transition:all .3s;box-shadow:0 3px 10px rgba(255,200,0,.3)}.btn-donate:hover{transform:translateY(-2px);box-shadow:0 5px 15px rgba(255,200,0,.4)}.coffee-icon{font-size:1.2em}.product-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid #e0e0e0}.btn-alternatives,.btn-view-retailer{flex:1;padding:10px 16px;border:none;border-radius:6px;font-size:.9em;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}.btn-view-retailer{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff}.btn-view-retailer:hover:not(.btn-disabled){transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.4)}.btn-share{position:absolute;bottom:10px;right:10px;background:rgba(102,126,234,.1);border:none;color:#667eea;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:2}.product-card .btn-alternatives{position:absolute;bottom:10px;right:52px;background:rgba(16,185,129,.1);border:none;color:#10b981;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:2}.product-card .btn-alternatives:hover{background:#10b981;color:#fff;transform:scale(1.1)}.product-card .btn-alternatives svg{width:20px;height:20px}.btn-back{display:inline-flex;align-items:center;padding:10px 20px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.95em;font-weight:500;transition:transform .2s,box-shadow .2s}.btn-back:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.4)}.btn-share:hover{background:#667eea;color:#fff;transform:scale(1.1)}.btn-share svg{width:18px;height:18px}.no-share .btn-share{display:none}.btn-favorite{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.9);border:none;color:#ccc;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:3;box-shadow:0 2px 4px rgba(0,0,0,.1)}.btn-favorite:hover{transform:scale(1.1);color:#e91e63}.btn-favorite.favorited{color:#e91e63;background:rgba(233,30,99,.1)}.btn-favorite.favorited svg{fill:#e91e63}.btn-favorite svg{width:18px;height:18px}html.theme-dark .btn-favorite{background:rgba(30,30,30,.9);color:#666}html.theme-dark .btn-favorite:hover{color:#e91e63}html.theme-dark .btn-favorite.favorited{color:#e91e63;background:rgba(233,30,99,.2)}.btn-add-to-list{position:absolute;top:10px;left:48px;background:rgba(255,255,255,.9);border:none;color:#888;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:5;box-shadow:0 2px 4px rgba(0,0,0,.1)}.btn-add-to-list:hover{transform:scale(1.1);color:#667eea}.btn-add-to-list.added{color:#4caf50;background:rgba(76,175,80,.1)}.btn-add-to-list svg{width:18px;height:18px}html.theme-dark .btn-add-to-list{background:rgba(30,30,30,.9);color:#666}html.theme-dark .btn-add-to-list:hover{color:#667eea}html.theme-dark .btn-add-to-list.added{color:#4caf50;background:rgba(76,175,80,.2)}.btn-view-retailer.btn-disabled{background:#e0e0e0;color:#999;cursor:not-allowed;transform:none}.btn-alternatives{background:#fff;color:#667eea;border:2px solid #667eea}.btn-alternatives:hover{background:#f5f5ff;transform:translateY(-2px)}.external-icon{opacity:.9}.toast{position:fixed;bottom:20px;right:20px;background:#333;color:#fff;padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.3);z-index:10000}@keyframes slideIn{from{transform:translateX(400px);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes slideOut{from{transform:translateX(0);opacity:1}to{transform:translateX(400px);opacity:0}}.scroll-top{position:fixed;bottom:30px;right:30px;width:48px;height:48px;background:var(--accent);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px var(--shadow-color);opacity:0;visibility:hidden;transition:all .3s ease;z-index:9999}.scroll-top.visible{opacity:1;visibility:visible}.scroll-top:hover{transform:translateY(-3px);box-shadow:0 6px 16px var(--shadow-color)}.scroll-top svg{width:24px;height:24px}@media (max-width:768px){.header h1{font-size:1.5em}.header--filtered h1{font-size:1.3em}.filters{display:grid;grid-template-columns:1fr 1fr;gap:10px}.dietary-filter-group{grid-column:1/-1}.filter-group input,.filter-group select{min-height:44px;font-size:16px}.product-grid{grid-template-columns:repeat(2,1fr);gap:16px}.product-actions{flex-direction:column}.btn-alternatives,.btn-view-retailer{width:100%;min-height:44px}.search-input{font-size:16px}.search-btn{min-height:44px;padding:0 20px}.toast{left:20px;right:20px;bottom:max(20px,env(safe-area-inset-bottom))}}@media (max-width:600px) and (min-width:481px){.product-grid{grid-template-columns:repeat(2,1fr);gap:12px}.product-card{padding:12px}.product-name{font-size:.95em}}@media (max-width:480px){body{padding:12px;padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right));padding-bottom:max(12px,env(safe-area-inset-bottom))}.header{position:fixed;top:0;left:0;right:0;z-index:100;margin:0;padding:10px 12px;padding-top:max(10px,env(safe-area-inset-top));background:linear-gradient(135deg,#667eea 0,#764ba2 100%);border-radius:0;box-shadow:0 2px 10px rgba(0,0,0,.2)}.container{padding-top:60px}.header h1,.header-row-brand .site-title{font-size:1.3em}.header-row-brand{white-space:nowrap}.header-tagline{display:none}.reset-text{display:none}.header-reset{padding:8px 12px}.search-box{padding:12px;border-radius:12px;margin-bottom:8px}.filter-box{padding:12px;border-radius:12px;margin-bottom:12px}.category-stats{margin-bottom:12px}.filters{gap:10px}.product-grid{grid-template-columns:1fr}.filter-group>label,.filter-group>span{font-size:.7em;text-transform:uppercase;letter-spacing:.5px;color:#888;margin-bottom:2px}.filter-group{flex:1;min-width:0}.custom-select-trigger,.filter-group select{font-size:.85em!important}.custom-select{min-width:0;width:100%}.custom-select-value{font-size:.85em}.custom-select-value img{height:16px}.dietary-filter-group{min-width:100%}.dietary-chip{padding:4px 10px;font-size:.8em}.category-stats{transition:max-height .3s ease,opacity .3s ease,margin .3s ease,padding .3s ease;overflow:hidden}.category-stats.collapsed{max-height:0;opacity:0;margin:0;padding:0}.search-input{padding:12px 16px;padding-right:80px}.search-btn{padding:0 12px;font-size:.85em;top:50%;bottom:auto;transform:translateY(-50%);height:calc(100% - 24px);right:8px}.results{padding:16px;border-radius:12px}.results-header{flex-direction:column;gap:8px;align-items:flex-start}.results-header h2{font-size:1.25em}.product-card{padding:16px}.product-name{font-size:1em}.product-price{font-size:1.3em}.pagination{flex-direction:row;gap:8px;padding:12px 8px}.pagination-btn{padding:8px 14px;font-size:.8em}.pagination-info{font-size:.8em;white-space:nowrap}.feedback-banner{padding:12px 16px;margin-top:24px}.donation-banner{padding:16px;margin-top:12px}.btn-donate{width:100%;justify-content:center}.footer-link{width:100%;justify-content:center}.results-bar{padding:10px 14px;border-radius:8px;margin-bottom:10px}.results-bar-sort{position:relative}.results-bar-sort label{display:none}.results-bar-sort::before{content:'↕️';position:absolute;left:8px;top:50%;transform:translateY(-50%);font-size:.8em;pointer-events:none;z-index:1}.results-bar-sort select{min-width:140px;font-size:.85em;padding:8px 10px 8px 28px;border:2px solid #667eea;background:#f8f9ff;border-radius:20px;font-weight:500;color:#333}html.theme-dark .results-bar-sort select{background:#2a3a52;border-color:#667eea;color:#e0e0e0}.results-bar-count{font-size:.9em}}@media (max-width:375px){.header h1,.header-row-brand .site-title{font-size:1.15em}.search-input{padding-right:90px}.search-btn{padding:0 12px;font-size:.85em}.product-meta{flex-wrap:wrap}.promo-keyword{font-size:.7em}}.shortcut-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:9998;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.shortcut-overlay.visible{opacity:1;visibility:visible}.shortcut-sheet{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:20px 20px 0 0;padding:24px;padding-bottom:max(24px,env(safe-area-inset-bottom));z-index:9999;transform:translateY(100%);transition:transform .3s ease;box-shadow:0 -4px 20px rgba(0,0,0,.15);max-width:500px;margin:0 auto}.shortcut-sheet.visible{transform:translateY(0)}.shortcut-handle{width:40px;height:4px;background:#ddd;border-radius:2px;margin:0 auto 20px}.shortcut-icon{width:64px;height:64px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:32px}.shortcut-title{font-size:1.3em;font-weight:700;text-align:center;margin-bottom:8px;color:#333}.shortcut-subtitle{text-align:center;color:#666;margin-bottom:20px;line-height:1.5}.shortcut-instructions{background:#f8f9fa;border-radius:12px;padding:16px;margin-bottom:20px}.shortcut-step{display:flex;align-items:center;gap:12px;margin-bottom:12px}.shortcut-step:last-child{margin-bottom:0}.shortcut-step-num{width:28px;height:28px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9em;flex-shrink:0}.shortcut-step-text{color:#333;font-size:.95em}.shortcut-buttons{display:flex;flex-direction:column;gap:10px}.shortcut-btn-primary{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;border:none;padding:14px 24px;border-radius:12px;font-size:1em;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.shortcut-btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.4)}.shortcut-btn-secondary{background:0 0;color:#666;border:none;padding:12px 24px;border-radius:12px;font-size:.95em;cursor:pointer}.shortcut-btn-secondary:hover{background:#f0f0f0}.shortcut-dismiss{text-align:center;margin-top:8px}.shortcut-dismiss-link{color:#999;font-size:.85em;text-decoration:underline;cursor:pointer;background:0 0;border:none}.shortcut-dismiss-link:hover{color:#666}.shortcut-btn-primary.native-install{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);font-size:1.1em;padding:14px 28px;animation:pulse 2s infinite}@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(102,126,234,.4)}50%{box-shadow:0 0 0 10px rgba(102,126,234,0)}}.bottom-nav{display:none}@media (max-width:768px){.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e0e0e0;padding:12px 0 8px 0;padding-bottom:max(16px,calc(8px + env(safe-area-inset-bottom)));z-index:100;justify-content:space-around;box-shadow:0 -2px 10px rgba(0,0,0,.1)}.bottom-nav-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 10px;background:0 0;border:none;color:#666;font-size:.7em;cursor:pointer;transition:color .2s;-webkit-tap-highlight-color:transparent;min-height:44px;min-width:48px;text-decoration:none}.bottom-nav-item.active{color:#667eea}.bottom-nav-item:active{transform:scale(.95)}.bottom-nav-icon{font-size:1.6em}.bottom-nav-icon svg{width:24px;height:24px}.list-badge{position:absolute;top:0;left:50%;margin-left:6px;background:#e91e63;color:#fff;font-size:.65em;font-weight:700;min-width:16px;height:16px;padding:0 4px;border-radius:8px;display:flex;align-items:center;justify-content:center}body{padding-bottom:max(85px,calc(75px + env(safe-area-inset-bottom)))}.scroll-top{display:none}}@media (max-width:768px) and (prefers-color-scheme:dark){html:not(.theme-light) .bottom-nav{background:var(--bg-primary);border-color:var(--border-color)}html:not(.theme-light) .bottom-nav-item{color:var(--text-secondary)}html:not(.theme-light) .bottom-nav-item.active{color:#667eea}}html.theme-dark .bottom-nav{background:var(--bg-primary);border-color:var(--border-color)}html.theme-dark .bottom-nav-item{color:var(--text-secondary)}html.theme-dark .bottom-nav-item.active{color:#667eea}.meer-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200}.meer-overlay.active{display:block}.meer-menu{position:fixed;bottom:0;left:0;right:0;background:var(--bg-primary,#fff);border-radius:16px 16px 0 0;padding:8px 0;padding-bottom:max(16px,env(safe-area-inset-bottom));z-index:201;transform:translateY(100%);transition:transform .25s ease}.meer-overlay.active .meer-menu{transform:translateY(0)}.meer-menu-handle{width:36px;height:4px;background:var(--border-color,#e0e0e0);border-radius:2px;margin:4px auto 12px}.meer-menu-item{display:flex;align-items:center;gap:12px;padding:14px 24px;text-decoration:none;color:var(--text-primary,#333);font-size:1rem;font-weight:500;transition:background .15s;border:none;background:0 0;width:100%;cursor:pointer;font-family:inherit}.meer-menu-item:hover{background:var(--bg-secondary,#f9f9f9)}.meer-menu-item-icon{font-size:1.2em;width:28px;text-align:center}.ptr-indicator{position:fixed;top:0;left:50%;transform:translateX(-50%) translateY(-100%);background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;padding:12px 20px;border-radius:0 0 20px 20px;font-size:.9em;z-index:1000;transition:transform .3s ease;display:flex;align-items:center;gap:8px;box-shadow:0 4px 12px rgba(0,0,0,.2)}.ptr-indicator.pulling{transform:translateX(-50%) translateY(0)}.ptr-indicator.refreshing .ptr-spinner{animation:spin 1s linear infinite}.ptr-spinner{display:inline-block;transition:transform .2s}@media (min-width:481px){.ptr-indicator{display:none}}.fab{position:fixed;bottom:90px;right:20px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;border:none;font-size:24px;cursor:pointer;box-shadow:0 4px 12px rgba(102,126,234,.4);z-index:99;display:flex;align-items:center;justify-content:center;transition:transform .3s,box-shadow .3s,opacity .3s;opacity:0;transform:scale(.8);pointer-events:none}.fab.visible{opacity:1;transform:scale(1);pointer-events:auto}.fab:hover{transform:scale(1.1);box-shadow:0 6px 20px rgba(102,126,234,.5)}.fab:active{transform:scale(.95)}@media (min-width:481px){.fab{bottom:30px}}@media (max-width:480px){.fab{width:50px;height:50px;font-size:20px;bottom:80px;right:16px}}.confirm-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:10000;justify-content:center;align-items:center;padding:20px}.confirm-overlay.active{display:flex}.confirm-dialog{background:var(--bg-card,#fff);border-radius:16px;max-width:400px;width:100%;padding:24px;box-shadow:0 10px 40px rgba(0,0,0,.3);animation:confirmSlideIn .2s ease-out}@keyframes confirmSlideIn{from{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirm-title{margin:0 0 16px 0;font-size:1.25em;color:var(--text-primary,#333)}.confirm-message{color:var(--text-secondary,#666);font-size:.95em;line-height:1.5}.confirm-message p{margin:0 0 12px 0}.confirm-message ul{margin:0 0 12px 0;padding-left:20px}.confirm-message li{margin-bottom:4px}.confirm-warning{color:#c62828;font-weight:500}.confirm-actions{display:flex;gap:12px;margin-top:24px}.confirm-btn{flex:1;padding:12px 20px;border-radius:8px;font-size:1em;font-weight:600;cursor:pointer;transition:all .2s;border:none}.confirm-btn-cancel{background:var(--bg-secondary,#f0f0f0);color:var(--text-primary,#333)}.confirm-btn-cancel:hover{background:var(--border-color,#e0e0e0)}.confirm-btn-delete{background:#c62828;color:#fff}.confirm-btn-delete:hover{background:#b71c1c}html.theme-dark .confirm-warning{color:#ef5350}.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:rgba(26,26,46,.98);backdrop-filter:blur(10px);border-top:1px solid rgba(79,172,254,.2);padding:16px 20px;z-index:10000;display:none;animation:slideUp .3s ease-out}.cookie-banner.show{display:block}@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.cookie-text{flex:1;min-width:280px;color:#b0b0b0;font-size:.9em;line-height:1.5}.cookie-text a{color:#4facfe;text-decoration:none}.cookie-text a:hover{text-decoration:underline}.cookie-buttons{display:flex;gap:12px;flex-shrink:0}.cookie-btn{padding:10px 20px;border-radius:8px;font-weight:600;font-size:.9em;cursor:pointer;transition:transform .2s,box-shadow .2s;border:none}.cookie-btn:hover{transform:translateY(-2px)}.cookie-btn-accept{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#1a1a2e}.cookie-btn-accept:hover{box-shadow:0 4px 15px rgba(79,172,254,.4)}.cookie-btn-info{background:rgba(255,255,255,.1);color:#e0e0e0;border:1px solid rgba(255,255,255,.2)}.cookie-btn-info:hover{background:rgba(255,255,255,.15)}@media (max-width:600px){.cookie-content{flex-direction:column;text-align:center}.cookie-buttons{width:100%;justify-content:center}}