/*
Theme Name: CF-THEME
*/

/* 変数（既存） */
@import url("/wp-content/themes/CF-THEME/assets/css/variable.css");

/* =========================================================
  Base
========================================================= */
html, body {
  overflow-x: hidden;
  font-family: Arial, "Noto Sans JP", sans-serif;
  color: #282828;
  line-height: 1.6;
  scroll-behavior: smooth;
}
html { font-size: var(--pc-font-size); }
@media (max-width:768px) { html { font-size: var(--sp-font-size); } }

a { transition: filter .3s ease; }
a:hover { filter: brightness(1.08); }

#main { margin-bottom: 64px; }
#main h1 { font-weight: 700; margin: 48px 0 16px; }
#main h2 { font-weight: 700; }
#main h3 { font-weight: 700; }

/* =========================================================
  Header
========================================================= */
:root {
  --header-h-desktop: 72px;
  --header-h-mobile: 56px;
}
.header {
  position: fixed; top: 0; left: 0; right: 0;
  height: var(--header-h-desktop);
  background: #fff;
  border-bottom: 1px solid #eee;
  z-index: 1000;
  display: flex; align-items: center;
}
.header-inner {
  max-width: 1120px; margin: 0 auto; padding: 0 16px;
  width: 100%; display: flex; align-items: center; gap: 16px;
}
.site-logo img, .custom-logo { height: 60px; width: auto; display: block; }
.btn-outline {
  display: inline-block; padding: 8px 12px;
  border: 1px solid #222; border-radius: 8px; text-decoration: none;
}
body { padding-top: var(--header-h-desktop); }
@media (max-width:768px) {
  .header { height: var(--header-h-mobile); }
  body { padding-top: var(--header-h-mobile); }
  .site-logo img, .custom-logo { height: 48px; }
}

/* =========================================================
  Hero（トップのキービジュアル）
========================================================= */
.kv-area { margin: 0 0 56px; }
.kv-area .wp-block-cover {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  border-radius: 0;
}
.kv-area .wp-block-cover__inner-container { max-width: 100%; text-align: center; }

