/* セクションタイトル */
.section-title {
  font-size: var(--font-size-xl);
  line-height: var(--line-height-xl);
  text-align: center;
  margin-bottom: var(--spacing-md);
  position: relative;
  display: inline-block;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  opacity: 0;
  color: var(--color-text-light);
  animation: fadeUpSlow 1.2s ease forwards;
}

.section-title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 100%;
  height: 2px;
  background-color: var(--color-accent);
  transform-origin: left center;
  transform: scaleX(0);
  opacity: 0;
  animation: lineGrow 0.7s ease forwards;
  animation-delay: 1.2s;
}

.section-title:hover::after {
  background-color: var(--color-accent-light);
}

@keyframes fadeUpSlow {
  0% {
    opacity: 0;
    transform: translateY(25px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes lineGrow {
  0% {
    transform: scaleX(0);
    opacity: 0;
  }
  100% {
    transform: scaleX(1);
    opacity: 1;
  }
}

/* サブタイトル */
.sub-title {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-lg);
  font-weight: 600;
  color: var(--color-sub);
  position: relative;
  transition: color 0.3s ease;
  letter-spacing: 0.5px;
}

.sub-title::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 50%;
  height: 2px;
  background-color: var(--color-accent);
  transform: scaleX(0);
  transition: transform 0.3s ease;
}

.sub-title:hover {
  color: var(--color-accent);
}

.sub-title:hover::before {
  transform: scaleX(1);
}

/* 通常テキスト */
p {
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  margin-bottom: var(--spacing-small);
  color: var(--color-text-dark);
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  text-align: justify;
  transition: color 0.3s ease;
}

p:hover {
  color: var(--color-accent);
  font-weight: 500;
}

/* レスポンシブ調整 */
@media (max-width: 768px) {
  .csection-container .container {
    padding: 0 1rem;
  }

  .section-title {
    font-size: var(--font-size-lg);
    line-height: var(--line-height-lg);
  }

  .sub-title {
    font-size: var(--font-size-base);
    line-height: var(--line-height-base);
  }

  .cta-button {
    padding: 0.8rem 1.5rem;
  }

  .company-overview-table th,
  .company-overview-table td {
    font-size: var(--font-size-xs);
    padding: 0.8rem;
  }

  .section-container .section .column {
    flex: 1 1 100%; /* モバイル時は1列 */
  }
}

@media (min-width: 1024px) {
  .section-container .container {
    padding: 0 3rem;
  }

  .section-title {
    font-size: var(--font-size-xl);
    line-height: var(--line-height-xl);
  }

  .sub-title {
    font-size: var(--font-size-lg);
    line-height: var(--line-height-lg);
  }
}

/* ベースコンテナ */
.content-article.page-content {
  max-width: 900px;
  margin: 0 auto;
  padding: var(--spacing-xl) var(--spacing-md);
  color: var(--color-text-dark);
  line-height: 1.75;
  box-sizing: border-box;
}

.content-article.page-content section {
  margin-bottom: var(--spacing-xl);
}

.content-article.page-content strong {
  color: var(--color-accent);
  font-weight: 700;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
  .content-article.page-content {
    padding: var(--spacing-lg) 1rem;
  }

  .content-article.page-content h2 {
    font-size: var(--font-size-base);
    line-height: var(--line-height-base);
  }

  .content-article.page-content p {
    font-size: var(--font-size-base);
    line-height: var(--line-height-base);
  }
}

@media (min-width: 1024px) {
  .content-article.page-content {
    padding: var(--spacing-xxl) 3rem;
  }

  .content-article.page-content h2 {
    font-size: var(--font-size-lg);
    line-height: var(--line-height-lg);
  }
}





/* カテゴリナビ */
#category-nav ul {
  display: flex;
  flex-wrap: wrap;
  row-gap: var(--spacing-sm); /* 2列目との縦の間隔 */
  column-gap: var(--spacing-sm); /* 横の間隔 */
  list-style: none;
  padding: 0;
  margin: 0 0 var(--spacing-lg);
}

