@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template: cocoon-master
Version: 1.1.2
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
/* 必要ならここにコードを書く */

/************************************
** レスポンシブデザイン用のメディアクエリ
************************************/
/* 1023px以下 */
@media screen and (max-width: 1023px){
  /* 必要ならここにコードを書く */
}

/* 834px以下 */
@media screen and (max-width: 834px){
  /* 必要ならここにコードを書く */
}

/* 480px以下 */
@media screen and (max-width: 480px){
  /* 必要ならここにコードを書く */
}

/************************************
** ロゴとタイトルの位置や横並び
************************************/
.custom-header-title-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 30%; /* ロゴとタイトルを上下調節 */
  left: 0;
  transform: translateY(-50%);
  margin-left: 40px; /* 左の余白調整 */
}

.custom-header-title-wrap img {
  width: 40px;
  height: auto;
  margin-right: 10px;
}

.custom-header-title-wrap .site-title-text {
  font-size: 32px; /* これのみが効いている */
  font-family: 'HKReiKK', sans-serif;
  font-weight: normal;
}

@media screen and (max-width: 480px) {
  .custom-header-title-wrap {
    margin-left: 80px; /* ← 好きな大きさに調整可 */
  }
}

/************************************
** 隷書体フォントを読み込む
************************************/
@font-face {
  font-family: 'HKReiKK';
  src: url('/wp/wp-content/themes/cocoon-child-master/fonts/hkreikk.woff') format('woff'),
       url('/wp/wp-content/themes/cocoon-child-master/fonts/hkreikk.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

/************************************
** サイトタイトルロゴテキストに適用
************************************/
.site-name,
.site-title-text {
  font-family: 'HKReiKK', sans-serif !important;
}

.site-name {
  font-size: 48px; /* ← これは効いていない */
  line-height: 1.2;
}

.site-title-text {
  font-size: 48px; /* ← これは効いていない */
  line-height: 1.2;
}

/* 本来のタイトル文字を非表示にする */
.site-name-text {
  display: none;
}

/************************************
** ヘッダーコンテナ調整
************************************/
.header-in {
  position:;
}

.header-container {
  position: fixed;
  top: 0px;
  width: 100%;
  z-index: 9999;
}

.admin-bar .header-container {
  top: 32px; /* ログインバー補正 */
}

body {
  padding-top: 40px; /* 固定ヘッダー分 */
}


/************************************
** 全幅設定
************************************/
.wrap,
.content,
.article,
.entry-content,
.container,
#main,
.main,
#content,
.l-entry,
.l-content,
.l-inner,
.l-container {
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  box-sizing: border-box !important;
}

body,html {
  padding: 0 !important;
  margin: 0 !important;
}

/************************************
** グローバルメニューのフォントと背景
************************************/
#navi .navi-in > ul > li > a {
  font-size: 16px !important;
  font-weight: normal !important;
  color: #ffffff !important;
}

#navi {
  background-color: #88abda !important;
}


/************************************
** 固定ページの日付非表示
************************************/
.home .date-tags,
.home .update-date {
  display: none !important;
}

/************************************
** フッター設定
************************************/
.footer-program {
  font-size: 16px !important; /* PCサイズ */
  text-align: center !important;
}

.footer-program span {
  font-size: 14px !important;
}

@media screen and (max-width: 767px) {
  .footer-program {
    font-size: 14px !important;
  }
  .footer-program span {
    font-size: 12px !important;
  }
}

/************************************
/* Smart Slider 3 のメインコンテナの余白をなくす例 */
/************************************
/* 
.n2-ss-slider-1,
.n2-ss-slider-2,
.n2-ss-slider-3 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}
ではだめで個別に書かないといけないが、.
n2-ss-slider-3 だけでよさそう */


.n2-ss-slider-3 {
    margin-top: 0 !important;
    margin-bottom: 2rem !important;
    padding-top: 0 !important;
    padding-bottom: 0rem !important;
}





/************************************
** サイトロゴにサイトのホームへのリンク、Coccon設定、アクセス解析に記載部分あり
した後のリンクの色と下線をもとに戻す
***********************************/
.site-title-text a {
  text-decoration: none;     /* 通常時の下線をなくす */
  color: inherit;            /* 通常時の色を親要素と同じにする */
  transition: color 0.3s ease; /* なめらかに色が変わる */
}

.site-title-text a:hover,
.site-title-text a:focus,
.site-title-text a:active {
  color: #007acc;  /* お好みの色に変更（例：やや明るめの青） */
}


/************************************
SmartSlider の矢印、スマホのみ大きくして透明度もかえる
***********************************/

@media screen and (max-width: 767px) {
  /* 矢印ボタンの背景を大きくし、色と透明度も調整 */
  #n2-ss-3-arrow-previous,
  #n2-ss-3-arrow-next {
    width: 64px !important;
    height: 64px !important;
    background-color: rgba(0, 0, 0, 0.2) !important;  /* 半透明の黒背景 */
    border-radius: 6px !important;                    /* 角丸にしたい場合 */
    display: flex !important;
    justify-content: center;
    align-items: center;
  }

  /* 矢印画像そのものの大きさ調整 */
  #n2-ss-3-arrow-previous img,
  #n2-ss-3-arrow-next img {
    width: 36px !important;
    height: 36px !important;
  }
}


/* ブランドカラー設定 */
:root {
  --brand: #C4D6FF;         /* ボタンの基調色（淡い青） */
  --brand-ink: #0A2A6B;     /* 文字色：濃い紺でコントラスト確保 */
  --brand-edge: #9BB8FF;    /* ふち色：境界を認識しやすく */
}

