/* =========================================================
   Front: News (text-only list)
   依存トークンが無い環境でも崩れないように fallback を併記
   ========================================================= */

:root{
  --news-bg: var(--c-bg, #f7f6f3);
  --news-card: var(--c-surface, #ffffff);
  --news-text: var(--c-text, #222);
  --news-muted: var(--c-muted, #6b7280);
  --news-accent: var(--c-accent, #a1905a);
  --news-danger: var(--c-danger, #b4645e);
  --news-border: var(--c-border, #e5e7eb);

  --news-space-2: var(--space-2, .25rem);
  --news-space-3: var(--space-3, .5rem);
  --news-space-4: var(--space-4, .75rem);
  --news-space-5: var(--space-5, 1rem);
  --news-space-6: var(--space-6, 1.25rem);
  --news-space-8: var(--space-8, 2rem);

  --news-radius: var(--radius-lg, 12px);
  --news-shadow: var(--shadow-sm, 0 1px 2px rgba(0,0,0,.06));
}

/* ===== Section ===== */
.newsSection{
  background: var(--news-bg);
  padding: var(--news-space-8) var(--container-gutter, 20px);
}
.newsHeader{
  display:flex; align-items:center; justify-content:space-between;
  max-width: var(--container-max, 1200px);
  margin: 0 auto var(--news-space-4);
}
.newsHeader h2{
  font: inherit;
  font-weight: 700;
  font-size: clamp(14px, 1.2vw, 16px);
  color: var(--news-text);
  letter-spacing: .04em;
}
.newsMore{
  font-size: 13px;
  color: var(--news-accent);
  text-decoration: none;
}
.newsMore:hover{ text-decoration: underline; }

/* ===== List wrapper ===== */
.newsList{
  max-width: var(--container-max, 1200px);
  margin: 0 auto;
  background: var(--news-card);
  border-radius: var(--news-radius);
  box-shadow: var(--news-shadow);
  overflow: hidden;
}

/* ===== Item ===== */
.newsItem{
  display:grid;
  grid-template-columns: auto auto 1fr auto;
  align-items:center;
  gap: var(--news-space-4);
  padding: var(--news-space-6) var(--news-space-6);
  color: var(--news-text);
  text-decoration:none;
  border-bottom: 1px solid var(--news-border);
}
.newsItem:last-child{ border-bottom: none; }
.newsItem:hover{
  background: rgba(0,0,0,.02);
}

/* badge */
.newsBadge{
  display:inline-flex; align-items:center; justify-content:center;
  min-width: 56px;
  padding: 4px 10px;
  font-size: 12px; font-weight: 700;
  color: #fff; background: var(--news-muted);
  border-radius: 999px;
}
.newsBadge--important{ background: var(--news-danger); }

/* date */
.newsDate{
  font-size: 12px; color: var(--news-muted);
  white-space: nowrap;
}

/* title */
.newsTitle{
  font-size: 14px;
  line-height: 1.6;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* arrow */
.newsArrow{
  font-size: 18px;
  color: var(--news-muted);
  padding-left: var(--news-space-4);
}

/* ===== Responsive ===== */
@media (max-width: 640px){
  .newsSection{ padding-left: var(--container-gutter, 16px); padding-right: var(--container-gutter, 16px); }
  .newsItem{
    grid-template-columns: auto 1fr auto;
    gap: var(--news-space-3);
    padding: var(--news-space-5) var(--news-space-5);
  }
  .newsDate{ order: 3; margin-left: var(--news-space-3); }
  .newsArrow{ display:none; } /* スマホは矢印非表示でも可 */
  .newsBadge{ min-width: 46px; padding: 3px 8px; font-size: 11px; }
  .newsTitle{ font-size: 13px; }
}
