/* ============================================
   プロテインコスパ比較 — 共通コンポーネント
   モバイルファースト (375px〜)
   ============================================ */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-md);
  line-height: 1.7;
  color: var(--color-text);
  background: var(--color-bg);
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; }

.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--sp-4); }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.95); backdrop-filter: blur(6px);
  border-bottom: 1px solid var(--color-border);
}
.site-header .container {
  display: flex; align-items: center; gap: var(--sp-3);
  height: 56px;
}
.logo { display: flex; align-items: center; gap: var(--sp-2); font-weight: 700; font-size: var(--text-lg); white-space: nowrap; }
.logo .logo-mark {
  width: 28px; height: 28px; border-radius: var(--radius-sm);
  background: var(--color-green-500); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 800;
}
.header-search { flex: 1; max-width: 380px; display: none; }
.header-search input {
  width: 100%; height: 38px; padding: 0 var(--sp-4);
  border: 1px solid var(--color-border-strong); border-radius: var(--radius-pill);
  font-size: var(--text-sm); background: var(--color-bg-soft);
}
.header-search input:focus { outline: 2px solid var(--color-green-500); outline-offset: -1px; }
.header-actions { margin-left: auto; display: flex; gap: var(--sp-2); align-items: center; }

@media (min-width: 720px) { .header-search { display: block; } }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  border: none; border-radius: var(--radius-pill);
  font-size: var(--text-sm); font-weight: 700; line-height: 1;
  padding: 0 var(--sp-4); height: 38px;
  transition: filter var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);
  white-space: nowrap;
}
.btn:hover { filter: brightness(.94); }
.btn:active { transform: scale(.97); }
.btn-cta { background: var(--color-orange-500); color: #fff; }
.btn-primary { background: var(--color-green-600); color: #fff; }
.btn-ghost { background: transparent; color: var(--color-text); border: 1px solid var(--color-border-strong); }
.btn-amazon { background: #ffd814; color: #131921; }
.btn-rakuten { background: #bf0000; color: #fff; }
.btn-lg { height: 48px; font-size: var(--text-md); padding: 0 var(--sp-5); }
.btn-sm { height: 30px; font-size: var(--text-xs); padding: 0 var(--sp-3); }

/* ---------- Tags / Badges ---------- */
.tag {
  display: inline-block; padding: 2px 10px; border-radius: var(--radius-pill);
  font-size: var(--text-xs); font-weight: 700; line-height: 1.6;
  background: var(--color-green-50); color: var(--color-green-700);
  border: 1px solid var(--color-green-100);
}
.tag-hot { background: var(--color-orange-50); color: var(--color-orange-700); border-color: var(--color-orange-100); }
.badge-rank {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 28px; height: 28px; border-radius: 50%;
  background: var(--color-text); color: #fff; font-weight: 800; font-size: var(--text-sm);
  font-family: var(--font-num);
}
.badge-rank.r1 { background: var(--color-orange-500); }
.badge-rank.r2 { background: var(--color-green-600); }
.badge-rank.r3 { background: var(--color-text-sub); }

/* ---------- Stars ---------- */
.stars { color: var(--color-star); font-size: var(--text-sm); letter-spacing: 1px; white-space: nowrap; }
.stars .muted { color: var(--color-border-strong); }
.stars-num { font-family: var(--font-num); font-weight: 700; margin-left: 4px; color: var(--color-text); }
.review-count { color: var(--color-text-faint); font-size: var(--text-xs); margin-left: 2px; }

/* ---------- Product card ---------- */
.card-grid {
  display: grid; gap: var(--sp-4);
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
}
@media (min-width: 720px) { .card-grid { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); } }

.p-card {
  display: flex; flex-direction: column;
  background: var(--color-bg); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: box-shadow var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
}
.p-card:hover { box-shadow: var(--shadow-pop); transform: translateY(-2px); }
.p-card-img {
  height: 110px; display: flex; align-items: center; justify-content: center;
  font-size: 44px; background: var(--color-bg-soft); border-bottom: 1px solid var(--color-border);
  overflow: hidden;
}
.p-card-img img, .detail-img img { width: 100%; height: 100%; object-fit: contain; display: block; }
.detail-img { overflow: hidden; }
.p-card-body { padding: var(--sp-3) var(--sp-4) var(--sp-4); display: flex; flex-direction: column; gap: 6px; flex: 1; }
.p-card-cat { font-size: var(--text-xs); color: var(--color-text-faint); }
.p-card-name { font-size: var(--text-sm); font-weight: 700; line-height: 1.45; min-height: 2.6em; }
.p-card-maker { font-size: var(--text-xs); color: var(--color-text-sub); }
.price-per-g { margin: 2px 0; line-height: 1.1; }
.price-per-g .num { font-family: var(--font-num); font-size: var(--text-num-hero); font-weight: 800; color: var(--color-green-600); }
.price-per-g .unit { font-size: var(--text-xs); color: var(--color-text-sub); font-weight: 700; margin-left: 2px; }
.price-per-g .label { display: block; font-size: var(--text-xs); color: var(--color-text-faint); }
.p-card-meta { font-size: var(--text-xs); color: var(--color-text-sub); }
.p-card-best-price { display: flex; align-items: baseline; flex-wrap: wrap; gap: 4px 6px; margin: 2px 0; }
.p-card-best-price .best-label { font-size: 10px; font-weight: 700; color: #fff; background: var(--color-green-600); border-radius: 4px; padding: 1px 5px; }
.p-card-best-price .best-num { font-family: var(--font-num); font-weight: 800; font-size: var(--text-md); }
.p-card-best-price .best-place { font-size: var(--text-xs); color: var(--color-text-sub); }
.p-card-best-price .compare-badge { font-size: 10px; color: var(--color-orange-600); border: 1px solid var(--color-orange-600); border-radius: 999px; padding: 0 6px; }
.p-card-tags { display: flex; flex-wrap: wrap; gap: 4px; }
.p-card-foot { margin-top: auto; padding-top: var(--sp-2); }
.p-card-foot .btn { width: 100%; }

/* ---------- Score pill ---------- */
.score-pill {
  display: inline-flex; align-items: baseline; gap: 3px;
  font-family: var(--font-num); font-weight: 800;
}
.score-pill .v { font-size: var(--text-lg); color: var(--color-text); }
.score-pill .max { font-size: var(--text-xs); color: var(--color-text-faint); font-weight: 400; }

/* ---------- Sections ---------- */
.section { padding: var(--sp-6) 0; }
.section-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: var(--sp-4); gap: var(--sp-3); }
.section-title { font-size: var(--text-xl); font-weight: 800; margin: 0; line-height: 1.4; }
.section-sub { color: var(--color-text-sub); font-size: var(--text-sm); margin: 4px 0 0; }
.section-more { font-size: var(--text-sm); font-weight: 700; color: var(--color-green-600); white-space: nowrap; }
.section-more:hover { text-decoration: underline; }

/* ---------- Hero ---------- */
.hero { padding: var(--sp-7) 0 var(--sp-6); text-align: center; }
.hero h1 { font-size: var(--text-2xl); font-weight: 800; line-height: 1.45; margin: 0 0 var(--sp-3); }
.hero h1 .accent { color: var(--color-green-600); }
.hero p { color: var(--color-text-sub); font-size: var(--text-md); max-width: 560px; margin: 0 auto var(--sp-5); }
.hero-ctas { display: flex; gap: var(--sp-3); justify-content: center; flex-wrap: wrap; }
@media (min-width: 720px) { .hero h1 { font-size: 2.5rem; } }

/* ---------- Ranking list ---------- */
.rank-list { display: flex; flex-direction: column; gap: var(--sp-2); }
.rank-row {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-bg);
  transition: border-color var(--dur-fast) var(--ease);
}
.rank-row:hover { border-color: var(--color-green-500); }
.rank-row .emoji { font-size: 26px; }
.rank-row .info { flex: 1; min-width: 0; }
.rank-row .info .name { font-size: var(--text-sm); font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rank-row .info .sub { font-size: var(--text-xs); color: var(--color-text-faint); }
.rank-row .metric { text-align: right; font-family: var(--font-num); font-weight: 800; color: var(--color-green-600); white-space: nowrap; }
.rank-row .metric small { display: block; font-size: 10px; color: var(--color-text-faint); font-weight: 400; font-family: var(--font-sans); }

/* ---------- Tabs ---------- */
.tabs { display: flex; gap: var(--sp-2); overflow-x: auto; padding-bottom: 2px; -webkit-overflow-scrolling: touch; }
.tab {
  border: 1px solid var(--color-border-strong); background: var(--color-bg);
  border-radius: var(--radius-pill); padding: 6px 16px;
  font-size: var(--text-sm); font-weight: 700; color: var(--color-text-sub);
  white-space: nowrap;
}
.tab.active { background: var(--color-green-600); border-color: var(--color-green-600); color: #fff; }

/* ---------- Filter bar ---------- */
.filter-bar {
  display: flex; flex-wrap: wrap; gap: var(--sp-2); align-items: center;
  padding: var(--sp-3) 0;
}
.filter-bar select, .filter-bar input[type="search"] {
  height: 36px; border: 1px solid var(--color-border-strong); border-radius: var(--radius-md);
  padding: 0 var(--sp-3); font-size: var(--text-sm); font-family: inherit; background: #fff;
  color: var(--color-text);
}
.filter-bar select:focus, .filter-bar input:focus { outline: 2px solid var(--color-green-500); outline-offset: -1px; }
.chip {
  border: 1px solid var(--color-border-strong); background: #fff; color: var(--color-text-sub);
  border-radius: var(--radius-pill); padding: 5px 14px; font-size: var(--text-xs); font-weight: 700;
}
.chip.active { background: var(--color-green-50); border-color: var(--color-green-500); color: var(--color-green-700); }

/* ---------- Table view ---------- */
.table-wrap { overflow-x: auto; border: 1px solid var(--color-border); border-radius: var(--radius-md); }
table.p-table { border-collapse: collapse; width: 100%; font-size: var(--text-sm); min-width: 760px; }
.p-table th, .p-table td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--color-border); white-space: nowrap; }
.p-table th { background: var(--color-bg-soft); font-size: var(--text-xs); color: var(--color-text-sub); cursor: pointer; user-select: none; position: sticky; top: 0; }
.p-table th:hover { color: var(--color-green-600); }
.p-table td.num { font-family: var(--font-num); font-weight: 700; text-align: right; }
.p-table td.num.best { color: var(--color-green-600); }
.p-table tr:hover td { background: var(--color-green-50); }

/* ---------- Chart ---------- */
.chart-box { border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--sp-4); background: #fff; }
.chart-hint { font-size: var(--text-xs); color: var(--color-text-faint); margin-top: var(--sp-2); }
.chart-legend { display: flex; flex-wrap: wrap; gap: var(--sp-3); font-size: var(--text-xs); color: var(--color-text-sub); margin-top: var(--sp-3); }
.chart-legend .key { display: inline-flex; align-items: center; gap: 5px; }
.chart-legend .dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }
.chart-tooltip {
  position: absolute; pointer-events: none; z-index: 30;
  background: #fff; border: 1px solid var(--color-border-strong); border-radius: var(--radius-md);
  box-shadow: var(--shadow-pop); padding: var(--sp-3) var(--sp-4);
  font-size: var(--text-xs); line-height: 1.6; min-width: 180px; display: none;
}
.chart-tooltip .t-name { font-weight: 700; font-size: var(--text-sm); }
.chart-tooltip .t-row { display: flex; justify-content: space-between; gap: var(--sp-3); }
.chart-tooltip .t-row b { font-family: var(--font-num); }

/* ---------- Forms ---------- */
.form-section {
  border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  padding: var(--sp-5); margin-bottom: var(--sp-4); background: #fff;
}
.form-section h2 { font-size: var(--text-lg); margin: 0 0 var(--sp-4); display: flex; align-items: center; gap: var(--sp-2); }
.form-section h2 .step {
  width: 24px; height: 24px; border-radius: 50%; background: var(--color-green-600); color: #fff;
  display: inline-flex; align-items: center; justify-content: center; font-size: var(--text-xs); font-family: var(--font-num);
}
.field { margin-bottom: var(--sp-4); }
.field label { display: block; font-size: var(--text-sm); font-weight: 700; margin-bottom: 6px; }
.field .req { color: var(--color-danger); font-size: var(--text-xs); margin-left: 4px; }
.field input[type="text"], .field input[type="number"], .field input[type="url"],
.field select, .field textarea {
  width: 100%; border: 1px solid var(--color-border-strong); border-radius: var(--radius-md);
  padding: 10px 14px; font-size: var(--text-md); font-family: inherit; background: #fff;
  color: var(--color-text);
}
.field input:focus, .field select:focus, .field textarea:focus { outline: 2px solid var(--color-green-500); outline-offset: -1px; }
.field .hint { font-size: var(--text-xs); color: var(--color-text-faint); margin-top: 4px; }
.field-row { display: grid; gap: var(--sp-3); grid-template-columns: 1fr 1fr; }
.calc-panel {
  position: sticky; bottom: 0; z-index: 40;
  background: var(--color-green-700); color: #fff;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  padding: var(--sp-3) var(--sp-4);
  display: flex; gap: var(--sp-4); align-items: center; justify-content: space-around;
  box-shadow: 0 -4px 16px rgba(23,33,26,.18);
}
.calc-panel .c-item { text-align: center; }
.calc-panel .c-item .v { font-family: var(--font-num); font-size: var(--text-xl); font-weight: 800; line-height: 1.2; }
.calc-panel .c-item .v small { font-size: var(--text-xs); font-weight: 400; }
.calc-panel .c-item .l { font-size: 10px; opacity: .85; }
.calc-panel .c-grade { background: #fff; color: var(--color-green-700); border-radius: var(--radius-md); padding: 4px 14px; font-family: var(--font-num); font-size: var(--text-xl); font-weight: 800; }
.star-input { display: flex; gap: 6px; font-size: 30px; color: var(--color-border-strong); }
.star-input button { background: none; border: none; font-size: inherit; color: inherit; padding: 0; line-height: 1; }
.star-input button.on { color: var(--color-star); }

/* ---------- Detail page ---------- */
.detail-grid { display: grid; gap: var(--sp-5); }
@media (min-width: 880px) { .detail-grid { grid-template-columns: 320px 1fr; } }
.detail-img {
  border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  height: 260px; display: flex; align-items: center; justify-content: center;
  font-size: 96px; background: var(--color-bg-soft);
}
.kpi-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-3); }
@media (min-width: 720px) { .kpi-grid { grid-template-columns: repeat(3, 1fr); } }
.kpi {
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  padding: var(--sp-3) var(--sp-4); background: #fff;
}
.kpi.hero-kpi { background: var(--color-green-50); border-color: var(--color-green-100); }
.kpi .l { font-size: var(--text-xs); color: var(--color-text-sub); }
.kpi .v { font-family: var(--font-num); font-size: var(--text-xl); font-weight: 800; line-height: 1.3; }
.kpi.hero-kpi .v { color: var(--color-green-600); font-size: var(--text-num-hero); }
.kpi .v small { font-size: var(--text-xs); font-weight: 400; color: var(--color-text-sub); }

