/* ==========================================================================
   archive.css — アーカイブ・一覧ページスタイル
   ========================================================================== */

/* ===== ARCHIVE WRAPPER ===== */
.archive{
  /* width/padding handled by inner .articleSec/.inner/.generalmg */
}

.articleSec{
  max-width:1200px;
  margin:0 auto;
  padding:2rem clamp(1.5rem,5vw,4rem);
}

.inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 clamp(1.5rem,5vw,4rem);
}

.generalmg{
  max-width:1200px;
  margin:0 auto;
  padding:2rem clamp(1.5rem,5vw,4rem);
}

/* ===== ARCHIVE GRID ===== */
.archive-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.5rem;
  margin-top:2rem;
}

/* ===== ARTICLE GRID CONTAINER (.article = grid wrapper) ===== */
.article{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.5rem;
  margin-top:1.5rem;
}

/* ===== ARTICLE CARD (article.card = individual card) ===== */
article.card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:16px;
  overflow:hidden;
  transition:all .5s var(--ease-out-expo);
  text-decoration:none;
  color:inherit;
  display:block;
}

/* Thumbnail container */
.article__thumbContainer,
.card-thumb{
  width:100%;
  overflow:hidden;
  background:var(--bg-elevated);
  position:relative;
}
.article__thumbContainer img,
.card-thumb img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .7s var(--ease-out-expo);
}

/* Category badge (inside thumbnail) */
.article__cat{
  position:absolute;top:10px;left:10px;
  display:flex;gap:.4rem;flex-wrap:wrap;
  list-style:none;margin:0;padding:0;
  z-index:2;
}
.article__cat li a{
  display:inline-block;
  font-family:var(--font-heading);
  font-size:.65rem;font-weight:700;
  padding:3px 10px;
  border-radius:100px;
  background:color-mix(in srgb,var(--bg) 80%,transparent);
  backdrop-filter:blur(6px);
  color:var(--text-primary);
  text-decoration:none;
  border:1px solid var(--border);
}

/* Bookmark button (inside thumbnail) */
.article__bookmark,
.bookmark-btn{
  position:absolute;top:10px;right:10px;
  width:34px;height:34px;
  border-radius:50%;
  background:color-mix(in srgb,var(--bg) 70%,transparent);
  backdrop-filter:blur(8px);
  border:1px solid var(--border);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .3s var(--ease-out-expo);
  z-index:2;
  font-size:.75rem;
  color:var(--text-primary);
}
.article__bookmark.is-bookmarked,
.bookmark-btn.is-bookmarked{background:var(--accent);border-color:var(--accent);color:#09090B}

/* Body */
.article__desc,
.card-body{padding:1.25rem 1.5rem 1.5rem}

.article__date{
  font-family:var(--font-heading);
  font-size:.75rem;
  color:var(--text-tertiary);
  display:block;
  margin-bottom:.5rem;
}

.article__ttl{
  font-family:var(--font-heading);
  font-size:1.05rem;font-weight:600;
  letter-spacing:-0.02em;
  line-height:1.5;
  margin-bottom:.75rem;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.article__ttl a{
  color:var(--text-primary);
  text-decoration:none;
}

.article__tags{display:flex;gap:.4rem;flex-wrap:wrap;list-style:none;padding:0}
.article__tags li a{
  font-family:var(--font-heading);
  font-size:.7rem;
  padding:3px 10px;
  border-radius:100px;
  background:var(--accent-soft);
  color:var(--accent);
  border:1px solid var(--accent-medium);
  text-decoration:none;
  display:inline-block;
  transition:border-color .3s,color .3s,background .3s;
}

/* ===== SEARCH FILTER ===== */
.search-filter{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:16px;
  padding:1.5rem 2rem;
  margin-bottom:2rem;
}

.search-filter__group{
  margin-bottom:1.25rem;
}
.search-filter__group:last-of-type{margin-bottom:0}

.search-filter__label{
  font-family:var(--font-heading);
  font-size:.75rem;font-weight:700;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--text-tertiary);
  margin-bottom:.75rem;
  display:block;
}

.search-filter__list{
  display:flex;gap:.5rem;flex-wrap:wrap;
  list-style:none;
}

.search-filter__item{
  font-family:var(--font-heading);
  font-size:.8rem;font-weight:500;
  padding:6px 16px;
  border-radius:100px;
  border:1px solid var(--border);
  background:transparent;
  color:var(--text-secondary);
  cursor:pointer;
  transition:all .3s var(--ease-out-expo);
  user-select:none;
  position:relative;
}
.search-filter__item.is-active{
  background:var(--accent-soft);
  border-color:var(--accent);
  color:var(--accent);
}
/* 検索フィルター: チェックボックスを非表示にしてpill型に */
.search-filter__item input[type="checkbox"]{
  position:absolute;
  opacity:0;
  width:0;height:0;
  pointer-events:none;
}
.search-filter__item:has(input:checked){
  background:var(--accent-soft);
  border-color:var(--accent);
  color:var(--accent);
}
.search-filter__count{
  font-size:.7rem;
  opacity:.6;
  margin-left:2px;
}

.search-filter__actions{
  display:flex;gap:.75rem;align-items:center;
  margin-top:1.25rem;
  padding-top:1.25rem;
  border-top:1px solid var(--border);
}

.search-filter__clear{
  font-family:var(--font-heading);
  font-size:.8rem;
  color:var(--text-tertiary);
  text-decoration:none;
  padding:10px 18px;
  border-radius:100px;
  border:1px solid var(--border);
  display:inline-flex;align-items:center;
  transition:all .3s var(--ease-out-expo);
}

.search-noresult{
  text-align:center;
  padding:4rem 2rem;
  font-family:var(--font-heading);
  font-size:1rem;
  color:var(--text-tertiary);
}
.search-noresult p{margin-bottom:.5rem}

/* ===== PAGINATION (wp-pagenavi) ===== */
.wp-pagenaviContainer{width:100%;  margin:3rem 0;}
#next{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.5rem;
}
.post_range{
  font-family:var(--font-heading);
  font-size:.75rem;
  color:var(--text-tertiary);
}

