@charset "utf-8";

/* ==========================================================================
   [nws_] News Page Specific Styles
   ========================================================================== */

/* リスト全体の枠線 */
.nws_list {
  list-style: none;
  border-top: 2px solid var(--color-border-light); /* 共通ヘッダーと同じ太さの線 */
}

/* 1件ずつの線 */
.nws_item {
  border-bottom: 1px solid var(--color-border-light);
}

/* リンクエリア */
.nws_link {
  display: flex;
  align-items: center;
  padding: 30px 10px; /* 少し広めにとってゆったりと */
  color: var(--color-text-main);
  transition: all var(--transition-base);
}

/* ホバー時の心地よい動き */
.nws_link:hover {
  background-color: var(--color-bg-light);
  padding-left: 20px; /* スッと右に動く */
}

/* 日付とカテゴリーのまとまり */
.nws_meta {
  display: flex;
  align-items: center;
  gap: 15px;
  width: 220px; /* PC版ではメタ情報の幅を固定 */
  flex-shrink: 0;
}

.nws_date {
  font-size: var(--fs-sm);
  font-weight: bold;
  letter-spacing: 0.05em;
}

/* カテゴリータグ */
.nws_cat {
  font-size: var(--fs-xs);
  font-weight: bold;
  padding: 4px 12px;
  border-radius: 50px;
  border: 1px solid;
}

/* カテゴリーごとの色分け（黒基調のテーマに合わせてシックに） */
.nws_cat.is_info {
  border-color: var(--color-main);
  color: var(--color-main);
}
.nws_cat.is_media {
  border-color: #888;
  color: #888;
}
.nws_cat.is_event {
  border-color: #555;
  color: #555;
}

/* タイトル */
.nws_ttl {
  font-size: var(--fs-base);
  line-height: 1.6;
  margin: 0;
  font-weight: normal;
}

/* ホバー時にタイトルを少し濃くする */
.nws_link:hover .nws_ttl {
  font-weight: bold;
}

/* ==========================================================================
   SP Responsive (Max-width: 768px)
   ========================================================================== */
@media (max-width: 768px) {
  .nws_link {
    flex-direction: column;
    align-items: flex-start;
    padding: 24px 10px;
    gap: 12px;
  }
  .nws_link:hover {
    padding-left: 10px; /* スマホでは右に動かさない（ブレ防止） */
  }
  .nws_meta {
    width: 100%; /* 幅固定を解除 */
  }
}
