/* ============================================
   Picks Top v1 — FIX (Yutaro 2026-05-06)
   Hero = 🅼 1行my picks. + 区切り + 数字 (編集要素ゼロ)
   Body = 🅴-A 方針 (Sort + Vertical Grid 4:5)
   T1 無彩色 / T6 大胆な余白 / T9 Inter Light Tabular
   ============================================ */

/* ---------- Hero (🅼 採用 / Issueラベル & Cover Pick 削除) ---------- */
.mp-hero {
  padding: 36px 20px 32px;
  background: #FFFFFF;
}

.mp-hero__title {
  font-family: 'Inter', sans-serif;
  font-weight: 200;
  font-size: 56px;
  letter-spacing: -0.04em;
  line-height: 0.95;
  color: #1A1A1A;
  margin: 0 0 24px;
  display: block;
}

.mp-hero__divider {
  width: 100%;
  max-width: 220px;
  height: 1px;
  background: rgba(26,26,26,0.18);
  margin: 0 0 26px;
}

.mp-hero__numbers {
  display: flex;
  gap: 0;
  margin: 0;
}

.mp-hero__num-block {
  flex: 1;
  border-right: 1px solid rgba(26,26,26,0.1);
  padding-right: 14px;
}
.mp-hero__num-block:last-child {
  border-right: none;
}
.mp-hero__num-block:not(:first-child) {
  padding-left: 14px;
}

.mp-hero__num {
  font-family: 'Inter', sans-serif;
  font-weight: 200;
  font-size: 36px;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.03em;
  color: #1A1A1A;
  line-height: 1;
  display: block;
  margin: 0 0 5px;
}

.mp-hero__lbl {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 9px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(26,26,26,0.5);
  margin: 0;
  display: block;
}

/* ---------- Sort bar (🅴-A 方針) ---------- */
.mp-sort {
  display: flex;
  gap: 6px;
  padding: 16px 20px 6px;
  align-items: center;
  flex-wrap: wrap;
}

.mp-sort__lbl {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 9px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(26,26,26,0.4);
  margin-right: 6px;
}

.mp-sort__btn {
  font-family: 'Inter', 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 12px;
  color: rgba(26,26,26,0.6);
  background: transparent;
  border: 1px solid rgba(26,26,26,0.12);
  border-radius: 999px;
  padding: 6px 13px;
  cursor: pointer;
  letter-spacing: 0.01em;
  -webkit-tap-highlight-color: transparent;
  transition: all 0.18s ease;
}

.mp-sort__btn.is-active {
  color: #FFFFFF;
  background: #1A1A1A;
  border-color: #1A1A1A;
  font-weight: 500;
}

/* ---------- Section header ---------- */
.mp-section {
  padding: 22px 20px 12px;
  display: flex;
  align-items: baseline;
  gap: 6px;
}

.mp-section__title {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #1A1A1A;
  margin: 0;
}

.mp-section__sep {
  color: rgba(26,26,26,0.3);
  margin: 0 2px;
  line-height: 1;
}

.mp-section__count {
  font-family: 'Inter', sans-serif;
  font-weight: 200;
  font-size: 16px;
  font-variant-numeric: tabular-nums;
  color: #1A1A1A;
  line-height: 1;
}

.mp-section__count-lbl {
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  font-size: 11px;
  color: rgba(26,26,26,0.5);
  letter-spacing: 0.05em;
  line-height: 1;
}

/* ---------- 2-Column Vertical Grid (4:5 縦長 / 🅴-A 方針) ---------- */
.mp-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px 14px;
  padding: 0 20px 32px;
}

.mp-card {
  display: block;
  text-decoration: none;
  color: inherit;
  -webkit-tap-highlight-color: transparent;
}

.mp-card__image {
  width: 100%;
  aspect-ratio: 4 / 5;
  background: #F5F2EC;
  border-radius: 4px;
  overflow: hidden;
  position: relative;
  margin-bottom: 12px;
  transition: opacity 0.2s ease;
}

.mp-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.mp-card__title {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 14px;
  line-height: 1.3;
  color: #1A1A1A;
  margin: 0 0 4px;
}

.mp-card__sub {
  font-family: 'Inter', 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 11px;
  color: rgba(26,26,26,0.55);
  margin: 0 0 8px;
  line-height: 1.3;
}

.mp-card__avatars {
  display: inline-flex;
  margin: 0 0 6px;
  vertical-align: middle;
}

.mp-card__avatars img {
  width: 17px;
  height: 17px;
  border-radius: 50%;
  border: 1.5px solid #FFFFFF;
  margin-left: -5px;
  object-fit: cover;
  background: #EFEBE4;
  display: block;
}

.mp-card__avatars img:first-child { margin-left: 0; }

.mp-card__price {
  font-family: 'Inter', sans-serif;
  font-weight: 200;
  font-size: 13px;
  font-variant-numeric: tabular-nums;
  color: #1A1A1A;
  margin: 0;
  line-height: 1;
}

/* ---------- CLINIC variant (Tifuler Visited count / price 位置を踏襲) ---------- */
.mp-card__visited {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  margin: 0;
  line-height: 1;
}

.mp-card__visited-num {
  font-family: 'Inter', sans-serif;
  font-weight: 200;
  font-size: 13px;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  color: #1A1A1A;
}

.mp-card__visited-lbl {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(26,26,26,0.5);
}

/* CLINIC: フィルター非表示 (mp-card 化対応) */
.mp-card.is-hidden { display: none; }

.mp-card:active .mp-card__image {
  opacity: 0.88;
}

/* ---------- 小型端末 (≤360px) ---------- */
@media (max-width: 360px) {
  .mp-hero { padding: 28px 16px 26px; }
  .mp-hero__title { font-size: 48px; }
  .mp-hero__num { font-size: 32px; }
  .mp-grid { padding: 0 16px 28px; gap: 24px 12px; }
  .mp-sort { padding: 14px 16px 4px; }
  .mp-section { padding: 18px 16px 10px; }
}