/* ヒーローCTAのベース（既存の hero-cta を活かします） */
.hero-cta { margin-top: 8px; display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.hero-cta .wp-block-button__link{
  font-weight: 700;
  padding: 12px 20px;
  border-radius: 9999px;
  border: 2px solid transparent;
  line-height: 1.2;
  box-shadow: 0 4px 14px rgba(0,0,0,.18);
  text-decoration: none;
  backdrop-filter: saturate(1.2) blur(2px); /* 写真上で視認性UP（未対応でも無害） */
}

/* 1) メイン（塗り）ボタン：ブランド色＋濃紺テキストで強コントラスト */
.hero-cta .btn-primary .wp-block-button__link{
  /* color-mix が使える環境ではわずかに透けさせて写真となじませる */
  background: color-mix(in srgb, var(--brand) 92%, transparent);
  color: var(--brand-ink) !important;
  border-color: var(--brand-edge);
}
/* color-mix 非対応ブラウザ用フォールバック */
@supports not (color-mix(in srgb, white 50%, black 50%)) {
  .hero-cta .btn-primary .wp-block-button__link { background: rgba(196,214,255,.92); }
}

/* 2) アウトライン：暗めのガラス面＋ブランド色の文字＆枠線 */
.hero-cta .btn-outline .wp-block-button__link{
  background: rgba(0,0,0,.20);      /* 写真が明るくても文字が沈みにくい */
  color: var(--brand) !important;    /* ブランド色の文字 */
  border-color: var(--brand);        /* ブランド色の枠線 */
}

/* ホバー（軽い浮き上がり） */
@media (hover:hover){
  .hero-cta .btn-primary .wp-block-button__link:hover{
    filter: brightness(0.98);
    transform: translateY(-1px);
  }
  .hero-cta .btn-outline .wp-block-button__link:hover{
    /* うっすらブランド色を足す */
    background: color-mix(in srgb, var(--brand) 25%, rgba(0,0,0,.20));
    transform: translateY(-1px);
  }
}

/* 固定ヘッダー対策の既存値を活かしつつ、#map はさらに上で止める */
:root { --header-offset: 72px; }  /* すでにあればこの行は不要 */

#map { 
  /* 既存のオフセット + 追加分（例：+48px） */
  scroll-margin-top: calc(var(--header-offset) + 48px);
}
#contact {
  scroll-margin-top: calc(var(--header-offset) + 72px);
}


/* モバイルはより多めに止めたい場合72px 80px 88px… と 8px刻み */
@media (max-width: 767px){
  #map { scroll-margin-top: calc(var(--header-offset) + 60px); }
}
@media (max-width: 767px){
  #contact {
    scroll-margin-top: calc(var(--header-offset) + 16px);
  }
}





/* 診療カレンダー見出しを“超シンプル＋中央”に */
.h-simple{
  text-align: center !important;
  background: none !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: .6em 0 .4em !important;
  color: inherit !important;
  display: block;
}
/* テーマや装飾スタイルの擬似要素を無効化 */
.h-simple::before,
.h-simple::after{ content: none !important; }



/* シンプル見出し（他節と揃える） */
.h-simple{
  text-align:center!important;background:none!important;border:0!important;box-shadow:none!important;
  padding:0!important;margin:.6em 0 .4em!important;
}
.h-simple::before,.h-simple::after{content:none!important}