/* スマホ時は横長にする */
@media (max-width: 768px) {
  .kv-area .wp-block-cover,
  .kv-area .wp-block-cover.alignfull,
  .kv-area .wp-block-cover.alignwide {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    border-radius: 0 !important;
    min-height: 30vh !important;
    height: auto !important;
    aspect-ratio: auto !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .kv-area .wp-block-cover__image-background {
    width: 100% !important; height: 100% !important;
    object-fit: cover !important;
    object-position: center 35% !important;
  }
  .kv-area .wp-block-cover__background {
    background-size: cover !important;
    background-position: 50% 35% !important;
  }
  .entry-content > .alignfull,
  .wp-block-post-content > .alignfull {
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
  }
}

/* =========================================================
  共通カード（トップなど）
========================================================= */
.card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width:1024px) {
  .card-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width:768px) {
  .card-grid { grid-template-columns: 1fr !important; gap: 20px !important; }
}
.card {
  border: 1px solid #eee;
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, .05);
}
.card__thumb { aspect-ratio: 4/3; background: #eee; overflow: hidden; }
.card__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.card__body { padding: 14px; }
.card__title { font-size: 16px; margin: 0 0 6px; line-height: 1.5; }
.card__date { color: #777; font-size: 13px; margin-bottom: 6px; display: block; }

/* =========================================================
  ブログ一覧＋サイドバー
========================================================= */
.post-container {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 40px;
}
@media (max-width:1024px) {
  .post-container { grid-template-columns: 1fr; }
}

/* 記事一覧2カラム（スマホ1） */
.post-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
@media(max-width:768px) {
  .post-list { grid-template-columns: 1fr; gap: 16px; }
}

/* 記事カード */
.post-card {
  border: 1px solid #eee;
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 2px 6px rgba(0,0,0,.04);
}
.post-card__thumb { aspect-ratio: 16/9; background:#f2f2f2; overflow:hidden; }
.post-card__thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.post-card__body { padding:12px 14px; }
.post-card__title { font-size:18px; margin:0 0 6px; line-height:1.5; }
.post-card__meta { color:#888; font-size:12px; display:flex; gap:8px; align-items:center; margin-bottom:6px; }
.post-card__cat { border:1px solid #ddd; border-radius:999px; padding:2px 8px; color:#666; }
.post-card__excerpt { color:#444; margin:0; }

/* ページネーション */
.pagination { text-align:center; margin-top:24px; }
.pagination .page-numbers {
  display:inline-block; padding:6px 10px; margin:0 4px;
  border:1px solid #ddd; border-radius:6px; text-decoration:none;
}
.pagination .current {
  background:#000; color:#fff; border-color:#000;
}

/* サイドバー */
.post-sidebar .widget { margin:0 0 20px; }
.widget-title { font-weight:700; font-size:16px; margin-bottom:8px; }
.post-sidebar ul { list-style:none; padding:0; margin:0; }
.post-sidebar ul li { margin:6px 0; }
.post-sidebar ul li a { color:#333; text-decoration:none; }
.post-sidebar ul li a:hover { text-decoration:underline; }

/* =========================================================
  Footer
========================================================= */
footer { background: #3D3D3D; color: #fff; }
.footer__inner { width: 88%; max-width: var(--content-width); margin: auto; }
.footer__nav .menu { display: flex; align-items: center; gap: 32px; }
@media (max-width:1023px) {
  .footer__nav .menu { flex-direction: column; align-items: flex-start; gap: 16px; }
}
.footer__copyright p { font-size: 12px; }

/* =========================================================
  Single Post（記事詳細）
========================================================= */
.post-main { max-width: 1120px; margin: 0 auto; padding: 24px 16px 64px; }
.post-body img { max-width: 100%; height: auto; border-radius: 6px; }

/* =========================================================
  スマホ調整まとめ
========================================================= */
@media (max-width:768px) {
  /* 通常ページ（is-global）だけに適用し、LP（is-lp）は除外 */
  .is-global main { padding: 40px 16px !important; }
  .is-global section { margin-bottom: 48px !important; }
}

/* ====== Blog List: Mobile / Tablet polish ====== */
@media (max-width: 1024px){
  /* タブレットでも無理なく2→1へ崩せるように */
  .post-container{ grid-template-columns: 1fr; gap: 28px; }
}

@media (max-width: 768px){
  /* 余白と読みやすさ */
  .post-main{ padding: 32px 16px 56px !important; }
  .section-title{ margin-bottom: 16px; font-size: clamp(18px, 5vw, 22px); }

  /* 記事リストは1カラム＋ほどよい間隔 */
  .post-list{ grid-template-columns: 1fr !important; gap: 16px !important; }

  /* カードの当たり判定（タップしやすく） */
  .post-card{ border-radius: 12px; box-shadow: 0 2px 8px rgba(0,0,0,.06); }
  .post-card__thumb{ aspect-ratio: 16/9; }
  .post-card__body{ padding: 12px; }

  /* タイトルは2行で省略（はみ出し防止） */
  .post-card__title{
    font-size: 16px;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 6px;
  }

  /* メタ情報は少し小さく */
  .post-card__meta{ font-size: 12px; gap: 6px; }

  /* 抜粋は2行で切る（読みやすさ優先） */
  .post-card__excerpt{
    color:#444;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden;
  }

  /* サイドバーは下に回るので見出しだけ少し詰める */
  .post-sidebar .widget{ margin: 0 0 16px; }
  .widget-title{ font-size: 15px; margin-bottom: 6px; }
  .post-sidebar ul li{ margin: 4px 0; }

  /* ページネーション：指で押しやすく */
  .pagination{ margin-top: 20px; }
  .pagination .page-numbers{
    padding: 10px 12px; margin: 0 3px;
    border-radius: 999px; min-width: 36px; display:inline-flex; align-items:center; justify-content:center;
  }
}

/* ====== 画像のブレ防止（どの幅でも） ====== */
.post-card__thumb img{ width:100%; height:100%; object-fit:cover; }

/* ====== 2カラムの最適な幅（デスクトップ用微調整：任意） ====== */
@media (min-width: 1121px){
  .post-container{ grid-template-columns: minmax(0, 1fr) 320px; }
}

/* ===== 強制パッチ：スマホで必ず「記事→サイドバー」の順に表示 ===== */
@media (max-width: 1024px){
  .post-container{
    display: flex !important;
    flex-direction: column !important;
    gap: 28px !important;
    width: 100% !important;
  }
  .article-area{ order: 1 !important; display: block !important; visibility: visible !important; }
  .post-sidebar{ order: 2 !important; }
}

/* 記事カードのグリッドを必ず有効化（他CSSに負けないように） */
@media (max-width: 768px){
  .post-list{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  .post-card__link{ display:block !important; text-decoration:none !important; color:inherit !important; }
  .post-card__thumb{ aspect-ratio:16/9 !important; overflow:hidden !important; }
  .post-card__thumb img{ width:100% !important; height:100% !important; object-fit:cover !important; display:block !important; }

  /* タイトル/抜粋は2行でトリム（高さ揃え） */
  .post-card__title{
    font-size:16px !important;
    display:-webkit-box !important; -webkit-box-orient:vertical !important; -webkit-line-clamp:2 !important;
    overflow:hidden !important; margin-bottom:6px !important;
  }
  .post-card__excerpt{
    color:#444 !important;
    display:-webkit-box !important; -webkit-box-orient:vertical !important; -webkit-line-clamp:2 !important;
    overflow:hidden !important;
  }
}

/* 画像のブレ防止（どの幅でも） */
.post-card__thumb img{ width:100%; height:100%; object-fit:cover; }

/* =========================================================
  LP専用パッチ：フッターが途中に来る問題を確実に防止
  - 該当LPの body クラス（page-id-XXXX）に置き換えてください
  - LP全体でfloatが残っていても ::after でクリア
========================================================= */

/* フッターを通常フローの最後へ戻す */
.page-id-XXXX footer,
.page-id-XXXX .site-footer,
.page-id-XXXX #colophon{
  position: static !important;
  float: none !important;
  clear: both !important;
}

/* コンテンツ末尾で回り込みを必ず解除 */
.page-id-XXXX .entry-content::after,
.page-id-XXXX #main::after{
  content: "";
  display: block;
  clear: both;
}

/* 予防的に、LPの大枠で高さが潰れないように */
.page-id-XXXX .entry-content,
.page-id-XXXX #main{
  overflow: visible;     /* 念のため */
}

/* LPをクラスで判別している場合は .is-lp でも同様に効かせられます（任意） */
.is-lp footer,
.is-lp .site-footer,
.is-lp #colophon{ position: static !important; float: none !important; clear: both !important; }
.is-lp .entry-content::after,
.is-lp #main::after{ content:""; display:block; clear:both; }
