/* ==========================================
   ◼︎ カラーパレット（青系ベース）
   ==========================================
*/

:root{
  /* ベース・メイン */
  --c-primary: #C8A88B;         /* メインベージュ（やわらかいトーン） */
  --c-primary-light: #E9D8C5;   /* 明るめベージュ（背景やホバー用） */

  /* アクセント・サブカラー */
  --c-accent: #D9A3A3;          /* 淡いピンク（女性らしさ） */
  --c-cta: #C97C7C;             /* 濃いめピンク（ボタンや強調箇所） */
  --c-ctabg: #F7E5E5;           /* ピンク背景の淡トーン */

  /* 背景系 */
  --c-bg: #FAF8F5;              /* ページ全体の背景 */
  --c-surface: #F1EBE4;         /* コンテンツブロック背景（柔らかいベージュ） */

  /* 境界線・装飾 */
  --c-border: #E5DDD4;
  --c-wood: #BFA890;            /* 木目感のあるブラウン（アイコンや区切り線に） */

  /* 文字色 */
  --c-text: #5B4634;            /* 本文用ブラウン */
  --c-text-muted: #7D6B5B;      /* 補足や説明テキスト */

  /* CTA・FAQ用 */
  --c-cta-pill: #D894A1;        /* ピル型ボタンのグラデーション用 */
  --faq-pill: #F9EFEC;          /* カード背景用ピンク */
  --faq-shadow: 0 8px 22px rgba(217, 163, 163, .12);
  --faq-shadow-hover: 0 14px 28px rgba(217, 163, 163, .18);
  --faq-icon: #E2A5A5;          /* 小アイコン（ハート・花モチーフなど） */
--c-cta-hover: #B35E6D;  /* hover時に少し暗くする */
--c-cta-text: #fff;      /* テキストは白固定 */
}

/*------------------- 見出し -------------------*/

h2 {
  font-size: 2.5rem;
  margin-bottom: 30px;
}
h2 span {
  font-size: 3rem;
}
h2 span.color {
  background: linear-gradient(
    90deg,
    var(--c-primary) 0%,
    var(--c-primary-light) 35%,
    var(--c-cta) 70%,
    var(--c-primary-light) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text; /* Safari以外 */
  font-weight: 700;
}

h2 em {
  position: relative;
   z-index: 1;
}
h2 em::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0.2em;
  width: 100%;
  height: 0.5em;
  background: #E3DED9;
  z-index: -1;
  border-radius: 2px;
}
.medical h2,
.concerns h2,
.feature-section h2,
.faq-accordion h2 {
  text-align: center;
}
.lead {
  width: 80%;
  margin: 75px auto;
  text-align: center;
}
@media (max-width: 768px) {
  h2 {
      font-size: 1.5rem;
  }
  h2 span {
    font-size: 1.8rem;
}
}


/*------------------- ヘッダー -------------------*/
header{
  position:absolute; 
  z-index:10; left:0; top:0; width:100%;
  box-sizing:border-box; 
	 position: sticky;
    top: 0;
    z-index: 10;
}

/* 横並び骨組み */
header .h_inbox{display:flex;justify-content:space-between;align-items: flex-end;gap:12px;background: #ffffffad;}

/* 左：ロゴ＋H1 */
header .h_left{width:45%;}
header .h_logo{
  display:flex;
  align-items: flex-start;
  flex-direction: column;
}
header .h_left .h_logo img{width:auto;max-width:30%;height:auto}
header h1{
  color: var(--c-text);
  font-size: clamp(12px, 1.1vw, 14px);
  letter-spacing:.14em; line-height:1.4;
  border-radius:4px;
	padding-left: 10px;
}

/* 右：縦積みコンテナ */
.h_right{display:flex;align-items:flex-start;}
.h_stack{display:flex;flex-direction:column;gap:10px}

/* ベージュの情報バッジ */
.info-badge .badge-inner{
  position:relative;
  display:flex; align-items:center; gap:10px;
  background:#e4cdb7; /* ベージュ */
  color:#5b4634; padding:10px 14px; border-radius:8px;
  box-shadow:0 2px 6px rgba(0,0,0,.06);
}
.info-badge .badge-ttl{font-weight:700; font-size:clamp(13px,1.1vw,14px)}
.info-badge .badge-sub{font-size:clamp(12px,.95vw,13px)}
.info-badge .badge-sub .sun{color:#c64a5d; font-weight:700}
.info-badge .badge-time{font-size:clamp(11px,.9vw,12px); opacity:.85}
.info-badge .badge-leaf{margin-left:auto; color:#9b7c63}

/* CTA 共通 */
.h_contact{display:flex; align-items:stretch;}
.cta{
  display:flex; 
  flex-direction:column; 
  justify-content:center;
  min-width: 240px; 
  text-decoration:none; 
  color:#fff;
  padding:8px 12px; 
  box-shadow:0 2px 8px rgba(0,0,0,.08);
  text-align: center;
}
.cta .cta-lbl{font-size:clamp(12px,1vw,13px); opacity:.95}
.cta .cta-main{
  display:flex; 
  align-items:center; gap:8px;
  margin-top:2px; 
  line-height:1;
  justify-content: center;
}
.cta .ico{display:inline-flex}
.cta .num{font-weight:800; letter-spacing:.04em; font-size:clamp(16px,1.5vw,20px)}
.cta .cta-note{font-size:clamp(10px,.8vw,12px); opacity:.9; margin-top:3px}

/* TEL */
.cta-tel{
  background:var(--c-primary);
}
.cta-tel:hover{
  background: #ebd6c2;
  color: #fff;
  filter:brightness(0.98);
}

/* WEB */
.cta-web{
  background:var(--c-cta);
}
.cta-web .num{
  font-weight:700;
}
.cta-web:hover{
  background: #db5e71;
  filter:brightness(0.98);
  color: #fff;
}

/* LINE */
.cta-line{
  background:#64b172;
  min-width: 170px;
}
.cta-line .num{
  font-weight:700;
}
.cta-line:hover{
  background: #7dc58a;
  filter:brightness(0.98);
  color: #fff;
}

/* 右端：メニューボタン */
.menu-btn{
  display:flex; 
  flex-direction:column; 
  align-items:center; 
  justify-content:center;
  gap:6px; 
  padding: 19px 12px; 
  min-width:88px;
  background: #b5ab9f;
  color:#fff; 
  border:none;
  box-shadow:0 2px 8px rgba(0,0,0,.08); 
  cursor:pointer;
}
.menu-btn .menu-text{font-size:12px; letter-spacing:.08em}
.menu-btn .bars{display:flex; flex-direction:column; gap:5px; width:30px}
.menu-btn .bars span{display:block; height:2px; background:#fff; border-radius:2px}

/* Tablet */
@media (max-width: 992px){
  header .h_left{width:52%}
  .cta{min-width:220px}
}

/* Mobile */
@media (max-width: 768px){
  header .h_inbox{flex-wrap:wrap; gap:10px}
  header .h_left{width:100%}
  header .h_logo{gap:10px}
  header .h_left .h_logo img{max-width:180px}
  header h1{font-size:12px; letter-spacing:normal;padding-left: 10px;}

  .h_right{width:100%; align-items:stretch}
  .h_stack{flex:1}
  .info-badge{order:1}
  .h_contact{order:2; gap:2px}
  .cta{flex:1; min-width:auto;padding: 5px;}
  .menu-btn{order:3; margin-left:auto; min-width:76px}
  .cta .cta-main {flex-direction: column;}
  .cta-line{height: 65px;}
}

/* ------------- メニュー本体 ------------- */
.nav{
  width:100%;
  background:#fff;
  display:flex; justify-content:center; align-items:center;
  position:relative; transition:.3s ease; z-index:5;
  box-shadow:0 2px 12px rgba(0,0,0,.06);
  font-size: 0.98rem;
}

/* スクロール固定用クラス（既存そのまま） */
.nav.fixed{
  position: fixed;
  top:0; 
  left:0; 
  width:100%;
  background:#fff; 
  z-index:15;
}

/* リスト：均等配置＋区切り線 */
.nav-list{
  display:flex; justify-content:space-between; gap:0;
  width:100%; list-style:none; margin:0; padding:0;
  border-left:1px solid var(--c-border);
}
.nav-item{
  position:relative;
  flex: 1;
  text-align: center;
  border-right: 1px solid var(--c-border);
}

/* リンク：縦並びで中央寄せ（上：日本語／下：英字） */
.nav-item > a{
	display:flex; 
	flex-direction:column; 
	align-items:center; 
	justify-content:center;
	font-size: 0.9rem;
	line-height: 1.5;
	text-decoration:none; color:var(--c-text-muted);
	font-weight:700; letter-spacing:.08em;
	padding:18px 10px 16px;
	position:relative;
  /* 下線アニメ（背景サイズで） */
  background: linear-gradient(var(--c-primary) 0 0) bottom / 0 2px no-repeat;
  transition: background-size .25s ease, color .25s ease, opacity .25s ease;
}

/* 下段の英字は data-en から生成 */
.nav-item > a::after{
  content: attr(data-en);
  display:block; margin-top:8px;
  font-weight:600; letter-spacing:.18em;
  font-size:14px;
  color: var(--c-primary);
  text-transform: lowercase;
}

/* ホバー：文字色＋下線を伸ばす */
.nav-item > a:hover{
  color:#7a5a2f; /* ほんのりブラウン寄り（好みで調整） */
  background-size: 100% 2px;
}

/* アクティブ状態（任意：クラス .is-current を付与） */
.nav-item.is-current > a{
  color:#7a5a2f;
  background-size:100% 2px;
}
@media (max-width: 1050px) {
  .nav {
    display: none;
  }
}

/* ------------- ドロップダウン ------------- */
.has-dropdown .dropdown{
  position:absolute; top:100%; left:50%;
  transform:translate(-50%, 12px);
  background:#fff; list-style:none; margin:0; padding:10px 0;
  min-width:220px; border-radius:10px;
  box-shadow:0 8px 20px rgba(0,0,0,.12);
  opacity:0; visibility:hidden; transition:.25s ease;
  border:1px solid var(--c-border);
}
.has-dropdown:hover .dropdown{
  opacity:1; visibility:visible; transform:translate(-50%, 8px);
  z-index:20;
}
.dropdown li{padding:0}
.dropdown li a{
  display:block; padding:10px 16px;
  color:var(--c-text-muted); font-weight:600; font-size:14px;
  text-decoration:none; transition:.2s ease;
}
.dropdown li a:hover{
  background:var(--c-bg);
  color:var(--c-text);
  padding-left:22px;
}

/* ------------- レスポンシブ ------------- */
@media (max-width: 1024px){
  .nav-item > a{padding:16px 8px}
  .nav-item > a::after{font-size:13px; letter-spacing:.16em}
}
@media (max-width: 840px){
  .nav-list{flex-wrap:wrap}
  .nav-item{flex:1 1 33.33%}
}
@media (max-width: 600px){
  .nav-item{flex:1 1 50%}
  .nav-item > a{padding:14px 6px}
}

/* ----------------------------------------------------
タブレット用（768px〜1024px）
---------------------------------------------------- */
@media screen and (min-width: 768px) and (max-width: 1024px) {
}

/* ----------------------------------------------------
スマホ用（〜767px）
---------------------------------------------------- */
@media (max-width: 768px) {

}

/*------------------- ハンバーガーメニュー -------------------*/
/* ハンバーガーアイコン */
.drawer-hamburger {
  position: relative;
  /* top: 20px;
  right: 20px; */
  background: #c5a9a2;
  width: 85px;
  height: 75px;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  z-index: 10001;
  cursor: pointer;
}
.drawer-hamburger-icon {
  width: 24px;
  height: 2px;
  background: #fff;
  position: relative;
  transition: all 0.3s ease;
  top: 8px;
}
span.menu_txt {
  top: 12px;
  position: relative;
}
.drawer-hamburger-icon::before,
.drawer-hamburger-icon::after {
  content: '';
  position: absolute;
  width: 100%;
  height: 2px;
  background: #fff;
  transition: all 0.3s ease;
}
.drawer-hamburger-icon::before {
  top: -8px;
}
.drawer-hamburger-icon::after {
  top: 8px;
}
.menu_txt::before {
  content: 'MENU';
  font-size: 10px;
  margin-top: 6px;
}
#drawer-checkbox:checked + #drawer-icon .drawer-hamburger-icon {
  background: transparent;
}
#drawer-checkbox:checked + #drawer-icon .drawer-hamburger-icon::before {
  transform: rotate(45deg);
  top: 0;
}
#drawer-checkbox:checked + #drawer-icon .drawer-hamburger-icon::after {
  transform: rotate(-45deg);
  top: 0;
}
#drawer-checkbox:checked + #drawer-icon .menu_txt::before {
  content: 'CLOSE';
}

