/* ============================================================
   home.css — winzheng.jp トップページ補助スタイル
   YZ指数ダッシュボード + サイドバー + 日本語タイポグラフィ
   ============================================================ */

/* --- 日本語タイポグラフィ最適化 --- */
.hero__title,
.hero__excerpt,
.article-card__title {
  font-feature-settings: "palt" 1;
}

/* --- YZ指数ダッシュボード --- */
.yz-dashboard {
  padding: 16px 0;
  border-bottom: 1px solid var(--border, #e5e5e3);
}

.yz-dashboard__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.yz-dashboard__header h2 {
  font-size: 15px;
  font-weight: 700;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text, #1c1c1e);
}

.yz-dashboard__more {
  font-size: 12px;
  color: var(--text-muted, #9ca3af);
  text-decoration: none;
}

.yz-dashboard__more:hover {
  color: var(--accent, #c5342e);
}

.yz-dashboard__rule {
  display: inline-block;
  width: 3px;
  height: 16px;
  border-radius: 2px;
  transform: translateY(1px);
}

.yz-dashboard__rule--red { background: var(--accent, #c5342e); }
.yz-dashboard__rule--gold { background: #b8860b; }

/* 3-column grid */
.yz-dashboard__grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px;
}

.yz-dashboard__card {
  background: #fff;
  border: 1px solid var(--border, #e5e5e3);
  border-top: 3px solid var(--border, #e5e5e3);
  border-radius: var(--radius, 6px);
  padding: 12px 14px;
}

.yz-dashboard__card--red { border-top-color: var(--accent, #c5342e); }
.yz-dashboard__card--gold {
  border-top-color: #b8860b;
  background: #fffdf7;
}
.yz-dashboard__card--neutral { border-top-color: #6b7280; }

.yz-dashboard__label {
  font-size: 11px;
  color: var(--text-muted, #9ca3af);
  font-weight: 600;
  letter-spacing: 0.04em;
  margin-bottom: 8px;
}

.yz-dashboard__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.yz-dashboard__list li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 13px;
  color: var(--text, #1c1c1e);
  padding: 4px 0;
  border-bottom: 1px dashed var(--border-light, #f0efed);
}

.yz-dashboard__list li:last-child {
  border-bottom: none;
}

.yz-dashboard__list li span {
  font-weight: 700;
  margin-right: 6px;
  min-width: 16px;
  flex-shrink: 0;
}

.yz-dashboard__card--red .yz-dashboard__list li span {
  color: var(--accent, #c5342e);
}

.yz-dashboard__card--gold .yz-dashboard__list li span {
  color: #8a6d1f;
}

.yz-dashboard__list li em {
  font-style: normal;
  font-weight: 700;
  font-size: 13px;
}

.yz-dashboard__card--red .yz-dashboard__list li em { color: var(--accent, #c5342e); }
.yz-dashboard__card--gold .yz-dashboard__list li em { color: #16a34a; }

/* 今週の変動 */
.yz-dashboard__changes {
  list-style: none;
  padding: 0;
  margin: 0;
}

.yz-dashboard__changes li {
  display: flex;
  align-items: center;
  padding: 4px 0;
  border-bottom: 1px dashed var(--border-light, #f0efed);
  font-size: 12px;
  color: var(--text, #1c1c1e);
}

.yz-dashboard__changes li:last-child {
  border-bottom: none;
}

.yz-dashboard__changes li em {
  font-style: normal;
  font-weight: 700;
  margin-left: auto;
}

.yz-dashboard__arrow {
  margin-right: 6px;
  font-weight: 700;
}

.yz-dashboard__change--up .yz-dashboard__arrow,
.yz-dashboard__change--up em {
  color: #16a34a;
}

.yz-dashboard__change--down .yz-dashboard__arrow,
.yz-dashboard__change--down em {
  color: #c5342e;
}

.yz-dashboard__change--incident .yz-dashboard__arrow {
  color: #d97706;
}

.yz-dashboard__change--incident {
  color: #92400e;
  font-size: 11px;
}

/* --- サイドバー: 最新レビュー --- */
.sidebar-reviews {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
}

.sidebar-reviews li {
  padding: 8px 0;
  border-bottom: 1px dashed var(--border-light, #f0efed);
}

.sidebar-reviews li:last-child {
  border-bottom: none;
}

.sidebar-reviews li a {
  display: block;
  font-size: 13px;
  line-height: 1.5;
  color: var(--text, #1c1c1e);
  text-decoration: none;
  font-feature-settings: "palt" 1;
}

.sidebar-reviews li a:hover {
  color: var(--accent, #c5342e);
}

.sidebar-reviews__meta {
  display: block;
  font-size: 11px;
  color: var(--text-muted, #9ca3af);
  margin-top: 2px;
}

/* --- サイドバー：和モダン設計 --- */
.home-grid aside {
  background: var(--bg-warm, #faf8f5);
  border: 1px solid var(--border-light, #e8e6e3);
  border-radius: var(--radius, 6px);
  padding: 16px 18px;
  box-shadow: var(--shadow-sm, 0 1px 2px rgba(0,0,0,0.04));
}

.home-grid aside .section-head {
  padding-bottom: 8px;
  border-bottom: 2px solid var(--accent, #c5342e);
  margin-bottom: 10px;
}

.home-grid aside .section-head h2 {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.home-grid aside .section-head + .sidebar-reviews,
.home-grid aside .section-head + .ranking {
  margin-top: 0;
}

/* レビューと人気の間の区切り */
.home-grid aside .sidebar-reviews {
  margin-bottom: 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border-light, #e8e6e3);
}

.home-grid aside .ranking__title a,
.home-grid aside .popular-title a {
  font-size: 13px;
  line-height: 1.4;
}

.home-grid aside .ranking__excerpt,
.home-grid aside .popular-excerpt {
  font-size: 11px;
}

.home-grid aside .ranking__meta,
.home-grid aside .popular-meta {
  font-size: 10px;
}

.home-grid aside .ranking__num {
  font-family: var(--font-serif);
  font-size: 20px;
  min-width: 26px;
  color: var(--border, #e5e5e3);
}

.home-grid aside .ranking__item:nth-child(1) .ranking__num { color: var(--accent, #c5342e); }
.home-grid aside .ranking__item:nth-child(2) .ranking__num { color: #b8860b; }
.home-grid aside .ranking__item:nth-child(3) .ranking__num { color: #6b7280; }

/* --- レスポンシブ --- */
@media (max-width: 1023px) {
  .yz-dashboard__grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 767px) {
  .yz-dashboard {
    padding: 12px 0;
  }

  .yz-dashboard__grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .yz-dashboard__card {
    padding: 10px 12px;
  }

  .home-grid aside {
    border: none;
    border-radius: 0;
    box-shadow: none;
    padding: 16px 0 0;
    background: transparent;
    border-top: 1px solid var(--border, #e5e5e3);
    margin-top: 16px;
  }
}
