*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}*{box-sizing:border-box;margin:0;padding:0}:root{--navy:#1a2332;--navy-light:#243447;--navy-mid:#2c3e50;--green:#2ecc71;--green-dark:#27ae60;--green-light:#d5f5e3;--green-glow:#2ecc7126;--grey:#95a5a6;--grey-light:#ecf0f1;--grey-dark:#7f8c8d;--primary:#2ecc71;--primary-dark:#27ae60;--primary-light:#d5f5e3;--accent:#3498db;--danger:#e74c3c;--warning:#f39c12;--text:#1a2332;--text-light:#7f8c8d;--bg:#f5f7fa;--white:#fff;--border:#dfe6e9;--shadow:0 2px 8px #1a233214;--shadow-md:0 4px 16px #1a23321f;--shadow-lg:0 8px 32px #1a233229;--radius:10px;--radius-lg:16px;--radius-xl:24px;--transition:all .25s ease}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.6}#root{text-align:left;max-width:100%;margin:0;padding:0}a{color:var(--green-dark);text-decoration:none;transition:color .2s}a:hover{color:var(--green);text-decoration:none}.navbar{background:var(--navy);box-shadow:var(--shadow-md);z-index:100;border-bottom:none;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:0 2rem;display:flex;position:sticky;top:0}.navbar-top{flex-shrink:0;justify-content:space-between;align-items:center;height:64px;display:flex}.navbar-brand a{color:var(--white);letter-spacing:.5px;align-items:center;gap:.5rem;font-size:1.4rem;font-weight:800;display:flex}.navbar-brand a:hover{text-decoration:none}.logo{font-size:1.6rem}.hamburger{cursor:pointer;border-radius:var(--radius);background:0 0;border:none;flex-direction:column;gap:5px;padding:8px;transition:background .2s;display:none}.hamburger:hover{background:var(--navy-light)}.hamburger span{background:var(--white);transform-origin:50%;border-radius:2px;width:22px;height:2px;transition:all .3s;display:block}.hamburger.open span:first-child{transform:rotate(45deg)translate(5px,5px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg)translate(5px,-5px)}.navbar-menu{align-items:center;gap:1.5rem;height:64px;display:flex}.navbar-links{gap:1.5rem;display:flex}.navbar-links a{color:#ffffffbf;padding:.5rem 0;font-size:.9rem;font-weight:500;transition:color .2s;position:relative}.navbar-links a:hover{color:var(--green);text-decoration:none}.navbar-links a:after{content:"";background:var(--green);height:2px;transition:transform .2s;position:absolute;bottom:0;left:0;right:0;transform:scaleX(0)}.navbar-links a:hover:after{transform:scaleX(1)}.navbar-auth{align-items:center;gap:.75rem;display:flex}.user-greeting{color:#fffc;font-size:.9rem}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;padding:.5rem 1.2rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn:hover{text-decoration:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-outline{border:1.5px solid var(--primary);color:var(--primary-dark);background:0 0}.btn-outline:hover{background:var(--primary-light)}.btn-sm{padding:.3rem .8rem;font-size:.8rem}.btn-lg{padding:.75rem 1.8rem;font-size:1rem}.btn-full{width:100%}.btn:disabled{opacity:.6;cursor:not-allowed}.app{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:2rem}.footer{text-align:center;color:var(--text-light);border-top:1px solid var(--border);background:var(--white);padding:1.5rem;font-size:.85rem}.hero{text-align:center;background:linear-gradient(135deg, var(--navy) 0%, var(--navy-light) 50%, var(--navy-mid) 100%);border-radius:0 0 var(--radius-xl) var(--radius-xl);margin:-2rem -2rem 2rem;padding:4rem 2rem 5rem}.hero h1{color:var(--white);margin-bottom:1rem;font-size:2.8rem;font-weight:800;line-height:1.15}.highlight{color:var(--green);position:relative}.hero p{color:#fffc;max-width:600px;margin-bottom:2rem;margin-left:auto;margin-right:auto;font-size:1.15rem}.hero-actions{justify-content:center;gap:1rem;display:flex}.section{margin-bottom:3rem}.section h2{margin-bottom:1.25rem;font-size:1.5rem;font-weight:700}.category-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;display:grid}.category-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;justify-content:center;align-items:center;min-height:80px;padding:1.25rem;transition:all .2s;display:flex}.category-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);text-decoration:none}.category-name{color:var(--text);font-size:.95rem;font-weight:600}.category-filters{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.chip{border:1px solid var(--border);background:var(--white);color:var(--text-light);cursor:pointer;border-radius:20px;padding:.4rem 1rem;font-size:.85rem;transition:all .2s}.chip:hover{border-color:var(--primary);color:var(--primary-dark)}.chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.deals-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;display:grid}.deal-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:box-shadow .2s;position:relative}.deal-card:hover{box-shadow:var(--shadow-md)}.deal-badge{background:var(--danger);color:#fff;border-radius:6px;padding:.2rem .6rem;font-size:.85rem;font-weight:700;position:absolute;top:1rem;right:1rem}.deal-card h3{margin-bottom:.5rem;padding-right:3rem;font-size:1.1rem}.deal-product{color:var(--text-light);font-size:.9rem}.deal-store{color:var(--text-light);margin-bottom:.75rem;font-size:.85rem}.deal-description{color:var(--text-light);margin-bottom:.5rem;font-size:.85rem}.deal-prices{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.price-old{color:var(--text-light);font-size:.95rem;text-decoration:line-through}.price-deal{color:var(--primary-dark);font-size:1.3rem;font-weight:700}.deal-expiry{color:var(--text-light);margin-bottom:.75rem;font-size:.8rem}.products-page h1,.deals-page h1,.compare-page h1,.products-toolbar{margin-bottom:1.5rem}.search-bar{gap:.5rem;margin-bottom:1rem;display:flex}.search-bar input{border:1px solid var(--border);border-radius:var(--radius);outline:none;flex:1;padding:.6rem 1rem;font-size:.95rem}.search-bar input:focus{border-color:var(--primary)}.products-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.product-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;padding:1.25rem;transition:box-shadow .2s;display:flex}.product-card:hover{box-shadow:var(--shadow-md)}.product-info h3{margin-bottom:.25rem;font-size:1rem}.product-brand{color:var(--primary-dark);font-size:.85rem;font-weight:500}.product-category,.product-unit{color:var(--text-light);font-size:.8rem}.back-link{color:var(--text-light);margin-bottom:1rem;font-size:.9rem;display:inline-block}.compare-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.compare-meta{color:var(--text-light);margin-top:.25rem}.savings-badge{background:var(--primary-light);color:var(--primary-dark);border-radius:var(--radius);padding:.6rem 1.2rem;font-size:1rem}.price-table{overflow-x:auto}.price-table table{border-collapse:collapse;background:var(--white);border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow);overflow:hidden}.price-table th{text-align:left;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;background:#f3f4f6;padding:.75rem 1rem;font-size:.85rem;font-weight:600}.price-table td{border-top:1px solid var(--border);padding:.75rem 1rem;font-size:.95rem}.cheapest-row{background:var(--primary-light)!important}.cheapest-tag{background:var(--primary);color:#fff;vertical-align:middle;border-radius:4px;margin-left:.5rem;padding:.1rem .5rem;font-size:.7rem;font-weight:700;display:inline-block}.price-cell{font-size:1.05rem;font-weight:700}.add-to-list-select{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:.3rem .5rem;font-size:.8rem}.auth-page{justify-content:center;align-items:center;min-height:60vh;display:flex}.auth-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-md);padding:2.5rem}.auth-card h2{margin-bottom:.25rem}.auth-subtitle{color:var(--text-light);margin-bottom:1.5rem}.form-group{margin-bottom:1rem}.form-group label{margin-bottom:.3rem;font-size:.9rem;font-weight:600;display:block}.form-group input{border:1px solid var(--border);border-radius:var(--radius);outline:none;width:100%;padding:.6rem .8rem;font-size:.95rem}.form-group input:focus{border-color:var(--primary)}.form-group small{color:var(--text-light);font-size:.8rem}.form-row{gap:1rem;display:flex}.form-row .form-group{flex:1}.auth-footer{text-align:center;color:var(--text-light);margin-top:1.25rem;font-size:.9rem}.alert{border-radius:var(--radius);margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.alert-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.alert-success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.lists-page{grid-template-columns:280px 1fr;gap:2rem;min-height:60vh;display:grid}.lists-sidebar{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);height:fit-content;padding:1.25rem}.lists-sidebar h2{margin-bottom:1rem;font-size:1.1rem}.create-list-form{gap:.5rem;margin-bottom:1rem;display:flex}.create-list-form input{border:1px solid var(--border);border-radius:var(--radius);outline:none;flex:1;padding:.4rem .6rem;font-size:.85rem}.create-list-form input:focus{border-color:var(--primary)}.lists-nav{list-style:none}.lists-nav li{border-radius:var(--radius);align-items:center;transition:background .2s;display:flex}.lists-nav li:hover{background:var(--bg)}.lists-nav li.active{background:var(--primary-light)}.lists-nav li button:first-child{text-align:left;cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;padding:.6rem .75rem;display:flex}.lists-nav li button:first-child span{font-size:.9rem;font-weight:600}.lists-nav li button:first-child small{color:var(--text-light);font-size:.75rem}.delete-btn{color:var(--text-light);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.3rem .5rem;font-size:1.2rem}.delete-btn:hover{color:var(--danger);background:#fef2f2}.list-detail{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}.list-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.list-header h2{font-size:1.3rem}.list-total{background:var(--primary-light);color:var(--primary-dark);border-radius:var(--radius);padding:.5rem 1rem;font-size:.95rem}.add-product-bar{gap:.5rem;margin-bottom:1rem;display:flex}.add-product-bar input{border:1px solid var(--border);border-radius:var(--radius);outline:none;flex:1;padding:.5rem .8rem;font-size:.9rem}.add-product-bar input:focus{border-color:var(--primary)}.search-results-dropdown{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);max-height:250px;box-shadow:var(--shadow-md);margin-bottom:1rem;overflow-y:auto}.search-result-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.6rem 1rem;display:flex}.search-result-item:last-child{border-bottom:none}.search-result-item small{color:var(--text-light)}.list-items table{border-collapse:collapse;width:100%}.list-items th{text-align:left;color:var(--text-light);text-transform:uppercase;border-bottom:2px solid var(--border);padding:.6rem .75rem;font-size:.8rem;font-weight:600}.list-items td{border-bottom:1px solid var(--border);padding:.6rem .75rem;font-size:.9rem}.list-items tr.checked td{opacity:.5;text-decoration:line-through}.list-items input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.loading{text-align:center;color:var(--text-light);padding:3rem;font-size:1.1rem}.empty-state{text-align:center;color:var(--text-light);padding:2rem}.empty-state h3{margin-bottom:.5rem}@media (width<=768px){.navbar{flex-direction:column;align-items:stretch;padding:0 1rem}.navbar-top{width:100%}.hamburger{display:flex}.navbar-menu{flex-direction:column;align-items:stretch;gap:0;width:100%;height:auto;padding-bottom:1rem;display:none}.navbar-menu.show{display:flex}.navbar-links{flex-direction:column;gap:0}.navbar-links a{color:#fffc;border-bottom:1px solid #ffffff1a;padding:.75rem 0;font-size:1rem}.navbar-links a:after{display:none}.navbar-auth{flex-direction:column;gap:.5rem;padding-top:.75rem}.navbar-auth .btn{text-align:center;width:100%}.main-content{padding:1rem}.hero{padding:2rem .5rem 2.5rem}.hero h1{font-size:1.8rem}.hero p{font-size:1rem}.hero-actions{flex-direction:column}.hero-actions .btn{width:100%}.category-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.lists-page{grid-template-columns:1fr}.compare-header{flex-direction:column}.deals-grid,.products-grid{grid-template-columns:1fr}.form-row{flex-direction:column;gap:0}.search-bar{flex-direction:column}.search-bar input{width:100%}.add-product-bar{flex-direction:column}.list-header{flex-direction:column;align-items:flex-start}.price-table,.list-items{-webkit-overflow-scrolling:touch;overflow-x:auto}}@media (width<=480px){.category-grid{grid-template-columns:1fr 1fr}.category-card{min-height:60px;padding:.75rem}.category-name{font-size:.85rem}.section h2{font-size:1.2rem}}.basket-search-page h1{margin-bottom:.5rem;font-size:1.8rem}.basket-search-page .page-subtitle{color:var(--text-light);margin-bottom:1.5rem;font-size:1rem}.basket-input-section{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-bottom:2rem;padding:1.5rem}.basket-textarea{border:2px solid var(--border);border-radius:var(--radius);resize:vertical;width:100%;min-height:120px;padding:1rem;font-family:inherit;font-size:1rem;line-height:1.6;transition:border-color .2s}.basket-textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-glow);outline:none}.location-section{background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);padding:.75rem 1rem}.location-section label{font-size:.9rem;font-weight:500}.location-section select{border:1px solid var(--border);border-radius:var(--radius);background:var(--white);cursor:pointer;padding:.35rem .6rem;font-size:.85rem}.location-section input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.basket-actions{gap:.75rem;margin-top:1rem;display:flex}.basket-summary{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem;display:grid}.summary-stat{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);text-align:center;flex-direction:column;align-items:center;padding:1.25rem 1rem;display:flex}.summary-stat.highlight{background:linear-gradient(135deg, var(--navy), var(--navy-light));color:var(--white)}.summary-stat.highlight .stat-label{color:#ffffffd9}.stat-value{font-size:1.6rem;font-weight:700;line-height:1.2}.stat-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;margin-top:.25rem;font-size:.8rem;font-weight:500}.basket-items{flex-direction:column;gap:.75rem;display:flex}.basket-item-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);border-left:4px solid var(--primary);transition:box-shadow .2s;overflow:hidden}.basket-item-card:hover{box-shadow:var(--shadow-md)}.basket-item-card.not-found{border-left-color:var(--danger);opacity:.7}.basket-item-header{justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.basket-item-info{flex-direction:column;gap:.2rem;min-width:0;display:flex}.searched-name{font-size:1rem;font-weight:600}.matched-name{color:var(--text-light);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;overflow:hidden}.matched-name .brand{color:var(--primary-dark)}.not-found-label{color:var(--danger);font-size:.85rem;font-style:italic}.basket-item-cheapest{white-space:nowrap;flex-direction:column;flex-shrink:0;align-items:flex-end;display:flex}.cheapest-price{color:var(--primary-dark);font-size:1.25rem;font-weight:700}.cheapest-store{color:var(--text-light);font-size:.75rem}.distance-tag{color:var(--primary-dark);background:var(--primary-light);border-radius:4px;margin-top:.15rem;padding:.1rem .4rem;font-size:.7rem;display:inline-block}.basket-item-stores{border-top:1px solid var(--border);background:var(--bg);-webkit-overflow-scrolling:touch;padding:0;overflow-x:auto}.store-prices-table{border-collapse:collapse;width:100%;min-width:400px;font-size:.85rem}.store-prices-table th{text-align:left;border-bottom:1px solid var(--border);color:var(--text-light);text-transform:uppercase;letter-spacing:.3px;padding:.6rem .75rem;font-size:.75rem;font-weight:600}.store-prices-table td{border-bottom:1px solid var(--border);padding:.5rem .75rem}.store-prices-table .cheapest-row{background:var(--primary-light);font-weight:600}.cheapest-badge{color:var(--primary-dark);font-size:.75rem;font-weight:600}.error-message{color:var(--danger);border-radius:var(--radius);background:#fef2f2;border:1px solid #fecaca;margin-bottom:1rem;padding:1rem;font-size:.9rem}@media (width<=640px){.basket-search-page h1{font-size:1.4rem}.basket-input-section{padding:1rem}.basket-textarea{min-height:140px;padding:.75rem;font-size:.95rem}.location-section{flex-direction:column!important;align-items:flex-start!important;gap:.5rem!important}.basket-actions{flex-direction:column}.basket-actions .btn{width:100%;padding:.75rem 1rem;font-size:1rem}.basket-summary{grid-template-columns:1fr;gap:.75rem}.summary-stat{flex-direction:row;justify-content:space-between;padding:1rem 1.25rem}.stat-value{font-size:1.4rem}.stat-label{margin-top:0}.basket-item-header{flex-direction:column;align-items:flex-start;gap:.5rem;padding:.75rem 1rem}.basket-item-cheapest{flex-direction:row;align-items:baseline;gap:.5rem}.cheapest-price{font-size:1.15rem}.cheapest-store{font-size:.75rem}.basket-item-stores{padding:0}.store-prices-table{min-width:360px;font-size:.8rem}.store-prices-table th,.store-prices-table td{padding:.4rem .5rem}}.page-header{flex-wrap:wrap;align-items:baseline;gap:1rem;margin-bottom:1.5rem;display:flex}.page-header h1{margin-bottom:0}.result-count{color:var(--text-light);background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:.2rem .75rem;font-size:.9rem;font-weight:500}.features-row{grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:1rem;display:grid}.feature-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;padding:1.5rem;transition:all .2s}.feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.feature-card h3{margin-bottom:.4rem;font-size:1rem}.feature-card p{color:var(--text-light);font-size:.85rem;line-height:1.4}.feature-icon{margin-bottom:.75rem;font-size:2rem;display:block}.category-card{flex-direction:column;gap:.4rem}.category-emoji{font-size:1.6rem}.category-filters-scroll{-webkit-overflow-scrolling:touch;margin-bottom:1.5rem;padding-bottom:.25rem;overflow-x:auto}.category-filters-scroll::-webkit-scrollbar{height:4px}.category-filters-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.category-filters-scroll .category-filters{flex-wrap:nowrap;margin-bottom:0}.active-filter-bar{background:var(--primary-light);border-radius:var(--radius);align-items:center;gap:.75rem;margin-bottom:1.25rem;padding:.5rem 1rem;font-size:.9rem;display:flex}.product-card{color:inherit;cursor:pointer;text-decoration:none}.product-card:hover{border-color:var(--primary);text-decoration:none}.product-details{flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.25rem;display:flex}.product-category-tag{background:var(--bg);color:var(--text-light);border:1px solid var(--border);border-radius:4px;padding:.1rem .5rem;font-size:.75rem}.product-compare-arrow{color:var(--primary);flex-shrink:0;font-size:1.2rem;font-weight:700;transition:transform .2s}.product-card:hover .product-compare-arrow{transform:translate(4px)}.deal-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.75rem;display:flex}.deal-footer .deal-expiry{margin-bottom:0}.compare-brand{color:var(--primary-dark);font-weight:600}.compare-sep{color:var(--border);margin:0 .25rem}.compare-stats{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.store-count-badge{background:var(--bg);color:var(--text-light);border-radius:var(--radius);border:1px solid var(--border);padding:.5rem 1rem;font-size:.9rem}.desktop-only{display:block}.mobile-only{display:none}.price-cards{flex-direction:column;gap:.75rem;display:flex}.price-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);transition:box-shadow .2s;overflow:hidden}.price-card:hover{box-shadow:var(--shadow-md)}.price-card-cheapest{border-color:var(--primary);background:var(--primary-light)}.price-card-header{justify-content:space-between;align-items:flex-start;gap:1rem;padding:1rem;display:flex}.price-card-sub{color:var(--text-light);margin-top:.15rem;font-size:.8rem}.price-card-footer{border-top:1px solid var(--border);background:var(--bg);justify-content:space-between;align-items:center;padding:.5rem 1rem;display:flex}.price-card-date{color:var(--text-light);font-size:.8rem}.lists-mobile-toggle{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:center;width:100%;margin-bottom:1rem;padding:.75rem 1rem;font-size:.95rem;font-weight:600;transition:all .2s;display:none}.lists-mobile-toggle:hover{border-color:var(--primary);color:var(--primary-dark)}.sidebar-empty{color:var(--text-light);text-align:center;padding:1rem 0;font-size:.85rem}.list-items-cards{flex-direction:column;gap:.5rem;display:flex}.list-item-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;transition:opacity .2s}.list-item-card.checked{opacity:.5}.list-item-card.checked .list-item-card-info strong{text-decoration:line-through}.list-item-card-main{align-items:center;gap:.75rem;display:flex}.list-item-card-info{flex-direction:column;flex:1;gap:.15rem;min-width:0;display:flex}.list-item-card-info strong{font-size:.9rem}.list-item-card-info small{color:var(--text-light);font-size:.8rem}.list-item-card-right{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.list-item-price{color:var(--primary-dark);font-size:.95rem;font-weight:700}.footer{background:var(--navy);color:#ffffffb3;border-top:none}.footer-content{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:2rem;max-width:1200px;margin:0 auto;padding:2rem 2rem 1rem;display:flex}.footer-brand{flex-direction:column;gap:.4rem;display:flex}.footer-brand .logo{font-size:1.2rem}.footer-brand strong{color:var(--white)}.footer-brand p{color:#fff9;max-width:280px;font-size:.85rem}.footer-links{gap:1.5rem;display:flex}.footer-links a{color:#fff9;font-size:.9rem;font-weight:500;transition:color .2s}.footer-links a:hover{color:var(--green)}.footer-bottom{text-align:center;color:#fff6;border-top:1px solid #ffffff1a;padding:1rem 2rem;font-size:.8rem}@media (width<=768px){.features-row{grid-template-columns:1fr;gap:.75rem}.feature-card{text-align:left;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.feature-icon{flex-shrink:0;margin-bottom:0;font-size:1.5rem}.desktop-only{display:none}.mobile-only,.lists-mobile-toggle{display:block}.lists-sidebar{display:none}.lists-sidebar.show{display:block}.lists-page{flex-direction:column;display:flex}.page-header{flex-direction:column;gap:.5rem}.compare-stats{flex-direction:column;align-items:flex-start}.deal-footer{flex-direction:column;align-items:flex-start;gap:.5rem}.footer-content{text-align:center;flex-direction:column;align-items:center;padding:1.5rem 1rem 1rem}.footer-links{flex-wrap:wrap;justify-content:center}.footer-brand p{max-width:100%}.active-filter-bar{flex-direction:column;align-items:flex-start;gap:.5rem}}@media (width<=480px){.features-row{gap:.5rem}.feature-card{padding:.75rem 1rem}.feature-card h3{font-size:.9rem}.feature-card p{font-size:.8rem}}.spot-mascot{filter:drop-shadow(0 4px 8px #0003);font-size:4rem;animation:2s ease-in-out infinite spot-bounce;display:inline-block}.spot-mascot-sm{font-size:2rem;animation:1s ease-in-out infinite spot-wag;display:inline-block}.spot-mascot-searching{font-size:3rem;animation:.6s ease-in-out infinite spot-sniff;display:inline-block}.spot-celebrate{font-size:3rem;animation:.8s ease-in-out infinite spot-celebrate;display:inline-block}@keyframes spot-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes spot-wag{0%,to{transform:rotate(0)}25%{transform:rotate(8deg)}75%{transform:rotate(-8deg)}}@keyframes spot-sniff{0%,to{transform:translate(0)rotate(0)}25%{transform:translate(6px)rotate(5deg)}75%{transform:translate(-6px)rotate(-5deg)}}@keyframes spot-celebrate{0%,to{transform:scale(1)rotate(0)}25%{transform:scale(1.1)rotate(-5deg)}50%{transform:scale(1.15)rotate(0)}75%{transform:scale(1.1)rotate(5deg)}}.avatar-selector{flex-wrap:wrap;justify-content:center;gap:.75rem;margin:1rem 0;display:flex}.avatar-option{border:3px solid var(--border);background:var(--white);cursor:pointer;width:64px;height:64px;transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:2rem;display:flex;position:relative}.avatar-option:hover{border-color:var(--green);box-shadow:0 0 0 4px var(--green-glow);transform:scale(1.1)}.avatar-option.selected{border-color:var(--green);background:var(--green-light);box-shadow:0 0 0 4px var(--green-glow);transform:scale(1.1)}.avatar-option.selected:after{content:"✓";background:var(--green);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.65rem;font-weight:700;display:flex;position:absolute;bottom:-4px;right:-4px}.avatar-section-label{text-align:center;color:var(--text-light);margin-bottom:.5rem;font-size:.85rem}.auth-page{justify-content:center;align-items:center;min-height:70vh;padding:2rem 1rem;display:flex}.auth-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:460px;box-shadow:var(--shadow-lg);padding:2.5rem;position:relative;overflow:hidden}.auth-card:before{content:"";background:linear-gradient(90deg, var(--green), var(--accent), var(--green));height:4px;position:absolute;top:0;left:0;right:0}.auth-mascot{text-align:center;margin-bottom:1rem}.auth-card h2{text-align:center;color:var(--navy);margin-bottom:.25rem;font-size:1.5rem}.auth-subtitle{color:var(--text-light);text-align:center;margin-bottom:1.5rem;font-size:.95rem}.auth-divider{color:var(--text-light);align-items:center;gap:1rem;margin:1.25rem 0;font-size:.8rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.savings-breakdown{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-top:1.5rem;padding:1.5rem}.savings-breakdown h3{color:var(--navy);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.1rem;display:flex}.savings-line{justify-content:space-between;padding:.5rem 0;font-size:.95rem;display:flex}.savings-line+.savings-line{border-top:1px solid var(--border)}.savings-line.total{border-top:2px solid var(--navy);margin-top:.25rem;padding-top:.75rem;font-size:1.1rem;font-weight:700}.savings-line.savings-amount{color:var(--green-dark);font-weight:600}.savings-line.fee-line{color:var(--text-light);font-size:.85rem}.savings-highlight{background:linear-gradient(135deg, var(--green-light), #e8f8f0);border:1px solid var(--green);border-radius:var(--radius-lg);text-align:center;margin-top:1rem;padding:1.25rem}.savings-highlight .amount{color:var(--green-dark);font-size:2rem;font-weight:800;display:block}.savings-highlight .label{color:var(--green-dark);font-size:.85rem;font-weight:500}.savings-dashboard{max-width:900px;margin:0 auto}.savings-dashboard h1{color:var(--navy);margin-bottom:.5rem;font-size:1.8rem}.dashboard-subtitle{color:var(--text-light);margin-bottom:2rem}.stats-grid{grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);text-align:center;transition:var(--transition);padding:1.25rem}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card .stat-icon{margin-bottom:.5rem;font-size:1.5rem;display:block}.stat-card .stat-value{color:var(--navy);font-size:1.4rem;font-weight:700;display:block}.stat-card .stat-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.stat-card.savings-total{background:linear-gradient(135deg, var(--green), var(--green-dark));color:var(--white)}.stat-card.savings-total .stat-value,.stat-card.savings-total .stat-label{color:var(--white)}.stat-card.savings-total .stat-label{opacity:.85}.chart-section{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-bottom:2rem;padding:1.5rem}.chart-section h3{color:var(--navy);margin-bottom:1rem}.chart-bar-group{flex-direction:column;gap:.75rem;display:flex}.chart-bar-item{align-items:center;gap:1rem;display:flex}.chart-bar-label{width:60px;color:var(--text-light);text-align:right;flex-shrink:0;font-size:.8rem}.chart-bar-track{background:var(--grey-light);border-radius:14px;flex:1;height:28px;position:relative;overflow:hidden}.chart-bar-fill{background:linear-gradient(90deg, var(--green), var(--green-dark));border-radius:14px;justify-content:flex-end;align-items:center;min-width:60px;height:100%;padding-right:.75rem;transition:width .8s;display:flex}.chart-bar-value{color:var(--white);font-size:.75rem;font-weight:700}.transaction-list{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.transaction-list h3{color:var(--navy);margin-bottom:1rem;padding:1.25rem 1.5rem 0}.transaction-item{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.5rem;transition:background .2s;display:flex}.transaction-item:hover{background:var(--bg)}.transaction-info{flex-direction:column;gap:.15rem;display:flex}.transaction-date{color:var(--text-light);font-size:.8rem}.transaction-desc{font-size:.95rem;font-weight:600}.transaction-amounts{flex-direction:column;align-items:flex-end;gap:.1rem;display:flex}.transaction-total{font-size:1rem;font-weight:700}.transaction-saved{color:var(--green-dark);font-size:.85rem;font-weight:600}.loyalty-banner{background:linear-gradient(135deg, var(--navy), var(--navy-light));border-radius:var(--radius-lg);color:var(--white);align-items:center;gap:1.25rem;margin-bottom:2rem;padding:1.5rem;display:flex}.loyalty-banner .loyalty-icon{flex-shrink:0;font-size:2.5rem}.loyalty-banner h3{color:var(--green);margin-bottom:.25rem;font-size:1rem}.loyalty-banner p{opacity:.8;font-size:.85rem}.loyalty-amount{color:var(--green);flex-shrink:0;margin-left:auto;font-size:1.5rem;font-weight:800}.spot-speech{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--border);color:var(--text);max-width:350px;margin-left:1rem;padding:1rem 1.25rem;font-size:.9rem;position:relative}.spot-speech:before{content:"";border:10px solid #0000;border-right-color:var(--white);border-left:0;width:0;height:0;position:absolute;top:50%;left:-10px;transform:translateY(-50%)}.spot-greeting{align-items:center;gap:.5rem;margin-bottom:1.5rem;display:flex}.share-btn{background:var(--navy);color:var(--white);border-radius:var(--radius);cursor:pointer;transition:var(--transition);border:none;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:inline-flex}.share-btn:hover{background:var(--navy-light);transform:translateY(-1px)}.suggestions-card{border-radius:var(--radius-lg);background:linear-gradient(135deg,#fef9e7,#fef5e0);border:1px solid #f7dc6f;margin-top:1.5rem;padding:1.25rem}.suggestions-card h3{color:var(--navy);align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:1rem;display:flex}.suggestion-item{justify-content:space-between;align-items:center;padding:.4rem 0;font-size:.9rem;display:flex}.suggestion-item+.suggestion-item{border-top:1px solid #f7dc6f4d}@media (width<=768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.loyalty-banner{text-align:center;flex-direction:column}.loyalty-amount{margin-left:0}.avatar-selector{gap:.5rem}.avatar-option{width:52px;height:52px;font-size:1.6rem}.hero{border-radius:0 0 var(--radius-lg) var(--radius-lg);margin:-1rem -1rem 1rem;padding:2.5rem 1rem 3rem}}@media (width<=480px){.stats-grid{grid-template-columns:1fr 1fr;gap:.75rem}.stat-card{padding:1rem}.stat-card .stat-value{font-size:1.2rem}.transaction-item{flex-direction:column;align-items:flex-start;gap:.5rem}.transaction-amounts{align-items:flex-start}}