/* メニュー全体 */
#drawer-checkbox {
  position: absolute;
  opacity: 0;
  pointer-events: none;
	position: fixed; 
	top: -100px; 
	left: -9999px;
}
#drawer-content {
  opacity: 0;
  transform: translateY(-20px);
  pointer-events: none;
  transition: opacity 0.4s ease, transform 0.4s ease;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: #fffdf7;
  z-index: 10000;
  overflow-y: auto;
  padding: 2rem 1rem;
}
#drawer-checkbox:checked ~ #drawer-content {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
/* ドロワー表示中は背景スクロール禁止 */
body.is-drawer-open {
  overflow: hidden;
}
/* ベース装飾 */
.drw_index {
  font-weight: bold;
  font-size: 1.2em;
  margin: 1.5em 0 0.5em;
  color: var(--c-cta);
}

.com_sp_menu li,
.com_medical li {
	margin-bottom: 0.6em;
	font-size: 1rem;
}
li.littl {
	font-size:1rem;
	font-weight:600;
}
.com_sp_menu li:not(.littl),
.com_medical li:not(.littl) {
  position: relative;
  padding-left: 1.4em; /* マーク分の余白 */
  list-style: none;
}

.com_sp_menu li:not(.littl)::before,
.com_medical li:not(.littl)::before {
  content: "";
  position: absolute;
  top: 0.55em;
  left: 0;
  width: 0.5em;
  height: 0.5em;
  background-color: var(--c-cta);
  border-radius: 50%;
}

.tel {
  font-size: 1em;
  margin-top: 1.5em;
}

.drw_info .schedule-table{
  margin: 10px 0;
}
.telp {
  font-size: 1.5rem;
}
.telp i {
  margin: 0 5px 0 0;
}
.web-reserve a {
  display: inline-block;
  font-size: 1.2rem;
  margin-top: 0.5em;
  background: var(--base-blue);
  color: #fff;
  padding: 0.6em 1.2em;
  border-radius: 30px;
  text-decoration: none;
}
/* ========== PCのサイトマップ段組み ========== */
@media (min-width: 1024px) {
  .com_sp_menu {
    column-count: 2;         /* まず2段に */
    column-gap: 2rem;
  }
  /* さらに横幅がある場合は3段に */
  @media (min-width: 1280px) {
    .com_sp_menu { column-count: 3; }
  }

  /* セクション見出し（.littl）は段をまたがない／余白を付与 */
  .com_sp_menu .littl {
    break-inside: avoid;
    -webkit-column-break-inside: avoid;
    column-break-inside: avoid;
    margin-top: 1rem;
    margin-bottom: .4rem;
    font-size: 1rem;
    color: #333;
  }

  /* 通常リンク（.littl以外）は段組み対象 */
  .com_sp_menu li:not(.littl) {
    break-inside: avoid;
    padding-left: 1.2em;
    margin-bottom: .5em;
  }
  .com_sp_menu li:not(.littl)::before {
    top: .55em;
    width: .45em; height: .45em;
    opacity: .9;
  }
}
@media (max-width: 768px) {
  .drawer-hamburger {
    height: 65px;
  }
}
/*------------------- ファーストビューブロック -------------------*/
.main-visual {
    position: relative;
    width: 100%;
    height: 94vh;
    overflow: hidden;
    padding: 0 5.8em 0px;
    top: -54px;
}

.background-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0;
  z-index: 1;
  transition: opacity 2s ease-in-out;
}

.background-image.active {
  opacity: 1;
  z-index: 2;
}

.image1 {
  background-image: url('../images/main.png');
  background-position: center left 60%;
}

.image2 {
  background-image: url('../images/main2.png');
}

.overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #dddddd29;
  z-index: 3;
}

/* キャッチコピー */
.text-content {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  z-index: 4;
  top: 33%;
}

.size3rem {
  font-size: 2.6rem;
  line-height: 1.5;
  margin-bottom: 25px;
}

.bgwrap {
  position: relative;
  display: inline-block;
}

.size1-5rem {
  font-size: 1rem;
  color: #5c4a1f;
  font-weight: 500;
  letter-spacing: 0.06em;
}
.bgwrap .catchhighlight {
  background: linear-gradient(90deg, #91B1CA, #7E92A4);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 700;
  text-shadow: 0 0 8px rgba(58, 141, 222, 0.4); /* 青系に合わせて調整 */
  font-size: 3.5rem;
}

.white {
  color: white;
}
.tel {
  font-size: 30px;
  color: #7A5A2F;
}

.clinic-features {
  display: flex;
  justify-content: center;
  gap: 2rem;
  margin: 3rem 0;
  flex-wrap: wrap;
  text-align: center;
}

.circle-icon p{
  width: 180px;
  height: 180px;
  margin: 0 auto;
  background: #ffffffb3; 
  color: var(--base-blue);
  border-radius: 50%;
  font-size: 1.2rem;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1.4;
  padding: 1rem;
  word-break: break-word;
  box-shadow: 0 0 15px rgba(58, 141, 222, 0.2), 
              0 0 30px rgba(58, 141, 222, 0.15), 
              0 0 45px rgba(58, 141, 222, 0.1);

  border: 1px solid rgba(58, 141, 222, 0.2);
}
@media (max-width: 768px) {
  .main-visual {
    padding: 3.2em 0.8em 0px;
	  top:-105px;
  }
  .size3rem {
    font-size: 1.2rem;
  }
  .bgwrap .catchhighlight {
    font-size: 2rem;
  }
  .image1 {
    background-image: url(../images/top/spmain.png);
    background-position: bottom center;
    background-size: contain;
    background-repeat: no-repeat;
}
}
/*-------------------------------------- 共通 --------------------------------------*/
.top_h2 {
  text-align: center;
  font-family: "Kiwi Maru", serif;
}
/*-------------------------------------- バナー --------------------------------------*/
.banner_box {
  width: 60%;
  margin: 10px auto;
}
.banner_box img {
  margin: 30px auto;
}
@media (max-width: 768px) {
  .banner_box {
  width: 100%;
  padding: 0 10px;
}
}

/*-------------------------------------- お知らせ --------------------------------------*/
/* セクション */
.info-section{
  padding: 75px 0;
  background: #fff;
  width: 90%;
  margin: 0 auto;
}

/* 2カラム */
.info-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 4vw, 48px);
}
/* @media (max-width: 900px){
  .info-grid{ grid-template-columns: 1fr; }
} */
.info-col {
    margin: 20px 0;
}
/* 見出し */
.info-header{
  text-align: center;
  margin-bottom: 18px;
  position: relative;
}
.info-header h2{
  color: var(--c-text);
  letter-spacing: .06em;
  font-size: clamp(20px, 2.6vw, 28px);
  margin: 0 0 4px;
}
.info-header .info-sub{
  color: var(--c-cta);
  font-size: 90%;
  font-weight: 700;
  letter-spacing: .2em;
  margin: 0 0 16px;
  opacity:.8;
}
/* .info-header::after{
  content:"";
  display:block;
  width: 64px;
  height: 4px;
  margin: 8px auto 0;
  background: linear-gradient(90deg, var(--c-primary-light), var(--c-primary));
  border-radius: 999px;
  opacity:.55;
} */

