/* 新着記事一覧ページ（/column/ 固定ページ・GeneratePress出力） */

/* ---- レイアウト ----
   .content-area と .widget-area は <body> の直下にある（.site-content ラッパーなし）。
   body.blog を flex コンテナにして 6fr/2fr の2カラムを実現する。
   .wrap と同じ幅制約 min(--container, 100% - 64px) を維持する。
---- */

body.blog,
body.search,
body.archive {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start;
  column-gap: 48px;
  background: var(--white);
}

body.blog .header,
body.search .header,
body.archive .header {
  flex: 0 0 100%;
}

body.blog #primary.content-area,
body.search #primary.content-area,
body.archive #primary.content-area {
  flex: 0 0 calc((min(var(--container), 100% - 64px) - 48px) * 0.75);
  width: auto !important;
  min-width: 0;
  margin-top: 50px;
  margin-bottom: 72px;
  padding: 56px 64px;
  border: 2px solid var(--navy-100);
  border-radius: 8px;
  background: var(--white);
}

body.blog .widget-area.is-right-sidebar,
body.search .widget-area.is-right-sidebar,
body.archive .widget-area.is-right-sidebar,
body.blog .sidebar,
body.search .sidebar,
body.archive .sidebar {
  flex: 0 0 calc((min(var(--container), 100% - 64px) - 48px) * 0.25);
  width: auto !important;
  min-width: 0;
  margin-top: 50px;
  margin-bottom: 72px;
}

body.blog .footer,
body.search .footer,
body.archive .footer {
  flex: 0 0 100%;
}

body.blog #main.site-main,
body.search #main.site-main,
body.archive #main.site-main {
  margin: 0;
}

body.search .site-content,
body.archive .site-content {
  display: flex;
  align-items: flex-start;
  column-gap: 48px;
  width: min(var(--container), calc(100% - 64px));
  margin: 0 auto;
  padding: 0;
}

body.search .page-header,
body.archive .page-header {
  display: none;
}

body.search .page-header .page-title,
body.archive .page-header .page-title {
  margin: 0;
  color: var(--navy-500);
  font-size: 32px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: .02em;
  font-feature-settings: "palt" 1;
}

.search-back-link {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin: 0 0 32px;
  color: var(--navy-500);
  font-size: 15px;
  font-weight: 600;
  line-height: 1.6;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.search-back-link:hover,
.search-back-link:focus-visible {
  color: var(--navy-700);
}

body.blog .page-hero,
body.search .page-hero,
body.archive .page-hero {
  flex: 0 0 100%;
  margin: 0 0 48px;
  background: var(--white);
}

body.blog .page-hero .wrap,
body.search .page-hero .wrap,
body.archive .page-hero .wrap {
  width: 100%;
  padding: 0;
}

body.blog .breadcrumb,
body.search .breadcrumb,
body.archive .breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  margin: 0 0 16px;
  color: #8A95A0;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.7;
}

body.blog .breadcrumb a,
body.search .breadcrumb a,
body.archive .breadcrumb a {
  color: #1A549F;
  font-weight: 500;
  text-decoration: underline;
  text-decoration-skip-ink: none;
  text-underline-position: from-font;
}

body.blog .breadcrumb span,
body.search .breadcrumb span,
body.archive .breadcrumb span {
  white-space: pre;
}

body.blog .page-hero h1,
body.search .page-hero h1,
body.archive .page-hero h1 {
  max-width: 952px;
  margin: 0;
  padding-bottom: 16px;
  border-bottom: 2px solid #E7EFF7;
  color: #1A549F;
  font-size: clamp(28px, 3vw, 38px);
  font-weight: 800;
  line-height: 1.5;
  letter-spacing: .05em;
  font-feature-settings: "palt" 1;
  text-align: justify;
}

body.search .page-hero .search-back-link {
  margin: 16px 0 0;
}

body.search .page-hero {
  margin-bottom: 24px;
}

/* ---- 記事カード ---- */

.inside-article {
  padding: 0 !important;
}

.site-main article.hentry {
  margin-bottom: 0 !important;
  padding: 32px 0;
  border-bottom: 1px solid var(--navy-100);
}

.site-main article.hentry:first-child {
  padding-top: 0;
}

body.search .site-main article.hentry:first-of-type {
  padding-top: 0;
}

body.archive #main.site-main > article.hentry:first-of-type {
  padding-top: 0 !important;
}

body.blog #main.site-main > article.hentry:first-of-type {
  padding-top: 0 !important;
}

.site-main article.hentry:last-child {
  border-bottom: 0;
}

/* サムネイルあり：横並び */
article.has-post-thumbnail .inside-article {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  grid-template-areas:
    "img header"
    "img summary"
    "img footer";
  column-gap: 32px;
  align-items: start;
}

article.has-post-thumbnail .post-image {
  grid-area: img;
  border-radius: 12px;
  overflow: hidden;
}

article.has-post-thumbnail .post-image a {
  display: block;
}

article.has-post-thumbnail .post-image img {
  width: 240px;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 12px;
  transition: transform 160ms ease;
}