.category-link {
  padding: var(--spacing-xs) var(--spacing-md);
  border: 1.5px solid var(--color-line);
  border-radius: var(--border-radius);
  color: var(--color-text-light);
  background-color: transparent;
  font-size: var(--font-size-base);
  font-weight: 600;
  cursor: pointer;
  user-select: none;
}

.category-link:hover,
.category-link:focus {
  border-color: var(--color-accent);
  color: var(--color-accent);
  outline: none;
}

.category-link.selected,
.category-link[aria-pressed="true"] {
  background-color: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
  cursor: default;
}

/* 検索＆並び替え */
#search-and-sort {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-lg);
}

#keyword-input,
#sort-select {
  padding: var(--spacing-xs) var(--spacing-sm);
  border: 1.5px solid var(--color-line);
  border-radius: var(--border-radius);
  font-size: var(--font-size-base);
  max-width: 320px;
}

#keyword-input:focus,
#sort-select:focus {
  border-color: var(--color-accent);
  outline: none;
}

/* タグフィルター */
#tag-filter {
  margin-top: 0;
  margin-bottom: var(--spacing-xxl);
  padding: 0 var(--spacing-xs);
}

#tag-filter ul,
#tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
  list-style: none;
  padding: 0;
  margin: 0;
}

#tag-list a,
#tag-filter a {
  display: inline-block;
  padding: var(--spacing-xs) var(--spacing-md);
  border: 1.5px solid var(--color-line);
  border-radius: var(--border-radius);
  font-size: var(--font-size-sm);
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.05em;
  text-transform: capitalize;
  background-color: transparent;
  user-select: none;
  text-decoration: none;
  color: var(--color-text-light);
}

#tag-list a:hover,
#tag-list a:focus-visible,
#tag-filter a:hover,
#tag-filter a:focus-visible {
  background-color: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
  outline: none;
}

#tag-list a.selected,
#tag-filter a.selected {
  background-color: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
  font-weight: 700;
  cursor: default;
}

/* 記事一覧 */
#post-list {
  display: block;
  width: 100%;
  padding: var(--spacing-lg);
  margin: 0 auto;
}

#post-list article {
  width: 100%;
  max-width: 800px; /* 最大幅を指定して、余裕を持たせる */
  margin: var(--spacing-md) auto; /* 上下の余白 */
  padding: var(--spacing-md);
  border: 1px solid var(--color-line);
  background-color: var(--color-bg);
  border-radius: var(--border-radius);
  box-sizing: border-box;
  transition: box-shadow 0.3s ease;
}

#post-list article:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

#post-list article h3 {
  font-weight: 700;
  margin-bottom: var(--spacing-sm);
}

#post-list article p {
  line-height: var(--line-height-base);
  margin-bottom: var(--spacing-lg);
  text-align: justify; /* 両端揃え */
}

#post-list article .post-meta {
  font-size: var(--font-size-sm);
  margin-top: var(--spacing-sm);
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}

#post-list article .post-meta span {
  display: inline-block;
}

#post-list article a {
  text-decoration: none;
  color: inherit;
}

#post-list article img {
  width: 100%;
  height: auto;
  margin-bottom: var(--spacing-md);
  border-radius: var(--border-radius);
}

/* ページネーション */
#pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-md);
  margin-top: var(--spacing-xl);
}

#pagination button {
  padding: var(--spacing-xs) var(--spacing-lg);
  border: 2px solid var(--color-line);
  background-color: var(--color-bg);
  border-radius: var(--border-radius);
  font-size: var(--font-size-base);
  cursor: pointer;
}

#pagination button:hover:not([disabled]),
#pagination button:focus:not([disabled]) {
  background-color: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
  outline: none;
}

#pagination button[disabled] {
  opacity: 0.4;
  cursor: default;
  border-color: var(--color-disabled);
  color: var(--color-disabled);
}

/* 区切り線 */
.section-divider {
  height: 2px;
  background-color: var(--color-line);
  margin: var(--spacing-xl) 0;
  border-radius: 1px;
  opacity: 0.4;
}