/* CTA（枠＋影） */
.info-cta{
  display:inline-block;
  margin-top: 14px;
  padding: 12px 20px;
  border: 1px dashed var(--c-border);
  background: #fff;
  color: var(--c-text-muted);
  text-decoration: none;
  border-radius: 12px;
  font-weight: 600;
  letter-spacing:.02em;
  transition: transform .12s ease, box-shadow .2s ease, border-color .2s ease, color .2s ease;
  box-shadow: 0 2px 10px rgba(0,0,0,.03);
}
.info-cta:hover,
.info-cta:focus{
  border-color: var(--c-primary);
  color: var(--c-cta);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  outline: none;
}

/* リスト */
.info-list{
  list-style: none;
  margin: 0;
  padding: 6px 0 0;
  border-top: 1px solid var(--c-border);
}
.info-item{
  display: grid;
  grid-template-columns: auto 100px 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 16px 6px;
  border-bottom: 1px solid var(--c-border);
  position: relative;
}
@media (max-width: 680px){
  .info-item{ grid-template-columns: 1fr; gap: 8px; }
  .info-section {padding: 20px 0;}
}

/* バッジ（パレットの色に寄せる） */
.badge{
  display:inline-block;
  background: var(--faq-pill);
  color: var(--c-text-muted);
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .02em;
  white-space: nowrap;
  box-shadow: var(--faq-shadow);
}
.badge-strong{ background: var(--c-surface); }
.badge-pink{ background: var(--c-ctabg); }

/* 日付 */
.date{
  color: var(--c-text-muted);
  font-size: 14px;
  letter-spacing: .02em;
  text-align: left;
  opacity:.95;
}

/* タイトル */
.info-item .title{
  color: var(--c-text);
  font-weight: 600;
  text-decoration: none;
  line-height: 1.6;
  display: inline-block;
  padding-right: 24px;
  position: relative;
  transition: color .15s ease;
  font-size: 1rem;
}
.info-item .title:hover,
.info-item .title:focus{
  color: var(--c-cta);
  outline: none;
}

/* 矢印 */
.chev{
  font-size: 22px;
  color: var(--c-primary);
  margin-left: 4px;
  opacity:.6;
  transition: transform .15s ease, opacity .15s ease, color .15s ease;
}

/* 行ホバー演出 */
.info-item:hover{
  /* background: linear-gradient(0deg, rgba(233,216,197,.28), rgba(233,216,197,0)); */
}
.info-item:hover .chev{ transform: translateX(2px); opacity:.85; color: var(--c-cta); }

/* フォーカスリング */
.info-item a:focus-visible{
  outline: 2px solid var(--c-cta);
  outline-offset: 2px;
  border-radius: 6px;
}
@media (max-width: 768px){
  .info-cta {
    font-size: 0.7rem;
  }
  .info-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap:5px;
  }
  .info-item {
    gap: 1px;
    }
  .info-item .title {
    font-size: 0.7rem;
  }
  .info-col {
    width: 100%;
  }
}
/*-------------------------------------- 無痛中絶手術 --------------------------------------*/
/* ===== 無痛中絶手術セクション ===== */

.section-abortion {
  background-image: url(../images/top/bg.png);
  background-size: cover;
  padding: 100px 0 180px;
  background-color: #fff5f7;
}

.section-abortion .inner {
  width: 90%;
  /* max-width: 1120px; */
  margin: 0 auto;
}

.section-abortion .flex_box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4%;
}

/* 画像ボックス */
.section-abortion .img_box {
  width: 48%;
}

.section-abortion .img_box img {
  width: 100%;
  display: block;
  border-radius: 40px;
  object-fit: cover;
}

/* テキストボックス */
.section-abortion .txt_box {
  width: 50%;
  color: #5c3a33;
  font-family: "YuGothic", "游ゴシック体", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
}

/* 小さな飾り付きタイトル */
.section-label {
  position: relative;
  text-align: center;
  margin-bottom: 4px;
}
.section-label::before {
  left: -10px;
  transform: translate(-100%, -50%);
}

.section-label::after {
  right: -10px;
  transform: translate(100%, -50%);
}

/* 英字サブタイトル */
.section-en {
  text-align: center;
  font-size: 90%;
  font-weight: 700;
  letter-spacing: .2em;
  color: var(--c-cta);
  margin-bottom: 18px;
}

/* リード文 */
.section-abortion .section-lead {
  font-size: 0.95rem;
  line-height: 2;
  background-color: #ffffff;
  padding: 20px 24px;
  /* border-radius: 20px; */
  box-shadow: 0 0 16px rgba(74, 54, 37, 0.08);
}

.section-abortion .section-lead span {
  font-size: 120%;
  font-weight: 700;
  color: var(--c-cta-hover);
}

/* ボタンエリア */
.section-abortion .btn-area {
  margin-top: 24px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}

.section-abortion .btn-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 28px;
  border-radius: 999px;
  font-size: 0.95rem;
  border: 1px solid transparent;
  text-decoration: none;
  white-space: nowrap;
  transition: all 0.25s ease;
}

.section-abortion .btn-primary {
  background-color:var(--c-cta-hover);
  color: #fff;
}

.section-abortion .btn-primary:hover {
  background-color: #97764a;
  background-color:var(--c-cta);
}

.section-abortion .btn-sub {
  background-color: #fff;
  border-color: #e2cfd3;
  color: #8b6a63;
}

.section-abortion .btn-sub:hover {
  background-color: #fdf5f7;
}

/* ===== SPレイアウト ===== */
@media screen and (max-width: 768px) {
  .section-abortion {
    padding: 48px 0;
  }

  .section-abortion .flex_box {
    flex-direction: column;
    gap: 24px;
  }

  .section-abortion .img_box,
  .section-abortion .txt_box {
    width: 100%;
  }

  .section-abortion .section-label::before,
  .section-abortion .section-label::after {
    width: 40px;
  }

  .section-abortion .section-lead {
    padding: 16px 18px;
    font-size: 0.9rem;
  }

  .section-abortion .btn-area {
    flex-direction: column;
  }

  .section-abortion .btn-pill {
    width: 100%;
    justify-content: center;
  }
}

/*-------------------------------------- 当院の特徴 --------------------------------------*/
.ingenuity {
      padding: 4.8vw 0 13.333vw;
    background-image: url(../images/top/reasonbg.png);
    background-size: 100% auto;
    background-position: center top;
    background-repeat: no-repeat;
}
/*------------------- 工夫 -------------------*/
.grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    /* gap: max(5vw, 65px) max(2.286vw, 29px); */
    margin-top: max(3.929vw, 51px);
}
.ingenuity .headline {
  text-align: center;
  padding-top: 20px;
}
.ingenuity img {
    width: 100%;
}
.ingenuity .sub {
  position: relative;
}
.ingenuity .sub:before, .ingenuity .sub:after {
    content: "";
    display: inline-block;
    width: 17.333vw;
    height: .133vw;
    margin: 0 2vw .667vw;
    background-color: #4c3d30;
    vertical-align: middle;
}
.ingenuity-inner {
      padding: 4.8vw 0 13.333vw;
    background-image: url(../images/img4.png);
    background-size: 100% auto;
    background-position: center top;
    background-repeat: no-repeat;
}
.ingenuity-inner .subtitle {
  width: 100%;
}

.ingenuity .box {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #fff;
  width: 86.667vw;
  margin: 0 auto;
  margin-top: 5vw;
  text-align: left;
  width: max(45vw, 585px);
    text-align: left;
}
.ingenuity .box .flex {
  display: flex;
}
.ingenuity .box .img {
  flex:1
}
.ingenuity .box h3 {
position: absolute;
    top: min(-2.429vw, -32px);
    left: min(-.714vw, -10px);
    width: max(22.143vw, 287px);
    height: max(3.571vw, 46px);
    padding: max(.857vw, 11px) 0 0 max(6.571vw, 85px);
    background-color: rgba(69, 91, 127, .95);
    font-size: 1.2rem;
    line-height: 1;
    color: #fff;
}
.ingenuity .box h3:before {
content: "";
    position: absolute;
    top: 0;
    right: 0;
    transform: translateX(100%);
    border-right: max(2.143vw, 27px) solid transparent;
    border-top: max(3.571vw, 46px) solid rgba(69, 91, 127, .95);
}
.ingenuity .box h3 span {
position: absolute;
    top: min(-.571vw, -8px);
    left: max(.571vw, 7px);
    font-size: max(4.143vw, 53px);
    font-style: italic;
    opacity: .5;
    letter-spacing: -.05em;
}
.reaingenuityson .box .img {
    width: 23.571vw;
}
.ingenuity .box p {
    width: max(21.429vw, 278px);
    padding: 1.2em;
}
.ingenuity .box a:after {
    content: "";
    position: absolute;
    bottom: 1.333vw;
    right: 1.333vw;
    border-left: 2vw solid transparent;
    border-bottom: 2vw solid var(--main-color);
}
/*-------------------------------------- 当院の特徴2 --------------------------------------*/
/*---------------------------------------------------------------------

 世代ごとの取り組み 

 ---------------------------------------------------------------------*/
