/*
Theme Name:sendai-bc.net_child
Template:sendai-bc.net
Version:1.0
*/

/* ---------------------------------------- */
/* 基本レイアウト・検索ページ全体
/* ---------------------------------------- */
.search .l-main {
    /* 検索結果ページ特有のスタイルがあればここに追加 */
}

/* 検索結果のメインタイトル (「キーワード」の検索結果) */
.search .c-title {
    font-size: 2em;
    margin-bottom: 30px;
    color: #333;
    border-bottom: 2px solid #0073aa;
    padding-bottom: 15px;
}
.search .c-title span { /* (xx件) の部分 */
    font-size: 0.7em;
    font-weight: normal;
    color: #555;
    margin-left: 10px;
}

/* 検索結果が0件だった場合のメッセージ (ページ全体で0件の場合) */
.search .l-main > p:not([class]) {
    padding: 20px;
    background-color: #f9f9f9;
    border: 1px solid #eee;
    margin: 30px 0;
    text-align: center;
}


/* ---------------------------------------- */
/* 各投稿タイプセクショングループ
/* ---------------------------------------- */
.search-results-group {
    margin-top: 0;
    margin-bottom: 40px;
    padding-top: 0;
    padding-bottom: 20px;
    border-bottom: 1px solid #e0e0e0;
}
.search-results-group:last-of-type {
    margin-bottom: 20px;
    border-bottom: none;
}

/* 特定のセクションのマージン調整 (症例ブログと新着情報) */
.search-results-group.search-results-blog,
.search-results-group.search-results-news2 {
    margin-top: 2em;    /* 上に指定のマージン */
    margin-bottom: 20px;  /* 下のマージンを調整 */
    padding-bottom: 10px; /* 下のパディングも調整 */
}


/* セクションタイトル (h2) */
.search-results-group h2 {
    font-size: 1.6em;
    color: #111;
    margin-top: 0;
    margin-bottom: 25px; /* h2とリスト/0件メッセージの間のマージン */
    padding-bottom: 10px;
    border-bottom: 1px solid #ccc; /* h2の下に区切り線 */
}
/* タイトル非表示指定のセクションではh2が出力されないので、その場合のulのマージン調整などが必要なら別途 */


/* セクション内の0件メッセージ (pタグ) */
.search-results-group > p { /* セクション直下のpタグ (0件メッセージ用) */
    margin-top: 0; /* h2があればそのmargin-bottomで制御 */
    margin-bottom: 0;
    padding: 15px;
    background-color: #f8f8f8;
    border-left: 3px solid #0073aa;
    color: #555;
}


/* ---------------------------------------- */
/* 症例ブログリストのスタイル (search-results-blog)
/* ---------------------------------------- */
.search-results-group.search-results-blog ul.p-articles__list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.search-results-group.search-results-blog li.p-article {
    display: flex;
    gap: 20px; /* サムネイルと本文の間隔 */
    margin-bottom: 25px;
    padding-bottom: 25px;
    border-bottom: 1px dotted #ccc;
}
.search-results-group.search-results-blog li.p-article:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

.search-results-group.search-results-blog .p-article__thumbnail {
    flex: 0 0 100px; /* サムネイルの幅を固定 */
}
.search-results-group.search-results-blog .p-article__thumbnail img {
    width: 100px;
    height: 50px;
    object-fit: cover;
    border-radius: 3px;
    display: block; /* 画像下の余白対策 */
}
.search-results-group.search-results-blog .p-article__thumbnail span.textlink a {
    display: block; /* 画像全体をリンク範囲に */
}

.search-results-group.search-results-blog .p-article__body {
    flex: 1; /* 残りの幅を本文エリアが取る */
    display: flex;
    flex-direction: column;
}
.search-results-group.search-results-blog .p-article__meta {
    margin-bottom: 8px;
    font-size: 0.9em;
    color: #777;
}
/* .search-results-group.search-results-blog .p-article-title-wrapper {} */ /* 特にスタイル不要なら空 */
.search-results-group.search-results-blog .p-article-title-wrapper span.textlink a {
    font-size: 1.2em;
    font-weight: bold;
    color: #0073aa;
    text-decoration: none;
    line-height: 1.4;
}
.search-results-group.search-results-blog .p-article-title-wrapper span.textlink a:hover {
    text-decoration: underline;
    color: #005a87;
}


/* ---------------------------------------- */
/* 新着情報リストのスタイル (search-results-news2)
/* ---------------------------------------- */
.search-results-group.search-results-news2 ul.search-results-list-simple {
    list-style: none;
    padding: 0;
    margin: 0;
}
.search-results-group.search-results-news2 li.news-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px dotted #ddd;
}
.search-results-group.search-results-news2 li.news-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.search-results-group.search-results-news2 .news-item__main {
    flex-grow: 1;
    margin-right: 15px;
}
.search-results-group.search-results-news2 .news-item__main span.textlink a {
    font-size: 1.1em;
    color: #0073aa;
    text-decoration: none;
}
.search-results-group.search-results-news2 .news-item__main span.textlink a:hover {
    text-decoration: underline;
    color: #005a87;
}

.search-results-group.search-results-news2 .news-item__meta {
    font-size: 0.9em;
    color: #777;
    white-space: nowrap;
}


