:root{--bg:#f8f9fb;--surface:#fff;--surface-hover:#fafbfc;--border:#e2e8f0;--border-light:#f1f5f9;--text:#1e293b;--text-muted:#64748b;--text-subtle:#94a3b8;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-soft:#eff6ff;--accent-border:#bfdbfe;--focus:#2563eb;--high:#dc2626;--high-bg:#fef2f2;--high-border:#fecaca;--mid:#d97706;--mid-bg:#fffbeb;--mid-border:#fde68a;--low:#16a34a;--low-bg:#f0fdf4;--low-border:#bbf7d0;--none:#6b7280;--none-bg:#f9fafb;--none-border:#e5e7eb;--primary-tag:#2563eb;--primary-tag-bg:#eff6ff;--secondary-tag:#ea580c;--secondary-tag-bg:#fff7ed;--success:#16a34a;--success-bg:#f0fdf4;--radius:10px;--radius-sm:6px;--radius-lg:14px;--shadow-sm:0 1px 2px #0000000a;--shadow:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000a;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic UI", sans-serif;--transition:.2s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}body{font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-size:15px;line-height:1.6}.skip-link{z-index:1000;background:var(--accent);color:#fff;border-radius:var(--radius-sm);padding:.75rem 1rem;font-weight:600;text-decoration:none;position:absolute;top:-100%;left:1rem}.skip-link:focus{outline:3px solid var(--focus);outline-offset:2px;top:1rem}:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.site-header{color:#fff;background:linear-gradient(135deg,#1e3a5f 0%,#2563eb 100%);padding:1.75rem 1.25rem;position:relative;overflow:hidden}.site-header:before{content:"";pointer-events:none;background:radial-gradient(#ffffff14 0%,#0000 70%);width:50%;height:200%;position:absolute;top:-50%;right:-10%}.site-header__inner{max-width:72rem;margin:0 auto;position:relative}.site-header h1{letter-spacing:-.01em;margin:0 0 .25rem;font-size:1.375rem;font-weight:800}.site-header p{color:#ffffffbf;margin:0;font-size:.875rem}.filter-bar{z-index:60;-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);width:100%;box-shadow:var(--shadow-sm);background:#ffffffeb;align-items:center;gap:.75rem;min-height:3.25rem;padding:.5rem 1.25rem;display:flex;position:sticky;top:0}.filter-bar__inner{align-items:center;gap:.75rem;width:100%;max-width:72rem;margin:0 auto;display:flex}.progress-wrap--bar{flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.progress-wrap--bar .progress-bar{background:var(--border);border-radius:999px;flex:1;min-width:2.5rem;height:6px;overflow:hidden}.progress-wrap--bar .progress-fill{background:linear-gradient(90deg, var(--accent), #60a5fa);border-radius:999px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.progress-wrap--bar .progress-text{color:var(--text);white-space:nowrap;font-size:.8125rem;font-weight:600}.filter-toggle{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);cursor:pointer;transition:all var(--transition);white-space:nowrap;flex-shrink:0;align-items:center;gap:.375rem;padding:.5rem .875rem;font-size:.8125rem;font-weight:600;display:inline-flex}.filter-toggle:hover{border-color:var(--accent-border);background:var(--accent-soft)}.filter-toggle.has-active-filters{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.filter-count-badge{font-size:.75rem;font-weight:700}.stat-text--bar{color:var(--text-muted);white-space:nowrap;flex-shrink:0;margin-left:auto;font-size:.75rem;font-weight:500}.controls{z-index:50;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow);padding:1rem 1.25rem;position:sticky;top:3.25rem}.controls__inner{flex-direction:column;gap:.75rem;max-width:72rem;margin:0 auto;display:flex}.search-input{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;max-width:28rem;color:var(--text);transition:all var(--transition);padding:.625rem 1rem;font-size:.9375rem}.search-input:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px #2563eb1a}.search-input::placeholder{color:var(--text-subtle)}.filter-row{flex-wrap:wrap;align-items:center;gap:.375rem;display:flex}.filter-row__label{color:var(--text-muted);margin-right:.25rem;font-size:.8125rem;font-weight:600}.btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;white-space:nowrap;transition:all var(--transition);user-select:none;border-radius:999px;padding:.375rem .75rem;font-size:.8125rem;font-weight:500}.btn:hover{border-color:var(--accent-border);background:var(--accent-soft);color:var(--accent)}.btn[aria-pressed=true]{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600;box-shadow:0 1px 3px #2563eb4d}.btn--category[aria-pressed=true]{background:#334155;border-color:#334155;box-shadow:0 1px 3px #3341554d}.btn--ghost{color:var(--text-muted);background:0 0;border-color:#0000}.btn--ghost:hover{background:var(--bg);color:var(--text);border-color:var(--border)}.stat-text{color:var(--text-muted);font-size:.8125rem;font-weight:500}.main{max-width:72rem;margin:0 auto;padding:1.25rem 1.25rem 4rem}.progress-wrap{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.progress-bar{background:var(--border);border-radius:999px;flex:1;min-width:6rem;height:6px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--accent), #60a5fa);border-radius:999px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.progress-text{color:var(--text-muted);font-size:.875rem;font-weight:500}.shopping-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin:0 0 1.5rem;padding:1.25rem}.shopping-panel h2{color:var(--text);margin:0 0 .75rem;font-size:.9375rem;font-weight:700}.shopping-actions{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.shopping-list{max-height:10rem;color:var(--text-muted);margin:0;padding-left:1.25rem;font-size:.875rem;overflow:auto}.shopping-list li{margin-bottom:.25rem;line-height:1.5}.cat-section{margin-bottom:2rem}.cat-header{border-bottom:2px solid var(--border-light);align-items:baseline;gap:.75rem;margin-bottom:.75rem;padding-bottom:.5rem;display:flex}.cat-label{color:var(--text);border-left:3px solid var(--accent);padding-left:.625rem;font-size:.875rem;font-weight:700}.cat-count,.cat-progress{color:var(--text-muted);font-size:.75rem;font-weight:500}.tbl-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}table{border-collapse:collapse;width:100%}thead th{background:var(--bg);color:var(--text-muted);text-align:left;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);padding:.625rem .875rem;font-size:.6875rem;font-weight:700}tbody tr{border-bottom:1px solid var(--border-light);cursor:pointer;transition:background var(--transition), border-color var(--transition)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--accent-soft)}tbody tr.is-checked{background:var(--success-bg);border-left:3px solid var(--success)}tbody tr.is-checked:hover{background:#dcfce7}tbody tr.is-hidden{display:none}td{vertical-align:top;padding:.75rem .875rem}.check-col{text-align:center;width:2.75rem}input[type=checkbox]{width:1.25rem;height:1.25rem;accent-color:var(--accent);cursor:pointer;border-radius:4px;flex-shrink:0}.item-card-header{flex-wrap:wrap;align-items:center;gap:.375rem .5rem;display:flex}.item-card-badge{display:none}.badge-col{white-space:nowrap}.item-name{color:var(--text);font-size:.9375rem;font-weight:600}.sub-cat{background:var(--bg);color:var(--text-muted);vertical-align:middle;border-radius:999px;margin-left:.375rem;padding:.125rem .5rem;font-size:.6875rem;font-weight:500;display:inline-block}.qty{white-space:nowrap;color:var(--text);font-size:.875rem}.memo,.recommend{color:var(--text-muted);font-size:.8125rem;line-height:1.5}.badge{white-space:nowrap;letter-spacing:.02em;border-radius:999px;align-items:center;gap:.25rem;padding:.1875rem .5rem;font-size:.6875rem;font-weight:700;display:inline-flex}.badge--high{background:var(--high-bg);color:var(--high);border:1px solid var(--high-border)}.badge--mid{background:var(--mid-bg);color:var(--mid);border:1px solid var(--mid-border)}.badge--low{background:var(--low-bg);color:var(--low);border:1px solid var(--low-border)}.badge--none{background:var(--none-bg);color:var(--none);border:1px solid var(--none-border)}.pickup{border-radius:999px;margin-right:.25rem;padding:.125rem .5rem;font-size:.6875rem;font-weight:600;display:inline-block}.pickup--primary{background:var(--primary-tag-bg);color:var(--primary-tag)}.pickup--secondary{background:var(--secondary-tag-bg);color:var(--secondary-tag)}.no-results{text-align:center;color:var(--text-muted);padding:4rem 1rem;font-size:.9375rem;display:none}.no-results.is-visible{display:block}.loading{text-align:center;color:var(--text-muted);padding:4rem 1rem;font-size:.9375rem}.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}@media (width<=768px){.site-header{padding:1.25rem 1rem}.site-header h1{font-size:1.125rem}.filter-bar{padding:.5rem .875rem}.controls{box-shadow:none;border-bottom:1px solid var(--border);background:var(--bg);padding:.875rem 1rem 1.25rem;display:none;position:static;top:auto}.controls.is-open{display:block}.controls .stat-text{display:none}.main{padding:1rem .75rem 4rem}.tbl-wrap{box-shadow:none;background:0 0;border:none}table,thead,tbody,tr,th,td{width:100%;display:block}thead{clip:rect(0, 0, 0, 0);width:1px;height:1px;position:absolute;overflow:hidden}tbody tr{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition);border-left:4px solid #0000;grid-template-columns:auto 1fr;grid-template-areas:"check item""pickup pickup""qty qty""memo memo""recommend recommend";gap:.25rem .75rem;margin-bottom:.625rem;padding:.875rem 1rem;display:grid}tbody tr:hover{box-shadow:var(--shadow);transform:translateY(-1px)}tbody tr.is-checked{border-left-color:var(--success);background:var(--success-bg);box-shadow:none}td{border:none;padding:0}td:before{content:attr(data-label);color:var(--text-subtle);letter-spacing:.06em;text-transform:uppercase;margin-bottom:.125rem;font-size:.625rem;font-weight:700;display:block}.check-col{grid-area:check;align-self:start;padding-top:.125rem}.check-col:before{display:none}.item-main{grid-area:item}.item-main:before{display:none}.item-card-badge{display:inline-flex}.badge-col{display:none}.pickup-col{grid-area:pickup}.pickup-col:empty{display:none}.qty{grid-area:qty}.memo{grid-area:memo}.recommend{grid-area:recommend}.item-name{font-size:.9375rem;line-height:1.4}input[type=checkbox]{width:1.375rem;height:1.375rem}.cat-header{padding-left:.25rem}.shopping-panel{border-radius:var(--radius);margin:0 0 1rem;padding:1rem}}@media (width>=769px){.filter-toggle{display:none}.filter-bar{padding:.5rem 1.5rem}.progress-wrap--bar .progress-text{font-size:.875rem}.controls{display:block!important}td[data-label=備考],td[data-label=推奨商品]{max-width:14rem}}