/* セクションの背景 */
.sedai {
  padding: 60px 0 0 0;
  position: relative;
  background: linear-gradient(to right, rgb(255 255 255) 0%, rgb(246 234 242 / 90%) 20%, /* #eaf0f6（明るめ）*/ rgb(250 245 248 / 90%) 80%, /* #f5f7fa（ほぼ白）*/ rgb(255 255 255) 100%);  z-index: 0;
  overflow: hidden;
  /* font-family: 'Noto Serif JP', serif; */
}

.sedai::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 80px;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
  z-index: 1;
}

.sedai::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 80px; 
  background: linear-gradient(to top, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
  z-index: 1;
}

.idx_inr {
  position: relative;
  display: block;
  margin: 0 auto;
}

.idx_box {
  display: block;
  position: relative
}

.idx_lst li {
  position: relative;
  display: block;
  padding-left: 1em;
  margin-bottom: .5em;
  background-repeat: no-repeat;
  background-position: 0 .4em;
  background-size: .8em auto
}

.sedai .idx_inr {
  max-width: 1400px;
  width: 100%;
  padding: 36px 0;
  margin-bottom: 30px;
  background-repeat: no-repeat;
  background-size: auto 100%;
  background-color: #fff;
  background-position: 100% 0
}

.sedai .idx_inr:nth-of-type(2) {
  background-position: 0 0
}
.sedai .idx_inr:nth-of-type(4) {
  background-position: 0 0
}
.sedai .idx_inr:nth-of-type(6) {
  background-position: 0 0
}

.sedai .idx_box {
  background-color: #ffffffa6;
  box-shadow: 3px 3px 5px rgba(162,162,162,.2);
  max-width: 858px;
  margin: 0 auto 0 0;
  padding: 30px 24px 24px 65px;
}

.sedai .idx_inr:nth-of-type(2) .idx_box {
  box-shadow: -3px 3px 5px rgba(162,162,162,.2);
  margin: 0 0 0 auto
}
.sedai .idx_inr:nth-of-type(4) .idx_box {
  box-shadow: -3px 3px 5px rgba(162,162,162,.2);
  margin: 0 0 0 auto
}
.sedai .idx_inr:nth-of-type(6) .idx_box {
  box-shadow: -3px 3px 5px rgba(162,162,162,.2);
  margin: 0 0 0 auto
}

.sedai_ttl {
  position: relative;
  font-size: 26.87px;
  margin: 0 0 24px;
  border-bottom: 1px solid var(--c-accent);
  color: #5b4633;
}
.sedai_ttl span{
  font-size: 135%;
  color: var(--c-cta);
}
  