.review-item { border-bottom: 1px solid var(--color-border); padding: var(--sp-4) 0; }
.review-item .r-head { display: flex; align-items: center; gap: var(--sp-2); margin-bottom: 4px; }
.review-item .avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--color-green-100); color: var(--color-green-700);
  display: inline-flex; align-items: center; justify-content: center; font-weight: 800; font-size: var(--text-sm);
}
.review-item .r-name { font-size: var(--text-sm); font-weight: 700; }
.review-item .r-date { font-size: var(--text-xs); color: var(--color-text-faint); }
.review-item p { margin: 4px 0 0; font-size: var(--text-sm); color: var(--color-text); }
.review-item .r-report { font-size: var(--text-xs); color: var(--color-text-faint); background: none; border: none; }
.review-item .r-report:hover { color: var(--color-danger); }

/* ---------- Notice / footer ---------- */
.notice-bar {
  background: var(--color-green-50); color: var(--color-green-700);
  font-size: var(--text-xs); text-align: center; padding: 6px var(--sp-4);
}
.price-note { font-size: var(--text-xs); color: var(--color-text-faint); }
.site-footer {
  margin-top: var(--sp-8);
  border-top: 1px solid var(--color-border);
  padding: var(--sp-6) 0; background: var(--color-bg-soft);
  font-size: var(--text-sm); color: var(--color-text-sub);
}
.site-footer .links { display: flex; flex-wrap: wrap; gap: var(--sp-4); margin-bottom: var(--sp-4); }
.site-footer .links a:hover { color: var(--color-green-600); }
.site-footer .legal { font-size: var(--text-xs); color: var(--color-text-faint); line-height: 1.8; }