.wp-pagenavi{
  display:flex;align-items:center;justify-content:center;
  gap:.5rem;
  flex-wrap:wrap;
}

.wp-pagenavi a,
.wp-pagenavi span{
  display:flex;align-items:center;justify-content:center;
  min-width:40px;height:40px;
  padding:0 12px;
  border-radius:10px;
  border:1px solid var(--border);
  background:var(--bg-card);
  font-family:var(--font-heading);
  font-size:.85rem;font-weight:500;
  color:var(--text-secondary);
  text-decoration:none;
  transition:all .3s var(--ease-out-expo);
}


.wp-pagenavi span.current{
  background:var(--accent);
  border-color:var(--accent);
  color:#09090B;
  font-weight:700;
}

.wp-pagenavi .pages{
  font-family:var(--font-heading);
  font-size:.8rem;
  color:var(--text-tertiary);
  border:none;
  background:transparent;
  min-width:auto;
}

.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink{
  font-size:1rem;
}

/* ===== ARCHIVE PAGE HEADER ===== */
.archive-header{
  padding:2rem 0;
  border-bottom:1px solid var(--border);
  margin-bottom:2rem;
}

.archive-header-title{
  font-family:var(--font-heading);
  font-size:clamp(1.5rem,3vw,2rem);
  font-weight:800;
  letter-spacing:-0.035em;
  color:var(--text-primary);
  margin-bottom:.5rem;
}

.archive-header-desc{
  font-family:var(--font-heading);
  font-size:.875rem;
  color:var(--text-tertiary);
}

/* ===== HOVER ===== */
@media(hover:hover){
  article.card:hover,
  .card:hover{
    border-color:var(--accent);
    transform:translateY(-4px);
    box-shadow:
      0 20px 60px -15px rgba(0,0,0,.3),
      0 0 40px var(--accent-glow);
  }
  article.card:hover .article__thumbContainer img,
  article.card:hover .card-thumb img{transform:none}
  .article__bookmark:hover,
  .bookmark-btn:hover{background:var(--accent);border-color:var(--accent);color:#09090B}
  .article__ttl a:hover{color:var(--accent)}
  .article__tags li a:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
  .search-filter__item:hover{
    border-color:var(--border-hover);
    color:var(--text-primary);
  }
  .search-filter__clear:hover{
    color:var(--text-primary);
    border-color:var(--border-hover);
  }
  .wp-pagenavi a:hover{
    border-color:var(--border-hover);
    color:var(--text-primary);
    background:var(--bg-elevated);
  }
}

/* ===== RESPONSIVE ===== */
@media(max-width:767px){
  .archive-grid{grid-template-columns:1fr}
  .article{grid-template-columns:1fr}
  .article__thumbContainer,.card-thumb{}
  .search-filter{padding:1.25rem 1.5rem}
}