.sedai_ttl:before {
  content: "";
  display: block;
  position: absolute;
  width: 99px;
  aspect-ratio: 1/1;
  left: -45px;
  top: -24px;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
.sedaittl01:before{
  background-image: url(../images/top/h-img.png);
  background-repeat: no-repeat;
}
.sedaittl02:before{
  background-image: url(../images/top/h-img2.png);
  background-repeat: no-repeat;
}
.sedaittl03:before{
  background-image: url(../images/top/h-img3.png);
  background-repeat: no-repeat;
}

.sedai_lead {
  display: flex;
  align-items: center;
  padding: 0 0 16px;
  margin: 0 auto 0 0;
  width: 100%;
}

.sedai_lead p {
  display: block;
}

.sedai_lead p i {
  display: block
}

.sedai_lead p .ja {
  font-size: 27.52px
}

.sedai_lead p .en {
  font-size: 39.63px;
  font-weight: 700
}

.sedai_lead figure {
  flex: 1
}

.sedai .idx_lst {
  font-size: 1.2rem
}
.sedai .idx_lst li {
  line-height: 1.3;
}
.sedai .idx_lst li::before {
  content: "●";
  font-size: 20px;
  color: var(--c-cta);
  margin-right: 10px;
  position: relative;
  top: 3px;
}

.sedai .idx_lst li span {
  display: block
}
.sedai .idx_lst li em {
    font-weight: 600;
    font-size: 19px;
}
.sedai01 li em{
  color: var(--c-cta);
}
.sedai02 li em{
    color: var(--c-cta);
}
.sedai03 li em{
    color: var(--c-cta);
}
.sedai04 li em{
  color: var(--c-cta);
}

.sedai_fig {
  position: absolute
}

.sedai .idx_gnr_btn {
  width: unset;
  left: unset;
  right: 36px;
  bottom: 20px
}

.idx_gnr_01 {
  background-image: url(../images/top/reasonbg01.png);
  background-repeat: no-repeat;
}


.idx_gnr_01 .sedai_lead p {
  margin-right: 42px
}

.idx_gnr_01 .sedai_lead figure img {
  width: 109px;
  aspect-ratio: 109/149
}
.idx_gnr_01 .sedai_fig {
  width: 366px;
  bottom: 40px;
  right: 0px;
}
.idx_gnr_01 .sedai_fig img {
  aspect-ratio: 366/272;
  padding: 10px;
  width: 366px;
}

.idx_gnr_02 {
  background-image: url(../images/top/reasonbg02.png);
  background-repeat: no-repeat;
}

.idx_gnr_02 .sedai_lead p {
  margin-right: 36px
}

.idx_gnr_02 .sedai_lead figure img {
  width: 103px;
  aspect-ratio: 103/138
}

.idx_gnr_02 .idx_lst li:nth-of-type(2) span:nth-of-type(2) {
  margin-left: -.4em
}

.idx_gnr_02 .sedai_fig {
  width: 309px;
  bottom: 0px;
  right: 42px;
}

.idx_gnr_02 .sedai_fig img {
  aspect-ratio: 378/269
}

.idx_gnr_03 {
  background-image: url(../images/top/reasonbg03.png);
  background-repeat: no-repeat;
}


.idx_gnr_03 .sedai_lead p {
  margin-right: 30px
}

.idx_gnr_03 .sedai_lead figure img {
  width: 117px;
  aspect-ratio: 117/144
}

.idx_gnr_03 .idx_lst li:nth-of-type(2),.idx_gnr_03 .idx_lst li:nth-of-type(3) {
  padding-left: 1em
}

.idx_gnr_03 .sedai_fig {
  width: 377px;
  bottom: 40px;
  right: 42px
}

.idx_gnr_03 .sedai_fig img {
  aspect-ratio: 377/269;
  width: 366px;
}


.idx_gnr_04{
  background-image: url(../images/top/reasonbg04.png);
  background-repeat: no-repeat;
}
.idx_gnr_04 .sedai_lead p {
  margin-right: 30px
}

.idx_gnr_04 .sedai_lead figure img {
  width: 117px;
  aspect-ratio: 117/144
}

.idx_gnr_04 .idx_lst li:nth-of-type(2),.idx_gnr_04 .idx_lst li:nth-of-type(3) {
  padding-left: 1em
}

.idx_gnr_04 .sedai_fig {
  width: 377px;
  bottom: 40px;
  right: 42px
}
.idx_gnr_04 .sedai_fig img {
  aspect-ratio: 377/269
}
.idx_gnr_05 {
  background-image: url(../images/top/reasonbg05.png);
  background-repeat: no-repeat;
}


.idx_gnr_05 .sedai_lead p {
  margin-right: 42px
}

.idx_gnr_05 .sedai_lead figure img {
  width: 109px;
  aspect-ratio: 109/149
}
.idx_gnr_05 .sedai_fig {
  width: 366px;
  bottom: 40px;
  right: 0px;
}
.idx_gnr_05 .sedai_fig img {
  aspect-ratio: 366/272;
  padding: 10px;
  width: 366px;
}

.idx_gnr_06 {
  background-image: url(../images/top/reasonbg06.png);
  background-repeat: no-repeat;
}

.idx_gnr_06 .sedai_lead p {
  margin-right: 36px
}

.idx_gnr_06 .sedai_lead figure img {
  width: 103px;
  aspect-ratio: 103/138
}

.idx_gnr_06 .idx_lst li:nth-of-type(2) span:nth-of-type(2) {
  margin-left: -.4em
}

.idx_gnr_06 .sedai_fig {
  width: 309px;
  bottom: 0px;
  right: 42px;
}

.idx_gnr_06 .sedai_fig img {
  aspect-ratio: 378/269
}



.spimg {
  display: none;
}
.spnone {
  display: block;
}


/*------------------------------
ボタン
------------------------------*/

.btn03 {
  position: relative;
}
.btn03 a {
  display: inline-block;
  position: relative;
  min-width: 250px;
  box-sizing: border-box;
  padding: 17px 38px 17px 25px;
  margin: 6px 0;
  line-height: 1;
  border-radius: 40px;
  text-align: left;
  font-weight: bold;
  text-decoration: none;
  font-size: 15px;
}
.btn03 a:hover::before {
  right: 20px;
}

.btn03 a:hover::before{
	right: 20px;
}

.btn03 a:hover::after{
	left:0;
	top:0;
}
.btn03 a i{
	margin-right: 7px;
	font-size: 12px;
}
/* 一つ目のボタン */
.sedaibtv01 a {
	border: 1px solid var(--c-cta-hover);
	color: var(--c-cta-hover);
	transition: background-color 1s ease, color 1s ease;
  text-align: center;
}
.sedaibtv01 a:hover {
	color: #fff;
	background:var(--c-cta);
}

/* 二つ目のボタン */
.sedaibtv02 a {
  border: 1px solid var(--c-cta);
  color: var(--c-cta);
	transition: background-color 1s ease, color 1s ease;
  text-align: center;
}
.sedaibtv02 a:hover {
	color:#fff;
	background:var(--c-cta);
}

/* 三つ目のボタン */
.sedaibtv03 a {
	border: 1px solid var(--c-cta);
	color: var(--c-cta);
	transition: background-color 1s ease, color 1s ease;
  text-align: center;
}

.sedaibtv03 a:hover{
	color:#fff;
	background-color:var(--c-cta);
}
.sedaibtv03 a:hover::before{
	border-color:var(--c-cta);
  color: #fff;
}

/* 四つ目のボタン */
.sedaibtv04 a {
	border: 1px solid var(--c-cta);
	color: var(--c-cta);
	transition: background-color 1s ease, color 1s ease;
}

.sedaibtv04 a:hover{
	color:#fff;
	background-color:var(--c-cta);
}
.sedaibtv04 a:hover::before{
	border-color: var(--c-cta);
  color: #fff;
}
/* ----------------------------------------------------
タブレット（768px～1024px）
---------------------------------------------------- */
@media screen and (min-width: 768px) and (max-width: 1024px) {
.sedai .idx_box {
    background-color: #ffffffd6;
  }
}
/* ----------------------------------------------------
スマホ用（〜767px）
---------------------------------------------------- */
@media screen and (max-width: 768px) {
  .spimg {
    display: block;
  }
  .sedai .idx_box {
    background-color: #ffffffed;
    padding: 20px 10px;
  }
  .sedai_ttl {
    font-size: 1rem;
  }
  .sedai_ttl span {
    font-size: 1.2rem;
  }
  .sedai_lead {
    width: 100%;
    margin: 15px auto
  }
  .idx_gnr_01 .sedai_lead p,
  .idx_gnr_02 .sedai_lead p,
  .idx_gnr_03 .sedai_lead p {
    margin-right: 0;
}
.sedai .idx_lst {
  font-size: 1rem;
}
.sedai .idx_lst li em {
  font-size: 18px;
}
.spnone {
  display: none;
}
.sedai .idx_inr,
.sedai .idx_inr:nth-of-type(2){
  background-position: left top;
}
.idx_lst li {
  padding-left: 0;
}
.sedai .idx_lst li::before {
  font-size: 15px;
}
.idx_gnr_04 .sedai_lead p {
  margin-right: 0;
}
.idx_gnr_05 .sedai_lead p {
    margin-right: 0;
}
.idx_gnr_06 .sedai_lead p {
  margin-right: 0;
}
.btn03 {
	text-align:center;
}
}

/*---------------------------------------------------------------------

 院長あいさつ 

 ---------------------------------------------------------------------*/

 /*------------------- スタッフ紹介 -------------------*/
.staff_head {
    width: 100%;
    height: 30vw;
    max-height: 440px;
    background-image: url(https://yuuki-dent.com/images/top/gree_corner1@2x.png), url(https://yuuki-dent.com/images/top/gree_corner2@2x.png), url(../images/top/headimg.png);
    background-repeat: no-repeat, no-repeat, no-repeat;
    background-position: left top, right bottom, center center;
    background-size: 189px auto, 198px auto, cover;
    position: relative;
    margin-top: 100px;
    margin-bottom: 35px;
}
.staff_head_inner {
  position: absolute;
    z-index: 1;
    left: 0;
    right: 0;
    top: 0;
    transform: translateY(-10%);
}
.staff_head_inner .head_txt {
  position: absolute;
  left: 9%;
  top: 50px;
}
.staff_head_inner .head_txt img {
    width: 240px;
}
.staff_head_inner .head_txt h2 {
    line-height: 1.6;
    font-size: 150%;
    color: #c8a88b;
    text-shadow: 2px 2px 7px #7a5a2f80;
}
.staff_head_inner .head_txt h2 span {
  font-size: 4.5rem;
  color: #7a5a2f;
}

.staff .main_box {
    width: 90%;
    padding: 0 3%;
    /* max-width: 1100px; */
    margin: 0 auto;
    text-align: left;
    position: relative;
    z-index: 5;
    /* display: flex;
    justify-content: space-between;
    flex-direction: row-reverse; */
}
.staff .main_box .flex_box {
  display: flex;
}
.staff .main_box .flex_box .txt_box {
    width: 63%;
	margin: auto 20px;
    /* max-width: 690px; */
}
.staff .main_box .flex_box .img_box {
    width: 34%;
    /* max-width: 340px; */
}
.staff .main_box .flex_box .txt p {
  margin-bottom: 10px;
  /* font-size: 1rem; */
}

.biography_box {
    background: #e9d8c533;
    width: 90%;
    padding: 15px 3%;
    /* max-width: 1100px; */
    margin: 20px auto;
    text-align: left;
    position: relative;
    z-index: 5;
}
.biography_box .flex_box {
  display: flex;
}
.biography_box .flex_box .txt_box {
  width: 50%;
}
.biography_box .ttl{
  font-size: 120%;
}
.btn-areas {
  width: 90%;
  margin: auto;
  display: flex;
  justify-content: flex-end;
}
/* ------------------------------------------------------
   ボタン基本設定
------------------------------------------------------ */
.c-btn-arrowcircle {
  --c-text: #7a5a2f;
  --c-accent: #C8A88B;
  --c-light: #E9D8C5;

  display: inline-flex;
  align-items: center;
  gap: 0;              /* テキストとの間隔 */
  padding: 0.8rem 0;
  color: var(--c-text);
  text-decoration: none;
  font-size: 1rem;
  font-weight: 600;
  border-bottom: 1px solid var(--c-text);
  position: relative;
  transition: border-color .3s ease;
}
a.c-btn-arrowcircle:hover {
color: var(--c-text);
}
/* ------------------------------------------------------
   矢印のラッパー
------------------------------------------------------ */
.c-btn-arrowcircle .arrow-wrap {
  position: relative;
  display: inline-block;
  width: 3.2rem;  
  height: 1.4rem;
}

/* ------------------------------------------------------
   細い棒（初期状態：短い）
------------------------------------------------------ */
.c-btn-arrowcircle .arrow-line {
  position: absolute;
  left: 10px;
  top: 50%;
  width: 2.2rem;
  height: 0.5px;
  background: var(--c-cta-hover);
  transform: translateY(-50%) scaleX(1);
  transform-origin: left center;
  transition: transform .35s ease;
}

/* ------------------------------------------------------
   ぼんやり丸（薄いアクセント）
------------------------------------------------------ */
.c-btn-arrowcircle .arrow-dot {
  position: absolute;
  left: 1.6rem;
  top: 50%;
  width: 1.4rem;
  height: 1.4rem;
  background: var(--c-ctabg);
  border-radius: 50%;
  filter: blur(6px);
  opacity: 0.9;
  transform: translateY(-50%);
  pointer-events: none;
  transition: transform .3s ease, opacity .3s ease;
}

/* ------------------------------------------------------
   矢印の先端（＞）
------------------------------------------------------ */
.c-btn-arrowcircle .arrow-tip {
  position: absolute;
  left: 2.2rem;
  top: 50%;
  width: 0.5rem;
  height: 0.5rem;
  border-right: 1px solid var(--c-cta-hover);
  border-top: 1px solid var(--c-cta-hover);
  transform: translateY(-50%) rotate(45deg);
  transition: left .35s ease, transform .35s ease;
}

/* ------------------------------------------------------
   ホバー時（右方向へ伸びるアニメーション）
------------------------------------------------------ */
.c-btn-arrowcircle:hover .arrow-line {
  transform: translateY(-50%) scaleX(1.6); /* 右にぐーんと伸びる */
}

.c-btn-arrowcircle:hover .arrow-tip {
  left: 3.6rem;  /* 棒が伸びた先端に追従 */
  transform: translateY(-50%) rotate(45deg);
}

.c-btn-arrowcircle:hover .arrow-dot {
  transform: translateY(-50%) scale(1.1);
  opacity: 1;
}
.highlight {
  font-weight: 700;
  color: #7a5a2f; /* もしくは #C8A88B */
}
.highlight {
  font-weight: 700;
  background: linear-gradient(transparent 60%, #F7E5E5 60%);
  color: #7a5a2f;
  padding: 0 2px;
}

/* ----------------------------------------------------
スマホ用（〜767px）
---------------------------------------------------- */
@media screen and (max-width: 768px) {
  .staff_head {
    height: 70vw;
    max-height: 100%;
    background-image: url(https://yuuki-dent.com/images/top/gree_corner1@2x.png), url(https://yuuki-dent.com/images/top/gree_corner2@2x.png), url(../images/top/headimg.png);
    background-size: 25% auto, 18% auto, cover;
    margin-bottom: 10%;
  }
  .staff_head_inner .head_txt h2 {
    writing-mode: lr;
    font-size: 100%;
  }
  .staff_head_inner .head_txt h2 span {
    font-size: 200%;
  }
  .staff_head_inner .head_txt {
    position: absolute;
    left: 4%;
    top: auto;
    bottom: -291px;
}
.staff .main_box {
  width: 100%;
}
.staff .main_box .flex_box {
  flex-direction: column;
}
.staff .main_box .flex_box .txt_box {
  order: 2;
  width: 100%;
	margin:0;
}
.staff .main_box .flex_box .img_box {
  order: 1;
  width: 100%;
}
.biography_box .flex_box {
  flex-direction: column;
}
.biography_box .flex_box .txt_box {
    width: 100%;
}
.staff_head_inner .head_txt img {
    width: 165px;
}
}
/*------------------------------------------
  院長あいさつ：文章折りたたみ部分
-------------------------------------------*/

/* 読みやすさ向上（任意） */
.staff .main_box .flex_box .txt p,
.staff-lead {
  line-height: 1.9;
}

/* リード文強調 */
.staff-lead {
  margin-bottom: 1rem;
}

/* 折りたたみ部分 */
.staff-more {
  transition: max-height 0.3s ease, opacity 0.3s ease;
}

/* PCでは常に表示 */
@media (min-width: 769px) {
  .staff-more {
    max-height: none;
    opacity: 1;
  }
  .staff-more-toggle {
    display: none;
  }
}

/* スマホの折りたたみ初期状態 */
@media (max-width: 768px) {
  .staff-more {
    max-height: 0;
    opacity: 0;
    overflow: hidden;
     transition: max-height 0.35s ease, opacity 0.35s ease;
  }
  .staff-more.is-open {
    max-height: 1500px;
    opacity: 1;
  }

   .staff-more-toggle {
    display: inline-flex;
    margin: 1rem auto 0; /* ← auto で中央寄せ */
    padding: 0.5rem 1.6rem;
    border-radius: 999px;
    border: 1px solid #c8a88b;
    background: #fff;
    color: #7a5a2f;
    font-size: 0.9rem;
    cursor: pointer;
    text-align: center;

    /* 中央寄せするために必要 */
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }

  .staff-more-toggle.is-open {
    background: #c8a88b;
    color: #fff;
  }
}

/*---------------------------------------------------------------------

中絶手術について

 ---------------------------------------------------------------------*/
 /* ===========================
   手術料金・同意書・予約ブロック
   =========================== */

.abort-info {
  background-image: url('../images/top/abortbg.png');
  background-position: center;
  padding: 48px 16px 56px;
}

.abort-info__inner {
  max-width: 90%;
  margin: 0 auto;
}

/* 見出しまわり */
.abort-info__header {
  margin-bottom: 28px;
}

.abort-info__headline {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}

.abort-info__line {
  display: inline-block;
  width: 40px;
  height: 2px;
  border-radius: 999px;
  background: #C8A88B;
}

.abort-info__title {
  font-size: 22px;
  letter-spacing: 0.06em;
  color: #4b3f35;
}

.abort-info__lead {
  font-size: 14px;
  color: #7a685b;
  line-height: 1.9;
  margin-top: 4px;
}

/* 本文エリア */
.abort-info__content {
  background: #ffffff;
  border-radius: 20px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.04);
  padding: 28px 26px 24px;
}

/* リスト */
.abort-info__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.abort-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  column-gap: 14px;
  row-gap: 4px;
  padding: 14px 0;
  border-bottom: 1px dashed #f0e2d5;
}

.abort-item:last-child {
  border-bottom: none;
}

/* 左の丸アイコン */
.abort-item__icon {
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, #ffffff, #E9D8C5);
  box-shadow: 0 0 0 6px rgba(233, 216, 197, 0.45);
  margin-top: 11px;
}

/* テキスト部分 */
.abort-item__body {}

.abort-item__title {
  font-size: 125%;
  font-weight: 700;
  color: var(--c-cta);
  margin: 0 0 4px;
}

.abort-item__text {
  font-size: 14px;
  color: #5f4f43;
  line-height: 1.9;
}

/* CTAボタン */
.abort-info__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 22px;
  justify-content: center;
}

.abort-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 26px;
  border-radius: 999px;
  font-size: 14px;
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease,
              background 0.18s ease, color 0.18s ease;
}