article.has-post-thumbnail:hover .post-image img,
article.has-post-thumbnail:focus-within .post-image img {
  transform: scale(1.03);
}

article.has-post-thumbnail .entry-header  { grid-area: header; }
article.has-post-thumbnail .entry-summary { grid-area: summary; }
article.has-post-thumbnail footer.entry-meta { grid-area: footer; }

body.blog .site-main .entry-summary,
body.search .site-main .entry-summary,
body.archive .site-main .entry-summary {
  margin-top: 24px !important;
}

/* タイトル */
.site-main .entry-title {
  margin: 0 0 10px;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.55;
}

.site-main .entry-title a {
  color: var(--navy-500);
  text-decoration: none;
  word-break: auto-phrase;
  overflow-wrap: break-word;
  transition: color 160ms ease;
}

.site-main .entry-title a:hover,
.site-main .entry-title a:focus-visible {
  color: var(--navy-700);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 5px;
}

/* 日付 */
.site-main .entry-header .entry-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 10px;
  color: var(--text-light);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
}

.site-main .entry-header .entry-meta .byline {
  display: none;
}

/* 抜粋 */
.site-main .entry-summary p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.75;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.site-main .read-more {
  display: none;
}

/* カテゴリタグ */
.site-main footer.entry-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
}

.site-main .cat-links .screen-reader-text,
.site-main .cat-links .gp-icon,
.site-main .comments-link {
  display: none;
}

.site-main .cat-links a {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 2px 8px;
  border: 1.5px solid var(--navy-500);
  border-radius: 6px;
  color: var(--navy-600);
  font-size: 13px;
  font-weight: 500;
  line-height: 20px;
  white-space: nowrap;
  text-decoration: none;
  transition: background-color 160ms ease, color 160ms ease;
}

.site-main .cat-links a:hover,
.site-main .cat-links a:focus-visible {
  background: var(--navy-500);
  color: var(--white);
}

/* ---- サイドバー（article.css の .side-box と揃える） ---- */

.inside-right-sidebar {
  display: grid;
  gap: 47px;
}

.widget.inner-padding {
  padding: 0 !important;
  border-radius: 8px;
  overflow: hidden;
  background: var(--white);
}

.widget .wp-block-heading {
  margin: 0;
  padding: 24px 0;
  background: var(--navy-500);
  color: var(--white);
  border-radius: 8px 8px 0 0;
  font-size: 22px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: .02em;
  text-align: center;
}

.widget .wp-block-group__inner-container {
  padding: 0;
}

/* 検索 */
.wp-block-search__label {
  display: none;
}

.wp-block-search__inside-wrapper {
  display: flex;
  border: 1.5px solid var(--navy-100);
  border-radius: 8px;
  overflow: hidden;
}

.wp-block-search__input {
  flex: 1;
  min-width: 0;
  padding: 10px 12px;
  border: 0;
  font-size: 15px;
  color: var(--ink);
  background: var(--white);
  outline: none;
}

.wp-block-search__button {
  margin-left: 0;
  padding: 10px 14px;
  background: var(--navy-500);
  color: var(--white);
  border: 0;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background-color 160ms ease;
}

.wp-block-search__button:hover {
  background: var(--navy-700);
}

/* 最近の投稿 */
.wp-block-latest-posts__list,
.wp-block-latest-comments,
.wp-block-categories-list,
.wp-block-archives-list {
  margin: 0;
  padding: 24px 0 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.wp-block-latest-posts__post-title,
.wp-block-latest-comments__comment-link,
.wp-block-latest-comments__comment-author,
.wp-block-archives-list a {
  display: block;
  color: var(--navy-500);
  font-size: 18px !important;
  font-weight: 500;
  line-height: 30px;
  text-decoration: none;
  transition: color 160ms ease;
}

.wp-block-latest-posts__post-title:hover,
.wp-block-latest-posts__post-title:focus-visible,
.wp-block-latest-comments__comment-link:hover,
.wp-block-latest-comments__comment-link:focus-visible,
.wp-block-latest-comments__comment-author:hover,
.wp-block-latest-comments__comment-author:focus-visible,
.wp-block-archives-list a:hover,
.wp-block-archives-list a:focus-visible {
  color: var(--navy-700);
  text-decoration: underline;
  text-underline-offset: 4px;
}

.wp-block-latest-comments__comment {
  margin: 0;
}

.archive-years {
  display: grid;
  gap: 14px;
  padding-top: 24px;
}

.archive-year {
  color: var(--navy-500);
}

.archive-year summary {
  cursor: pointer;
  font-size: 18px;
  font-weight: 600;
  line-height: 30px;
}

.archive-months {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  padding-top: 8px;
}

.archive-months a {
  color: var(--navy-500);
  font-size: 16px !important;
  font-weight: 500;
  line-height: 26px;
  text-decoration: none;
  transition: color 160ms ease;
}

.archive-months a:hover,
.archive-months a:focus-visible {
  color: var(--navy-700);
  text-decoration: underline;
  text-underline-offset: 4px;
}

.wp-block-categories-list {
  flex-direction: row;
  flex-wrap: wrap;
  gap: 8px;
}

.wp-block-categories-list a {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 2px 8px;
  border: 1.5px solid var(--navy-500);
  border-radius: 6px;
  color: var(--navy-600);
  font-size: 13px !important;
  font-weight: 500;
  line-height: 20px;
  white-space: nowrap;
  text-decoration: none;
  transition: background-color 160ms ease, color 160ms ease;
}

.wp-block-categories-list a:hover,
.wp-block-categories-list a:focus-visible {
  background: var(--navy-500);
  color: var(--white);
}

/* ページネーション */
.pagination.navigation {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--navy-100);
}