/* 診療時間テーブル（以前の見た目に近い最小スタイル） */
.table-hours{margin:10px auto 0;border-collapse:collapse;text-align:center}
.table-hours th,.table-hours td{border:1px solid #ccc;padding:6px 8px;white-space:nowrap}
.table-hours caption{caption-side:top;font-weight:700;margin-bottom:.4em}

/* アンカーの停止位置（必要なら既存の値で調整） */
:root { --header-offset: 72px; } /* すでにあれば不要 */
#contact { scroll-margin-top: calc(var(--header-offset) + 72px); } /* 数値は好みで */



/* 診療案内テーブルの曜日ヘッダー色を以前と同じに */
.table-hours thead th{ background:#f0f0f0; }         /* 平日 */
.table-hours thead th:nth-child(1){ background:#f9d5d5; } /* 日 */
.table-hours thead th:nth-child(7){ background:#d5e5f9; } /* 土 */

/* 境界と余白も以前の数値に合わせる */
.table-hours th,
.table-hours td{ border:1px solid #ccc; padding:5px; }


/* ハンバーガー　babamenu を強制上書き */
#header #header-in #babamenu-fab{
  width: 40px !important;
  height: 40px !important;
  background: #88abda !important;  /* 医院色 */
  border-radius: 9px !important;
}
#header #header-in #babamenu-fab::before{
  font-size: 20px !important;
}

/* ボタン影を完全に無効化（hover時も含めて） */
#babamenu-fab,
#header #header-in #babamenu-fab,
#babamenu-fab:hover,
#babamenu-fab:focus {
  box-shadow: none !important;
}

#babamenu-fab{
  box-shadow: none !important;
  border: 1px solid rgba(0,0,0,.08); /* 任意。いらなければ削除 */
}



/************************************
既存の .page-title-space / .post-title-space と .page-space / .post-space は下位互換として残しつつ、将来は .title-space / .body-space に寄せる。下のCSSは過去のクラスも新設計にマッピングする。
***********************************/
/**************************************************
* 設定：数値はここだけ触れば全体が揃います
**************************************************/
:root{
  /* 固定ヘッダー高さ分のオフセット（タイトルが隠れないように） */
  --header-offset-pc: 6rem;
  --header-offset-sp: 3rem;

  /* タイトル（見出し）の上マージン */
  --title-mt-pc: 7rem;
  --title-mt-sp: 3rem;

  /* 本文冒頭の上マージン */
  --body-mt-pc: 6rem;
  --body-mt-sp: 0rem;

  /* タイトル・本文の左右インデント */
  --side-pad-pc: 1rem;     /* ≒ 16px */
  --side-pad-sp: 0.5rem;   /* ≒ 8px */

  /* .entry-content 直下ブロックへ最低限の左右パディング（front含む） */
  --page-side-pad-pc: 22px;
  --page-side-pad-sp: 12px;
}

/**************************************************
* ① タイトルがヘッダーに隠れる問題：統一
**************************************************/
.title-space,
.page-title-space,
.post-title-space{
  scroll-margin-top: var(--header-offset-pc);
  margin-top: var(--title-mt-pc) !important;
  padding-left: var(--side-pad-pc);
  padding-right: var(--side-pad-pc);
  box-sizing: border-box;
}
@media (max-width: 767px){
  .title-space,
  .page-title-space,
  .post-title-space{
    scroll-margin-top: var(--header-offset-sp);
    margin-top: var(--title-mt-sp) !important;
    padding-left: var(--side-pad-sp);
    padding-right: var(--side-pad-sp);
  }
}


/* タイトルが隠れる問題あとで追加 */
/* 単一投稿のタイトルを .title-space と同等に揃える */
.single .entry-title{
  scroll-margin-top: var(--header-offset-pc);
  margin-top: var(--title-mt-pc) !important;
  padding-left: var(--side-pad-pc);
  padding-right: var(--side-pad-pc);
  box-sizing: border-box;
}
@media (max-width: 767px){
  .single .entry-title{
    scroll-margin-top: var(--header-offset-sp);
    margin-top: var(--title-mt-sp) !important;
    padding-left: var(--side-pad-sp);
    padding-right: var(--side-pad-sp);
  }
}



/**************************************************
* ② 本文の左右インデントと上マージン：統一
**************************************************/
.body-space,
.page-space,
.post-space{
  margin-top: var(--body-mt-pc) !important;
  padding-left: var(--side-pad-pc);
  padding-right: var(--side-pad-pc);
  box-sizing: border-box;
}
@media (max-width: 767px){
  .body-space,
  .page-space,
  .post-space{
    margin-top: var(--body-mt-sp) !important;
    padding-left: var(--side-pad-sp);
    padding-right: var(--side-pad-sp);
  }
}

/**************************************************
* ③ .entry-content 直下セクションに最低限の左右余白（固定/フロント共通）
**************************************************/
body.page .entry-content > .wp-block-group,
body.page .entry-content > .wp-block-columns,
body.page .entry-content > .wp-block-media-text,
body.page .entry-content > .wp-block-cover,
body.page .entry-content > .wp-block-html,
body.page .entry-content > .wp-block-paragraph,
body.page .entry-content > .wp-block-heading{
  padding-left: var(--page-side-pad-pc);
  padding-right: var(--page-side-pad-pc);
  box-sizing: border-box;
}
@media (max-width: 767px){
  body.page .entry-content > .wp-block-group,
  body.page .entry-content > .wp-block-columns,
  body.page .entry-content > .wp-block-media-text,
  body.page .entry-content > .wp-block-cover,
  body.page .entry-content > .wp-block-html,
  body.page .entry-content > .wp-block-paragraph,
  body.page .entry-content > .wp-block-heading{
    padding-left: var(--page-side-pad-sp);
    padding-right: var(--page-side-pad-sp);
  }
}

/**************************************************
* ④ 幅広/全幅の踏み抜き抑制（本文領域に限定）
**************************************************/
.body-space > .alignwide,
.body-space > .alignfull,
body.page .entry-content > .alignwide,
body.page .entry-content > .alignfull{
  margin-left: 0 !important;
  margin-right: 0 !important;
  max-width: 100% !important;
}

/* 画像端の1px段差/にじみ対策（任意） */
.wp-block-media-text__media img,
.wp-block-cover img{
  display: block;
  width: 100%;
  height: auto;
}

/* PC：Media+Text の左右余白を body-space と同じに */
.home .entry-content .wp-block-media-text{
  padding-left: var(--side-pad-pc) !important;
  padding-right: var(--side-pad-pc) !important;
  box-sizing: border-box;
}
/* スマホ */
@media (max-width: 767px){
  .home .entry-content .wp-block-media-text{
    padding-left: var(--side-pad-sp) !important;
    padding-right: var(--side-pad-sp) !important;
  }
}

/* Media+Text の「テキスト側コンテンツ」既定パディングをカット（二重防止） */
.home .entry-content .wp-block-media-text .wp-block-media-text__content{
  padding: 0 !important;
}

/* Media+Text の中に .post-space を入れている場合も二重回避 */
.home .entry-content .wp-block-media-text .post-space{
  padding-left: 0 !important;
  padding-right: 0 !important;
}


/* ============================================
   Media+Text を広く見せる（フロント限定）
   - 左右パディングを本文より少なめ
   - 中の余白を0に
   - カラム間の隙間を適度に
   ============================================ */
:root{
  --media-pad-pc: 22px;   /* ここを触れば広さ調整（PC） 初期値 12px */
  --media-pad-sp: 20px;    /* （SP） */ 初期値 8px
  --media-gap: 16px;      /* 画像と文の間隔 */
}

/* PC */
.home .entry-content .wp-block-media-text{
  /* 本文（22px）より狭い余白にして見かけ幅を広く */
  padding-left: var(--media-pad-pc) !important;
  padding-right: var(--media-pad-pc) !important;

  /* 画像とテキストの間隔 */
  column-gap: var(--media-gap);
  grid-column-gap: var(--media-gap);

  box-sizing: border-box;
}
/* スマホ */
@media (max-width: 767px){
  .home .entry-content .wp-block-media-text{
    padding-left: var(--media-pad-sp) !important;
    padding-right: var(--media-pad-sp) !important;
    column-gap: calc(var(--media-gap) * 0.8);
    grid-column-gap: calc(var(--media-gap) * 0.8);
  }

  /* モバイルで縦積み時の詰まり防止（幅いっぱい使う） */
  .home .entry-content .wp-block-media-text.is-stacked-on-mobile{
    grid-template-columns: 1fr !important;
  }
}

/* ブロック内部の“更に内側の余白”をゼロ化（二重パディング防止） */
.home .entry-content .wp-block-media-text .wp-block-media-text__content{
  padding: 0 !important;
}

/* 念のため画像のはみ出し防止 */
.home .entry-content .wp-block-media-text__media img{
  display:block; max-width:100%; height:auto;
}

/* スマホ時にメディア＋テキストの画像を横幅いっぱいに */
@media (max-width: 767px){
  .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__media img{
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
  }

  /* 画像を含む列自体も幅100%に */
  .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__media,
  .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__content{
    flex: 1 1 100% !important;
    max-width: 100% !important;
  }
}





/* 診療時間テーブル */

/* ===============================
   診療時間テーブル（元デザイン準拠）
   =============================== */

/* ベース */
.table-hours{
  margin: 10px auto 0;
  border-collapse: collapse;
  text-align: center;
  width: 100%;                /* 表を枠内に収める */
  table-layout: fixed;        /* 列幅を均等化 */
}
.table-hours caption{
  caption-side: top;
  font-weight: 700;
  margin-bottom: .4em;
}
.table-hours th,
.table-hours td{
  border: 1px solid #ccc;
  padding: 5px;               /* 元の数値 */
  white-space: nowrap;
  line-height: 1.4;
}

/* ヘッダー行（曜日見出しは薄グレー。左上は別処理） */
.table-hours thead th{
  background: #f0f0f0;
  font-weight: 700;
}

/* 左上セル（“時段不明”→斜め線） */
.table-hours thead th.blank-cell{
  background:
    repeating-linear-gradient(-45deg,#f0f0f0 0 2px,#fff 2px 6px);
}

/* ▼曜日カラー（列単位で反映）
   先頭に blank-cell があるため：
   日曜＝2列目、土曜＝8列目
*/
.table-hours thead th:nth-child(2):not(.blank-cell),
.table-hours tbody td:nth-child(2){
  background: #f9d5d5;  /* 日曜：赤系 */
}
.table-hours thead th:nth-child(8),
.table-hours tbody td:nth-child(8){
  background: #d5e5f9;  /* 土曜：青系 */
}

/* 左端の行見出し（午前／午後）だけ少し薄いグレー */
.table-hours th[scope="row"]{
  background: #f7f7f7;
  font-weight: 600;
  width: 8ch;
}

/* スマホ最適化（横スクロールを出しにくく） */
@media (max-width: 767px){
  .table-hours th,
  .table-hours td{ padding: 4px; font-size: 14px; }
  .table-hours th[scope="row"]{ width: 7ch; }
}

/* アンカー位置（見出し #contact に合わせて停止） */
:root { --header-offset: 72px; }  /* 既存があれば不要 */
#contact { scroll-margin-top: calc(var(--header-offset) + 72px); }

/* 左上セル：無色（白）にする */
.table-hours thead th.blank-cell{
  background: #fff !important;   /* 斜線などを打ち消す */
}

/* 追加分 */
/* 日曜＝列背景を赤（ヘッダ/ボディ両方） */
.table-hours thead th:nth-child(2):not(.blank-cell),
.table-hours tbody td:nth-child(2){
  background: #f9d5d5 !important;
}

/* 金曜＝色付けしない（ヘッダは平日と同じ薄グレー、ボディは透明） */
.table-hours thead th:nth-child(7){
  background: #f0f0f0 !important;   /* 平日と同じ */
}
.table-hours tbody td:nth-child(7){
  background: transparent !important;
}

/* 土曜＝列背景を青（ヘッダ/ボディ両方） */
.table-hours thead th:nth-child(8),
.table-hours tbody td:nth-child(8){
  background: #d5e5f9 !important;
}

/* さらに左上の「ヘッダーラベル」セルは背景色なし（白） */
.table-hours thead th:first-child {
  background: #fff !important;
}



/* ===== アンカー停止位置を一元管理（#contact も含む） ===== */
:root{
  --stop-pc: 72px;   /* PC時ヘッダー相当分 */
  --stop-sp: 112px;  /* SPで「もう少し下」の例。96/112に調整可 */
}

/* まず既存の #contact 指定を無効化（競合つぶし） */
#contact{ scroll-margin-top: 0 !important; }

/* ページ全体でアンカー停止位置を指定 */
html{ scroll-padding-top: var(--stop-pc) !important; }
@media (max-width: 767px){
  html{ scroll-padding-top: var(--stop-sp) !important; }
}



/***** スマホの左右余白：やりすぎを戻す＆狙い撃ちにする *****/

/* 1) スマホで body-space をゼロにしていたルールを打ち消す */
@media (max-width: 767px){
  .home .entry-content .wp-block-group.body-space{
    padding-left: var(--side-pad-sp, 12px) !important;
    padding-right: var(--side-pad-sp, 12px) !important;
  }
}

/* 2) 「メディア＋テキスト」だけを狭くする（以前の要望通り0～4px） */
@media (max-width: 767px){
  .home .entry-content .wp-block-media-text.is-stacked-on-mobile,
  .home .entry-content .wp-block-group .wp-block-media-text.is-stacked-on-mobile{
    padding-left: 4px !important;   /* 0にしたければ 0px に */
    padding-right: 4px !important;
  }
  .home .entry-content .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__content,
  .home .entry-content .wp-block-group .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__content{
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

/* 3) さらに“完全ゼロ”にしたいセクションだけ手動で
   グループに edge-tight を付けたときだけ 0 にするユーティリティ */
@media (max-width: 767px){
  .wp-block-group.body-space.edge-tight{
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}


/* PC時：Media+Textのメディアとテキストの間に余白をつける */
@media (min-width: 768px){
  .home .entry-content .wp-block-media-text{
    column-gap: 24px !important;       /* ブロックの間隔 */
    grid-column-gap: 24px !important;  /* 旧プロパティ互換 */
  }
}


/* スマホ時、mt-text-first のブロックだけ テキスト→メディア の順にする */
@media (max-width: 767px){
  .wp-block-media-text.is-stacked-on-mobile.mt-text-first{
    /* 1列表示にして、表示順を content → media に指定 */
    grid-template-columns: 100% !important;
    grid-template-areas:
      "content"
      "media" !important;
  }
  .wp-block-media-text.is-stacked-on-mobile.mt-text-first .wp-block-media-text__content{
    grid-area: content !important;
  }
  .wp-block-media-text.is-stacked-on-mobile.mt-text-first .wp-block-media-text__media{
    grid-area: media !important;
  }
}





/* Mobile Only: ヘッダー横並びナビを隠し、ハンバーガー＋ドロワーに限定 */
@media (max-width:1024px){
  /* ヘッダーの横並びナビを非表示 */
  #navi,
  header#header + #navi,
  #header-container + #navi,
  header#header nav { display: none !important; }

  /* ハンバーガー（モバイルボタン）は残す */
  header#header .mobile-menu-buttons,
  header#header .mbt-header-mobile-buttons { display: flex !important; }

  /* ---- 電話ボタンの強調（クラス優先＋hrefフォールバック） ---- */

  /* 1) メニューの電話項目に CSSクラス「drawer-phone」を付けた場合（推奨） */
  li.drawer-phone > a{
    display:block !important;
    margin:10px 14px !important;
    padding:12px 14px !important;
    text-align:center !important;
    background:#1f7ae0 !important;
    color:#fff !important;
    border-radius:9999px !important;
    font-weight:700 !important;
  }
	
		


  /* 2) フォールバック：href が tel: のリンクすべて（構造差対応） */
  #navi-drawer a[href^="tel:"],
  .navi-drawer a[href^="tel:"],
  .mobile-menu-drawer a[href^="tel:"],
  .drawer a[href^="tel:"],
  .drawer-nav a[href^="tel:"]{
    display:block !important;
    margin:10px 14px !important;
    padding:12px 14px !important;
    text-align:center !important;
    background:#3b82f6 !important;
    color:#fff !important;
    border-radius:9999px !important;
    font-weight:700 !important;
  }
}


  /* 電話番号の下 */
@media (max-width:1024px){
  li.drawer-phone::after{
    content: "月火木金 9:00–12:30 / 15:30–18:00\A水土  9:00–12:30";
    display: block;
    margin: 6px 18px 10px;
    font-size: 12px;
    opacity: .75;
    text-align: center;
    white-space: pre-line; /* \A を改行として扱う */
  }
}







/* === KB Hamburger：PCはヘッダー内で縦中央、SPは左上固定 ================= */

/* 共通：見た目 */
#kbBurger{
  width:44px; height:44px; padding:8px;
  border:0; border-radius:10px; line-height:1; cursor:pointer;
}
#kbBurger svg rect{ fill:#fff; }

/* ── スマホ/タブレット（左上固定） ── */
@media (max-width:1024px){
  #kbBurger{
    position: fixed;
    left: 12px; right: auto;
    top: max(12px, env(safe-area-inset-top));     /* ノッチ配慮 */
    z-index: 10050;
    background: rgba(0,0,0,.25);
  }
  /* WP管理バー表示時は46px下げる */
  .admin-bar #kbBurger{ top: calc(max(12px, env(safe-area-inset-top)) + 46px) !important; }

  /* テーマ側のモバイルメニューと競合する場合は隠す */
  .mobile-menu-toggle, .menu-button, #navi-mobile { display: none !important; }
}

/* ── PC（ヘッダー内で縦中央に絶対配置） ── */
@media (min-width:1025px){
  /* どれかの親が必ず基準になるように（Cocoon想定） */
  #header #header-in, #header-in, #header-container { position: relative; }

  #kbBurger{
    position: absolute;           /* ← ヘッダー内の子にする前提（JSで移動します） */
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10050;
    background: rgba(255,255,255,.12);
    backdrop-filter: blur(6px) saturate(140%);
  }
}

/* ── ドロワー＆バックドロップ ── */
.kb-drawer{
  position: fixed; inset: 0 auto 0 0;
  width: min(82vw, 360px); max-width: 100%;
  background: #fff; box-shadow: 2px 0 20px rgba(0,0,0,.12);
  transform: translateX(-100%); transition: transform .25s ease;
  z-index: 10020; overflow-y: auto; -webkit-overflow-scrolling: touch;
}
.kb-drawer.is-open{ transform: translateX(0); }

.kb-drawer-close{
  position: sticky; top: 0; margin-left: auto;
  width: 44px; height: 44px; border: 0; background: transparent;
  font-size: 28px; cursor: pointer;
}
.kb-drawer-nav{ padding: 12px 16px 24px; }
.kb-drawer-nav ul{ list-style: none; margin: 0; padding: 0; }
.kb-drawer-nav a{ display: block; padding: 12px 8px; text-decoration: none; }

#kbBackdrop{
  position: fixed; inset: 0; background: rgba(0,0,0,.35); z-index: 10015;
}
#kbBackdrop[hidden]{ display: none; }
/* ====================================================================== */





/* ===== 1) PC：ロゴ/タイトルを縦中央に、右上ボタンも同じ見た目 ===== */
@media (min-width:1025px){
  /* ヘッダー内の縦中央揃え（Cocoon想定）*/
  #header #header-in{ display:flex; align-items:center; }
  /* タイトル／ロゴの行揃えを安定 */
  #header #header-in .site-title, 
  #header #header-in .site-title-text, 
  #header #header-in .site-logo-image, 
  #header #header-in .logo-image{ display:flex; align-items:center; }

  /* 右上の自作ボタン (#kbBurger) を“暗めの丸角”で */
  #header #header-in, #header-in, #header-container{ position:relative; }
  #kbBurger{
    position:absolute; right:16px; top:50%; transform:translateY(-50%);
    width:44px; height:44px; padding:8px; border:0; border-radius:12px;
    background:rgba(0,0,0,.25);
    backdrop-filter:saturate(140%) blur(6px);
    box-shadow:0 2px 10px rgba(0,0,0,.08);
    z-index:10050;
  }
  #kbBurger svg rect{ fill:#fff; }
}