/* メインボタン（グラデーション＋影） */
.abort-btn--primary {
  background-image: linear-gradient(135deg, #C8A88B, #d7bba0);
  color: #ffffff;
  box-shadow: 0 10px 22px rgba(200, 168, 139, 0.45);
}

.abort-btn--primary::before {
  content: "";
  position: absolute;
  inset: 2px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.55);
  pointer-events: none;
}

.abort-btn--primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgba(200, 168, 139, 0.55);
  color: #ffffff;
}

/* アウトラインボタン */
.abort-btn--outline {
  border: 1px solid #C8A88B;
  background: #ffffff;
  color: #4b3f35;
}

.abort-btn--outline:hover {
  background: #fdf7f0;
}

/* 矢印 */
.abort-btn__arrow {
  font-size: 14px;
  transform: translateX(1px);
}

/* -------------------------
   レスポンシブ調整
   ------------------------- */
@media (max-width: 768px) {
  .abort-info__content {
    padding: 22px 18px 20px;
  }

  .abort-item {
    grid-template-columns: 14px minmax(0, 1fr);
    column-gap: 10px;
  }

  .abort-info__cta {
    justify-content: flex-start;
  }

  .abort-btn {
    width: 100%;
    justify-content: center;
  }
  .abort-info__inner {
  max-width: 100%;
}
}
/*---------------------------------------------------------------------

 治療の流れ

 ---------------------------------------------------------------------*/
 /* ============================
   中絶手術の流れ
   ============================ */

.abort-flow {
  position: relative;
  padding: 3.5rem 1rem 4.5rem;
  background: #fbf6f6;
  z-index: 0;
}
.abort-flow::before {
    content: "";
    position: absolute;
    right: 0;
    top: 0;
    width: 55%;
    height: 70%;
    background: url(../images/top/flowbg00.png) no-repeat right top;
    background-size: contain;
    pointer-events: none;
    opacity: .5;
    z-index: -1;
}
.abort-flow::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 60%; /* 好みで調整 */
  height: 80%;
  background: url("../images/top/flowbg.png") no-repeat left bottom;
  background-size: contain;
  pointer-events: none;
  opacity: .8; /* 全体の薄さ */
  z-index: -1;
}

.abort-flow__inner {
  max-width: 90%;
  margin: 0 auto;
}

/* 見出し */
.abort-flow__header {
  text-align: center;
  margin-bottom: 2.5rem;
}

.abort-flow__eyebrow {
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #C8A88B;
  margin-bottom: 0.25rem;
}

.abort-flow__title {
  font-size: 1.5rem;
  letter-spacing: 0.06em;
  color: #4a3f37;
  margin-bottom: 0.6rem;
}

.abort-flow__lead {
  font-size: 0.9rem;
  color: #7a685b;
  line-height: 1.9;
}

/* タイムライン */
.abort-flow__list {
  position: relative;
  list-style: none;
  margin: 0;
  padding: 0 0 0 1.5rem;
}

.abort-flow__list::before {
  content: "";
  position: absolute;
  left: 0.5rem;
  top: 0.5rem;
  bottom: 0;
  width: 0.125rem;
  background: linear-gradient(to bottom, #E9D8C5, rgba(233,216,197,0.1));
}

.abort-flow__item {
  position: relative;
  margin-bottom: 1.6rem;
}

.abort-flow__item:last-child {
  margin-bottom: 0;
}

/* 丸マーカー */
.abort-flow__item::before {
  content: "";
  position: absolute;
  left: -1.5rem;
  top: 0.3rem;
  width: 1.125rem;
  height: 1.125rem;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #ffffff, #E9D8C5);
  box-shadow: 0 0 0 0.25rem rgba(233, 216, 197, 0.6);
}

/* STEPヘッダー */
.abort-flow__step-head {
  display: flex;
  align-items: baseline;
  gap: 0.6rem;
  margin-bottom: 0.4rem;
}

.abort-flow__step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 4.5rem;
  padding: 0.25rem 0.7rem;
  border-radius: 999px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #ffffff;
  background: #C8A88B;
}

.abort-flow__step-title {
  font-size: 1.125rem;
}

/* カード本体 */
.abort-flow__card {
  margin-top: 0.3rem;
  margin-left: 0.4rem;
  background: #ffffff;
  border-radius: 1.125rem;
  box-shadow: 0 0.6rem 1.8rem rgba(0, 0, 0, 0.06);
  padding: 1.25rem 1.4rem;
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  column-gap: 1.25rem;
  row-gap: 0.9rem;
}

.abort-flow__card-main {
  font-size: 1rem;
  color: #5f4f43;
  margin: auto 0;
}

.abort-flow__text {
  margin-bottom: 0.6rem;
  line-height: 1.9;
}

/* メタ情報 */
.abort-flow__meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
  gap: 0.25rem 1.1rem;
  margin: 0.4rem 0 0.8rem;
}
.flow_left,
.flow_right {
    background: #f9f2f3;
    padding: 15px 10px;
}
.abort-flow__meta dt {
  font-size: 80%;
  font-weight: 700;
  color: var(--c-text-muted);
  margin-bottom: 7px;
}

.abort-flow__meta dd {
  font-size: 0.9rem;
  color: #4a3f37;
  margin: 0 0 0.25rem;
}

