/* =========================================================
   JWL — news.php / news_detail.php styles
   ========================================================= */

.news-body {
  max-width: 960px;
  margin: 0 auto;
  padding: clamp(40px, 6vw, 72px) var(--pad-x) clamp(80px, 10vw, 140px);
  font-family: var(--font-jp);
  color: var(--text);
}

/* ---------- News list page ---------- */
.news-page-list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid var(--border);
}
.news-page-item { border-bottom: 1px solid var(--border); }
.news-page-item a {
  display: block;
  padding: 28px 4px;
  color: inherit;
  transition: padding .3s, color .2s;
}
.news-page-item a:hover {
  padding-left: 14px;
  color: var(--text);
}
.news-page-item a:hover .news-page-title { color: var(--accent-3); }

.news-page-meta {
  display: flex;
  gap: 16px;
  align-items: center;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.news-page-meta time {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-2);
  letter-spacing: 0.04em;
}
.news-page-title {
  font-size: clamp(17px, 2vw, 20px);
  font-weight: 600;
  line-height: 1.55;
  margin: 0 0 8px;
  transition: color .2s;
}
.news-page-summary {
  margin: 0;
  color: var(--text-2);
  font-size: 14px;
  line-height: 1.75;
}

.news-empty {
  padding: 48px 0;
  text-align: center;
  color: var(--text-2);
}

/* Category (tag) color variants — override base .news-tag (from style.css) */
.news-tag-release  { color: var(--accent-2); border-color: rgba(34,211,238,0.4); }
.news-tag-jline    { color: var(--accent-3); border-color: rgba(20,184,166,0.4); }
.news-tag-recruit  { color: #fbbf24; border-color: rgba(251,191,36,0.4); }
.news-tag-partner  { color: #a78bfa; border-color: rgba(167,139,250,0.4); }
.news-tag-event    { color: #f472b6; border-color: rgba(244,114,182,0.4); }
.news-tag-media    { color: #60a5fa; border-color: rgba(96,165,250,0.4); }
.news-tag-other    { color: var(--text-2); }

/* ---------- Pager ---------- */
.news-pager {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 32px;
  margin: 48px 0 0;
  padding: 24px 0;
  border-top: 1px solid var(--border);
  font-family: var(--font-en);
  font-size: 14px;
  letter-spacing: 0.06em;
}
.news-pager a {
  color: var(--text-2);
  padding: 10px 18px;
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  transition: all .2s;
}
.news-pager a:hover { color: var(--accent-3); border-color: var(--accent-3); }
.news-pager-state {
  font-family: var(--font-mono);
  color: var(--text-3);
  font-size: 13px;
}

/* ---------- Detail page ---------- */
.news-detail-hero { padding-bottom: clamp(32px, 4vw, 48px); }
.news-detail-meta {
  display: flex;
  gap: 16px;
  align-items: center;
  margin: 10px 0 18px;
  flex-wrap: wrap;
}
.news-detail-meta time {
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--text-2);
  letter-spacing: 0.04em;
}
.news-detail-title {
  font-size: clamp(26px, 4vw, 44px);
  line-height: 1.35;
}

.news-detail-article {
  line-height: 2;
  color: var(--text);
  font-size: 15.5px;
}
.news-detail-article p { margin: 0 0 1.4em; }
.news-detail-article p:last-child { margin-bottom: 0; }
.news-detail-article h2 {
  margin: 2.4em 0 0.8em;
  font-size: clamp(22px, 2.6vw, 28px);
  font-weight: 700;
  line-height: 1.4;
  border-left: 3px solid var(--accent-3);
  padding-left: 14px;
}
.news-detail-article h3 {
  margin: 2em 0 0.6em;
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 700;
}
.news-detail-article h4 {
  margin: 1.6em 0 0.5em;
  font-size: 16px;
  font-weight: 600;
  color: var(--text-2);
}
.news-detail-article ul,
.news-detail-article ol {
  margin: 0 0 1.4em;
  padding-left: 1.6em;
}
.news-detail-article li { margin-bottom: 0.4em; }
.news-detail-article ul li::marker { color: var(--accent-3); }
.news-detail-article a {
  color: var(--accent-3);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.news-detail-article a:hover { text-decoration-thickness: 2px; }
.news-detail-article blockquote {
  margin: 1.6em 0;
  padding: 14px 22px;
  border-left: 3px solid var(--accent-3);
  background: rgba(20,184,166,0.05);
  color: var(--text-2);
  border-radius: 0 6px 6px 0;
}
.news-detail-article hr {
  margin: 2.4em 0;
  border: 0;
  height: 1px;
  background: var(--border);
}
.news-detail-article strong { color: var(--text); font-weight: 700; }

.news-detail-back {
  margin-top: 56px;
  padding-top: 32px;
  border-top: 1px solid var(--border);
  display: flex;
  justify-content: center;
}

@media (max-width: 640px) {
  .news-page-item a:hover { padding-left: 6px; }
  .news-detail-title { font-size: clamp(22px, 6vw, 32px); }
}