/* ===== 2) スマホ：左の #kbBurger は出さない（右の“本来の”だけ使う） ===== */
@media (max-width:1024px){
  #kbBurger{ display:none !important; }  /* ←左に出ていた自作ボタンを非表示 */

  /* 右の“本来の”ハンバーガーを同じ見た目に（Cocoon想定の複数セレクタ） */
  #header .menu-button,
  #header .mobile-menu-toggle,
  #header .drawer-menu-button,
  #navi .menu-button{
    position:relative;
    width:44px; height:44px; padding:8px;
    border:0; border-radius:12px;
    background:rgba(0,0,0,.25);
    backdrop-filter:saturate(140%) blur(6px);
    box-shadow:0 2px 10px rgba(0,0,0,.08);
    z-index:10050;
  }
  /* アイコンを白に */
  #header .menu-button i,
  #header .menu-button svg,
  #header .mobile-menu-toggle i,
  #header .mobile-menu-toggle svg{ color:#fff; fill:#fff; }
}





/* ❶ PCヘッダーの青帯を薄く・一定高に（56px想定） */
@media (min-width: 1025px){
  #header, #header-in, #header-container { padding-top:0 !important; padding-bottom:0 !important; }
  #navi { height:56px !important; padding:0 !important; }

  /* メニュー項目を縦センター＆上下の余白を詰める */
  #navi ul { display:flex; align-items:center; height:56px !important; }
  #navi ul li a{
    display:flex; align-items:center;
    height:56px !important;           /* ここで帯の厚みを実質固定 */
    padding:0 14px !important;         /* 左右の余白はお好みで */
    line-height:1.2 !important;
  }

  /* ロゴ行も同じ高さに寄せてズレ防止 */
  .site-branding, .logo, .logo-image, .site-title-text{
    display:flex; align-items:center;
    height:56px !important; padding:0 !important; margin:0 !important;
  }
}