/* 小見出し＋ドットリスト */
.abort-flow__subhead {
  font-size: 0.9rem;
  font-weight: 600;
  margin: 0.4rem 0 0.3rem;
  color: #c0747a;
}

.abort-flow__list-dot {
  list-style: none;
  margin: 0;
  padding: 0;
}

.abort-flow__list-dot li {
  position: relative;
  padding-left: 0.9rem;
  margin-bottom: 0.25rem;
  font-size: 0.9rem;
  color: #5f4f43;
}

.abort-flow__list-dot li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 0.35rem;
  height: 0.35rem;
  border-radius: 50%;
  background: #E9D8C5;
}

/* 右側：画像＋ひと言 */
.abort-flow__card-side {
  align-self: stretch;
  font-size: 80%;
  color: #7a685b;
  width: 80%;
  margin: auto;
}

.abort-flow__image {
  margin: 0 0 0.5rem;
  border-radius: 50px 0 50px 0;
  overflow: hidden;
  background: #f7eee7;
}

.abort-flow__image img {
  display: block;
    width: 95%;
    height: auto;
    margin: 10px auto;
    border-radius: 50px 0 50px 0;
}
.abort-flow__image {
  border-radius: 40px 0 40px 0;
  padding: 12px;
  background: linear-gradient(135deg, #f7eee7 0%, #f0e4dc 100%);
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
}

.abort-flow__note {
  font-size: 0.85rem;
  line-height: 1.8;
}

/* ============================
   レスポンシブ
   ============================ */

@media (max-width: 880px) { 
  .abort-flow__card {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 786px) { 
  .abort-flow__inner {
    max-width: 100%;
    width: 100%;
  }
  .abort-flow {
    padding: 2.5rem 0.9rem 3.5rem;
  }
  .abort-flow__card {
    padding: 1.1rem 0.8rem;
  }
  .abort-flow__image {
    max-width: 100%;
    margin: 0 auto 0.6rem;
  }
  .abort-flow__card-side {
    width: 100%;
  }

}
/*---------------------------------------------------------------------

 バナーブロック

 ---------------------------------------------------------------------*/
/* バナー全体の余白 */
.link-banners {
  padding: 2.5rem 1rem 3rem;
}

.link-banners__inner {
  max-width: 70rem; /* 約1120px */
  margin: 0 auto;
}

/* PC：フレックスで中央寄せ＋折り返し */
.link-banners__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;       /* 下段も中央寄せになる */
  gap: 1.5rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

/* 各バナー */
.link-banners__item {
  margin: 0;
  flex: 0 1 12.5rem; /* 最小幅 約200px、あとは自動で調整 */
}

.link-banners__link {
  display: block;
  overflow: hidden;
  background: #ffffff;
  border: 0.09rem solid #E9D8C5;
  box-shadow: 0 0.9rem 1.8rem rgba(0, 0, 0, 0.06);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

/* 画像をそのまま見せる */
.link-banners__link img {
  display: block;
  width: 100%;
  height: auto;
}

/* ホバー時の演出 */
.link-banners__link:hover {
  transform: translateY(-0.15rem);
  box-shadow: 0 1.2rem 2.1rem rgba(0, 0, 0, 0.10);
  border-color: #C8A88B;
}

/* SP：2カラム表示に切り替え */
@media (max-width: 40rem) {
  .link-banners {
    padding: 2rem 0.9rem 2.5rem;
  }

  .link-banners__list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.2rem;
  }

  .link-banners__item {
    flex: none; /* flex指定をリセット */
  }
}
/*---------------------------------------------------------------------

 アクセス

 ---------------------------------------------------------------------*/
 /* アクセス全体 */
.access-block {
  /* :root を使わず、このブロック内だけで色変数を定義 */
  --c-primary: #C8A88B;
  --c-primary-light: #E9D8C5;
  --c-text-main: #7a5a2f;

  padding: 3.5rem 1rem;
  background: #fbf6f6;
}
.access-block__map {
  margin: 20px 0;
}
.access-block__inner {
  max-width: 70rem; /* 約1120px */
  margin: 0 auto;
}

.access-block__title {
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--c-text-main);
  letter-spacing: 0.08em;
  margin-bottom: 0.3rem;
}

.access-block__lead {
  font-size: 0.9rem;
  color: #a5855a;
  margin-bottom: 1.8rem;
}

/* タブボタン */
.access-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  margin-bottom: 1.8rem;
}

.access-tab {
  flex: 1 1 10rem;
  padding: 0.65rem 1rem;
  border-radius: 999px;
  border: 1px solid var(--c-primary-light);
  background: #fff;
  color: var(--c-text-main);
  font-size: 0.9rem;
  letter-spacing: 0.03em;
  text-align: center;
  cursor: pointer;
  transition: background 0.25s ease, border-color 0.25s ease, color 0.25s ease,
              box-shadow 0.25s ease, transform 0.2s ease;
}

.access-tab.is-active {
  background: var(--c-primary-light);
  border-color: var(--c-primary);
  box-shadow: 0 0.4rem 1rem rgba(0, 0, 0, 0.06);
  transform: translateY(-1px);
}

.access-tab:hover {
  border-color: var(--c-primary);
}

/* コンテンツパネル */
.access-panels {
  background: #fff;
  border-radius: 1.5rem;
  padding: 1.8rem 2rem 2rem;
  box-shadow: 0 0.6rem 1.4rem rgba(0, 0, 0, 0.06);
}

.access-panel {
  display: none;
}

.access-panel.is-active {
  display: block;
}

.access-panel__title {
  font-size: 1.1rem;
  color: var(--c-text-main);
  margin-bottom: 0.9rem;
}

.access-panel__list {
  margin: 0;
  padding-left: 0;
  list-style: none;
}

.access-panel__list li {
  position: relative;
  padding-left: 1.3rem;
  margin-bottom: 0.4rem;
  line-height: 1.7;
  font-size: 0.95rem;
}

/* 行頭の小さな● */
.access-panel__list li::before {
  content: "";
  position: absolute;
  left: 0.3rem;
  top: 0.7em;
  width: 0.35rem;
  height: 0.35rem;
  border-radius: 50%;
  background: var(--c-primary);
}

.access-panel__note {
  margin-top: 0.8rem;
  font-size: 0.85rem;
  color: #8f8f8f;
}

/* スマホ調整 */
@media (max-width: 768px) {
  .access-block {
    padding: 2.5rem 1rem 3rem;
  }

  .access-panels {
    padding: 1.4rem 1.2rem 1.6rem;
    border-radius: 1.1rem;
  }

  .access-tabs {
    gap: 0.5rem;
  }

  .access-tab {
    flex: 1 1 100%;
    font-size: 0.85rem;
    padding: 0.55rem 0.8rem;
  }
}


/* -------------------footer------------------- */
/* フッター全体 */

.footer {
  position: relative; /* 疑似要素を適切に配置するために relative を設定 */
  padding: 40px 20px;
  background: url(../images/footerbg.png);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* .footer::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.footer::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  z-index: 0; 
} */

/* フッター内のテキストを前面に配置 */
.footerinner {
  position: relative;
  z-index: 2; /* コンテンツを最前面に */
  color: #7A5A2F;
}

/* フッター内のテキストの視認性を確保 */
.footer-content {
  position: relative;
  z-index: 3; /* テキストを最前面に */
  color: #7A5A2F; /* 適宜調整 */
}

/* フッター上部（ロゴ・住所・予約） */
.footer-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 1100px;
  margin: 0 auto;
  border-bottom: 1px solid #ddd;
  padding-bottom: 20px;
}

.footer-logo img {
  width: 300px;
  margin: 0 auto;
}

/* フッターの情報エリア */
.footer-info {
  text-align: left;
  font-size: 14px;
  color: #7A5A2F;
}

/* 各項目のアイコン */
.footer-info p {
  position: relative;
  padding-left: 25px;
  margin: 5px 0;
}