.pagination .nav-links {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px;
}

.pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 8px;
  border-radius: 6px;
  color: var(--navy-500);
  font-size: 15px;
  font-weight: 600;
  transition: background-color 160ms ease, color 160ms ease;
}

.pagination .page-numbers.current {
  background: var(--navy-500);
  color: var(--white);
}

.pagination a.page-numbers:hover,
.pagination a.page-numbers:focus-visible {
  background: var(--navy-100);
  color: var(--navy-700);
}

/* ---- レスポンシブ ---- */

@media (max-width: 900px) {
  body.blog,
  body.search,
  body.archive {
    column-gap: 0;
  }

  body.search .site-content,
  body.archive .site-content {
    flex-wrap: wrap;
    column-gap: 0;
    width: min(var(--container), calc(100% - 64px));
  }

  body.blog #primary.content-area,
  body.search #primary.content-area,
  body.archive #primary.content-area {
    flex: 0 0 min(var(--container), 100% - 64px);
    margin-bottom: 0;
    padding: 40px;
  }

  body.blog .widget-area.is-right-sidebar,
  body.search .widget-area.is-right-sidebar,
  body.archive .widget-area.is-right-sidebar,
  body.blog .sidebar,
  body.search .sidebar,
  body.archive .sidebar {
    flex: 0 0 min(var(--container), 100% - 64px);
    margin-top: 40px;
    margin-bottom: 48px;
  }

  article.has-post-thumbnail .inside-article {
    grid-template-columns: 180px minmax(0, 1fr);
    column-gap: 20px;
  }

  article.has-post-thumbnail .post-image img {
    width: 180px;
  }
}

@media (max-width: 640px) {
  body.blog #primary.content-area,
  body.blog .widget-area.is-right-sidebar,
  body.blog .sidebar,
  body.search #primary.content-area,
  body.search .widget-area.is-right-sidebar,
  body.search .sidebar,
  body.archive #primary.content-area,
  body.archive .widget-area.is-right-sidebar,
  body.archive .sidebar {
    flex: 0 0 min(var(--container), 100% - 48px);
  }

  body.search .site-content,
  body.archive .site-content {
    width: min(var(--container), calc(100% - 48px));
  }

  body.blog #primary.content-area,
  body.search #primary.content-area,
  body.archive #primary.content-area {
    padding: 24px 20px;
  }

  article.has-post-thumbnail .inside-article {
    grid-template-columns: 1fr;
    grid-template-areas: "img" "header" "summary" "footer";
  }

  article.has-post-thumbnail .post-image img {
    width: 100%;
    height: auto;
  }

  .site-main .entry-title {
    font-size: 17px;
  }

  .site-main .entry-summary p {
    -webkit-line-clamp: 3;
  }
}

@media (prefers-reduced-motion: reduce) {
  article.has-post-thumbnail .post-image img {
    transition-duration: .01ms;
  }

  article.has-post-thumbnail:hover .post-image img {
    transform: none;
  }
}

@media (min-width: 641px) and (max-width: 900px) {
  body.blog #primary.content-area,
  body.search #primary.content-area,
  body.archive #primary.content-area,
  body.blog .widget-area.is-right-sidebar,
  body.search .widget-area.is-right-sidebar,
  body.archive .widget-area.is-right-sidebar,
  body.blog .sidebar,
  body.search .sidebar,
  body.archive .sidebar {
    flex: 0 0 min(100% - 48px, 720px);
  }

  body.blog .widget-area.is-right-sidebar,
  body.search .widget-area.is-right-sidebar,
  body.archive .widget-area.is-right-sidebar,
  body.blog .sidebar,
  body.search .sidebar,
  body.archive .sidebar {
    flex-basis: min(100% - 48px, 560px);
    width: min(100% - 48px, 560px);
    margin-inline: auto;
  }

  body.blog #primary.content-area,
  body.search #primary.content-area,
  body.archive #primary.content-area {
    padding: 36px 32px;
  }

  body.search .site-content,
  body.archive .site-content {
    width: min(100% - 48px, 720px);
  }

  article.has-post-thumbnail .inside-article {
    grid-template-columns: 220px minmax(0, 1fr);
    column-gap: 24px;
  }

  article.has-post-thumbnail .post-image img {
    width: 220px;
  }

  .site-main .entry-title {
    font-size: 19px;
  }
}
