.auth-modal-overlay{align-items:center;background:var(--overlay);display:flex;inset:0;justify-content:center;position:fixed;z-index:300}.auth-modal{background:var(--surface);border-radius:1.25rem;box-shadow:var(--shadow-lg);padding:20px;width:min(420px,calc(100vw - 28px))}.auth-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.auth-modal-header h3{color:var(--ink);font-size:20px;font-weight:700}.auth-close{align-items:center;background:var(--surface-soft);border:none;border-radius:50%;color:var(--muted);cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;transition:background .2s,color .2s;width:32px}.auth-close:hover{background:var(--danger-soft);color:var(--danger)}.auth-form{grid-gap:10px;display:grid;gap:10px}.auth-form input{background:var(--surface-soft);border:1.5px solid var(--line);border-radius:var(--radius-sm);color:var(--ink);font-size:14px;padding:10px 12px;transition:border-color .2s,box-shadow .2s}.auth-form input:focus{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.12);outline:none}.auth-error{color:var(--danger);font-size:13px;margin:0}.auth-submit{background:linear-gradient(135deg,var(--brand-blue) 0,var(--brand-teal) 100%);border:none;border-radius:var(--radius-sm);box-shadow:0 4px 12px rgba(var(--accent-rgb),.3);color:var(--text-on-accent);cursor:pointer;font-size:15px;font-weight:700;padding:11px;transition:opacity .2s,transform .16s}.auth-submit:hover{opacity:.92;transform:translateY(-1px)}.auth-toggle{background:#0000;border:none;color:var(--accent);cursor:pointer;display:block;font-size:13px;font-weight:600;margin-top:12px;padding:4px;text-align:center;width:100%}.auth-toggle:hover{text-decoration:underline}.google-signin-btn{display:flex;justify-content:center;margin-top:4px}.auth-account-info{display:flex;flex-direction:column;gap:16px;padding:8px 0 4px}.auth-account-name{color:var(--ink);font-size:15px;font-weight:600}.header{background:var(--surface);border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.header-container{align-items:center;display:flex;gap:24px;justify-content:space-between;margin:0 auto;max-width:1160px;padding:12px 20px}.header-top-row{align-items:center;display:flex;gap:12px}.logo{min-width:0}.logo-link{align-items:center;display:flex;gap:0;text-decoration:none}.header-menu-btn{align-items:center;background:var(--surface);border:1.5px solid var(--line);border-radius:10px;color:var(--accent);cursor:pointer;display:inline-flex;flex-shrink:0;font-size:18px;height:38px;justify-content:center;line-height:1;transition:border-color .2s,background .2s;width:38px}.mobile-auth-btn,.mobile-header-controls,.mobile-lang-btn{display:none}.header-menu-btn:hover{background:rgba(var(--accent-rgb),.08);border-color:var(--accent)}.logo-image{display:block;height:auto;width:clamp(160px,22vw,200px)}.search-bar{align-items:center;display:flex;flex:1 1;gap:8px;max-width:520px}.search-input-wrap{flex:1 1;position:relative}.search-input{background:var(--surface-soft);border:1.5px solid var(--line);border-radius:var(--radius-sm);color:var(--ink);font-size:14px;padding:10px 16px;transition:border-color .2s,box-shadow .2s,background .2s;width:100%}.search-input-wrap .search-input{padding-right:42px}.search-clear-btn{align-items:center;background:var(--line);border:none;border-radius:50%;color:var(--muted);cursor:pointer;display:inline-flex;font-size:12px;height:24px;justify-content:center;line-height:1;position:absolute;right:10px;top:50%;transform:translateY(-50%);transition:background .2s,color .2s;width:24px}.search-clear-btn:hover{background:var(--line);color:var(--ink)}.search-button{align-items:center;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-sm);color:var(--accent);cursor:pointer;display:inline-flex;flex-shrink:0;height:39px;justify-content:center;transition:border-color .2s,background .2s,color .2s;width:39px}.search-button svg{fill:currentColor;height:18px;width:18px}.search-button:hover{background:rgba(var(--accent-rgb),.08);border-color:var(--accent)}.search-input::placeholder{color:var(--muted)}.search-input:focus{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.12);outline:none}.cart-button{align-items:center;background:linear-gradient(135deg,var(--brand-blue) 0,var(--brand-teal) 100%);border:none;border-radius:var(--radius-sm);box-shadow:0 4px 12px rgba(var(--accent-rgb),.32);color:var(--text-on-accent);cursor:pointer;display:flex;font-size:15px;font-weight:700;gap:8px;padding:8px 16px;transition:opacity .2s,transform .16s;white-space:nowrap}.cart-button:hover{opacity:.9;transform:translateY(-1px)}.cart-icon{fill:currentColor;display:block;height:18px;width:18px}.cart-count{background-color:#fff;border-radius:50%;color:var(--brand-navy);font-size:11px;font-weight:800;height:22px;justify-content:center;width:22px}.cart-count,.header-actions{align-items:center;display:flex}.header-actions{gap:10px}.lang-menu{position:relative}.lang-btn{align-items:center;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-sm);color:var(--ink);cursor:pointer;display:inline-flex;font-size:18px;height:38px;justify-content:center;transition:border-color .2s,background .2s;width:38px}.lang-btn:hover{background:rgba(var(--accent-rgb),.05);border-color:var(--accent)}.lang-dropdown{grid-gap:4px;background:var(--surface);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-lg);display:grid;gap:4px;padding:6px;position:absolute;right:0;top:calc(100% + 8px);width:150px;z-index:40}.lang-option{background:#0000;border:none;border-radius:8px;color:var(--ink);cursor:pointer;font-size:13px;font-weight:600;padding:8px 10px;text-align:left}.lang-option:hover{background:var(--surface-soft)}.lang-option.active{background:rgba(var(--accent-rgb),.1);color:var(--accent)}.auth-user{color:var(--muted);font-size:13px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-btn{background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-sm);color:var(--ink);cursor:pointer;font-size:14px;font-weight:600;padding:9.5px 16px;transition:border-color .2s,background .2s}.auth-btn:hover{background:rgba(var(--accent-rgb),.05);border-color:var(--accent)}.auth-btn.secondary{background:var(--surface-soft)}@media (max-width:768px){.header-container{flex-direction:column;gap:10px;padding:10px 16px}.header-top-row{justify-content:space-between;width:100%}.mobile-auth-btn{align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:10px;color:var(--ink);cursor:pointer;display:inline-flex;font-size:13px;font-weight:700;justify-content:center;padding:9px 12px}.mobile-header-controls{align-items:center;display:inline-flex;gap:8px}.mobile-lang-btn{display:inline-flex;font-size:16px;height:35.5px;width:35.5px}.mobile-auth-btn:hover{background:var(--surface-soft)}.header-actions{display:none}.search-bar{max-width:100%;width:100%}.logo-image{width:clamp(140px,42vw,220px)}}@media (max-width:480px){.header-container{gap:10px;padding:8px 14px}.header-menu-btn{display:none}}.landing-shell{display:flex;flex-direction:column;gap:40px}.hero-banner{background:linear-gradient(135deg,var(--brand-blue) 0,var(--brand-teal) 100%);border-radius:1.5rem;color:var(--text-on-accent);padding:40px 36px 32px}.hero-content h1{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;letter-spacing:-.02em;line-height:1.15;margin:0 0 12px}.hero-content>p{color:#ffffffe6;font-size:1rem;margin:0 0 20px;max-width:520px}.hero-stats{color:#ffffffeb;display:flex;flex-wrap:wrap;font-size:14px;font-weight:600;gap:16px;margin-bottom:28px}.hero-stats span{align-items:center;display:flex;gap:6px}.hero-search-form{width:100%}.hero-search-row{display:flex;flex-wrap:wrap;gap:10px}.hero-category-select{background:#fffffff2;border:none;border-radius:var(--radius-sm);color:var(--ink);cursor:pointer;flex-shrink:0;font-size:14px;font-weight:600;height:48px;min-width:180px;padding:0 14px}.hero-category-select:focus{outline:2px solid var(--surface);outline-offset:2px}.hero-input-wrap{display:flex;flex:1 1;gap:8px;min-width:200px}.hero-search-input{background:#fffffff2;border:none;border-radius:var(--radius-sm);color:var(--ink);flex:1 1;font-size:14px;height:48px;padding:0 16px}.hero-search-input::placeholder{color:var(--muted)}.hero-search-input:focus{background:var(--surface);outline:2px solid var(--surface);outline-offset:2px}.hero-search-btn{background:#00000040;border:none;border-radius:var(--radius-sm);color:var(--text-on-accent);cursor:pointer;font-size:15px;font-weight:700;height:48px;padding:0 24px;transition:background .2s;white-space:nowrap}.hero-search-btn:hover{background:#00000059}.landing-recent-section{display:flex;flex-direction:column;gap:16px}.landing-recent-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.recent-card{align-items:center;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:12px 10px;text-align:center;transition:box-shadow .2s,transform .2s,border-color .2s}.recent-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.recent-card-img-wrap{align-items:center;background:var(--surface-soft);border-radius:8px;display:flex;flex-shrink:0;height:72px;justify-content:center;padding:6px;width:72px}.recent-card-img{height:100%;object-fit:contain;width:100%}.recent-card-name{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--ink);display:-webkit-box;font-size:11px;font-weight:600;line-height:1.3;margin:0;overflow:hidden}.landing-categories-section{display:flex;flex-direction:column;gap:16px}.landing-section-header{align-items:center;display:flex;justify-content:space-between}.landing-section-header h2{color:var(--ink);font-size:1.4rem;font-weight:800;letter-spacing:-.01em;margin:0}.section-link{background:none;border:none;color:var(--accent);cursor:pointer;font-size:14px;font-weight:600;padding:0}.section-link:hover{text-decoration:underline}.landing-categories-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.category-card{align-items:center;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:20px 12px;text-align:center;transition:box-shadow .2s,transform .2s,border-color .2s}.category-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.category-icon-emoji{font-size:2.2rem;line-height:1}.category-name{color:var(--ink);font-size:12px;font-weight:600;line-height:1.3}.how-it-works{background:var(--surface);border:1px solid var(--line);border-radius:1.5rem;padding:36px 32px}.how-it-works h2{color:var(--ink);font-size:1.4rem;font-weight:800;letter-spacing:-.01em;margin:0 0 28px;text-align:center}.hiw-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.hiw-step{flex-direction:column;gap:10px;text-align:center}.hiw-icon,.hiw-step{align-items:center;display:flex}.hiw-icon{border-radius:50%;font-size:28px;height:60px;justify-content:center;width:60px}.hiw-icon-blue{background:rgba(var(--accent-rgb),.16)}.hiw-icon-green{background:#22b8a629}.hiw-icon-purple{background:#1f4a7921}.hiw-step h3{color:var(--ink);font-size:15px;font-weight:700;margin:0}.hiw-step p{color:var(--muted);font-size:13px;line-height:1.5;margin:0}@media (max-width:640px){.hero-banner{border-radius:1rem;padding:28px 20px 24px}.hero-search-row{flex-direction:column}.hero-category-select,.hero-input-wrap{min-width:0;min-width:auto;width:100%}.hero-stats{font-size:13px;gap:10px}.landing-categories-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.how-it-works{border-radius:1rem;padding:24px 18px}.landing-shell{gap:28px}}@media (max-width:380px){.landing-categories-grid{grid-template-columns:repeat(3,1fr)}.category-card{gap:6px;padding:14px 8px}.category-icon-emoji{font-size:1.8rem}.category-name{font-size:11px}}.product-tile{background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;height:100%;min-height:500px;padding:18px;transition:box-shadow .22s ease,transform .22s ease}.product-tile:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.product-tile:hover .product-image{transform:scale(1.05)}.product-media{background:var(--surface-soft);border:1px solid var(--line);border-radius:16px;display:grid;min-height:160px;overflow:hidden;padding:12px;place-items:center}.product-image-link{display:grid;height:100%;place-items:center;width:100%}.product-image{height:135px;object-fit:contain;transition:transform .3s ease;width:135px}.product-header{border-bottom:1.5px solid var(--line);display:flex;flex-direction:column;gap:10px;padding-bottom:14px}.product-name{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;font-size:15px;font-weight:700;line-height:1.4;margin:0;min-height:42px;overflow:hidden}.product-name a{color:var(--ink);text-decoration:none;transition:color .15s}.product-name a:hover{color:var(--accent-strong)}.product-chips{display:flex;flex-wrap:wrap;gap:6px;min-height:28px}.product-brand,.product-unit,.product-unit-price{align-items:center;background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius-pill);color:var(--muted);display:inline-flex;font-size:11px;font-weight:600;padding:4px 10px}.product-price-section{padding:0}.price-display{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.price{color:var(--accent-green);font-size:26px;font-weight:800;letter-spacing:-.02em}.supermarket{background:#22b8a61f;border-radius:var(--radius-pill);color:var(--accent-green-strong);font-size:12px;font-weight:700;padding:5px 10px}.quantity-control{align-items:center;display:flex;gap:8px}.quantity-stepper{align-items:center;display:inline-flex;gap:3px}.qty-btn{background:var(--surface);border:1.5px solid var(--line);border-radius:8px;font-size:16px;line-height:1;transition:border-color .2s,color .2s}.qty-btn:hover{border-color:var(--accent);color:var(--accent-strong)}.quantity-control input{appearance:textfield;background:var(--surface-soft);border:1.5px solid var(--line);border-radius:8px;color:var(--ink);font-size:14px;padding:7px 6px;text-align:center;transition:border-color .2s;width:50px}.quantity-control input::-webkit-inner-spin-button,.quantity-control input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.quantity-control input:focus{border-color:var(--accent);outline:none}.add-to-cart-btn{align-items:center;background:linear-gradient(135deg,var(--brand-blue) 0,var(--brand-teal) 100%);border:none;border-radius:var(--radius-sm);box-shadow:0 4px 12px rgba(var(--accent-rgb),.3);color:var(--text-on-accent);cursor:pointer;display:inline-flex;height:34px;justify-content:center;margin-left:auto;margin-top:0;padding:0;transition:opacity .2s,transform .16s;width:40px}.add-to-cart-icon{height:19px;width:19px}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.product-actions-row{align-items:center;display:flex;gap:10px;margin-top:auto}.add-to-cart-btn:hover{opacity:.9;transform:translateY(-1px)}.add-to-cart-btn:active{transform:scale(.98)}@media (max-width:600px){.product-tile{gap:10px;min-height:0;min-height:auto;padding:14px}.product-media{min-height:120px}.product-image{height:110px;width:110px}.price{font-size:22px}.add-to-cart-btn{height:32px;width:38px}.product-actions-row{gap:8px}}.product-grid-container{width:100%}.product-grid-layout{grid-gap:22px;align-items:start;display:grid;gap:22px;grid-template-columns:minmax(260px,320px) minmax(0,1fr)}.product-sidebar{position:sticky;top:84px}.product-content-area{min-width:0}.products-toolbar{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:14px}.products-count{color:var(--muted);font-size:13px;font-weight:700}.mobile-open-filters{background:var(--surface);border:1px solid var(--line);border-radius:10px;color:var(--ink);cursor:pointer;display:none;font-size:13px;font-weight:700;padding:8px 12px}.mobile-open-filters:hover{background:var(--surface-soft)}.product-grid{grid-gap:18px;align-items:stretch;animation:fadeIn .3s ease-in;display:grid;gap:18px;grid-template-columns:repeat(3,minmax(0,1fr))}.product-grid>*{height:100%}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.product-filter-bar{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.filter-item{display:flex;flex-direction:column;gap:7px;width:100%}.filter-item label{color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.desktop-category-menu{background:radial-gradient(circle at 100% 0,rgba(var(--accent-rgb),.09),#0000 42%),linear-gradient(180deg,var(--surface) 0,var(--surface-soft) 100%);border:1px solid var(--line);border-radius:20px;box-shadow:0 14px 28px #0f172a14;max-height:430px;overflow:auto;padding:14px;width:100%}.desktop-category-menu-head{align-items:center;border-bottom:1px solid var(--line);display:flex;gap:10px;justify-content:space-between;margin-bottom:12px;padding-bottom:10px}.desktop-category-current{background:rgba(var(--accent-rgb),.12);border:1px solid rgba(var(--accent-rgb),.22);border-radius:999px;color:var(--ink);font-size:13px;font-weight:700;padding:6px 10px}.category-tree{list-style:none;margin:0;padding-left:0}.category-tree li{margin:4px 0}.tree-node-row{align-items:center;display:flex;gap:8px}.tree-node-row.root{grid-gap:8px;align-items:center;display:grid;gap:8px;grid-template-columns:1fr auto;padding:3px 0}.tree-node-row.depth-1,.tree-node-row.depth-2,.tree-node-row.depth-3,.tree-node-row.depth-4{padding-left:10px}.tree-expand-btn,.tree-expand-spacer{align-items:center;border-radius:10px;display:inline-flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.tree-expand-btn{background:var(--surface);border:1px solid var(--line);color:var(--muted);cursor:pointer;transition:transform .2s ease,background .2s ease,color .2s ease,box-shadow .2s ease}.tree-expand-btn:hover{background:var(--surface-soft);box-shadow:0 4px 10px rgba(var(--accent-rgb),.12);color:var(--accent-strong)}.tree-expand-btn.expanded{background:rgba(var(--accent-rgb),.12);color:var(--accent-strong);transform:rotate(90deg)}.tree-node{background:none;border:none;border-radius:var(--radius-sm);color:var(--ink);cursor:pointer;font-size:13px;font-weight:600;padding:9px 12px;text-align:left;transition:background .15s,color .15s,border-color .15s;width:100%}.tree-node:hover{background:rgba(var(--accent-rgb),.1);color:var(--accent-strong)}.tree-node.selected{background:rgba(var(--accent-rgb),.16);color:var(--accent-strong);font-weight:700}.root-expand{background:var(--surface)}.root-expand-spacer{background:#0000;border:1px dashed var(--line)}.tree-node-root{align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:15px;box-shadow:0 8px 16px #0f172a0f;display:inline-flex;gap:11px;min-height:48px}.tree-node-root:hover{border-color:rgba(var(--accent-rgb),.28)}.tree-node-sub{align-items:center;border:1px solid #0000;border-radius:10px;display:inline-flex}.tree-node-sub:hover{border-color:rgba(var(--accent-rgb),.2)}.tree-node-icon{align-items:center;background:linear-gradient(135deg,rgba(var(--accent-rgb),.14) 0,rgba(var(--accent-rgb),.24) 100%);border:1px solid rgba(var(--accent-rgb),.25);border-radius:50%;color:var(--accent-strong);display:inline-flex;flex-shrink:0;font-size:11px;font-weight:800;height:28px;justify-content:center;width:28px}.tree-node-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.clear-path{background:var(--danger-soft);border:1px solid var(--danger-border);border-radius:var(--radius-sm);color:var(--danger);cursor:pointer;display:block;font-size:13px;font-weight:700;margin-bottom:10px;padding:8px 12px;text-align:left;transition:background .15s;width:100%}.clear-path:hover{background:var(--danger-soft-strong)}.desktop-category-menu-head .clear-path{font-size:12px;margin-bottom:0;padding:6px 10px;width:auto}.mobile-filter-menu,.mobile-filter-overlay{display:none}.pagination{align-items:center;display:flex;gap:12px;justify-content:center;margin-top:18px}.page-btn{background:var(--surface);border:1px solid var(--line);border-radius:10px;color:var(--ink);cursor:pointer;font-size:13px;font-weight:700;padding:8px 12px}.page-btn:hover:not(:disabled){background:var(--surface-soft)}.page-btn:disabled{cursor:not-allowed;opacity:.45}.page-status{color:var(--muted);font-size:13px;font-weight:700}.mobile-filter-toggle{align-items:center;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:10px;padding:10px 12px;width:100%}.mobile-filter-icon{color:var(--accent);font-size:18px}.mobile-filter-text{color:var(--ink);font-size:14px;font-weight:700}.mobile-filter-current{color:var(--muted);font-size:12px;margin-left:auto;max-width:55%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-filter-overlay{animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:var(--overlay-soft);inset:0;position:fixed;z-index:360}.mobile-filter-drawer{animation:slideInUp .24s ease;background:radial-gradient(circle at 100% 0,rgba(var(--accent-rgb),.1),#0000 45%),linear-gradient(180deg,var(--surface) 0,var(--surface-soft) 100%);border-radius:18px 18px 0 0;border-top:1px solid var(--line);bottom:0;box-shadow:0 12px 30px #10182829;left:0;max-height:82vh;overflow-y:auto;padding:16px;position:absolute;right:0;width:100%}.mobile-filter-head{align-items:center;border-bottom:1px solid var(--line);display:flex;gap:8px;justify-content:space-between;margin-bottom:12px;padding-bottom:10px}.mobile-filter-head h3{font-size:17px;margin:0}.mobile-filter-close{background:var(--surface);border:1px solid var(--line);border-radius:8px;color:var(--ink);cursor:pointer;height:32px;width:32px}.mobile-filter-close:hover{background:var(--surface-soft)}@keyframes slideInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.error,.loading,.no-products{background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);color:var(--muted);font-size:18px;font-weight:500;padding:56px 20px;text-align:center}@media (max-width:768px){.product-grid-layout{gap:12px;grid-template-columns:1fr}.product-sidebar{display:none}.product-grid{gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}.mobile-open-filters{align-items:center;display:inline-flex;justify-content:center}.mobile-filter-menu,.mobile-filter-overlay{display:block}}@media (max-width:480px){.product-grid{grid-template-columns:1fr}}.pd-container{color:var(--ink);margin:0 auto;max-width:960px;padding:28px 20px 56px}.pd-breadcrumbs{align-items:center;display:inline-flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}.pd-breadcrumb-link,.pd-breadcrumb-part{color:var(--muted);font-size:13px}.pd-breadcrumb-link{background:none;border:none;cursor:pointer;padding:0;text-decoration:underline}.pd-breadcrumb-sep{color:var(--muted)}.pd-breadcrumb-part.current{color:var(--ink);font-weight:700}.pd-back-mobile{display:none}.pd-grid{grid-gap:28px;align-items:start;display:grid;gap:28px;grid-template-columns:360px 1fr;margin-bottom:36px}.pd-image-card{align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:1.25rem;display:flex;flex-direction:column;padding:24px}.pd-image-wrap{display:flex;justify-content:center;position:relative;width:100%}.pd-image{background:var(--surface-soft);border-radius:12px;max-height:280px;object-fit:contain;width:100%}.pd-image-nav{align-items:center;background:#ffffffeb;border:1px solid var(--line);border-radius:999px;color:var(--ink);cursor:pointer;display:flex;font-size:20px;height:30px;justify-content:center;line-height:1;position:absolute;top:50%;transform:translateY(-50%);width:30px}.pd-image-nav-prev{left:8px}.pd-image-nav-next{right:8px}.pd-image-dots{align-items:center;display:flex;gap:6px;justify-content:center;margin-top:10px}.pd-image-dot{background:var(--line);border:none;border-radius:999px;cursor:pointer;height:8px;width:8px}.pd-image-dot.active{background:var(--accent)}.pd-ean{align-items:center;color:var(--muted);display:flex;font-size:13px;gap:8px;margin-top:16px}.pd-ean-icon{font-size:16px;letter-spacing:-2px}.pd-info{display:flex;flex-direction:column}.pd-brand-badge{background:var(--success-soft);border-radius:999px;color:var(--accent-green-strong);display:inline-block;font-size:13px;font-weight:600;margin-bottom:10px;padding:4px 14px;width:fit-content}.pd-name{font-size:clamp(1.35rem,2.5vw,1.8rem);font-weight:700;line-height:1.25;margin:0 0 12px}.pd-unit-row{align-items:center;color:var(--muted);display:flex;font-size:14px;gap:6px;margin-bottom:18px}.pd-best-card{background:var(--success-soft);border:1px solid var(--success-border);border-radius:1rem;margin-bottom:18px;padding:18px 20px}.pd-best-label{color:var(--accent-green-strong);font-size:12px;font-weight:600;letter-spacing:.05em;margin:0 0 6px;text-transform:uppercase}.pd-best-price-row{align-items:baseline;display:flex;flex-wrap:wrap;gap:10px}.pd-best-price{color:var(--accent-green);font-size:2.4rem;font-weight:800;line-height:1}.pd-best-super{align-items:center;color:var(--accent-green-strong);display:inline-flex;font-size:1rem;font-weight:600;gap:8px}.pd-supermarket-logo{flex-shrink:0;height:26px;object-fit:contain;object-position:center;width:88px}.pd-supermarket-logo-link{align-items:center;display:inline-flex;line-height:0}.pd-best-unit{color:var(--accent-green);font-size:13px;margin:6px 0 2px}.pd-best-updated{color:var(--accent-green-strong);font-size:12px;margin:2px 0 0}.pd-actions-card{background:var(--surface);border:1px solid var(--line);border-radius:1rem;display:flex;flex-direction:column;gap:14px;margin-bottom:10px;padding:16px 20px}.pd-qty-row{align-items:center;display:flex;justify-content:space-between}.pd-qty-label{color:var(--ink);font-size:14px;font-weight:600}.pd-qty-stepper{gap:10px}.pd-qty-btn,.pd-qty-stepper{align-items:center;display:flex}.pd-qty-btn{background:var(--surface);border:1.5px solid var(--line);border-radius:8px;color:var(--ink);cursor:pointer;font-size:18px;height:34px;justify-content:center;line-height:1;transition:border-color .15s;width:34px}.pd-qty-btn:hover{border-color:var(--accent);color:var(--accent)}.pd-qty-value{font-size:16px;font-weight:700;min-width:36px;text-align:center}.pd-cart-row{display:flex;gap:10px}.pd-add-btn{background:var(--brand-navy);border:none;border-radius:10px;color:var(--text-on-accent);cursor:pointer;flex:1 1;font-size:15px;font-weight:700;padding:14px;transition:background .15s}.pd-add-btn:hover:not(:disabled){background:var(--accent-strong)}.pd-add-btn:disabled{background:var(--muted);cursor:not-allowed}.pd-fav-btn{align-items:center;background:var(--surface);border:1.5px solid var(--line);border-radius:10px;cursor:pointer;display:flex;flex-shrink:0;font-size:22px;height:50px;justify-content:center;transition:border-color .15s;width:50px}.pd-fav-btn--active,.pd-fav-btn:hover{border-color:var(--danger)}.pd-fav-btn--active{background:var(--danger-soft-alt)}.pd-refresh-link{background:none;border:none;color:var(--muted);cursor:pointer;display:inline;font-size:13px;padding:0;text-decoration:underline}.pd-refresh-link:hover{color:var(--ink)}.pd-refresh-link:disabled{cursor:not-allowed;opacity:.6}.pd-refresh-ok{color:var(--accent-green);font-size:13px;margin:4px 0 0}.pd-refresh-err{color:var(--danger);font-size:13px;margin:4px 0 0}.pd-comparison{margin-top:8px}.pd-comparison-title{font-size:1.25rem;font-weight:700;margin:0 0 16px}.pd-cards{display:flex;flex-direction:column;gap:12px}.pd-price-card{align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:1rem;display:flex;gap:16px;justify-content:space-between;padding:16px 20px}.pd-price-card--best{background:var(--success-soft);border:2px solid var(--success-border)}.pd-pc-left{align-items:center;display:flex;flex:1 1;gap:12px;min-width:0}.pd-pc-info{display:flex;flex-direction:column;gap:3px}.pd-pc-name-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.pd-pc-name{font-size:15px;font-weight:700}.pd-pc-badge{background:var(--accent-green);border-radius:999px;color:var(--text-on-accent);font-size:11px;font-weight:700;letter-spacing:.02em;padding:3px 9px}.pd-pc-unit{font-size:13px}.pd-pc-date,.pd-pc-unit{color:var(--muted);margin:0}.pd-pc-date{font-size:12px}.pd-pc-right{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:4px}.pd-pc-price{color:var(--ink);font-size:1.4rem;font-weight:800}.pd-pc-cheapest{background:var(--success-soft);color:var(--accent-green-strong)}.pd-pc-cheapest,.pd-pc-tied{border-radius:999px;font-size:11px;font-weight:700;padding:3px 9px}.pd-pc-tied{background:rgba(var(--accent-rgb),.16);color:var(--accent-strong)}.pd-pc-delta{color:var(--danger);font-size:1.1rem;font-weight:800}.pd-pc-pct{color:var(--danger);font-size:12px}.pd-loading{align-items:center;color:var(--muted);display:flex;font-size:16px;justify-content:center;min-height:60vh}.pd-carousel-section{border-top:1px solid var(--line);margin-top:36px;padding-top:28px}.pd-carousel-title{font-size:1.25rem;font-weight:700;margin:0 0 20px}.pd-carousel-container{align-items:center;display:flex;gap:16px;position:relative}.pd-carousel-btn{align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:8px;color:var(--accent);cursor:pointer;display:flex;flex-shrink:0;font-size:24px;height:40px;justify-content:center;transition:all .15s;width:40px}.pd-carousel-btn:hover:not(:disabled){background:var(--surface-soft);border-color:var(--accent)}.pd-carousel-btn:disabled{cursor:not-allowed;opacity:.4}.pd-carousel-viewport{border-radius:12px;flex:1 1;overflow:hidden}.pd-carousel-track{display:flex;gap:16px;transition:transform .3s ease}.pd-carousel-item{display:flex;flex-basis:calc(33.333% - 11px);flex-direction:column;flex-grow:0;flex-shrink:0;gap:12px}.pd-carousel-img-wrap{align-items:center;background:var(--surface-soft);border:1px solid var(--line);border-radius:12px;display:flex;justify-content:center;min-height:200px;padding:12px;position:relative}.pd-carousel-img{border-radius:8px;height:100%;max-height:200px;object-fit:contain;width:100%}.pd-carousel-badge-current{background:var(--accent);border-radius:999px;color:var(--text-on-accent);font-size:11px;font-weight:700;padding:4px 10px;position:absolute;right:8px;top:8px}.pd-carousel-name{color:var(--ink);font-size:14px;font-weight:600;line-height:1.3;margin:0}.pd-carousel-price{align-items:center;color:var(--accent-green);display:flex;font-size:1.2rem;font-weight:800;gap:6px;margin:0}.pd-carousel-store{align-items:center;display:inline-flex}.pd-carousel-link{background:var(--accent);border:none;border-radius:8px;color:var(--text-on-accent);cursor:pointer;font-size:13px;font-weight:700;padding:10px;transition:background .15s}.pd-carousel-link:hover{background:var(--accent-strong)}@media (max-width:720px){.pd-breadcrumbs{display:none}.pd-back-mobile{align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:10px;color:var(--accent);cursor:pointer;display:inline-flex;font-size:22px;height:38px;justify-content:center;line-height:1;margin-bottom:12px;width:38px}.pd-grid{grid-template-columns:1fr}.pd-image-card{margin:0 auto;max-width:380px;width:100%}.pd-carousel-item{flex-basis:calc(50% - 8px);flex-grow:0;flex-shrink:0}.pd-supermarket-logo{height:24px;width:80px}}@media (max-width:480px){.pd-best-price{font-size:1.9rem}.pd-price-card{flex-direction:column;padding:14px 16px}.pd-pc-right,.pd-price-card{align-items:flex-start;gap:10px}.pd-pc-right{align-items:center;flex-direction:row}.pd-carousel-item{flex-basis:100%;flex-grow:0;flex-shrink:0}.pd-carousel-container{gap:10px}.pd-actions-card{padding:14px 16px}}.cart-page{background:var(--surface);bottom:0;display:flex;flex-direction:column;left:0;overflow:hidden;position:fixed;right:0;top:0;z-index:9999}@keyframes cartSlideInUp{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}.cart-page-header{align-items:center;background:var(--surface);border-bottom:1px solid var(--line);display:flex;justify-content:space-between;padding:2rem}.cart-page-title{color:var(--ink);font-size:1.875rem;font-weight:700;margin:0}.cart-page-count{color:var(--muted);font-size:.875rem;margin:.25rem 0 0}.cart-header-buttons{align-items:center;display:flex;gap:1rem}.cart-clear-btn{background:var(--accent);border:none;border-radius:var(--radius-sm);color:var(--text-on-accent);cursor:pointer;font-size:.875rem;font-weight:600;padding:.625rem 1.25rem;transition:background .2s ease}.cart-clear-btn:hover{background:var(--accent-strong)}.cart-close-btn{align-items:center;background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--muted);cursor:pointer;display:flex;font-size:1.25rem;font-weight:400;justify-content:center;line-height:1;padding:.625rem .875rem;transition:all .2s ease}.cart-close-btn:hover{background:var(--line);color:var(--ink)}.cart-page-content{grid-gap:0;display:grid;flex:1 1;gap:0;grid-template-columns:1.5fr 1fr;overflow:hidden}.cart-items-section{border-right:1px solid var(--line);flex:1 1;overflow-y:auto;padding:2rem}.cart-items-list{display:flex;flex-direction:column;gap:1rem}.cart-item-row{grid-gap:1rem;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);display:grid;gap:1rem;grid-template-columns:60px 1fr auto auto auto;padding:1rem;transition:box-shadow .2s ease}.cart-item-row:hover{box-shadow:0 4px 12px #00000014}.cart-item-image{background:var(--surface-soft);border-radius:8px;height:60px;overflow:hidden;width:60px}.cart-item-image img{height:100%;object-fit:cover;width:100%}.cart-item-info{display:flex;flex-direction:column;gap:.25rem}.cart-item-brand{color:var(--muted);font-size:.75rem;letter-spacing:.5px;margin:0;text-transform:uppercase}.cart-item-name{color:var(--ink);font-size:.9375rem;font-weight:600;line-height:1.3;margin:0}.cart-item-qty{align-items:center;background:var(--surface-soft);border:1px solid var(--line);border-radius:6px;display:flex;gap:.5rem;padding:.25rem}.qty-btn{background:#0000;border:none;border-radius:4px;color:var(--ink);cursor:pointer;font-size:1rem;height:28px;transition:background .2s ease;width:28px}.qty-btn:hover{background:var(--line)}.qty-input{background:#0000;border:none;color:var(--ink);font-size:.875rem;font-weight:600;text-align:center;width:40px}.qty-input:focus{outline:none}.cart-item-price{color:var(--ink);font-size:1rem;font-weight:700;min-width:70px;text-align:right}.cart-item-delete{align-items:center;background:#0000;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:1.25rem;height:36px;justify-content:center;transition:background .2s ease;width:36px}.cart-item-delete:hover{background:var(--danger-soft)}.cart-comparison-section{background:var(--surface-soft);display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto;padding:2rem}.comparison-header{margin-bottom:.5rem}.comparison-header h2{color:var(--ink);font-size:1.125rem;font-weight:700;margin:0}.scenario-card-highlighted{background:linear-gradient(135deg,rgba(var(--accent-rgb),.18) 0,#22b8a629 100%);border:2px solid rgba(var(--accent-rgb),.35);border-radius:12px;box-shadow:0 4px 20px rgba(var(--accent-rgb),.2);margin-bottom:1rem;padding:1.5rem;text-align:center}.scenario-badge{background:linear-gradient(135deg,var(--brand-navy),var(--brand-teal));border-radius:20px;color:var(--text-on-accent);display:inline-block;font-size:.8125rem;font-weight:700;letter-spacing:.5px;margin-bottom:.75rem;padding:.5rem 1rem}.scenario-amt{color:var(--accent-green);font-size:2.5rem;font-weight:800;line-height:1;margin:.75rem 0}.scenario-desc{color:var(--ink);font-size:.875rem;font-weight:500;margin:.75rem 0 1rem}.scenario-stores{border-top:1px solid rgba(var(--accent-rgb),.35);display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;padding-top:1rem}.store-badge{align-items:center;background:#ffffffad;border-radius:8px;color:var(--ink);display:flex;font-size:.8125rem;font-weight:600;gap:.5rem;padding:.5rem .75rem}.supermarket-logo{flex-shrink:0;height:26px;object-fit:contain;object-position:center;width:88px}.supermarket-logo-link{align-items:center;display:inline-flex;line-height:0}.store-name{flex:1 1}.store-count{color:var(--muted);font-size:.75rem;margin-left:auto;opacity:.8;text-align:right;white-space:nowrap}.scenarios-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr}.supermarket-podium{align-items:flex-end;display:flex;gap:12px;justify-content:center;padding:8px 0 2px}.podium-item{align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:12px 12px 8px 8px;box-shadow:var(--shadow-sm);display:flex;flex:1 1;flex-direction:column;justify-content:flex-start;min-width:0;padding:10px 8px;text-align:center}.podium-item.first{background:linear-gradient(180deg,rgba(var(--accent-rgb),.22) 0,#22b8a633 100%);border-color:rgba(var(--accent-rgb),.35);min-height:184px}.podium-item.second{background:linear-gradient(180deg,var(--surface-soft) 0,var(--surface-soft-2) 100%);min-height:156px}.podium-item.third{background:linear-gradient(180deg,rgba(var(--accent-rgb),.16) 0,rgba(var(--accent-rgb),.28) 100%);border-color:rgba(var(--accent-rgb),.3);min-height:138px}.podium-pill{background:#fffc;border-radius:999px;color:var(--ink);font-size:11px;font-weight:800;margin-bottom:8px;padding:4px 10px}.podium-icon{align-items:center;display:inline-flex;justify-content:center;min-height:26px}.podium-store{color:var(--ink);font-size:13px;font-weight:700;margin-top:8px;word-break:break-word}.podium-price{color:var(--accent-green-strong);font-size:16px;font-weight:800;margin-top:8px}.scenario-card-alt{grid-gap:1rem;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:10px;display:grid;gap:1rem;grid-template-columns:32px 1fr auto;padding:1rem;transition:all .2s ease}.scenario-card-alt:hover{border-color:var(--accent);box-shadow:0 2px 8px rgba(var(--accent-rgb),.1)}.scenario-rank{color:var(--muted);font-size:1.375rem;font-weight:700;text-align:center;width:32px}.scenario-store{color:var(--ink);font-size:.9375rem;font-weight:600}.scenario-price{color:var(--accent-green);font-size:1.25rem;font-weight:700}.savings-badge{background:linear-gradient(135deg,var(--success-soft) 0,var(--success-soft-2) 100%);border:1px solid var(--success-border);border-radius:10px;color:var(--accent-green-strong);font-size:.875rem;font-weight:600;margin-top:.5rem;padding:1rem;text-align:center}.cart-empty{align-items:center;color:var(--muted);display:flex;flex:1 1;font-size:1rem;justify-content:center}.cart-page-open{overflow:hidden}@media (max-width:1024px){.cart-page-content{grid-template-columns:1fr}.cart-items-section{border-bottom:1px solid var(--line);border-right:none}.cart-comparison-section{background:var(--surface)}}@media (max-width:768px){.cart-page{animation:cartSlideInUp .24s ease}.cart-page-header{padding:1rem}.cart-page-title{font-size:1.5rem}.cart-comparison-section,.cart-items-section{padding:1rem}.cart-item-row{gap:.75rem;grid-template-columns:50px 1fr}.cart-item-delete,.cart-item-price,.cart-item-qty{grid-column:2}.scenario-amt{font-size:1.875rem}.supermarket-podium{gap:8px}.podium-item.first{min-height:160px}.podium-item.second{min-height:142px}.podium-item.third{min-height:128px}.cart-clear-btn{font-size:.8125rem;padding:.5rem 1rem}.supermarket-logo{height:24px;width:80px}}@media (prefers-reduced-motion:reduce){.cart-page{animation:none!important}}@media (max-width:480px){.cart-page-header{align-items:flex-start;flex-direction:column;gap:1rem;padding:.75rem}.cart-page-content{display:flex;flex-direction:column}.cart-page-title{font-size:1.25rem}.cart-comparison-section,.cart-items-section{padding:.75rem}.cart-item-row{grid-template-columns:40px 1fr}.scenario-amt{font-size:1.5rem}.podium-store{font-size:12px}.podium-price{font-size:14px}}.scanner-overlay{align-items:flex-end;background:var(--overlay-strong);display:flex;inset:0;justify-content:center;position:fixed;z-index:400}@media (min-width:480px){.scanner-overlay{align-items:center}}.scanner-modal{background:var(--surface);border-radius:1.5rem 1.5rem 0 0;display:flex;flex-direction:column;gap:20px;max-height:92vh;max-width:480px;overflow-y:auto;padding:20px 20px calc(20px + env(safe-area-inset-bottom, 0px));width:100%}@media (min-width:480px){.scanner-modal{border-radius:1.5rem;max-height:80vh;padding:24px}}.scanner-header{align-items:center;display:flex;justify-content:space-between}.scanner-header h3{color:var(--ink);font-size:18px;font-weight:700}.scanner-close{align-items:center;background:var(--surface-soft);border:none;border-radius:50%;color:var(--muted);cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;transition:background .2s,color .2s;width:32px}.scanner-close:hover{background:var(--danger-soft);color:var(--danger)}.scanner-camera-wrap{align-items:center;aspect-ratio:4/3;background:var(--ink-deep);border-radius:var(--radius-md);display:flex;justify-content:center;overflow:hidden;position:relative}.scanner-video{display:block;height:100%;object-fit:cover;width:100%}.scanner-video-hidden{display:none}.scanner-html5-reader{display:none;height:100%;width:100%}.scanner-html5-reader-active{display:block}.scanner-html5-reader>div{border:none!important}.scanner-html5-reader video{height:100%!important;object-fit:cover!important;width:100%!important}.scanner-html5-reader #reader__dashboard,.scanner-html5-reader #reader__scan_region>img,.scanner-html5-reader img{display:none!important}.scanner-viewfinder{align-items:center;display:flex;inset:0;justify-content:center;pointer-events:none;position:absolute}.scanner-viewfinder:before{border:2.5px solid #ffffffd9;border-radius:8px;box-shadow:0 0 0 9999px var(--overlay-soft);content:"";height:36%;width:70%}.scanner-hint{bottom:12px;color:var(--text-on-accent);font-size:13px;font-weight:500;left:0;position:absolute;right:0;text-align:center;text-shadow:0 1px 3px #0009}.scanner-no-camera{align-items:center;background:var(--surface-soft);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:12px;padding:28px 16px;text-align:center}.scanner-camera-icon{font-size:3rem;opacity:.5}.scanner-no-camera p{color:var(--muted);font-size:14px;line-height:1.5}.scanner-divider{align-items:center;color:var(--muted);display:flex;font-size:13px;gap:12px}.scanner-divider:after,.scanner-divider:before{background:var(--line);content:"";flex:1 1;height:1px}.scanner-manual-label{color:var(--muted);font-size:13px;font-weight:600;margin-bottom:-8px}.scanner-manual-form{display:flex;gap:8px}.scanner-manual-input{background:var(--surface-soft);border:1.5px solid var(--line);border-radius:var(--radius-sm);color:var(--ink);flex:1 1;font-size:15px;padding:11px 14px;transition:border-color .2s,box-shadow .2s}.scanner-manual-input:focus{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.12);outline:none}.scanner-manual-btn{background:var(--accent);border:none;border-radius:var(--radius-sm);color:var(--text-on-accent);cursor:pointer;font-size:14px;font-weight:700;padding:11px 18px;transition:background .2s,transform .15s;white-space:nowrap}.scanner-manual-btn:hover{background:var(--accent-strong);transform:translateY(-1px)}.bottom-nav{display:none}@media (max-width:768px){.bottom-nav{align-items:center;background:var(--surface);border-top:1px solid var(--line);bottom:0;box-shadow:0 -4px 20px #00000014;display:flex;height:calc(64px + env(safe-area-inset-bottom, 0px));justify-content:space-around;left:0;padding-bottom:env(safe-area-inset-bottom,0);position:fixed;right:0;z-index:200}}.bottom-nav-tab{-webkit-tap-highlight-color:transparent;align-items:center;background:#0000;border:none;color:var(--muted);cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:4px;justify-content:center;padding:8px 0;position:relative;transition:color .18s}.bottom-nav-tab:active{color:var(--accent);transform:scale(.95)}.bottom-nav-tab-icon{fill:currentColor;height:26px;width:26px}.bottom-nav-tab-label{font-size:10px;font-weight:600;letter-spacing:.02em}.bottom-nav-tab-active{color:var(--accent)}.bottom-nav-badge{background:var(--danger);border:1.5px solid var(--surface);border-radius:50%;color:var(--text-on-accent);font-size:10px;font-weight:800;height:16px;line-height:1;min-width:16px;padding:0 3px;position:absolute;right:calc(50% - 22px);top:4px}.bottom-nav-badge,.bottom-nav-fab-wrap{align-items:center;display:flex;justify-content:center}.bottom-nav-fab-wrap{flex:0 0 72px;margin-top:-28px}.bottom-nav-fab{-webkit-tap-highlight-color:transparent;align-items:center;background:linear-gradient(135deg,var(--brand-blue) 0,var(--brand-teal) 100%);border:none;border-radius:50%;box-shadow:0 4px 16px rgba(var(--accent-rgb),.4),0 1px 4px #00000026;color:var(--text-on-accent);cursor:pointer;display:flex;height:60px;justify-content:center;transition:transform .2s,box-shadow .2s;width:60px}.bottom-nav-fab:active{box-shadow:0 2px 8px rgba(var(--accent-rgb),.35);transform:scale(.92)}.bottom-nav-fab svg{fill:var(--text-on-accent);display:block;height:28px;margin:0 auto;width:28px}.barcode-popup-overlay{align-items:center;background:var(--overlay);display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:420}.barcode-popup{grid-gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);display:grid;gap:10px;padding:16px;width:min(360px,calc(100vw - 28px))}.barcode-popup h3{color:var(--ink);font-size:18px;margin:0}.barcode-popup-header{align-items:center;display:flex;gap:8px;justify-content:space-between}.barcode-popup-header h3{color:var(--ink);font-size:18px;margin:0}.barcode-popup-close-x{align-items:center;background:var(--surface-soft);border:none;border-radius:8px;color:var(--ink);cursor:pointer;display:flex;flex-shrink:0;font-size:16px;height:32px;justify-content:center;line-height:1;transition:background .15s;width:32px}.barcode-popup-close-x:hover{background:var(--line)}.barcode-popup p{color:var(--muted);line-height:1.45;margin:0}.barcode-popup-btn{background:var(--accent);border:none;border-radius:10px;color:var(--text-on-accent);cursor:pointer;font-weight:700;padding:10px 12px}.barcode-popup-btn:hover{background:var(--accent-strong)}.barcode-popup-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}.barcode-popup-btn.secondary{background:var(--line);color:var(--ink)}.barcode-popup-btn.secondary:hover{background:var(--line)}.barcode-loader-popup{gap:12px;justify-items:center;text-align:center}.barcode-loader-spinner{animation:barcode-spin .9s linear infinite;border:3px solid var(--line);border-radius:999px;border-top-color:var(--accent);height:34px;width:34px}@keyframes barcode-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (prefers-reduced-motion:reduce){.barcode-loader-spinner{animation:none}}.install-gate-overlay{align-items:center;background:linear-gradient(160deg,#1f4a79f2,#1f4a79e6 45%,#2e9ccfd6);display:flex;inset:0;justify-content:center;padding:18px;position:fixed;z-index:12000}.install-gate-card{grid-gap:14px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff5;border:1px solid #ffffff6b;border-radius:20px;box-shadow:0 26px 56px #00000061;display:grid;gap:14px;padding:22px 20px 18px;width:min(440px,calc(100vw - 32px))}.install-gate-pill{background:rgba(var(--accent-rgb),.12);border-radius:999px;color:var(--accent-strong);font-size:12px;font-weight:700;justify-self:start;padding:6px 12px}.install-gate-card h2{color:var(--ink);font-size:28px;letter-spacing:-.02em;line-height:1.1;margin:0}.install-gate-card p{color:var(--muted);font-size:15px;line-height:1.5;margin:0}.install-gate-primary,.install-gate-secondary{border:none;border-radius:12px;cursor:pointer;font-size:16px;font-weight:700;padding:13px 14px}.install-gate-primary{background:linear-gradient(135deg,var(--brand-blue) 0,var(--brand-teal) 100%);color:var(--text-on-accent)}.install-gate-secondary{background:var(--line);color:var(--ink)}.install-gate-ios-help{grid-gap:10px;display:grid;gap:10px}.install-gate-note{color:var(--muted);font-size:12px}@media (min-width:769px){.install-gate-overlay{display:none}}.ad-slot{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.ad-slot-label{background:var(--surface-soft);border-bottom:1px solid var(--line);color:var(--muted);display:block;font-size:11px;font-weight:700;letter-spacing:.06em;padding:8px 10px;text-transform:uppercase}.ad-slot .adsbygoogle{min-height:90px}.ad-slot--rail .adsbygoogle{min-height:280px}.ad-slot--mobile .adsbygoogle{min-height:72px}.app-footer{background:var(--surface-soft);border-top:1px solid var(--line);padding:20px 16px calc(80px + env(safe-area-inset-bottom, 0px));text-align:center;width:100%}.app-footer-link{color:var(--muted);font-size:.875rem;text-decoration:none}.app-footer-link:hover{color:var(--accent);text-decoration:underline}@media (min-width:769px){.app-footer{padding:20px 16px}}.contact-page{margin:60px auto;max-width:480px;padding:0 20px;text-align:center}.contact-title{color:var(--ink);font-size:1.6rem;font-weight:700;margin-bottom:32px}.contact-card{align-items:center;background:var(--surface-soft);border:1px solid var(--line);border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:32px 24px}.contact-name{color:var(--ink);font-size:1.15rem;font-weight:600}.contact-email{color:var(--accent);font-size:1rem;text-decoration:none}.contact-email:hover{text-decoration:underline}*{box-sizing:border-box;margin:0;padding:0}.App{display:flex;flex-direction:column;min-height:100vh}.app-shell{margin:0 auto;width:100%}.app-shell--with-rails{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:minmax(0,180px) minmax(0,1160px) minmax(0,180px);max-width:1440px}.app-shell--single{max-width:1160px}.desktop-ad-rail{align-self:start;position:sticky;top:88px}.desktop-ad-rail:empty,.mobile-ad-wrap:empty{display:none}.mobile-ad-wrap{display:none;margin:8px auto 0;max-width:1160px;padding:0 20px;width:100%}.main-content{flex:1 1;padding:24px 20px 56px;width:100%}.route-fade{animation:routeFadeIn .22s ease}@keyframes routeFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.route-fade{animation:none}}@media (max-width:1280px){.app-shell--with-rails{gap:14px;grid-template-columns:minmax(0,150px) minmax(0,1fr) minmax(0,150px)}}@media (min-width:769px){.header-menu-btn{display:none}}@media (max-width:768px){.app-shell,.app-shell--single,.app-shell--with-rails{display:block;max-width:1160px}.desktop-ad-rail{display:none}.mobile-ad-wrap{display:block;padding:0 12px}.main-content{padding:16px 12px calc(80px + env(safe-area-inset-bottom, 0px))}}:root{--ink:#1d3553;--muted:#5d7087;--line:#d6e4ed;--surface:#fff;--surface-soft:#f3f8fb;--surface-soft-2:#e8f1f7;--accent:#2e9ccf;--accent-strong:#1f4a79;--accent-green:#22b8a6;--accent-green-strong:#1a9d8f;--brand-navy:#1f4a79;--brand-blue:#2e9ccf;--brand-teal:#22b8a6;--accent-rgb:46,156,207;--warm:#dff4ff;--text-on-accent:#fff;--overlay:#00000080;--overlay-strong:#000000b3;--overlay-soft:#00000061;--danger:#dc2626;--danger-soft:#fee2e2;--danger-soft-strong:#fbded9;--danger-border:#f1c6c1;--danger-soft-alt:#fff1f2;--success-soft:#e8f8f4;--success-soft-2:#e2f6f1;--success-border:#bfe9df;--ink-deep:#000;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--radius-sm:0.625rem;--radius-md:1rem;--radius-lg:1.25rem;--radius-pill:999px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f3f8fb;background-color:var(--surface-soft);color:#1d3553;color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;padding-bottom:env(safe-area-inset-bottom,0)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root,body,html{height:100%;width:100%}body,html{overflow-x:hidden;overscroll-behavior-x:none;scroll-behavior:smooth;touch-action:pan-y}.pd-actions-card,.pd-image-card,.pd-price-card,.product-grid>*,a,button,input{transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease,opacity .2s ease}@media (prefers-reduced-motion:reduce){body,html{scroll-behavior:auto}.pd-actions-card,.pd-image-card,.pd-price-card,.product-grid>*,a,button,input{transition:none}}
/*# sourceMappingURL=main.be99b753.css.map*/