/* ---------- Category grid ---------- */
.cat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-3); }
@media (min-width: 720px) { .cat-grid { grid-template-columns: repeat(5, 1fr); } }
.cat-card {
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  padding: var(--sp-4) var(--sp-2); text-align: center; background: #fff;
  transition: border-color var(--dur-fast) var(--ease);
}
.cat-card:hover { border-color: var(--color-green-500); }
.cat-card .emoji { font-size: 30px; }
.cat-card .name { font-size: var(--text-xs); font-weight: 700; margin-top: 4px; }
.cat-card .count { font-size: 10px; color: var(--color-text-faint); }

/* ---------- Breadcrumb / misc ---------- */
.breadcrumb { font-size: var(--text-xs); color: var(--color-text-faint); padding: var(--sp-3) 0; }
.breadcrumb a:hover { color: var(--color-green-600); text-decoration: underline; }
.pagination { display: flex; gap: var(--sp-2); justify-content: center; padding: var(--sp-5) 0; }
.pagination button {
  min-width: 36px; height: 36px; border: 1px solid var(--color-border-strong);
  background: #fff; border-radius: var(--radius-md); font-size: var(--text-sm); font-weight: 700;
  color: var(--color-text-sub);
}
.pagination button.active { background: var(--color-green-600); border-color: var(--color-green-600); color: #fff; }

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
