:root{--color-bg: #f7f6f3;--color-surface: #ffffff;--color-surface-raised: #f1efec;--color-border: #e8e6e1;--color-line-strong: #1c1b19;--color-ink: #1c1b19;--color-ink-muted: #8a8884;--color-accent: #C8A800;--color-accent-ink: #1c1b19;--color-accent-soft: rgba(200, 168, 0, .12);--color-danger: #c2452f;--color-success: #3f9b6b;--color-scrim: rgba(0, 0, 0, .6);--color-shadow-cast: #000;--shadow-card: 4px 4px 0 var(--color-line-strong);--shadow-card-hover: 7px 7px 0 var(--color-line-strong);--shadow-card-active: 1px 1px 0 var(--color-line-strong);--shadow-soft: 0 1px 2px rgba(27, 25, 22, .06), 0 8px 24px rgba(27, 25, 22, .06);--shadow-menu: 0 4px 12px rgba(0, 0, 0, .2);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-6: 24px;--space-8: 32px;--space-12: 48px;--space-16: 64px;--font-sans: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Mono", monospace;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-lg: 18px;--text-xl: 22px;--text-2xl: 28px;--leading-tight: 1.2;--leading-base: 1.5;--radius-none: 0;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 18px;--radius-full: 9999px;--sidebar-w: 268px;--ease-out: cubic-bezier(.16, 1, .3, 1);--duration-fast: .12s;--duration-base: .24s;color-scheme:light}:root[data-theme=dark]{--color-bg: #161618;--color-surface: #212124;--color-surface-raised: #2a2a2e;--color-border: #34343a;--color-line-strong: #34343a;--color-ink: #ededee;--color-ink-muted: #95959a;--color-accent: #F5C000;--color-accent-ink: #161618;--color-accent-soft: rgba(245, 192, 0, .16);--color-danger: #e0654b;--color-success: #5ab588;--shadow-card: 4px 4px 0 #000;--shadow-card-hover: 7px 7px 0 #000;--shadow-card-active: 1px 1px 0 #000;--shadow-soft: 0 1px 2px rgba(0, 0, 0, .4), 0 10px 28px rgba(0, 0, 0, .45);color-scheme:dark}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--color-bg: #161618;--color-surface: #212124;--color-surface-raised: #2a2a2e;--color-border: #34343a;--color-line-strong: #34343a;--color-ink: #ededee;--color-ink-muted: #95959a;--color-accent: #F5C000;--color-accent-ink: #161618;--color-accent-soft: rgba(245, 192, 0, .16);--color-danger: #e0654b;--color-success: #5ab588;--shadow-card: 4px 4px 0 #000;--shadow-card-hover: 7px 7px 0 #000;--shadow-card-active: 1px 1px 0 #000;--shadow-soft: 0 1px 2px rgba(0, 0, 0, .4), 0 10px 28px rgba(0, 0, 0, .45);color-scheme:dark}}.shell{display:flex;flex-direction:row;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);flex-shrink:0;display:flex;flex-direction:column;background:var(--color-bg);border-right:1px solid var(--color-border);overflow:hidden;transition:width var(--duration-base) var(--ease-out),margin-left var(--duration-base) var(--ease-out),opacity var(--duration-fast) var(--ease-out)}.shell.is-collapsed .sidebar{margin-left:calc(-1 * var(--sidebar-w));opacity:0;pointer-events:none}.sidebar-head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-4) var(--space-4) var(--space-3);flex-shrink:0}.app-logo{font-family:var(--font-mono);font-size:var(--text-base);font-weight:700;letter-spacing:-.03em;white-space:nowrap}.app-logo:before{content:"〜";color:var(--color-accent);margin-right:4px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);color:var(--color-ink-muted);font-size:var(--text-lg);line-height:1;transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.icon-btn:hover{background:var(--color-surface-raised);color:var(--color-ink)}.sidebar-open{position:absolute;top:var(--space-4);left:var(--space-4);z-index:20;width:38px;height:38px;background:var(--color-surface);border:2px solid transparent;box-shadow:var(--shadow-card);color:var(--color-ink);opacity:0;transform:scale(.85);pointer-events:none;transition:opacity var(--duration-base) var(--ease-out),transform var(--duration-base) var(--ease-out),box-shadow var(--duration-base) var(--ease-out)}.shell.is-collapsed .sidebar-open{opacity:1;transform:scale(1);pointer-events:auto}.shell.is-collapsed .sidebar-open:hover{background:var(--color-surface);color:var(--color-ink);box-shadow:var(--shadow-card-hover);transform:translate(-2px,-2px)}.search-input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-sm);background:var(--color-surface);border:0;outline:0;font:inherit;color:var(--color-ink)}.search-input::placeholder{color:var(--color-ink-muted)}.sidebar-scroll{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-6);padding:var(--space-2) var(--space-4) var(--space-4)}.sidebar-section{display:flex;flex-direction:column;gap:var(--space-2)}.section-head{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-1) 2px;border-radius:var(--radius-sm);text-align:left;transition:color var(--duration-fast) var(--ease-out)}.section-head .section-label{flex-shrink:0}.section-summary{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right;font-size:var(--text-xs);font-weight:600;color:var(--color-accent);letter-spacing:.02em}.sidebar-section:not(.is-collapsed) .section-summary{display:none}.section-chevron{flex-shrink:0;font-size:var(--text-base);line-height:1;color:var(--color-ink-muted);transform:rotate(90deg);transition:transform var(--duration-base) var(--ease-out)}.sidebar-section.is-collapsed .section-chevron{transform:rotate(0)}.section-head:hover .section-chevron{color:var(--color-ink)}.sidebar-section.is-collapsed .section-body{display:none}.chip-row,.toggle-row{display:flex;flex-wrap:wrap;gap:var(--space-1)}.toggle-row{margin-top:var(--space-1)}.sidebar-foot{flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3) var(--space-4) var(--space-4);border-top:1px solid var(--color-border)}.sidebar-actions{display:flex;flex-wrap:wrap;gap:var(--space-1)}.sidebar-actions .header-action-btn{flex:1;font-size:var(--text-xs);font-family:var(--font-mono);letter-spacing:.02em;padding:var(--space-2) var(--space-2);white-space:nowrap}.theme-toggle{display:flex;align-items:center;gap:var(--space-2);align-self:flex-start;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);color:var(--color-ink-muted);font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;text-transform:uppercase;transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.theme-toggle:hover{background:var(--color-surface-raised);color:var(--color-ink)}.theme-toggle-icon{font-size:var(--text-base)}.build-version{font-size:var(--text-xs);color:var(--color-ink-muted);padding:0 var(--space-2);font-family:var(--font-mono);letter-spacing:.02em}a.shortcuts-link{text-decoration:none;transition:color var(--duration-fast)}a.shortcuts-link:hover{color:var(--color-accent)}.group-options{display:flex;flex-wrap:wrap;gap:var(--space-2)}.cat-nav{list-style:none;display:flex;flex-direction:column;gap:1px}.cat-nav-group{display:flex;flex-direction:column}.cat-nav-item{width:100%;text-align:left;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-none);display:flex;align-items:center;justify-content:space-between}.cat-nav-item.active{background:var(--color-surface-raised);color:var(--color-accent)}.cat-nav-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cat-nav-arrow{font-size:var(--text-base);color:var(--color-ink-muted);transition:transform var(--duration-fast) var(--ease-out);flex-shrink:0;line-height:1}.cat-nav-arrow.open{transform:rotate(90deg)}.cat-nav-types{list-style:none;display:flex;flex-direction:column;gap:1px;padding-left:var(--space-3)}.cat-nav-type{font-size:var(--text-xs);padding:var(--space-1) var(--space-3);color:var(--color-ink-muted)}.cat-nav-type.active{color:var(--color-accent);background:var(--color-surface-raised)}.product-area{position:relative;flex:1;overflow-y:auto;display:flex;flex-direction:column;padding:var(--space-8) var(--space-12) var(--space-16);transition:padding var(--duration-base) var(--ease-out)}.shell.is-collapsed .product-area{padding-left:var(--space-16);padding-right:var(--space-16)}.product-grid{width:100%;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-8)}@media(max-width:900px){.product-area{padding:var(--space-6) var(--space-6) var(--space-12)}.shell.is-collapsed .product-area{padding-left:var(--space-12);padding-right:var(--space-6)}}.mobile-bar,.mobile-sheet{display:none}@media(max-width:760px){.shell{flex-direction:column}.sidebar{display:none!important}.product-area{padding:var(--space-4) var(--space-4) calc(72px + env(safe-area-inset-bottom,0px) + var(--space-4))!important}.product-grid{padding:0}.mobile-bar{display:flex;align-items:center;gap:var(--space-2);position:fixed;left:0;right:0;bottom:0;z-index:50;padding:var(--space-2) var(--space-3);padding-bottom:calc(var(--space-2) + env(safe-area-inset-bottom,0px));background:var(--color-surface);border-top:1px solid var(--color-border)}.mobile-bar-search{flex:1;min-width:0;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-surface-raised);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-ink-muted)}.mobile-bar-search-icon{flex-shrink:0}.mobile-bar-search .search-input{flex:1;padding:0;border-radius:0;background:transparent;font-size:var(--text-sm)}.mobile-bar-context{display:flex;align-items:center;gap:var(--space-1);flex-shrink:0}.mobile-bar-pill{padding:3px var(--space-2);background:var(--color-accent-soft);color:var(--color-accent);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;white-space:nowrap}.mobile-bar-expand{flex-shrink:0;width:36px;height:36px;display:grid;place-items:center;background:var(--color-surface-raised);border-radius:var(--radius-sm);color:var(--color-ink);cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.mobile-bar-expand:hover,.mobile-bar-expand.is-open{background:var(--color-accent);color:var(--color-accent-ink)}.mobile-bar-expand-icon{display:block;width:16px;height:12px;position:relative}.mobile-bar-expand-icon:before,.mobile-bar-expand-icon:after,.mobile-bar-expand .mobile-bar-expand-icon+span{display:none}.mobile-bar-expand-icon{width:14px;height:2px;background:currentColor;border-radius:1px;box-shadow:0 5px 0 currentColor,0 -5px 0 currentColor}.mobile-sheet{display:flex;position:fixed;top:0;left:0;right:0;bottom:calc(52px + env(safe-area-inset-bottom,0px));z-index:45;align-items:flex-end}.mobile-sheet-inner{position:relative;z-index:1;width:100%;max-height:85vh;background:var(--color-surface);border-top:1px solid var(--color-line-strong);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;flex-direction:column;overflow:hidden;transition:transform var(--duration-base) var(--ease-out);will-change:transform}.mobile-sheet-handle{flex-shrink:0;align-self:center;width:36px;height:4px;margin:var(--space-3) 0 var(--space-2);background:var(--color-border);border-radius:var(--radius-full);cursor:grab}.mobile-sheet-handle:active{cursor:grabbing}.mobile-sheet-scroll{flex:1;min-height:0;overflow-y:auto;padding:var(--space-2) var(--space-4) var(--space-4);display:flex;flex-direction:column;gap:var(--space-6)}.mobile-sheet-foot{flex-shrink:0;padding:var(--space-3) var(--space-4);padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom,0px));border-top:1px solid var(--color-border);display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;gap:var(--space-2)}.mobile-sheet-foot .organize-btn{width:auto;padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.mobile-sheet-foot .sidebar-actions{display:contents}.mobile-sheet-foot .header-action-btn{flex:none;font-size:var(--text-xs);padding:var(--space-1) var(--space-2)}.mobile-sheet-foot .import-dropdown{position:relative}.mobile-sheet-foot .theme-toggle{margin-left:auto;padding:var(--space-1) var(--space-2)}.mobile-sheet-scrim{position:absolute;inset:0;background:var(--color-scrim);cursor:pointer}.mobile-sheet-close{position:absolute;top:var(--space-3);right:var(--space-3);z-index:3;width:32px;height:32px;border-radius:var(--radius-full);background:#00000059;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);color:#ffffffd9;font-size:var(--text-sm);display:grid;place-items:center;cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.mobile-sheet-close:hover{background:#0009;color:#fff}}.product-group{display:contents}.group-label{padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--color-border);background:var(--color-bg);position:sticky;top:0;z-index:2}.product-row{display:contents}.product-card{display:flex;flex-direction:row;align-items:center;gap:var(--space-3);padding:6px var(--space-4);border-bottom:1px solid var(--color-border);box-shadow:none;border-left:none;border-right:none;border-top:none;border-radius:0;overflow:hidden;min-height:48px}.product-card:hover{box-shadow:none;transform:none;background:var(--color-surface-raised)}.product-card:active{box-shadow:none;transform:none;background:var(--color-surface)}.product-img{width:36px;height:36px;flex:0 0 36px;background:var(--color-surface-raised);overflow:hidden}.product-img img{width:100%;height:100%;object-fit:contain;padding:2px}.product-img-placeholder{width:100%;height:100%;background:var(--color-surface-raised)}.product-info{flex:1 1 0;display:grid;grid-template-columns:minmax(0,1fr) min-content;grid-template-rows:auto auto;column-gap:var(--space-3);min-width:0}.product-retailer{grid-column:1;grid-row:1;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--color-ink-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.product-name{grid-column:1;grid-row:2;font-size:var(--text-sm);font-weight:500;line-height:var(--leading-tight);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-footer{grid-column:2;grid-row:1 / 3;display:flex;align-items:center;white-space:nowrap;margin-top:0}.product-footer .price-stamp{font-size:var(--text-sm);padding:2px 6px}.product-footer .pill{display:none}.empty-state{grid-column:1 / -1;padding:var(--space-16) var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);text-align:center;max-width:420px;margin:var(--space-16) auto 0}.empty-state-critter{width:124px;animation:cl-float 4s var(--ease-out) infinite;cursor:pointer;-webkit-tap-highlight-color:transparent}.empty-state-critter svg{display:block;width:100%;height:auto;overflow:visible;transform-origin:50% 100%}.cl-head,.cl-eyes,.cl-blink{transform-box:view-box}.cl-head{transform-origin:256px 230px;animation:cl-tilt 7s ease-in-out infinite}.cl-eyes{transform-origin:256px 188px;animation:cl-look 7s ease-in-out infinite}.cl-blink{transform-origin:256px 185px;animation:cl-blink 7s ease-in-out infinite}@keyframes cl-float{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}@keyframes cl-look{0%,12%{transform:translate(0)}19%,31%{transform:translate(-9px)}38%,47%{transform:translate(0)}54%,67%{transform:translate(9px)}74%,to{transform:translate(0)}}@keyframes cl-tilt{0%,12%{transform:rotate(0)}19%,31%{transform:rotate(-4deg)}38%,47%{transform:rotate(0)}54%,67%{transform:rotate(4deg)}74%,to{transform:rotate(0)}}@keyframes cl-blink{0%,84%,90%,to{transform:scaleY(1)}87%{transform:scaleY(.1)}}.empty-state-critter.is-hop svg{animation:cl-hop .6s var(--ease-out)}.empty-state-critter.is-hop .cl-blink{animation:cl-wide .6s var(--ease-out)}.empty-state-critter.is-dizzy svg{animation:cl-shudder 1.4s ease-in-out}.empty-state-critter.is-dizzy .cl-head{animation:cl-wobble 1.4s ease-in-out}.empty-state-critter.is-dizzy .cl-eyes{animation:cl-woozy 1.4s linear}.empty-state-critter.is-dizzy .cl-blink{animation:none}@keyframes cl-hop{0%{transform:translateY(0) scale(1)}22%{transform:translateY(3px) scale(1.12,.88)}52%{transform:translateY(-20px) scale(.94,1.06)}76%{transform:translateY(0) scale(1.05,.96)}to{transform:translateY(0) scale(1)}}@keyframes cl-wide{0%,to{transform:scale(1)}40%{transform:scale(1.4)}}@keyframes cl-shudder{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(2px)}}@keyframes cl-wobble{0%,to{transform:rotate(0)}14%{transform:rotate(-13deg)}34%{transform:rotate(11deg)}54%{transform:rotate(-8deg)}72%{transform:rotate(6deg)}88%{transform:rotate(-3deg)}}@keyframes cl-woozy{0%{transform:rotate(0)}to{transform:rotate(720deg)}}@media(prefers-reduced-motion:reduce){.empty-state-critter,.empty-state-critter.is-hop svg,.empty-state-critter.is-dizzy svg,.cl-head,.cl-eyes,.cl-blink{animation:none}}.empty-state-title{font-size:var(--text-xl);font-weight:700;letter-spacing:-.02em}.detail-overlay{position:fixed;inset:0;z-index:100;background:var(--color-scrim);display:flex;justify-content:flex-end}.detail-panel{position:relative;width:380px;max-width:90vw;height:100%;background:var(--color-bg);border-left:1px solid var(--color-border);box-shadow:-8px 0 0 var(--color-shadow-cast);overflow-y:auto;padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4);animation:detail-slide var(--duration-base) var(--ease-out)}@keyframes detail-slide{0%{transform:translate(24px);opacity:0}to{transform:translate(0);opacity:1}}.detail-close{position:absolute;top:var(--space-3);right:var(--space-3);width:32px;height:32px;padding:0;justify-content:center;font-size:var(--text-base)}.detail-hero{width:100%;height:200px;background:var(--color-surface-raised);display:flex;align-items:center;justify-content:center;overflow:hidden}.detail-hero img{max-width:100%;max-height:100%;object-fit:contain}.detail-name{font-size:var(--text-xl);font-weight:700;line-height:var(--leading-tight)}.detail-price-row{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3)}.detail-price-row .price-stamp{font-size:var(--text-lg);padding:var(--space-1) var(--space-3)}.detail-delta{font-family:var(--font-mono);font-size:var(--text-xs)}.detail-delta.down{color:var(--color-success)}.detail-delta.up{color:var(--color-danger)}.detail-section{display:flex;flex-direction:column;gap:var(--space-2);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.sparkline{width:100%;height:56px;background:var(--color-surface);border:1px solid transparent}.price-log{list-style:none;display:flex;flex-direction:column;gap:2px}.price-log li{display:flex;justify-content:space-between;align-items:baseline;padding:2px 0}.price-log-price{font-family:var(--font-mono);font-weight:600;font-size:var(--text-sm)}.section-label-row{display:flex;align-items:center;gap:var(--space-2)}.specs-refresh{font-size:var(--text-sm);line-height:1;padding:0 2px;color:var(--color-text-tertiary);opacity:.6}.specs-refresh:hover{opacity:1}.specs-loading{font-size:var(--text-xs);padding:var(--space-2) 0}.spec-groups{display:flex;flex-direction:column;gap:var(--space-4)}.spec-group-name{font-size:var(--text-xs);font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:var(--space-1)}.spec-table{display:grid;grid-template-columns:minmax(120px,40%) 1fr;gap:1px;background:var(--color-border);border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.spec-table dt,.spec-table dd{background:var(--color-surface);padding:var(--space-1) var(--space-2);font-size:var(--text-xs);margin:0}.spec-table dt{color:var(--color-text-secondary);font-weight:500}.spec-table dd{color:var(--color-text)}.price-trend{font-size:var(--text-xs);font-weight:600;letter-spacing:.03em;padding:2px var(--space-2);border-radius:var(--radius-pill);display:inline-block;margin-top:var(--space-1)}.price-trend--trend-low{background:color-mix(in srgb,#22c55e 18%,transparent);color:#4ade80}.price-trend--trend-below{background:color-mix(in srgb,#22c55e 10%,transparent);color:#86efac}.price-trend--trend-above{background:color-mix(in srgb,#f97316 10%,transparent);color:#fb923c}.price-trend--trend-high{background:color-mix(in srgb,#ef4444 18%,transparent);color:#f87171}.source-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}.source-row{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;align-items:center;gap:2px var(--space-3);padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid transparent}.source-row-main{display:flex;align-items:center;gap:var(--space-2);grid-column:1;grid-row:1}.source-retailer{font-size:var(--text-sm);font-weight:600}.source-variant{font-size:var(--text-xs);grid-column:1;grid-row:2}.source-link-out{grid-column:2;grid-row:1 / 3;font-size:var(--text-xs);color:var(--color-accent);text-decoration:none;white-space:nowrap;align-self:center}.source-link-out:hover{text-decoration:underline}.variation-chips{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-bottom:var(--space-2)}.variation-chip{font-size:var(--text-xs);font-weight:600;padding:2px var(--space-2);background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-pill);color:var(--color-text-secondary)}.revisit-banner--new-source{background:color-mix(in srgb,var(--color-accent) 15%,transparent);color:var(--color-accent)}.match-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}.match-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid transparent;cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.match-row:hover{background:var(--color-surface-raised)}.match-retailer{font-size:var(--text-sm);font-weight:600}.detail-section--collapsible{padding-top:0;border-top:none}.detail-section--collapsible details{padding-top:var(--space-4);border-top:1px solid var(--color-border)}.detail-section--collapsible summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:var(--space-2);-webkit-user-select:none;user-select:none}.detail-section--collapsible summary::-webkit-details-marker{display:none}.detail-section--collapsible summary:after{content:"›";font-size:var(--text-sm);color:var(--color-ink-muted);transition:transform var(--duration-fast) var(--ease-out);margin-left:auto}.detail-section--collapsible details[open] summary:after{transform:rotate(90deg)}.detail-section--collapsible .search-links{margin-top:var(--space-2)}.search-links{display:flex;flex-wrap:wrap;gap:var(--space-2)}.search-link{display:flex;flex-direction:column;gap:2px;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);color:var(--color-ink);text-decoration:none;transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out)}.search-link:hover{background:var(--color-surface-raised);border-color:var(--color-ink-muted)}.search-link-name{font-size:var(--text-sm)}.search-link-policy{font-size:var(--text-xs);color:var(--color-ink-muted)}.return-policy-tag{display:inline-block;margin-left:var(--space-2);font-size:var(--text-xs);color:var(--color-ink-muted);border:1px solid var(--color-border);padding:1px var(--space-2)}.id-grid{display:grid;grid-template-columns:max-content 1fr;column-gap:var(--space-4);row-gap:var(--space-1);font-size:var(--text-sm)}.id-grid dt{color:var(--color-ink-muted);text-transform:uppercase;font-size:var(--text-xs);letter-spacing:.06em;align-self:center}.id-grid dd{font-family:var(--font-mono);word-break:break-all}.notes-input{width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-none);resize:vertical}.detail-actions{display:flex;gap:var(--space-3);margin-top:var(--space-2);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.detail-delete{color:var(--color-danger);border-color:var(--color-danger)}.product-card.bought{opacity:.55}.product-card.bought:hover{opacity:1}.bought-check{color:var(--color-success);font-weight:700;font-size:var(--text-xs);margin-right:3px}.bought-from-badge{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-success);white-space:nowrap;margin-left:var(--space-2)}.product-card.ruled-out{opacity:.35;filter:grayscale(1)}.product-card.ruled-out:hover{opacity:.7;filter:grayscale(.5)}.ruled-out-check{color:var(--color-ink-muted);font-weight:700;font-size:var(--text-xs);margin-right:3px}.detail-rule-out{color:var(--color-ink-muted)}.rank-badge{font-family:var(--font-mono);font-size:10px;font-weight:700;background:var(--color-accent);color:var(--color-bg);padding:1px 5px;line-height:1.4;margin-left:var(--space-2);letter-spacing:.04em;flex-shrink:0}.rank-section{padding:var(--space-3) var(--space-4)!important}.rank-row{display:flex;align-items:center;justify-content:space-between}.rank-btns{display:flex;gap:var(--space-1)}.rank-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;background:var(--color-surface-raised);border:1px solid transparent;color:var(--color-ink-muted);cursor:pointer;transition:background var(--duration-fast),color var(--duration-fast)}.rank-btn:hover{background:var(--color-surface);color:var(--color-ink)}.rank-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-bg);box-shadow:var(--shadow-card-active)}.rank-btn-clear{background:transparent;border-color:transparent;color:var(--color-ink-muted);font-size:var(--text-xs)}.rank-btn-clear:hover{color:var(--color-danger);background:transparent}.pill--ruled-out.active{background:color-mix(in srgb,var(--color-ink-muted) 15%,var(--color-surface));color:var(--color-ink-muted)}.decided-section{background:color-mix(in srgb,var(--color-success) 8%,var(--color-surface));border-color:color-mix(in srgb,var(--color-success) 30%,var(--color-border))}.decided-header{display:flex;align-items:center;gap:var(--space-3)}.decided-icon{font-size:var(--text-lg);font-weight:700;color:var(--color-success);line-height:1}.decided-info{flex:1;display:flex;flex-direction:column;gap:2px}.decided-label{font-size:var(--text-sm);font-weight:700;color:var(--color-success)}.decided-date{font-size:var(--text-xs)}.decided-undo{font-size:var(--text-xs);padding:2px var(--space-2)}.decided-detail{font-size:var(--text-sm);display:flex;gap:var(--space-2)}.decided-hide-type{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid color-mix(in srgb,var(--color-success) 20%,var(--color-border));font-size:var(--text-sm)}.decided-hide-type-btn{font-size:var(--text-xs);padding:2px var(--space-2);white-space:nowrap}.decided-type-hidden-note{font-size:var(--text-xs);font-style:italic}.decided-type-restore{font-size:var(--text-xs);text-decoration:underline;cursor:pointer;background:none;border:none;color:var(--color-ink-muted);padding:0}.decided-type-restore:hover{color:var(--color-ink)}.hidden-types-row{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-6);border-top:1px solid var(--color-border);background:var(--color-bg);flex-wrap:wrap;width:100%}.hidden-types-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em}.hidden-type-pill{display:inline-flex;align-items:center;gap:4px;font-size:var(--text-xs);font-family:var(--font-mono);background:var(--color-surface-raised);border:1px solid transparent;padding:2px var(--space-2);color:var(--color-ink-muted)}.hidden-type-restore{background:none;border:none;color:var(--color-ink-muted);cursor:pointer;font-size:10px;line-height:1;padding:0 1px;display:flex;align-items:center}.hidden-type-restore:hover{color:var(--color-ink)}.buying-form-section{background:var(--color-surface)}.research-context{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-surface-raised);border:1px solid transparent}.research-row{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;font-size:var(--text-sm)}.research-row .muted{min-width:90px;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em}.research-tags{display:flex;gap:var(--space-2);flex-wrap:wrap}.research-stores{font-size:var(--text-sm)}.form-field{display:flex;flex-direction:column;gap:var(--space-2)}.form-label-sm{display:flex;align-items:center;gap:var(--space-2)}.form-optional{text-transform:none;letter-spacing:0;font-weight:400;color:var(--color-ink-muted);font-size:var(--text-xs)}select.bought-retailer-select{font-family:inherit;font-size:var(--text-sm);color:var(--color-ink);background:var(--color-surface);border:1px solid transparent;padding:var(--space-2) var(--space-3);cursor:pointer;width:100%;outline:none}select.bought-retailer-select:focus{border-color:var(--color-accent)}input.bought-model-input,input.bought-retailer-other{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);width:100%}.form-check-row{display:flex;align-items:flex-start;gap:var(--space-2);font-size:var(--text-sm);cursor:pointer}.form-check-row input[type=checkbox]{width:14px;height:14px;margin-top:2px;accent-color:var(--color-accent);flex-shrink:0}.buying-form-actions{display:flex;gap:var(--space-3)}.btn-skip{font-size:var(--text-xs);color:var(--color-ink-muted);text-decoration:underline;text-underline-offset:2px;cursor:pointer;background:none;border:none;padding:0;font-family:inherit}.btn-skip:hover{color:var(--color-ink)}.sw-share-banner{position:fixed;top:0;left:0;right:0;z-index:300;display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-family:var(--font-mono);font-size:var(--text-sm);font-weight:700;letter-spacing:.02em}.sw-share-banner--saving{background:var(--color-surface-raised);color:var(--color-ink-muted);border-bottom:1px solid var(--color-border)}.sw-share-banner--saved{background:var(--color-accent);color:var(--color-accent-ink);border-bottom:2px solid var(--color-line-strong);box-shadow:0 2px 0 var(--color-line-strong)}.sw-share-banner--error{background:var(--color-danger);color:#fff}.sw-share-banner-close{background:none;border:none;cursor:pointer;color:inherit;opacity:.5;font-size:var(--text-xs);padding:0;line-height:1}.sw-share-banner-close:hover{opacity:1}.sw-toast{position:fixed;bottom:var(--space-6);left:50%;transform:translate(-50%) translateY(12px);opacity:0;transition:opacity var(--duration-base) var(--ease-out),transform var(--duration-base) var(--ease-out);z-index:200;display:flex;align-items:center;gap:var(--space-3);background:var(--color-surface);border:1px solid transparent;box-shadow:var(--shadow-card);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);white-space:nowrap;pointer-events:none}.sw-toast--visible{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.sw-toast-close{background:none;border:none;cursor:pointer;color:var(--color-ink-muted);font-size:var(--text-xs);padding:0;line-height:1}.toast-error{color:var(--color-danger)}.board-view{display:flex;flex-direction:column;gap:var(--space-12);padding:var(--space-6) 0 var(--space-12)}.board-cat{display:flex;flex-direction:column;gap:var(--space-6)}.board-cat-head{display:flex;align-items:center;gap:var(--space-4);padding:0 var(--space-6)}.board-cat-head:after{content:"";flex:1;height:1px;background:var(--color-border)}.board-cat-label{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-ink-muted);flex-shrink:0}.board-section{display:flex;flex-direction:column;gap:var(--space-3)}.board-section-head{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-6)}.board-section-label{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-ink)}.board-section-count{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-ink-muted);background:var(--color-surface);border:1px solid transparent;padding:1px 6px;line-height:1.6}.board-seeall{margin-left:auto;font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.04em;color:var(--color-accent);padding:2px var(--space-2);white-space:nowrap}.board-seeall:hover{text-decoration:underline}.board-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-4);padding:0 var(--space-6);align-items:start}.layout-toggle{display:flex;gap:var(--space-2);margin-top:var(--space-2)}.row-list{display:flex;flex-direction:column;gap:var(--space-2);padding:0 var(--space-6)}.row-card{display:flex;align-items:stretch;width:100%;box-sizing:border-box;gap:0;padding:0;height:84px;border:1px solid transparent;border-radius:var(--radius-md);background:var(--color-surface);overflow:hidden;cursor:pointer;transition:box-shadow .12s ease,transform .12s ease}.row-card:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}.row-card--decided{opacity:.5}.row-card--ruled-out{opacity:.45}.row-card--ruled-out .row-card-name{text-decoration:line-through}.row-card-thumb{position:relative;flex:0 0 auto;width:112px;align-self:stretch}.row-card-thumb img,.row-card-thumb .board-card-img-ph{width:100%;height:100%;object-fit:cover;display:block}.row-card-done{position:absolute;inset:0;color:#fff;background:#00000073;display:grid;place-items:center;font-size:1.4rem}.row-card-main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:2px;padding:var(--space-2) var(--space-4)}.row-card-name{font-weight:600;color:var(--color-ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.row-card-meta{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2);font-size:.8rem}.row-card-sku{font-size:.72rem;padding:1px var(--space-2);border-radius:var(--radius-sm);background:var(--color-surface-raised)}.row-card-note{font-size:.78rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.row-card-side{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4)}.row-card-actions{display:flex;align-items:center;gap:var(--space-2)}.row-card:hover .board-rank,.row-card:hover .board-ruleout,.row-card--ruled-out .board-ruleout{opacity:1}@media(max-width:560px){.row-card-note{display:none}}.board-card{display:flex;flex-direction:column;border-radius:var(--radius-md);overflow:hidden}.board-card--decided{opacity:.5}.board-card--decided:hover{opacity:.9}.board-card--ruled-out{opacity:.4;filter:grayscale(1)}.board-card--ruled-out:hover{opacity:.75;filter:grayscale(.4)}.board-card-img{width:100%;aspect-ratio:4 / 5;background:var(--color-surface-raised);overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center}.board-card-img img{width:100%;height:100%;object-fit:contain;padding:var(--space-3)}.board-card-img-ph{width:100%;height:100%;background:var(--color-surface-raised)}.board-rank{position:absolute;top:var(--space-2);left:var(--space-2);font-family:var(--font-mono);font-size:11px;font-weight:700;line-height:1;letter-spacing:.04em;padding:3px 5px;background:var(--color-surface);color:var(--color-ink-muted);border:1px solid transparent;opacity:0;transition:opacity var(--duration-fast) var(--ease-out)}.board-rank.is-set{background:var(--color-accent);color:var(--color-accent-ink);border-color:var(--color-accent);box-shadow:var(--shadow-card-active);opacity:1}.board-card:hover .board-rank{opacity:1}.board-rank:hover{transform:translate(1px,1px)}.board-ruleout{position:absolute;top:var(--space-2);right:var(--space-2);font-family:var(--font-mono);font-size:11px;font-weight:700;line-height:1;padding:3px 5px;background:var(--color-surface);color:var(--color-ink-muted);border:1px solid transparent;opacity:0;transition:opacity var(--duration-fast) var(--ease-out)}.board-card:hover .board-ruleout,.board-card--ruled-out .board-ruleout{opacity:1}.board-ruleout:hover{color:var(--color-danger);border-color:var(--color-danger)}.board-done{position:absolute;inset:0;background:var(--color-scrim);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:700;color:var(--color-accent)}.board-sku-badge{position:absolute;bottom:var(--space-2);left:var(--space-2);font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.04em;padding:1px 5px;background:var(--color-bg);color:var(--color-ink-muted);border:1px solid transparent;pointer-events:none}.board-ignore{position:absolute;bottom:var(--space-2);right:var(--space-2);font-size:var(--text-xs);padding:2px var(--space-2);background:var(--color-surface);border:1px solid transparent;color:var(--color-ink-muted)}.board-ignore:hover{color:var(--color-ink)}.board-card-body{padding:var(--space-3);display:flex;flex-direction:column;gap:3px;border-top:1px solid var(--color-border)}.board-card-retailer{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--color-ink-muted);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.board-card-name{font-size:var(--text-sm);font-weight:600;line-height:var(--leading-tight);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:calc(var(--text-sm) * var(--leading-tight) * 2)}.board-card-foot{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-1)}.board-card-note{font-size:var(--text-xs);font-style:italic;color:var(--color-ink-muted);line-height:var(--leading-tight);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:2px}@media(max-width:560px){.board-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-3);padding:0 var(--space-4)}}.organize-btn{width:100%;justify-content:center;font-size:var(--text-xs);font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:var(--space-3);color:var(--color-ink-muted)}.organize-btn:hover{color:var(--color-ink)}.organize-icon{color:var(--color-accent)}.organize-btn.active{color:var(--color-ink);border-color:var(--color-accent);background:var(--color-accent-soft)}.org-panel{width:440px}.org-header{display:flex;flex-direction:column;gap:var(--space-3)}.org-title{font-size:var(--text-lg);font-weight:700;letter-spacing:-.01em}.org-apply-all{font-size:var(--text-sm);justify-content:center}.org-apply-all:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.org-loading,.org-empty{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-8) 0;align-items:center}.org-section{display:flex;flex-direction:column;gap:var(--space-2);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.org-section-head{display:flex;align-items:center;gap:var(--space-2)}.org-count{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-ink-muted);background:var(--color-surface);border:1px solid transparent;padding:1px 6px;line-height:1.6}.org-section-hint{font-size:var(--text-xs);margin-top:calc(-1 * var(--space-1))}.org-triage-list{list-style:none;display:flex;flex-direction:column;gap:1px}.org-triage-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--color-border)}.org-triage-item:last-child{border-bottom:none}.org-triage-img{width:32px;height:32px;flex-shrink:0;object-fit:contain;background:var(--color-surface-raised)}.org-triage-img-ph{background:var(--color-surface-raised)}.org-triage-name{flex:1;font-size:var(--text-xs);line-height:var(--leading-tight);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-width:0}.org-cat-picker,.detail-cat-picker{font-family:inherit;font-size:var(--text-xs);color:var(--color-ink);background:var(--color-surface);border:1px solid transparent;padding:var(--space-1) var(--space-2);cursor:pointer;flex-shrink:0;max-width:120px}.detail-cat-picker{max-width:100%;width:100%;font-size:var(--text-sm);padding:var(--space-2) var(--space-3)}.org-cat-picker:focus,.detail-cat-picker:focus{border-color:var(--color-accent);outline:none}.org-all-done{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-8) 0}.org-all-done-icon{font-size:var(--text-2xl);font-family:var(--font-mono);font-weight:700;color:var(--color-accent)}.import-dropdown{position:relative;flex:1}.import-dropdown .header-action-btn{width:100%}.import-menu{position:absolute;bottom:calc(100% + 6px);left:0;right:0;background:var(--color-surface);border:2px solid transparent;border-radius:var(--radius-md);box-shadow:var(--shadow-card);z-index:50;display:none;flex-direction:column;min-width:160px;overflow:hidden}.import-menu.open{display:flex}.import-menu-item{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-family:var(--font-mono);letter-spacing:.04em;cursor:pointer;white-space:nowrap;display:block;color:var(--color-ink)}.import-menu-item:hover{background:var(--color-surface-raised)}.import-menu-item--disabled{opacity:.4;cursor:default;pointer-events:none}.import-menu-hint{display:block;font-size:10px;letter-spacing:0;color:var(--color-ink-muted);margin-top:2px;font-family:var(--font-sans)}.bm-overlay{position:fixed;inset:0;z-index:100;background:var(--color-scrim);display:flex;align-items:center;justify-content:center}.bm-modal{width:600px;max-width:90vw;max-height:80vh;background:var(--color-bg);border:1px solid transparent;box-shadow:-8px 8px 0 var(--color-shadow-cast);display:flex;flex-direction:column;animation:bm-in var(--duration-base) var(--ease-out)}@keyframes bm-in{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.bm-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);flex-shrink:0}.bm-title{font-size:var(--text-lg);font-weight:700}.bm-subtitle{font-size:var(--text-sm);color:var(--color-ink-muted);margin-top:2px}.bm-close{width:28px;height:28px;padding:0;justify-content:center;flex-shrink:0}.bm-tabs{display:flex;gap:var(--space-4);padding:0 var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0}.bm-tab{padding:var(--space-2) 0;font-size:var(--text-sm);font-family:var(--font-mono);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;color:var(--color-ink-muted);margin-bottom:-1px;transition:color var(--duration-fast),border-color var(--duration-fast)}.bm-tab.active{color:var(--color-ink);border-bottom-color:var(--color-accent)}.bm-list{flex:1;overflow-y:auto}.bm-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-6);border-bottom:1px solid var(--color-border);cursor:pointer;-webkit-user-select:none;user-select:none}.bm-item:hover{background:var(--color-surface-raised)}.bm-item input[type=checkbox]{width:14px;height:14px;flex-shrink:0;accent-color:var(--color-accent);cursor:pointer}.bm-favicon{width:16px;height:16px;flex-shrink:0;border-radius:2px;object-fit:contain}.bm-info{flex:1;min-width:0}.bm-item-title{font-size:var(--text-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bm-item-domain{font-size:var(--text-xs);color:var(--color-ink-muted);font-family:var(--font-mono)}.bm-signals{display:flex;gap:var(--space-1);flex-shrink:0}.bm-signal{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:1px 5px}.bm-signal-retailer{background:var(--color-accent);color:var(--color-accent-ink)}.bm-signal-url{background:var(--color-ink);color:var(--color-bg)}.bm-signal-keyword{background:var(--color-surface-raised);color:var(--color-ink-muted);border:1px solid transparent}.bm-footer{padding:var(--space-3) var(--space-6);border-top:1px solid var(--color-border);display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.bm-sel-actions{display:flex;gap:var(--space-3);flex:1}.bm-sel-btn{font-size:var(--text-xs);color:var(--color-ink-muted);text-decoration:underline;text-underline-offset:2px;cursor:pointer;background:none;border:none;padding:0;font-family:inherit}.bm-sel-btn:hover{color:var(--color-ink)}.bm-import-btn{font-size:var(--text-sm)}.share-modal{max-width:480px}.share-body{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.share-url{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-ink-muted);word-break:break-all}.org-card{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4) 0;border-top:1px solid var(--color-border)}.org-card-head{display:flex;align-items:center;gap:var(--space-2)}.org-badge{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;letter-spacing:.05em;padding:2px 6px;border:1px solid transparent}.badge-accent{color:var(--color-accent)}.badge-ink{color:var(--color-ink)}.badge-muted{color:var(--color-ink-muted)}.badge-danger{color:var(--color-danger)}.org-card-dismiss{margin-left:auto;font-size:var(--text-xs);color:var(--color-ink-muted);padding:2px 6px}.org-card-title{font-size:var(--text-sm);font-weight:600}.org-card-sub{font-size:var(--text-xs);margin-top:-4px}.org-card-detail{font-family:var(--font-mono);font-size:var(--text-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.org-rename-input{font-family:inherit;font-size:var(--text-sm);background:var(--color-surface);border:1px solid transparent;color:var(--color-ink);padding:var(--space-2) var(--space-3);width:100%}.org-rename-input:focus{border-color:var(--color-accent);outline:none}.org-card-actions{display:flex;gap:var(--space-2);flex-wrap:wrap}.org-card-action{font-size:var(--text-xs)}.no-price-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface);border-bottom:1px solid var(--color-border);font-size:var(--text-sm);flex-shrink:0}.no-price-banner-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.btn-sm{font-size:var(--text-xs);padding:var(--space-1) var(--space-3)}.card-ignore-btn{position:absolute;bottom:var(--space-2);right:var(--space-2);font-size:var(--text-xs);color:var(--color-ink-muted);padding:2px 6px;opacity:0;transition:opacity .15s}.product-card:hover .card-ignore-btn{opacity:1}.product-card{position:relative}.board-uncat-badge{font-size:9px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-ink-muted);background:var(--color-surface-raised, var(--color-surface));border:1px solid var(--color-border);border-radius:3px;padding:1px 5px;line-height:1.6;white-space:nowrap}.cat-add-form{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);margin-top:var(--space-2);background:var(--color-surface);border:1px solid var(--color-accent);border-radius:var(--radius-sm)}.cat-add-input,.cat-add-type-input{font-family:inherit;font-size:var(--text-sm);color:var(--color-ink);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);width:100%}.cat-add-input:focus,.cat-add-type-input:focus{border-color:var(--color-accent);outline:none}.cat-add-actions{display:flex;gap:var(--space-2)}.org-custom-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-3)}.org-custom-cat{border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.org-custom-cat-head{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:var(--color-surface-raised, var(--color-surface));border-bottom:1px solid var(--color-border)}.org-custom-cat-name{font-size:var(--text-sm);font-weight:600}.org-custom-delete-cat{font-size:var(--text-xs);color:var(--color-ink-muted);padding:var(--space-1) var(--space-2)}.org-custom-delete-cat:hover{color:var(--color-danger, #e74c3c)}.org-custom-types{list-style:none;padding:0;margin:0}.org-custom-type{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border)}.org-custom-type:last-child{border-bottom:none}.org-custom-type-name{font-size:var(--text-sm)}.org-custom-delete{font-size:var(--text-xs);color:var(--color-ink-muted);padding:var(--space-1) var(--space-2);opacity:0;transition:opacity .1s}.org-custom-type:hover .org-custom-delete{opacity:1}.org-custom-delete:hover{color:var(--color-danger, #e74c3c)}.tag-nav-wrap{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-2) 0 0}.tag-search-row{padding-bottom:var(--space-1)}.tag-search-input{width:100%;font-size:11px;padding:5px 8px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-ink);outline:none;box-sizing:border-box}.tag-search-input::placeholder{color:var(--color-ink-muted)}.tag-search-input:focus{border-color:var(--color-accent)}.tag-nav{display:flex;flex-wrap:wrap;gap:var(--space-1);padding:0}.tag-chip{font-size:11px;font-weight:500;padding:3px 8px;border-radius:12px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-ink-muted);cursor:pointer;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;transition:background .1s,color .1s,border-color .1s}.tag-chip:hover{background:var(--color-surface-raised, var(--color-surface));color:var(--color-ink)}.tag-chip.active{background:var(--color-accent);color:var(--color-bg);border-color:var(--color-accent);font-weight:600}.tag-chip-count{font-size:10px;opacity:.7}.list-nav{padding-top:var(--space-4)}.list-nav-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.list-nav-label{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-ink-muted)}.list-nav-create{font-size:var(--text-lg);color:var(--color-ink-muted);line-height:1;padding:0 var(--space-1)}.list-nav-create:hover{color:var(--color-ink)}.list-nav-item{display:flex;align-items:center;gap:var(--space-2);width:100%;text-align:left;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-ink-muted)}.list-nav-item:hover{color:var(--color-ink);background:var(--color-surface-raised, var(--color-surface))}.list-nav-item.active{color:var(--color-ink);font-weight:600;background:var(--color-surface-raised, var(--color-surface))}.list-nav-auto{font-size:12px;opacity:.6}.list-view{padding:var(--space-4) 0}.list-view-head{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.list-view-name{font-size:var(--text-lg);font-weight:700;flex:1}.list-smart-badge{font-size:var(--text-xs);background:var(--color-surface-raised, var(--color-surface));border:1px solid var(--color-border);border-radius:12px;padding:2px 8px;color:var(--color-ink-muted)}.list-view-close{color:var(--color-ink-muted);padding:var(--space-1) var(--space-2)}.list-member-badge{font-size:9px;font-weight:600;letter-spacing:.04em;padding:1px 5px;border-radius:3px;border:1px solid var(--color-border)}.list-member-auto{color:var(--color-accent);border-color:var(--color-accent);background:transparent}.list-member-manual{color:var(--color-ink-muted);background:transparent}.list-create-modal{position:fixed;inset:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.list-create-inner{background:var(--color-surface);border-radius:var(--radius-md, 12px);padding:var(--space-5);width:100%;max-width:480px;max-height:80vh;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-4)}.list-create-head{display:flex;align-items:center;justify-content:space-between}.list-create-title{font-size:var(--text-lg);font-weight:700}.list-create-close{color:var(--color-ink-muted);padding:var(--space-1) var(--space-2)}.list-create-name{font-family:inherit;font-size:var(--text-base);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);color:var(--color-ink);width:100%}.list-create-name:focus{outline:none;border-color:var(--color-accent)}.list-create-tags-head{display:flex;flex-direction:column;gap:var(--space-1)}.list-create-label{font-size:var(--text-sm);font-weight:600}.list-create-hint{font-size:var(--text-xs)}.list-create-tag-chips{display:flex;flex-wrap:wrap;gap:var(--space-1);max-height:200px;overflow-y:auto}.list-create-actions{display:flex;gap:var(--space-2)}.board-compare-btn,.row-compare-btn{position:absolute;bottom:var(--space-2);left:var(--space-2);width:26px;height:26px;border-radius:var(--radius-sm);background:var(--color-surface);border:1.5px solid var(--color-border);color:var(--color-ink-muted);font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out);z-index:2}.board-card-img:hover .board-compare-btn,.board-card--comparing .board-compare-btn{opacity:1}.board-compare-btn.is-active,.row-compare-btn.is-active{opacity:1;background:var(--color-accent);border-color:var(--color-accent);color:var(--color-accent-ink)}.row-compare-btn{position:static;opacity:0;width:28px;height:28px;flex-shrink:0}.row-card:hover .row-compare-btn,.row-card--comparing .row-compare-btn{opacity:1}.board-card--comparing{outline:2px solid var(--color-accent);outline-offset:2px}.row-card--comparing{background:var(--color-accent-soft)}.compare-bar{position:fixed;bottom:var(--space-6);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-ink);color:var(--color-bg);border-radius:var(--radius-full);box-shadow:var(--shadow-soft),0 8px 32px #0000004d;z-index:50;white-space:nowrap;animation:compare-bar-in .18s var(--ease-out) both}@keyframes compare-bar-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.compare-bar-label{font-size:var(--text-sm)}.compare-bar-go{font-size:var(--text-sm);padding:6px var(--space-3)}.compare-bar-clear{font-size:var(--text-sm);padding:6px var(--space-2);color:var(--color-bg);opacity:.7}.compare-bar-clear:hover{opacity:1;background:#ffffff1a}.compare-overlay{position:fixed;inset:0;background:var(--color-scrim);z-index:60;display:flex;align-items:stretch;justify-content:center}.compare-panel{background:var(--color-bg);width:100%;max-width:1100px;display:flex;flex-direction:column;overflow:hidden}.compare-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0}.compare-title{font-size:var(--text-xl);font-weight:700;letter-spacing:-.02em}.compare-scroll{flex:1;overflow:auto;padding:var(--space-4) var(--space-6) var(--space-12)}.compare-table{width:100%;border-collapse:collapse;table-layout:fixed}.compare-th-label{width:200px;min-width:140px}.compare-th-product{padding:var(--space-4) var(--space-3) var(--space-6);text-align:center;vertical-align:top;border-bottom:2px solid var(--color-border)}.compare-product-img{width:80px;height:80px;object-fit:contain;margin:0 auto var(--space-2);display:block}.compare-product-img-ph{width:80px;height:80px;background:var(--color-surface-raised);border-radius:var(--radius-sm);margin:0 auto var(--space-2)}.compare-product-name{font-size:var(--text-sm);font-weight:600;line-height:var(--leading-tight);margin-bottom:var(--space-1)}.compare-product-price{font-size:var(--text-lg);font-weight:700;color:var(--color-accent);font-family:var(--font-mono)}.compare-group-row td{padding:var(--space-3) var(--space-3) var(--space-1);font-size:var(--text-xs);font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-ink-muted);background:var(--color-surface-raised);border-top:1px solid var(--color-border)}.compare-row{border-bottom:1px solid var(--color-border)}.compare-row:hover{background:var(--color-surface-raised)}.compare-cell-label{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--color-ink-muted);font-weight:500;vertical-align:middle}.compare-cell{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);text-align:center;vertical-align:middle}.compare-no-specs{padding:var(--space-8) var(--space-4);text-align:center;font-size:var(--text-sm)}.star-rating{display:inline-flex;align-items:center;gap:4px;font-size:var(--text-sm);color:var(--color-ink-muted)}.star-rating--inline{font-size:var(--text-xs);margin-top:2px}.star-glyph{color:var(--color-accent);font-size:.9em;letter-spacing:-1px}.star-num{color:var(--color-ink-muted)}.detail-rating{margin-top:var(--space-1)}.value-metric{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--color-ink-muted);background:var(--color-surface-raised);display:inline-block;padding:2px 6px;border-radius:var(--radius-sm);margin-top:var(--space-1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--color-bg);color:var(--color-ink);font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-base);-webkit-font-smoothing:antialiased;transition:background var(--duration-base) var(--ease-out),color var(--duration-base) var(--ease-out)}#app{height:100%;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea{font-family:inherit;font-size:inherit;color:inherit;background:var(--color-surface);border:1px solid transparent;outline:none}input:focus,textarea:focus{border-color:var(--color-accent)}.price-stamp{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:700;letter-spacing:-.02em;color:var(--color-ink);display:inline-block}.price-stamp.drop{background:var(--color-accent);color:var(--color-accent-ink);padding:2px 8px;border-radius:var(--radius-sm);box-shadow:var(--shadow-card-active)}.card{background:var(--color-surface);border:2px solid transparent;border-radius:var(--radius-md);box-shadow:none;transition:box-shadow var(--duration-base) var(--ease-out),transform var(--duration-base) var(--ease-out);cursor:pointer}.card:hover{box-shadow:var(--shadow-card-hover);transform:translate(-3px,-3px)}.card:active{box-shadow:var(--shadow-card-active);transform:translate(1px,1px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px solid transparent;border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-ink);font-size:var(--text-sm);font-weight:600;transition:background var(--duration-fast) var(--ease-out),box-shadow var(--duration-base) var(--ease-out),transform var(--duration-base) var(--ease-out),border-color var(--duration-fast) var(--ease-out)}.btn:hover{background:var(--color-surface-raised)}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--color-accent);color:var(--color-accent-ink);border:2px solid transparent;box-shadow:var(--shadow-card)}.btn-primary:hover{background:var(--color-accent);box-shadow:var(--shadow-card-hover);transform:translate(-3px,-3px)}.btn-primary:active{box-shadow:var(--shadow-card-active);transform:translate(1px,1px)}.btn-ghost{box-shadow:none;border-color:transparent;background:transparent}.btn-ghost:hover{box-shadow:none;transform:none;background:var(--color-surface-raised);border-color:transparent}.pill{display:inline-flex;align-items:center;padding:3px var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;text-transform:uppercase;border:1px solid transparent;background:var(--color-surface-raised);color:var(--color-ink-muted);white-space:nowrap;transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out)}.pill:hover{color:var(--color-ink)}.pill.active{background:var(--color-accent-soft);color:var(--color-accent);border-color:var(--color-accent);box-shadow:var(--shadow-card-active)}.section-label{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-ink-muted)}.muted{color:var(--color-ink-muted);font-size:var(--text-sm)}.divider{border:none;border-top:1px solid var(--color-border)}.sync-dialog{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:var(--space-4)}.sync-dialog-scrim{position:absolute;inset:0;background:var(--color-scrim)}.sync-dialog-card{position:relative;width:100%;max-width:360px;display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-6);background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-menu)}.sync-dialog-head{display:flex;align-items:center;justify-content:space-between}.sync-dialog-title{font-weight:700;font-size:var(--text-lg)}.sync-dialog-sub{font-size:var(--text-sm);line-height:var(--leading-base)}.sync-dialog-status{font-size:var(--text-base)}.sync-dialog-input{width:100%;padding:var(--space-3);border-radius:var(--radius-sm);background:var(--color-surface-raised);font-size:var(--text-base)}.sync-dialog-input:focus{border-color:var(--color-accent)}.sync-dialog-error{color:var(--color-danger);font-size:var(--text-sm)}.sync-dialog-note{color:var(--color-success);font-size:var(--text-sm)}.sync-vault-row{display:flex;flex-direction:column;gap:var(--space-1)}.sync-vault-file{display:flex;align-items:center;gap:var(--space-2)}.sync-vault-filename{font-weight:600;font-size:var(--text-sm);word-break:break-all}.sync-vault-rename-btn{flex-shrink:0}.btn-text{background:none;border:none;padding:0;font-size:var(--text-xs);font-weight:600;color:var(--color-accent);cursor:pointer;letter-spacing:.04em;text-transform:uppercase}.sync-vault-link{font-size:var(--text-xs);text-decoration:none}.sync-vault-link:hover{text-decoration:underline}.sync-vault-row-actions{display:flex;gap:var(--space-2)}.sync-dialog .btn-primary,.sync-dialog .btn-ghost{width:100%}.sync-oauth{width:100%;justify-content:center;font-weight:600}.sync-oauth--apple{background:var(--color-ink);color:var(--color-bg)}.sync-oauth--google{background:var(--color-surface-raised);color:var(--color-ink)}.sync-or{display:flex;align-items:center;gap:var(--space-2);color:var(--color-ink-muted);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em}.sync-or:before,.sync-or:after{content:"";flex:1;height:1px;background:var(--color-border)}