/* ❷ SPドロワー：白地で文字が消える対策（白固定されている場合に可視化） */
@media (max-width: 1024px){
  /* ドロワーパネルの背景と文字色を念のため固定 */
  .drawer, #drawer, .drawer-nav, .drawer-menu { background:#fff !important; }
  .drawer a, #drawer a, .drawer-menu a { color:#222 !important; }
}

/* ❸ PCだけでメニュー文字を白に（SPの白地に白文字事故を防止） */
@media (min-width: 1025px){
  #navi a { color:#fff !important; }
}

/* ❹ 以前の“強いリセット”がSPにも効かないようにPC限定へ（必要なら） */
@media (min-width: 1025px){
  #header-container, header#header, #header #header-in, nav#navi,
  #header-container *, header#header *, #header #header-in *, nav#navi *{
    border:0 !important; box-shadow:none !important; background-clip:padding-box !important;
  }
}

/* ========== PCヘッダーの帯を薄く＆一段で揃える（Cocoon想定） ========== */
:root{
  --header-h: 52px;   /* 青帯(メニュー行)の高さ。40〜56で調整 */
  --logo-h:   34px;   /* ロゴ画像の最大高さ。header-h より小さめに */
}

@media (min-width: 1025px){

  /* 1) 余計な上下パディング/最小高さをゼロに */
  #header, #header-in, #header-container{
    padding-top:0 !important; padding-bottom:0 !important;
    min-height: 0 !important;
  }

  /* 2) ロゴ/サイトタイトル周りの行高・余白を圧縮 */
  .site-branding, .logo, .logo-image, .site-title-text{
    display:flex; align-items:center;
    height: var(--header-h) !important;
    margin:0 !important; padding:0 !important; line-height:1.1 !important;
  }
  /* ロゴ画像を小さく固定 */
  .custom-logo, .site-logo-image, .logo img{
    max-height: var(--logo-h) !important; height:auto !important; width:auto !important;
  }
  /* キャッチフレーズが生きていたら高さを食うので消す */
  #header .site-description{ display:none !important; }

  /* 3) グローバルナビの行を固定高＋縦中央に */
  #navi{ height: var(--header-h) !important; padding:0 !important; }
  #navi ul{ display:flex; align-items:center; height:100% !important; margin:0 !important; }
  #navi ul li{ margin:0 !important; }
  #navi ul li > a{
    display:flex; align-items:center; justify-content:center;
    height: var(--header-h) !important;
    padding:0 14px !important;            /* ←左右のゆとりはここで調整 */
    line-height:1.2 !important;
  }

  /* 4) ヘッダー一帯を左右フレックスで一段に（ロゴ左／メニュー右） */
  #header-in{
    display:flex; align-items:center; gap:12px;
  }
  #header-in .site-branding{ margin-right:auto !important; }
  #header-in #navi{ margin-left:auto !important; }
}


