@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);
  }
}

/**************************************************
* ② 本文の左右インデントと上マージン：統一
**************************************************/
.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;
  }
}