/* 住所アイコン */
.footer-info p:nth-child(1)::before {
  content: "\f3c5"; /* FontAwesomeのマップピンアイコン */
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

/* アクセス方法アイコン */
.footer-info p:nth-child(2)::before {
	content: "\f095";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

/* モノレールアイコン */
.footer-info p:nth-child(3)::before {
  content: "\f238"; /* FontAwesomeの電車アイコン */
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

/* 電話番号アイコン */
.footer-info p:nth-child(4)::before {
  content: "\f095"; /* FontAwesomeの電話アイコン */
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  color: #fff;
}


/* 診療時間 表全体 */
.footer-schedule {
  text-align: center;
  padding: 20px 10px;
  margin: 0 auto;
  color: #7a5a2f;
}

/* 見出し */
.footer-schedule h3 {
  font-size: 1.2rem;
  font-weight: 700;
  color: #7a5a2f;
  margin-bottom: 12px;
}

/* 表 */
.schedule-table {
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 4px 16px rgb(0 0 0 / 10%);
}

/* ヘッダー */
.schedule-table th {
  background: linear-gradient(135deg, #e9d8c5, #c8a88b);
  color: #fff;
  padding: 12px;
  font-weight: 600;
  font-size: 14px;
  border-right: 1px solid rgba(255,255,255,0.2);
}

.schedule-table th:last-child {
  border-right: none;
}

/* 行 */
.schedule-table td {
  padding: 12px 8px;
  font-size: 14px;
  color: #7A5A2F;
  border-bottom: 1px solid #eee;
  border-right: 1px solid #f5f1ed;
}

.schedule-table td:last-child {
  border-right: none;
}

/* 土曜 */
.schedule-table .sat {
  color: #b48866;
  font-weight: bold;
}

/* 休診（木・日） */
.schedule-table .closed {
  color: #ccc;
  background: #faf6f2;
  font-weight: bold;
}

/* 最終行のボーダー消し */
.schedule-table tr:last-child td {
  border-bottom: none;
}

/* 注釈 */
.footer-schedule .note {
  font-size: 12px;
  line-height: 1.6;
  margin-top: 6px;
  color: #7A5A2F;
}
/* ----------------------------------------------------
スマホ用（〜767px）
---------------------------------------------------- */

@media (max-width: 768px) {
  .footer-top {
    display: block;
  }
  .footer-schedule {
      margin: 15px 0;
      padding: 0;
  }

  .schedule-table th, .schedule-table td {
      font-size: 12px;
      padding: 6px;
  }
  .footer-reservation {
    text-align: center;
}
.web-reserve {
  display: inline-block;
}
}

/* ナビゲーションメニュー */
.footer-nav {
  text-align: center;
  margin: 20px 0;
}

.footer-nav ul {
  list-style: none;
  padding: 0;
}

.footer-nav ul li {
  display: inline-block;
  margin: 0 10px;
}

.footer-nav ul li a {
  text-decoration: none;
  font-size: 16px;
}

/* 診療内容のリンク */
.footer-links {
	display: flex;
	justify-content: center;
	max-width: 1100px;
	margin: 20px auto;
}

.footer-section {
  width: 30%;
}

.footer-section p {
  font-size: 18px;
  margin-bottom: 10px;
  border-bottom: 1px solid #7A5A2F;
  padding-bottom: 5px;
}

.footer-section ul {
  list-style: none;
  padding: 0;
}

.footer-section ul li {
  margin-bottom: 8px;
}

.footer-section ul li a {
  text-decoration: none;
  font-size: 14px;
}

/* フッターのバナー */
.footer-banners {
  text-align: center;
  margin: 20px 0;
}

.footer-banners a {
  display: inline-block;
  margin: 0 10px;
}

.footer-banners img {
  width: 250px;
  border-radius: 5px;
  transition: transform 0.3s ease-in-out;
}

.footer-banners img:hover {
  transform: scale(1.05);
}

/* フッター下部（著作権） */
.footer-bottom {
  text-align: center;
  font-size: 14px;
  color: #555;
  border-top: 1px solid #ddd;
  padding-top: 15px;
}
@media (max-width: 768px) {
  .footer-links {
    flex-direction: column;
  }
  .footer-section {
    width: 100%;
}
}

/* 中絶FAQページ */
/* =========================
   FAQ レイアウト共通
========================= */
.faq-layout {
  padding: 60px 0;
}

.faq-layout__inner {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	gap: 3%
}

.faq-header {
	margin-bottom: 32px;
	width: 70%;
}

.faq-header__title {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.4;
  margin: 12px 0 8px;
}

.faq-header__lead {
  font-size: 14px;
  line-height: 1.8;
  color: #555;
}

/* 2カラム */
.faq-layout__body {
	width: 30%;
	margin-top: 4%;
}

.faq-main {
  flex: 1 1 auto;
  min-width: 0;
}

.faq-sidebar {
/* 	flex: 0 0 40%; */
    background: #fff6f8;
    padding: 20px 15px;
    border: solid 1px #f1bfca;
    border-radius: 25px;
}
p.side_ttl {
    font-size: 1.5rem;
    font-family: "Noto Serif JP", serif;
    margin-bottom: 5px;
    font-weight: 600;
}
@media (max-width: 768px) {
.faq-layout__inner {
	flex-direction: column;
}
	.faq-header,.faq-layout__body {
		width:100%;
		padding: 10px;
	}
	p.side_ttl {
		font-size: 1rem;
		font-weight: 700;
}
}
/* =============================
   サイドバー検索ブロック（wp-block-search）
============================= */

/* 外枠 */
.faq-sidebar .wp-block-search {
	padding: 16px 18px;
	background: #f3dae0;
	border-radius: 10px;
	box-shadow: 0 2px 8px rgba(0,0,0,0.04);
	margin-bottom: 30px;
}

/* ラベル */
.faq-sidebar .wp-block-search__label {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 10px;
  display: block;
  letter-spacing: 0.05em;
}

/* 入力＋ボタンのラッパー */
.faq-sidebar .wp-block-search__inside-wrapper {
  display: flex;
  align-items: stretch;
  gap: 8px;
}

/* 入力欄 */
.faq-sidebar .wp-block-search__input {
  flex: 1 1 auto;
  padding: 10px 14px;
  font-size: 13px;
  border: 1px solid #ddd;
  border-radius: 999px;
  background: #fff;
  transition: 0.25s ease;
}

.faq-sidebar .wp-block-search__input:focus {
  border-color: #c94b68;
  box-shadow: 0 0 0 3px rgba(201,75,104,0.15);
  outline: none;
}

/* ボタン */
.faq-sidebar .wp-block-search__button {
  flex: 0 0 auto;
  padding: 0 16px;
  border-radius: 999px;
  background: #c94b68;
  border: none;
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  display: flex;
  align-items: center;
  cursor: pointer;
  transition: 0.2s ease;
  height: 38px;
}

.faq-sidebar .wp-block-search__button:hover {
  background: #b4415c;
  box-shadow: 0 2px 6px rgba(0,0,0,0.12);
}

.faq-sidebar .wp-block-search__button:active {
  transform: translateY(1px);
  box-shadow: none;
}
.widget-title {
    font-size: 1.3rem;
    color: #c94b68;
    padding: 10px 0 5px;
}
/* SPは縦並び */
@media (max-width: 768px) {
  .faq-sidebar .wp-block-search__inside-wrapper {
    flex-direction: column;
  }

  .faq-sidebar .wp-block-search__button {
    width: 100%;
    justify-content: center;
  }
}

/* =========================
   FAQ カード（一覧）
========================= */
.faq-list {
  display: grid;
  gap: 20px;
}

.faq-card {
  background: #fff;
  border-radius: 12px;
  padding: 18px 20px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.04);
  transition: transform .2s ease, box-shadow .2s ease;
}

.faq-card__link {
  display: flex;
  gap: 14px;
  text-decoration: none;
  color: inherit;
}

.faq-card__label {
  flex: 0 0 auto;
  font-weight: 700;
  font-size: 18px;
  color: #c94b68; /* くすみピンク系などに調整OK */
  margin-top: 4px;
}

.faq-card__content {
  flex: 1 1 auto;
  min-width: 0;
}
.faq-card__content {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.faq-card__more {
  margin-top: auto; /* これで一番下に押し込む */
  align-self: flex-end; /* 右端に寄せる */
  display: inline-block;
}

.faq-card__title {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 4px;
}

.faq-card__cats {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 4px 0 8px;
  padding: 0;
  list-style: none;
}

.faq-card__cat {
	font-size: 0.9rem;
  padding: 3px 8px;
  border-radius: 999px;
  background: #f6f6f8;
  color: #666;
}

.faq-card__excerpt {
  font-size: 13px;
  line-height: 1.7;
  color: #555;
  margin-bottom: 6px;
}

.faq-card__more {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  font-weight: 600;
  color: #c94b68;
}

.faq-card__more::after {
  content: '▶';
  font-size: 10px;
}

.faq-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.08);
}
.lead_box.w1200 {
    padding: 0 0 65px;
}
/* =========================
   ページネーション
========================= */
.faq-pagination {
  margin-top: 32px;
  text-align: center;
}

.faq-main__empty {
  font-size: 14px;
  color: #666;
}

/* =========================
   single FAQ
========================= */
.faq-single-head {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 10px;
}

.faq-single-head__label {
	flex: 0 0 auto;
	font-weight: 700;
	font-size: 2.5rem;
	color: #c94b68;
	margin-top: 4px;
}

.faq-single-cats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0;
  margin: 6px 0 0;
  list-style: none;
}

.faq-single-cats__item a {
  display: inline-block;
  font-size: 11px;
  padding: 4px 10px;
  border-radius: 999px;
  background: #f6f6f8;
  color: #666;
  text-decoration: none;
}

.faq-single {
  background: #fff;
  border-radius: 12px;
  padding: 24px 24px 28px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.04);
}

.faq-single__answer-label {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 12px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.faq-single__answer-label::before {
  content: 'A';
  display: inline-flex;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  background: #c94b68;
  color: #fff;
}

.faq-single__content {
  font-size: 14px;
  line-height: 1.9;
}

.faq-single__content p {
  margin-bottom: 1.3em;
}

.faq-single__note {
  margin-top: 24px;
  padding: 16px 18px;
  border-radius: 10px;
  background: #fff6f6;
}

.faq-single__note-text {
  font-size: 12px;
  line-height: 1.8;
  color: #666;
}

.faq-single__back {
  margin-top: 24px;
  text-align: right;
}

.faq-single__back-link {
  font-size: 13px;
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* =========================
   SP レイアウト
========================= */
@media (max-width: 768px) {
  .faq-layout {
    padding: 40px 0;
  }

  .faq-layout__body {
    flex-direction: column;
  }

  .faq-sidebar {
    flex-basis: auto;
  }

  .faq-header__title {
    font-size: 22px;
  }

  .faq-card {
    padding: 16px;
  }

  .faq-single {
    padding: 18px 16px 22px;
  }
}