/* === PCヘッダー最終パッチ：ロゴが上へ逃げるのを止め、帯を薄く固定 === */
:root{
  --header-h: 52px;   /* 青帯の高さ（40〜56の範囲で好みへ） */
  --logo-h:   34px;   /* ロゴ画像の最大高さ（header-hより少し小さめ） */
}

@media (min-width:1025px){

  /* A) 絶対配置をやめて通常フローへ（ここが一番重要） */
  .custom-header-title-wrap{
    position: static !important;
    top: auto !important;
    left: auto !important;
    transform: none !important;
    margin-left: 0 !important;  /* 必要なら後で調整 */
    display: flex !important;
    align-items: center !important;
    gap: 10px;
  }

  /* B) 親をフレックス化して“縦中央＆一段”に固定 */
  #header-in{
    display: flex !important;
    align-items: center !important;
    gap: 16px;
    height: var(--header-h) !important;
    min-height: var(--header-h) !important;
    padding: 0 !important;
    margin: 0 !important;
  }
  /* 左：ロゴ塊は左寄せ */
  .site-branding{ margin-right: auto !important; display:flex !important; align-items:center !important; }
  /* ロゴの暴れ止め */
  .custom-logo, .site-logo-image, .logo img{
    max-height: var(--logo-h) !important;
    height: auto !important; width: auto !important; display:block !important;
  }
  /* キャッチフレーズが高さを食うのを無効化 */
  #header .site-description{ display:none !important; }

  /* C) 右：グローバルナビも同じ高さに */
  #navi{
    height: var(--header-h) !important;
    padding: 0 !important; margin-left: auto !important;
  }
  #navi .navi-in, #navi .navi-in > ul{
    display: flex !important;
    align-items: center !important;
    height: 100% !important;
    margin: 0 !important;
  }
  #navi .navi-in > ul > li{ margin: 0 !important; }
  #navi .navi-in > ul > li > a{
    display: flex !important;
    align-items: center !important; justify-content: center;
    height: 100% !important;
    padding: 0 14px !important;     /* ←左右のゆとりはここで調整 */
    line-height: 1.2 !important;
  }

  /* D) 余計な上下パディング/最小高さを完全に殺す（競合ケア） */
  #header, #header-container{
    padding-top: 0 !important; padding-bottom: 0 !important;
    min-height: var(--header-h) !important;
  }
}