/* ---------------------------------------- */
/* その他の投稿タイプリスト (タイトルのみ表示)
/* (search-results-treatment, search-results-page などに適用)
/* ---------------------------------------- */
.search-results-group:not(.search-results-blog):not(.search-results-news2) ul.search-results-list-simple {
    list-style: none;
    padding: 0;
    margin: 0;
}
.search-results-group:not(.search-results-blog):not(.search-results-news2) li.search-result-item-simple {
    padding: 10px 0;
    border-bottom: 1px dotted #ddd;
}
.search-results-group:not(.search-results-blog):not(.search-results-news2) li.search-result-item-simple:last-child {
    border-bottom: none;
    padding-bottom: 0;
}
.search-results-group:not(.search-results-blog):not(.search-results-news2) .search-result-item-simple span.textlink a {
    font-size: 1.1em;
    color: #0073aa;
    text-decoration: none;
    display: block;
    padding: 5px 0;
}
.search-results-group:not(.search-results-blog):not(.search-results-news2) .search-result-item-simple span.textlink a:hover {
    text-decoration: underline;
    color: #005a87;
}


/* ---------------------------------------- */
/* 検索キーワードハイライト
/* ---------------------------------------- */
.search-highlight {
    background-color: #fff3cd;
    font-weight: bold;
    padding: 0.1em 0.2em;
    border-radius: 2px;
}


/* ---------------------------------------- */
/* ページネーション
/* ---------------------------------------- */
.search .u-mgt30 {
    text-align: center;
    margin-top: 40px; /* 最後のセクションとの間隔を広めに */
    margin-bottom: 30px;
    clear: both;
}
.search .wp-pagenavi a,
.search .wp-pagenavi span,
.search .page-numbers {
    display: inline-block;
    padding: 8px 14px;
    margin: 0 4px;
    border: 1px solid #ddd;
    text-decoration: none;
    border-radius: 4px;
    background-color: #fff;
    color: #0073aa;
    transition: background-color 0.2s, color 0.2s;
}
.search .wp-pagenavi span.current,
.search .page-numbers.current {
    background-color: #0073aa;
    color: #fff;
    border-color: #0073aa;
    font-weight: bold;
}
.search .wp-pagenavi a:hover,
.search .page-numbers:not(.dots):not(.current):hover {
    background-color: #f0f8ff;
    border-color: #0073aa;
    color: #005a87;
}
.search .page-numbers.dots {
    border: none;
    background-color: transparent;
    padding-left: 0;
    padding-right: 0;
}


/* ---------------------------------------- */
/* レスポンシブ対応 (例: 768px以下)
/* ---------------------------------------- */
@media (max-width: 768px) {
    .search .c-title {
        font-size: 1.6em;
        padding-bottom: 10px;
    }
    .search .c-title span {
        display: block;
        margin-left: 0;
        margin-top: 5px;
    }

    .search-results-group {
        margin-bottom: 30px;
    }
    .search-results-group.search-results-blog,
    .search-results-group.search-results-news2 {
        margin-top: 1.5em;
        margin-bottom: 15px;
    }

    .search-results-group h2 {
        font-size: 1.4em;
        margin-bottom: 15px;
    }

    /* ブログリストのモバイル調整 */
    .search-results-group.search-results-blog li.p-article {
        /* flex-direction: column; */ /* 必要なら縦積みに */
        /* gap: 15px; */
    }
    .search-results-group.search-results-blog .p-article__thumbnail {
        /* flex: 0 0 80px; */ /* モバイルでサムネイルを小さくする場合 */
        /* margin-right: 15px; */
    }
    .search-results-group.search-results-blog .p-article__thumbnail img {
        /* width: 80px; height: 40px; */
    }
    .search-results-group.search-results-blog .p-article-title-wrapper span.textlink a {
        font-size: 1.1em;
    }

    /* 新着情報リストのモバイル調整 */
    .search-results-group.search-results-news2 li.news-item {
        /* flex-direction: column; */ /* 必要なら縦積みに */
        /* align-items: flex-start; */
        /* gap: 5px; */
    }
    .search-results-group.search-results-news2 .news-item__main span.textlink a {
        font-size: 1em;
    }
    .search-results-group.search-results-news2 .news-item__meta {
        /* margin-top: 5px; */
    }

    /* その他の投稿タイプリストのモバイル調整 */
    .search-results-group:not(.search-results-blog):not(.search-results-news2) .search-result-item-simple span.textlink a {
        font-size: 1em;
    }

    .search .wp-pagenavi a,
    .search .wp-pagenavi span,
    .search .page-numbers {
        padding: 6px 10px;
        margin: 0 2px;
    }
}

/* "center-block"クラスを持つulにのみ適用 */
ul.center-block {
  /* --- この3行が中身を左寄せのまま中央配置する核となる部分です --- */
  width: fit-content;   /* ① 幅をコンテンツ（一番長いli）の幅に合わせる */
  margin-left: auto;    /* ② 左の余白を自動で最大にする */
  margin-right: auto;   /* ③ 右の余白を自動で最大にする */
  /* ------------------------------------------------------------- */

  /* 以下は見た目の調整なので、お好みで変更・削除してください */
  text-align: left;       /* 中のテキストが左寄せであることを保証 */
  /*border: 1px solid #ccc;  分かりやすくするために枠線を追加 */
  padding-left: 10px;     /* マーカーの表示領域を確保 */
  list-style-position: inside; /* マーカーをpaddingの内側に配置する場合 */
}

 /* テキストに蛍光ペンのアンダーライン */
.text-line {
    background: linear-gradient(transparent 60%, #FFF8B8 60%);
}


/* ----------------------- */
 /* 限定解除の説明文 */
/* ----------------------- */
.genteikaijo {
  background-color: #f2f2f2;
  color: #000;
  margin: 10px 0 0 0;
  padding: 10px;
}

.genteikaijo p {
  font-size: 0.6em;
  margin: 0 0 5px 0;
}

.genteikaijo p:last-child {
  margin-bottom: 0;
}

.genteikaijo strong {
  font-weight: bold;
}