:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--font-size:16px;--background:oklch(14.5% 0 0);--foreground:oklch(98.5% 0 0);--card:oklch(18% 0 0);--card-foreground:oklch(98.5% 0 0);--muted:oklch(26.9% 0 0);--muted-foreground:oklch(70.8% 0 0);--primary:oklch(98.5% 0 0);--primary-foreground:oklch(20.5% 0 0);--accent:oklch(26.9% 0 0);--accent-foreground:oklch(98.5% 0 0);--border:oklch(26.9% 0 0);--input-background:oklch(22% 0 0);--ring:oklch(43.9% 0 0);--destructive:oklch(63.7% .237 25.331);--color-bg:var(--background);--color-bg-elevated:oklch(18% 0 0);--color-surface:var(--card);--color-surface-hover:oklch(24% 0 0);--color-border:var(--border);--color-border-subtle:oklch(22% 0 0);--color-text:var(--foreground);--color-text-muted:var(--muted-foreground);--color-text-faint:oklch(55% 0 0);--color-accent:var(--primary);--color-accent-on:var(--primary-foreground);--color-deal:oklch(72% .17 155);--color-deal-bg:oklch(28% .06 155);--color-deal-on:oklch(20% .05 155);--color-error:var(--destructive);--radius:.625rem;--radius-sm:calc(var(--radius) - 4px);--radius-md:calc(var(--radius) - 2px);--radius-lg:var(--radius);--radius-full:9999px;--space-xs:.25rem;--space-sm:.5rem;--space-md:.75rem;--space-lg:1rem;--space-xl:1.5rem;--space-2xl:2rem;--sidebar-width:16.5rem;--header-height:4rem;--compare-source-width:17rem;--compare-cell-padding:var(--space-sm);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:var(--font-size);color:var(--color-text);background:var(--color-bg);font-weight:400;line-height:1.5}*{box-sizing:border-box}body{background:var(--color-bg);min-height:100vh;margin:0}#root{flex-direction:column;width:100%;min-height:100vh;display:flex}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.app{flex-direction:column;flex:1;min-height:100vh;display:flex}.app-header{z-index:10;align-items:center;gap:var(--space-md) var(--space-lg);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);background:color-mix(in oklch, var(--color-bg) 92%, transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex-wrap:wrap;flex-shrink:0;display:flex;position:sticky;top:0}.app-header-brand{align-items:center;gap:var(--space-md);flex-shrink:0;min-width:0;display:flex}.app-logo{flex-shrink:0;font-size:1.25rem;line-height:1}.app-header h1{letter-spacing:-.01em;color:var(--color-text);margin:0;font-size:1.125rem;font-weight:500;line-height:1.4}.app-header .tagline{color:var(--color-text-muted);margin:.125rem 0 0;font-size:.8125rem}.app-header-search{flex:1;min-width:min(100%,14rem);max-width:28rem}.app-body{flex:1;min-height:0;display:flex;overflow:hidden}.app-content{padding:var(--space-lg);padding-bottom:var(--space-2xl);flex:1;overflow-y:auto}.filter-sidebar{width:var(--sidebar-width);border-right:1px solid var(--color-border);background:var(--color-bg);flex-shrink:0;overflow-y:auto}.filter-sidebar-inner{padding:var(--space-md) var(--space-lg) var(--space-lg);gap:var(--space-lg);flex-direction:column;display:flex}.filter-section{flex-direction:column;display:flex}.section-label,.filter-panel-title{margin:0 0 var(--space-sm);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-size:.6875rem;font-weight:600}.filter-panel{gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);background:var(--color-surface);flex-direction:column;display:flex}.filter-panel-title{margin-bottom:0}.filter-checkbox{color:var(--color-text);cursor:pointer;align-items:flex-start;gap:.5rem;font-size:.875rem;line-height:1.35;display:flex}.filter-checkbox input{accent-color:var(--color-accent);margin-top:.15rem}.filter-field-hint{color:var(--color-text-faint);margin:.35rem 0 0;font-size:.75rem;line-height:1.4}.filter-panel-note{color:var(--color-text-faint);margin:0;font-size:.6875rem;line-height:1.4}.filter-field{gap:var(--space-xs);flex-direction:column;display:flex}.filter-field-label{color:var(--color-text-muted);margin:0;font-size:.75rem;font-weight:500}.filter-control{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--input-background);width:100%;color:var(--color-text);padding:.4375rem .625rem;font-size:.8125rem}.filter-control:focus{border-color:var(--ring);box-shadow:0 0 0 1px var(--ring);outline:none}.filter-source-list{flex-direction:column;gap:.375rem;display:flex}.filter-source-btn{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--input-background);width:100%;color:var(--color-text);cursor:pointer;align-items:center;gap:.5rem;padding:.4375rem .625rem;font-size:.8125rem;font-weight:500;transition:background .15s,border-color .15s,color .15s;display:flex}.filter-source-btn:hover:not(.active){background:var(--color-surface-hover);border-color:var(--muted)}.filter-source-btn.active{border-color:var(--primary);background:var(--primary);color:var(--primary-foreground)}.filter-source-flag{flex-shrink:0;font-size:.9375rem;line-height:1}.filter-source-name{text-align:left;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.filter-source-state{text-transform:uppercase;letter-spacing:.04em;opacity:.55;flex-shrink:0;font-size:.625rem;font-weight:600}.filter-chip-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:.375rem;display:grid}.filter-chip{text-align:center;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--input-background);min-width:0;color:var(--color-text);cursor:pointer;padding:.375rem;font-size:.8125rem;font-weight:500;transition:background .15s,border-color .15s,color .15s}.filter-chip:hover:not(.active){background:var(--color-surface-hover);border-color:var(--muted)}.filter-chip.active{border-color:var(--primary);background:var(--primary);color:var(--primary-foreground)}.filter-range-row{align-items:center;gap:.375rem;display:flex}.filter-range-input{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--input-background);width:0;min-width:0;color:var(--color-text);appearance:textfield;flex:1;padding:.4375rem .5rem;font-size:.8125rem}.filter-range-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.filter-range-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.filter-range-input:focus{border-color:var(--ring);box-shadow:0 0 0 1px var(--ring);outline:none}.filter-range-sep{color:var(--color-text-faint);flex-shrink:0;font-size:.75rem}.filter-range-unit{color:var(--color-text-muted);flex-shrink:0;font-size:.75rem;font-weight:500}.filter-segmented{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--input-background);grid-template-columns:repeat(4,minmax(0,1fr));gap:.25rem;padding:.25rem;display:grid}.filter-segmented button{border-radius:calc(var(--radius-sm) - 2px);min-width:0;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:.375rem .25rem;font-size:.8125rem;font-weight:500;transition:background .15s,color .15s}.filter-segmented button.currency-symbol{padding:.4375rem .125rem;font-size:1.125rem;font-weight:600;line-height:1}.filter-segmented button:hover:not(.active){background:var(--color-surface-hover);color:var(--color-text)}.filter-segmented button.active{background:var(--primary);color:var(--primary-foreground)}.search-field{position:relative}.search-field:before{content:"";opacity:.55;width:.875rem;height:.875rem;color:var(--color-text-muted);pointer-events:none;background:currentColor;position:absolute;top:50%;left:.625rem;transform:translateY(-50%);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='white'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z'/%3E%3C/svg%3E") 50%/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='white'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z'/%3E%3C/svg%3E") 50%/contain no-repeat}.search-input{border-radius:var(--radius-md);background:var(--input-background);width:100%;color:var(--color-text);border:1px solid #0000;padding:.5rem .75rem .5rem 2rem;font-size:.875rem;transition:box-shadow .15s,border-color .15s}.search-input::placeholder{color:var(--color-text-muted)}.search-input:focus{border-color:var(--ring);box-shadow:0 0 0 1px var(--ring);outline:none}.status-message{margin:0 0 var(--space-lg);text-align:center;color:var(--color-text-muted);font-size:.875rem}.status-message--error{color:var(--color-error)}.status-message--empty{padding:var(--space-xl) var(--space-lg);border-radius:var(--radius-lg);background:var(--color-surface);border:1px dashed var(--color-border)}.results-count{margin:0 0 var(--space-md);color:var(--color-text-muted);font-size:.8125rem}.compare-columns{margin:0}.compare-scroll{-webkit-overflow-scrolling:touch;margin:0 calc(-1 * var(--space-lg));padding:0 var(--space-lg);overflow-x:auto}.compare-table{gap:var(--space-sm);flex-direction:column;width:fit-content;max-width:100%;margin-inline:auto;display:flex}.compare-row{gap:var(--space-sm);align-items:stretch;min-height:8rem;display:grid}.compare-row--header{min-height:auto;top:var(--compare-sticky-top,0);z-index:1;padding-bottom:var(--space-sm);background:var(--color-bg);border-bottom:1px solid var(--color-border);position:sticky}.compare-header-cell{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);padding:var(--compare-cell-padding);font-size:.75rem;font-weight:600}.compare-row--header>.compare-header-cell{max-width:var(--compare-source-width);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.compare-product-group{gap:var(--space-sm);flex-direction:column;display:flex}.compare-product-group--multi{padding-block:var(--space-sm);border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-bg) 92%, var(--muted));box-shadow:inset 0 0 0 1px var(--color-border);padding-inline:0}.compare-product-group-title{padding:0 var(--compare-cell-padding);color:var(--color-text);margin:0;font-size:.875rem;font-weight:600}.compare-row--size+.compare-row--size{border-top:1px dashed color-mix(in srgb, var(--color-border) 70%, transparent);padding-top:var(--space-sm)}.compare-row-tag{text-transform:uppercase;letter-spacing:.06em;border-radius:var(--radius-sm);background:var(--muted);color:var(--color-text-muted);align-self:flex-start;padding:.125rem .375rem;font-size:.625rem;font-weight:600}.compare-row-tag--derived{background:color-mix(in srgb, var(--accent) 18%, var(--muted));color:var(--foreground)}.compare-row-tag--multipack{background:color-mix(in srgb, var(--primary) 12%, var(--muted));color:var(--color-text-muted)}.compare-cell{width:var(--compare-source-width);max-width:var(--compare-source-width);padding:var(--compare-cell-padding);align-items:stretch;min-width:0;min-height:8rem;display:flex}.compare-cell .result-card{width:100%;height:100%}.compare-empty-hint{margin:var(--space-lg) 0 0;color:var(--color-text-muted);text-align:center;font-size:.875rem}.compare-empty{border:1px dashed var(--color-border-subtle);border-radius:var(--radius-md);width:100%;min-height:8rem;color:var(--color-text-faint);justify-content:center;align-items:center;font-size:1.25rem;display:flex}.result-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);flex-direction:column;transition:border-color .15s,box-shadow .15s;display:flex;position:relative;overflow:hidden}.result-card__debug-id{top:var(--space-xs);right:var(--space-xs);z-index:3;border:1px solid color-mix(in oklch, var(--color-accent) 50%, transparent);border-radius:var(--radius-sm);background:color-mix(in oklch, var(--color-bg) 85%, var(--color-accent));color:var(--color-text);letter-spacing:.02em;opacity:0;pointer-events:none;white-space:nowrap;padding:.125rem .375rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.6875rem;font-weight:600;line-height:1.2;transition:opacity .12s;position:absolute}.result-card--dev:hover .result-card__debug-id,.result-card--dev:focus-within .result-card__debug-id{opacity:1}.result-card:hover{border-color:color-mix(in oklch, var(--color-border) 70%, var(--color-text-muted));box-shadow:0 4px 24px oklch(0% 0 0/.25)}.result-card-link{min-height:0;color:inherit;flex-direction:column;flex:1;text-decoration:none;display:flex}.result-card--has-link:hover .result-name{text-underline-offset:.12em;text-decoration:underline}.result-card--has-link:focus-within{outline:2px solid var(--color-accent);outline-offset:2px}.result-card--compact{flex-direction:column}.result-card--compact .result-card-media{aspect-ratio:4/3;width:100%;height:auto;min-height:6.5rem;max-height:8.5rem;padding:var(--space-sm)}.result-card--compact .result-card-media img{object-fit:contain;width:auto;max-width:100%;height:auto;max-height:100%;padding:0;display:block}.result-card--compact .result-thumb-placeholder{width:1.5rem;height:1.5rem}.result-card--compact .result-card-body{padding:var(--space-sm) var(--space-md) var(--space-md);gap:.25rem}.result-card--compact .result-name{-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.875rem;display:-webkit-box;overflow:hidden}.result-card--compact .result-price{margin-top:var(--space-xs);font-size:1rem}.result-card--compact .result-per-litre{font-size:.75rem}.result-card--best{border-color:color-mix(in oklch, var(--color-deal) 40%, var(--color-border));background:color-mix(in oklch, var(--color-deal-bg) 60%, var(--color-surface))}.result-card-media{aspect-ratio:1;background:var(--muted);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.result-card-media img{object-fit:contain;width:100%;height:100%;padding:var(--space-md)}.result-thumb-placeholder{opacity:.35;background:var(--color-text-muted);width:3rem;height:3rem;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='white'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M4 16l4.586-4.586a2 2 0 012.828 0L16 16m-2-2l1.586-1.586a2 2 0 012.828 0L20 14m-6-6h.01M6 20h12a2 2 0 002-2V6a2 2 0 00-2-2H6a2 2 0 00-2 2v12a2 2 0 002 2z'/%3E%3C/svg%3E") 50%/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='white'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M4 16l4.586-4.586a2 2 0 012.828 0L16 16m-2-2l1.586-1.586a2 2 0 012.828 0L20 14m-6-6h.01M6 20h12a2 2 0 002-2V6a2 2 0 00-2-2H6a2 2 0 00-2 2v12a2 2 0 002 2z'/%3E%3C/svg%3E") 50%/contain no-repeat}.badge{top:var(--space-sm);right:var(--space-sm);border-radius:var(--radius-sm);align-items:center;padding:.2rem .5rem;font-size:.6875rem;font-weight:600;display:inline-flex;position:absolute}.badge--deal{background:color-mix(in oklch, var(--color-deal) 30%, transparent);color:var(--color-deal)}.badge--special-order{left:var(--space-sm);background:color-mix(in oklch, var(--color-text-muted) 25%, var(--color-surface));color:var(--color-text-muted);border:1px solid color-mix(in oklch, var(--color-border) 80%, transparent);right:auto}.result-card-body{padding:var(--space-md) var(--space-lg) var(--space-lg);flex-direction:column;gap:.25rem;min-width:0;display:flex}.result-brand{color:var(--color-text-muted);margin:0;font-size:.75rem}.result-name{color:var(--color-text);margin:0;font-size:.9375rem;font-weight:500;line-height:1.35}.result-category{color:var(--color-text-muted);margin:0;font-size:.75rem}.source-badge{margin-top:var(--space-xs);border-radius:var(--radius-full);background:var(--accent);color:var(--accent-foreground);align-self:flex-start;padding:.125rem .5rem;font-size:.6875rem;font-weight:500;display:inline-block}.result-price{margin:var(--space-sm) 0 0;color:var(--color-text);font-size:1rem;font-weight:600}.result-price-note,.result-per-litre{color:var(--color-text-muted);margin:0;font-size:.75rem}.app-footer{padding:var(--space-lg);border-top:1px solid var(--color-border);text-align:center;background:var(--color-bg-elevated);flex-shrink:0;margin-top:auto}.app-footer p{margin:0 0 var(--space-xs);color:var(--color-text-muted);font-size:.75rem;line-height:1.5}.app-footer p:last-child{margin-bottom:0}.api-status{right:var(--space-lg);bottom:var(--space-lg);z-index:40;max-width:min(22rem, calc(100vw - 2 * var(--space-lg)));position:fixed}.api-status-trigger{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.8125rem;line-height:1.3;display:inline-flex;box-shadow:0 4px 24px #00000059}.api-status-trigger:hover{background:var(--color-surface-hover)}.api-status-dot{border-radius:var(--radius-full);flex-shrink:0;width:.5rem;height:.5rem}.api-status-dot--ok{background:var(--color-deal)}.api-status-dot--error{background:var(--color-error)}.api-status-panel{margin-top:var(--space-sm);padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-elevated);box-shadow:0 8px 32px #00000073}.api-status-section+.api-status-section{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle)}.api-status-heading{margin:0 0 var(--space-sm);letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);font-size:.6875rem;font-weight:600}.api-status-dl{gap:var(--space-sm);margin:0;display:grid}.api-status-dl div{gap:.125rem;display:grid}.api-status-dl dt{color:var(--color-text-faint);margin:0;font-size:.75rem}.api-status-dl dd{color:var(--color-text);margin:0;font-size:.8125rem}.api-status-muted{color:var(--color-text-muted);font-size:.75rem}.api-status-error-text{color:var(--color-error)}.api-status-badge{border-radius:var(--radius-full);padding:.125rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.api-status-badge--ok{background:var(--color-deal-bg);color:var(--color-deal)}.api-status-badge--error{color:var(--color-error);background:oklch(28% .06 25)}.api-status-source-list{gap:var(--space-sm);margin:0;padding:0;list-style:none;display:grid}.api-status-source-list li{flex-direction:column;gap:.125rem;display:flex}.api-status-source-name{font-size:.8125rem;font-weight:500}.api-status-source-meta{color:var(--color-text-muted);font-size:.75rem}.api-status-actions{align-items:center;gap:var(--space-sm);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle);flex-wrap:wrap;display:flex}.api-status-refresh{padding:var(--space-xs) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.75rem}.api-status-refresh:hover:not(:disabled){background:var(--color-surface-hover)}.api-status-refresh:disabled{opacity:.6;cursor:not-allowed}@media (width<=47.99rem){.app{--compare-sticky-top:var(--header-height)}.app-body{flex-direction:column;overflow:visible}.filter-sidebar{border-right:none;border-bottom:1px solid var(--color-border);width:100%;max-height:none}.filter-sidebar-inner{gap:var(--space-md);padding:var(--space-md) var(--space-lg);flex-direction:column;display:flex}.filter-panel{gap:var(--space-sm)}.app-content{overflow:visible}}