/* === PC：グローバルナビ(#navi)をど真ん中に固定（Cocoon想定） === */
@media (min-width:1025px){
  /* ナビ全体を1行・縦中央 */
  #navi{
    height: var(--header-h, 52px) !important;
    padding: 0 !important;
  }
  #navi .navi-in{
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important; /* 中央寄せの土台 */
    gap: 0 !important;
  }

  /* メニューULをフレックス化＋中央寄せ（他の兄弟要素があっても真ん中） */
  #navi .navi-in > ul{
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-left: auto !important;
    margin-right: auto !important;      /* ←左右オートで中央固定 */
    padding: 0 !important;
  }

  /* 既存テーマの float を打ち消して中央寄せを確実に */
  #navi .navi-in > ul > li{ float:none !important; }
  #navi .navi-in > ul > li > a{
    display:flex !important; align-items:center !important; justify-content:center;
    height: var(--header-h, 52px) !important;
    padding: 0 14px !important;
    line-height: 1.2 !important;
  }

  /* PCではモバイル用トグル等を非表示（左右の崩れ防止） */
  #navi .menu-button,
  #navi .mobile-menu-toggle,
  #navi .drawer-menu-button{ display:none !important; }
}






/* 旧 全幅100% 指定は SP のみに適用 */
@media (max-width:1024px){
  .wrap, .content, .article, .entry-content, .container,
  #main, #content, .main, .l-entry, .l-content, .l-inner, .l-container{
    max-width:100% !important;
    width:100% !important;
    margin:0 !important; padding:0 !important;
    box-sizing:border-box !important;
  }
}



/* ===== PC：本文だけ幅クランプ（ヘッダー/フッターは100%のまま） ===== */
:root{
  --pc-max: 1120px;   /* 本文の最大幅：960〜1280pxで好みへ */
  --pc-pad: 22px;     /* 本文左右の内側余白 */
  --pc-text: 70ch;    /* 段落の行長（任意。不要なら削除） */
}

@media (min-width:1025px){
  /* 本文“器”を中央固定（Cocoon構造に合わせて#content配下に限定） */
  #content,
  #content #main,
  #content #main .entry,
  #content #main .entry .entry-content{
    max-width: var(--pc-max) !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: var(--pc-pad) !important;
    padding-right: var(--pc-pad) !important;
    box-sizing: border-box !important;
  }

  /* 直下ブロックもまとめてクランプ（“選択的に全幅”にしたい物は除外） */
  #content #main .entry .entry-content > *:not(.edge-full):not(.alignfull){
    max-width: var(--pc-max) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    width: auto !important;
  }

  /* 代表的ブロック（保険） */
  #content #main .entry .entry-content > .wp-block-group,
  #content #main .entry .entry-content > .wp-block-cover,
  #content #main .entry .entry-content > .wp-block-media-text,
  #content #main .entry .entry-content > .wp-block-columns,
  #content #main .entry .entry-content > .wp-block-image,
  #content #main .entry .entry-content > .wp-block-table,
  #content #main .entry .entry-content > .wp-block-calendar,
  #content #main .entry .entry-content > .wp-block-embed,
  #content #main .entry .entry-content > .wp-block-buttons{
    max-width: var(--pc-max) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* 行長の伸び過ぎを自然に抑える（任意） */
  #content #main .entry .entry-content > p{ max-width: var(--pc-text); }
}



/* 変数（本文幅・左右余白）— 既にあれば不要 */
:root{
  --pc-max: 1120px;  /* 本文の最大幅 */
  --pc-pad: 22px;    /* 本文の左右余白 */
}

/* ① ヒーロー（カバー）だけ“横いっぱい”
   ─ ブロックに「追加CSSクラス：edge-full」を付けるだけでOK */
@media (min-width:1025px){
  #content .edge-full{
    position: relative !important;
    left: 50% !important; right: 50% !important;
    margin-left: -50vw !important; margin-right: -50vw !important;
    width: 100vw !important; max-width: 100vw !important;
    padding-left: 0 !important; padding-right: 0 !important;
  }
  /* ただし中のテキストやボタンは読みやすい本文幅に戻す */
  #content .edge-full > .wp-block-cover__inner-container{
    max-width: var(--pc-max) !important;
    margin: 0 auto !important;
    padding-left: var(--pc-pad) !important;
    padding-right: var(--pc-pad) !important;
    box-sizing: border-box !important;
  }
}

/* ② SmartSlider を本文と同じ幅に“箱詰め” */
@media (min-width:1025px){
  /* SmartSliderの外側ラッパーを本文幅で中央寄せ */
  .n2-ss-align,
  .n2-section-smartslider,
  .n2-ss-section-main-content{
    max-width: var(--pc-max) !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: var(--pc-pad) !important;
    padding-right: var(--pc-pad) !important;
    box-sizing: border-box !important;
  }
  /* スライダー本体も親幅に追従（念のため） */
  .n2-ss-slider{ width:100% !important; }
}

/* （オプション）ホームの“最初のカバーだけ”自動で全幅にしたい時 */
@media (min-width:1025px){
  .home .entry-content > .wp-block-cover:first-of-type{
    position: relative !important;
    left: 50% !important; right: 50% !important;
    margin-left: -50vw !important; margin-right: -50vw !important;
    width: 100vw !important; max-width: 100vw !important;
  }
  .home .entry-content > .wp-block-cover:first-of-type > .wp-block-cover__inner-container{
    max-width: var(--pc-max) !important;
    margin: 0 auto !important;
    padding-left: var(--pc-pad) !important;
    padding-right: var(--pc-pad) !important;
  }
}




:root{
  --pc-max: 1120px;   /* 本文最大幅（お好みで 960〜1280） */
  --pc-pad: 22px;     /* 本文左右の内側余白 */
}

/* 1) 「全幅で見せたい」ブロックに .edge-full を付けるだけで横いっぱいに */
@media (min-width:1025px){
  #content .edge-full{
    position: relative !important;
    left: 50% !important; right: 50% !important;
    margin-left: -50vw !important; margin-right: -50vw !important;
    width: 100vw !important; max-width: 100vw !important;
    padding-left: 0 !important; padding-right: 0 !important;
  }

  /* SmartSlider を .edge-full 内で横いっぱいに */
  #content .edge-full .n2-ss-align,
  #content .edge-full .n2-section-smartslider,
  #content .edge-full .n2-ss-section-main-content{
    width: 100vw !important; max-width: 100vw !important;
    margin: 0 auto !important; padding-left: 0 !important; padding-right: 0 !important;
    box-sizing: border-box !important;
  }
  #content .edge-full .n2-ss-slider{ width: 100% !important; }
  
  /* スライダー上のテキストを“本文幅”に収めたい場合（任意） */
  #content .edge-full .n2-ss-slider .n2-ss-layer-parallax,
  #content .edge-full .n2-ss-slider .n2-ss-layer-content{
    max-width: var(--pc-max) !important;
    margin-left: auto !important; margin-right: auto !important;
    padding-left: var(--pc-pad) !important; padding-right: var(--pc-pad) !important;
  }
}

/* 2) それ以外（通常）は本文幅にクランプ（既に導入済みの方針を維持） */
@media (min-width:1025px){
  /* SmartSlider を本文幅で中央寄せ（通常運用） */
  .n2-ss-align,
  .n2-section-smartslider,
  .n2-ss-section-main-content{
    max-width: var(--pc-max) !important;
    width: 100% !important;
    margin-left: auto !important; margin-right: auto !important;
    padding-left: var(--pc-pad) !important; padding-right: var(--pc-pad) !important;
    box-sizing: border-box !important;
  }
}



/* SPで少しだけ“はみ出して”大きく見せる */
@media (max-width: 767px){
  .sp-gain-16, .sp-gain-16 img{ width: calc(100% + 16px) !important; }
  .sp-gain-16{ margin-left:-8px !important; margin-right:-8px !important; }

  .sp-gain-24, .sp-gain-24 img{ width: calc(100% + 24px) !important; }
  .sp-gain-24{ margin-left:-12px !important; margin-right:-12px !important; }

  .sp-gain-32, .sp-gain-32 img{ width: calc(100% + 32px) !important; }
  .sp-gain-32{ margin-left:-16px !important; margin-right:-16px !important; }

  /* 完全に画面いっぱい（フルブリード）にしたいとき */
  .sp-edge{
    position: relative !important;
    left: 50% !important; right: 50% !important;
    margin-left:-50vw !important; margin-right:-50vw !important;
    width:100vw !important; max-width:100vw !important; padding:0 !important;
  }
  .sp-edge img{ width:100vw !important; height:auto !important; display:block !important; }
}


/* ヘッダ＾画像2番目のテキストの大きさPCのみ大きく */
/* PCのみ：2行目 p.hero2 を“やや小さめ＆ノンボールド”に */
/* PCのみ：ヒーロー2行目の p.hero2 を“少し小さめ＆ノンボールド”に強制 */
@media (min-width:1025px){
  body .wp-block-cover__inner-container p.hero2,
  body .wp-block-cover__inner-container p.hero2.has-small-font-size,
  body .wp-block-cover__inner-container p.hero2[class*="wp-elements-"]{
    font-size: 1.12rem !important;   /* ← もう少しなら 1.12〜1.10rem に */
    line-height: 1.6 !important;
    font-weight: 400 !important;     /* normal */
    color: #fff !important;
  }
}


/* 一部のタブレットで表示がおかしい。メディアとテキストのカラム幅潰れ防止（全体適用） */
/* メディアとテキストのカラム潰れ防止（強制版） */
.wp-block-media-text{
  display: grid !important;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr) !important;
  align-items: center;
  width: 100%;
}
.wp-block-media-text__media,
.wp-block-media-text__content{
  min-width: 0 !important;
  width: 100% !important;
}
.wp-block-media-text__content{
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: break-word;
  line-break: strict;
}
/* タブレット帯では縦積みに逃がす保険（必要に応じて） */
@media (max-width:1180px){
  .wp-block-media-text.is-stacked-on-mobile{
    grid-template-columns: 1fr !important;
    display:block !important;
  }
}
/* 一部端末の文字拡大の暴走を抑止（戻った直後に効くことがある） */
html{ -webkit-text-size-adjust:100%; text-size-adjust:100%; }
