@charset "UTF-8";

/* =======================================================
基本設定
======================================================= */
@font-face {
  font-family: "Zen Maru Gothic";
  font-weight: 400;
  src: url("../fonts/ZenMaruGothic/ZenMaruGothic-Regular.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: "Zen Maru Gothic";
  font-weight: 500;
  src: url("../fonts/ZenMaruGothic/ZenMaruGothic-Medium.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: "Zen Maru Gothic";
  font-weight: 700;
  src: url("../fonts/ZenMaruGothic/ZenMaruGothic-Bold.woff") format("woff");
  font-display: swap;
}
html {
  font-size: min(calc(16 / 1104 * 100vw), 16px);
}
* {
  padding: 0;
  margin: 0;
}
*,
*::before,
*::after {
  box-sizing: border-box;
  font-style: normal;
  word-wrap: break-word;
  overflow-wrap: anywhere;
  overflow-wrap: break-word;
  outline: none;
  box-shadow: none;
  line-break: strict;
  -webkit-tap-highlight-color: rgb(0 0 0 / 0%);
}
*,
*:focus,
a:focus {
  outline: none;
}
body,
.ly-head,
.ly-main,
.ly-foot {
  min-width: 64rem;
}
body {
  font-family: "Zen Maru Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.0625rem;
  line-height: 1.6;
  color: #222;
  letter-spacing: 0.04em;
  background: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
}
article,
aside,
figcaption,
figure,
picture,
footer,
main,
header,
nav,
section {
  display: block;
}
table {
  border-spacing: 0;
  border-collapse: separate;
}
ul,
ol {
  list-style: none;
}
p,
li,
dt,
dd,
th,
td {
  -ms-line-break: strict;
  line-break: strict;
  overflow-wrap: anywhere;
}
a {
  color: inherit;
  text-decoration: none;
}
img {
  width: 100%;
  height: auto;
  vertical-align: middle;
  image-rendering: optimize-contrast;
}
picture {
  line-height: 0;
}
input,
button,
select,
textarea {
  font-size: 1rem;
  color: #222;
  cursor: pointer;
  background-color: transparent;
  border: none;
  border-radius: 0;
  outline: none;
  appearance: none;
}
input:-webkit-autofill {
  box-shadow: 0 0 0 62.5rem #fff inset;
}
input[type="checkbox"] {
  display: none;
}
input[type="radio"] {
  display: none;
}
button,
textarea {
  font-family: inherit;
  font-size: 100%;
}
details {
  display: block;
}
summary {
  cursor: pointer;
}
/* PC SP */
.pc {
  display: initial;
}
.sp {
  display: none;
}
@media only screen and (device-width >= 64.0625rem) {
  /* PCのみホバー効果 */
  a,
  .hp-hover {
    transition: all 0.3s ease;
  }
  label:hover {
    cursor: pointer;
  }
}
@media screen and (width <= 750px) {
  html {
    font-size: calc(16 / 750 * 100vw);
  }
  body,
  .ly-head,
  .ly-main,
  .ly-foot {
    width: 100%;
    min-width: 46.875rem;
    max-width: 46.875rem;
  }
  body {
    font-size: 1.75rem;
    line-height: 1.5;
  }
  .sp {
    display: initial;
  }
  .pc {
    display: none;
  }
}

/* =============================
共通レイアウト
============================== */
/* 全体のWrapper */
.ly-allwrapper {
  max-width: 125rem;
  margin: 0 auto;
  overflow: hidden;
}
/* inner */
.ly-head-inner,
.ly-foot-inner,
.ly-cont,
.ly-cont-inner {
  position: relative;
  width: 64rem;
  height: 100%;
  margin-right: auto;
  margin-left: auto;
}
/* 2カラム */
.ly-cont--col {
  display: flex;
  flex-wrap: wrap;
  gap: 2.75rem;
  justify-content: space-between;
}
.ly-cont-main {
  width: 43.75rem;
}
.ly-cont-side {
  width: 17.5rem;
}
/* bl_media */
.bl-media-list {
  display: grid;
  gap: 3.5rem;
}
.bl-media {
  display: flex;
  gap: 0 2rem;
}
.bl-media-img-wrapper {
  width: 29.5rem;
}
.el-media-ttl {
  margin-bottom: 1.5rem;
  font-size: 1.625rem;
}
.bl-media-body {
  width: 32rem;
}
.el-media-txt:not(:first-of-type) {
  margin-top: 1.5rem;
}
/* bl_card */
.bl-card-unit {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
}
.bl-card {
  position: relative;
  width: 20rem;
}
.bl-card-link {
  display: block;
  width: 100%;
  height: 100%;
  padding: 1.5rem;
}
.el-card-ttl {
  margin-bottom: 1rem;
  font-size: 1.375rem;
  text-align: center;
}
@media screen and (width >= 751px) {
  .bl-media.--reverse {
    flex-direction: row-reverse;
  }
}
@media screen and (width <= 750px) {
  /* inner */
  .ly-cont,
  .ly-cont-inner {
    width: 43.125rem;
  }
  /* 2カラム */
  .ly-cont--col {
    gap: 5rem;
  }
  .ly-cont-main,
  .ly-cont-side {
    width: 100%;
  }
  /* bl_media */
  .bl-media-img-wrapper {
    margin-bottom: 2rem;
  }
  .el-media-ttl {
    margin-bottom: 1.5rem;
    font-size: 2rem;
  }
  /* bl_card */
  .bl-card-unit{
    gap: 3rem;
  }
  .bl-card {
    width: 100%;
  }
  .el-card-ttl {
    font-size: 2rem;
  }
}

/* =============================
下層MV - パンくず
============================== */
/* MV */
.bl-lower-mv {
  margin: 2rem 2.5rem 0;
  display: flex;
  align-items: center;
  height: 16.25rem;
  padding: 0 2rem;
  border-radius: 0.625rem;
  background: url(../images/common/lower-mv-bg.jpg) top center / cover no-repeat;
  position: relative;
}
.bl-lower-mv::before {
  content: "";
  position: absolute;
  background: #f2f8f8;
  width: 125rem;
  height: calc(100% + 5.5rem);
  top: -2rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.el-lower-mv-ttl {
  width: 64rem;
  padding-top: 3.75rem;
  margin: 0 auto;
  font-size: 1.25rem;
  letter-spacing: 0.075rem;
  color: #fff;
  position: relative;
}
.el-lower-mv-ttl::before {
  content: "";
  position: absolute;
  width: 100%;
  width: 15.875rem;
  height: 2.75rem;
  top: 0;
  left: 0;
}
/* パンくず */
.bl-breadcrumbs {
  padding-bottom: 13.625rem;
  position: relative;
}
.bl-breadcrumbs-inner {
  display: flex;
  width: 64rem;
  margin: 1.5rem auto 0;
  overflow: hidden;
  white-space: nowrap;
}
.bl-breadcrumbs-inner > li {
  font-size: 0.8125rem;
}
.bl-breadcrumbs-inner > li:first-child {
  display: flex;
  align-items: center;
}
.bl-breadcrumbs-inner > li:last-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.bl-breadcrumbs-inner > li:first-of-type ~ li::before {
  margin: 0 0.4375rem;
  content: ">";
}
.bl-breadcrumbs-inner .home {
  display: flex;
  align-items: center;
  width: 1rem;
}
@media screen and (width <= 750px) {
  /* MV */
  .bl-lower-mv {
    margin: 2rem 1.875rem 0;
    padding: 0 1.875rem;
    background: url(../images/common/lower-mv-bg-sp.jpg) top center / cover no-repeat;
  }
  .el-lower-mv-ttl {
    width: 43.125rem;
    font-size: 1.875rem;
  }
  .bl-breadcrumbs {
    background: #f2f8f8;
  }
  /* パンくず */
  .bl-breadcrumbs-inner {
    width: 43.125rem;
    margin-top: 2rem;
    /* z-index: 5; */
  }
  .bl-breadcrumbs-inner > li {
    font-size: 1.375rem;
  }
  .bl-breadcrumbs-inner > li:first-of-type ~ li::before {
    margin: 0 0.625rem;
  }
  .bl-breadcrumbs-inner .home {
    width: 1.75rem;
  }
}

/* =============================
共通パーツ
============================== */
/* 各sectionメイン見出し */
.el-main-ttl {
  line-height: 1.5;
  font-size: 2rem;
  letter-spacing: 0.12rem;
  margin-bottom: 1.5rem;
  position: relative;
}
.el-main-ttl.--underline {
  text-align: center;
  padding-bottom: 2rem;
}
.el-main-ttl.--underline::before {
  content: "";
  position: absolute;
  background: url(../images/common/ttl-underline.svg) top center / contain no-repeat;
  width: 18.625rem;
  height: 2rem;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
}
/* bl_bullet-list */
.bl-bullet-list > li {
  position: relative;
  padding-left: 1em;
}
.bl-bullet-list > li::before {
  content: "";
  position: absolute;
  width: 0.5rem;
  height: 0.5rem;
  background: #197474;
  border-radius: 0.5rem;
  top: 50%;
  left: 0.75rem;
  transform: translateY(-50%);
}
.bl-bullet-list.bl-bullet-list--square > li {
  padding-left: calc(1em + 0.5rem);
}
.bl-bullet-list.bl-bullet-list--square > li::before {
  content: "■";
}
/* bl_num-list */
.bl-num-list {
  counter-reset: num;
}
.bl-num-list > li {
  position: relative;
  padding-left: 1.2em;
}
.bl-num-list > li::before {
  position: absolute;
  top: 0;
  left: 0;
  content: counter(num) ".";
  counter-increment: num;
}
.bl-num-list.bl-num-list--circle > li:first-of-type::before {
  content: "①";
}
.bl-num-list.bl-num-list--circle > li:nth-of-type(2)::before {
  content: "②";
}
.bl-num-list.bl-num-list--circle > li:nth-of-type(3)::before {
  content: "③";
}
.bl-num-list.bl-num-list--circle > li:nth-of-type(4)::before {
  content: "④";
}
.bl-num-list.bl-num-list--circle > li:nth-of-type(5)::before {
  content: "⑤";
}
.bl-num-list.bl-num-list--brackets {
  counter-reset: cnt;
}
.bl-num-list.bl-num-list--brackets > li {
  padding-left: 2em;
  counter-increment: cnt;
}
.bl-num-list.bl-num-list--brackets > li::before {
  content: "(" counter(cnt) ") ";
}

/* el_btn */
.bl-btn-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2rem;
}
.el-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  background: #f57b45;
  border-radius: 3.125rem;
  color: #fff;
  position: relative;
  transition: all 0.3s ease;
  z-index: 5;
}
.el-btn:hover {
  background: #b7420f;
}
.el-btn.--green {
  background: #197474;
}
.el-btn.--green:hover {
  background: #125252;
}
.el-btn.--more {
  font-size: 1.125rem;
  width: 20rem;
  height: 3.125rem;
  margin: 3.5rem auto 0;
}
.el-btn.--more::after {
  content: "";
  position: absolute;
  background: url(../images/common/btn-arrow.svg) top center / contain no-repeat;
  width: 0.75rem;
  height: 0.75rem;
  top: 50%;
  right: 1rem;
  transform: translateY(-50%);
}
.el-btn.--reservation {
  margin-top: 3.75rem;
}
.el-btn.--reservation > span {
  color: #f57b45;
  font-size: 0.875rem;
  letter-spacing: 0.035rem;
  display: flex;
  justify-content: center;
  align-items: center;
  background: url(../images/common/btn-bubble.svg) top center / contain no-repeat;
  width: 8.125rem;
  height: 2.0625rem;
  padding-bottom: 0.4rem;
  position: absolute;
  top: -1.3rem;
  left: 50%;
  transform: translateX(-50%);
}
.el-btn.--reservation::before {
  content: "";
  position: absolute;
  width: 2.5rem;
  height: 2.5rem;
  background: url(../images/common/icon-calender.svg) top center / contain no-repeat;
  top: 50%;
  left: 1.125rem;
  transform: translateY(-50%);
}
/* el_label */
.el-label {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 0.125rem;
  color: #fff;
  background: #000;
}
/* ※ */
.el-att {
  position: relative;
  display: flex;
  font-size: 0.875rem;
}
.el-att::before {
  flex: 0 1 auto;
  content: "※";
}
.el-att.center {
  justify-content: center;
}
.el-att01,
.el-att02,
.el-att03 {
  padding-left: 2.5em;
}
.el-att01::before {
  content: "※1";
}
.el-att02::before {
  content: "※2";
}
.el-att03::before {
  content: "※3";
}
span.el-att {
  display: block;
}
.el-link {
  color: #00f;
  text-decoration: underline;
}
.el-txt.--center {
  text-align: center;
}
.el-txt + .el-txt{
  margin-top: 1.4em;
}
@media screen and (width <= 750px) {
  /* bl_bullet-list */
  .bl-bullet-list > li {
    padding-left: 2em;
  }
  .bl-bullet-list > li::before {
    width: 1rem;
    height: 1rem;
    left: 1.875rem;
  }
  /* e;-btn */
  .el-btn.--more {
    font-size: 1.875rem;
    width: 39.375rem;
    height: 5.5rem;
    margin: 5.5rem auto 0;
  }
  .el-btn.--more::after {
    width: 1.5rem;
    height: 1.5rem;
    right: 1.5rem;
  }
  .el-btn.--reservation {
    margin-top: 5.5rem;
  }
  .el-btn.--reservation > span {
    font-size: 1.625rem;
    letter-spacing: 0.065rem;
    width: 17.25rem;
    height: 3.75rem;
    top: -2.5rem;
  }
  .el-btn.--reservation::before {
    width: 4rem;
    height: 4rem;
    left: 2rem;
  }
  /* 各sectionメイン見出し */
  .el-main-ttl {
    font-size: 2.625rem;
    letter-spacing: 0.1575rem;
    margin-bottom: 2rem;
  }
  .el-main-ttl.--underline {
    text-align: center;
    padding-bottom: 2.75remrem;
  }
  .el-main-ttl.--underline::before {
    background: url(../images/common/ttl-underline.svg) top center / contain no-repeat;
    width: 24.375rem;
    height: 2.75rem;
  }
  /* ※ */
  .el-att {
    font-size: 1.375rem;
  }
}
/* =============================
装飾
============================== */
.--lower-top,
.--green-top01,
.--green-top02,
.--green-top03,
.--white-top01,
.--white-top02{
  position: relative;
}
.--green-top01,
.--green-top02,
.--green-top03{
	background: #197474;
}
.--white-top01,
.--white-top02{
	background: #F5F8F5;
}
.--lower-top::before,
.--green-top01::before,
.--green-top02::before,
.--green-top03::before,
.--white-top01::before,
.--white-top02::before{
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
.--lower-top{
  margin-top: -13.625rem;
  background: #fff;
  padding-top: 3.5rem;
}
.--lower-top::before {
  background: url(../images/common/lower-top.svg) top center / cover no-repeat #f2f8f8;
  width: 125rem;
  height: 14.625rem;
  top: 0;
}
.--green-top01{
  padding-top: 12.5rem;
  margin-top: -8rem;
}
.--green-top01::before{
	background: url(../images/common/green-top01.svg) top center / cover no-repeat;
	width: 125rem;
	height: 6.25rem;
	top: calc(-6.25rem + 2px);
}
.--green-top02{
	padding: 1.25rem 0 9.75rem;
}
.--green-top02::before{
	background: url(../images/common/green-top02.svg) top center / cover no-repeat;
	width: 125rem;
	height: 10.125rem;
	top: calc(-10.125rem + 2px);
}
.--green-top03::before{
	background: url(../images/common/green-top03.svg) top center / cover no-repeat;
	width: 125rem;
	height: 14.625rem;
	top: calc(-14.625rem + 2px);
}
.--white-top01 {
  padding-top: 0.5rem;
}
.--white-top01::before{
	background: url(../images/common/white-top01.svg) top center / cover no-repeat;
	width: 125rem;
	height: 10.125rem;
	top: calc(-10.125rem + 2px);
}
.--white-top02{
	padding: 0 0 10.375rem;
}
.--white-top02::before{
	background: url(../images/common/white-top02.svg) top center / cover no-repeat;
	width: 125rem;
	height: 13.375rem;
	top: calc(-13.3rem + 2px);
}
@media screen and (width <= 750px) {
  .--lower-top::before,
  .--green-top01::before,
  .--green-top02::before,
  .--green-top03::before,
  .--white-top01::before,
  .--white-top02::before{
    width: calc(100% + 2px);
  }
  .--lower-top{
    margin-top: -13.2rem;
    padding-top: 5rem;
  }
  .--lower-top::before {
    background: url(../images/common/lower-top-sp.svg) top center / cover no-repeat #f2f8f8;
    height: 14.625rem;
  }
  .--green-top01{
    padding-top: 4.5rem;
		margin-top: 0;
	}
  .--green-top01::before{
		content: none;
	}
  .--green-top02{
    padding-top: 5rem;
	}
  .--green-top02::before{
		background: url(../images/common/green-top02-sp.svg) top center / cover no-repeat;
		height: 13.25rem;
		top: calc(-13.25rem + 2px);
	}
  .--green-top03::before{
		background: url(../images/common/green-top03-sp.svg) top center / cover no-repeat;
		height: 13.375rem;
		top: calc(-10rem + 2px);
	}
  .--white-top01 {
    padding-top: 4rem;
	}
  .--white-top01::before{
		background: url(../images/common/white-top01-sp.svg) top center / cover no-repeat;
		height: 13.25rem;
		top: calc(-13.25rem + 2px);
	}
	.--white-top02::before{
		background: url(../images/common/white-top02-sp.svg) top center / cover no-repeat;
		width: 100%;
		height: 13.375rem;
		top: calc(-13.3rem + 2px);
	}
}
/* =============================
ヘルプタグ
============================== */
/* ユニット */
.hp-unit {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
/* 明朝体 */
.hp-mincho {
  font-family: noto-serif-jp, "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-weight: bold;
}
/* bold */
.hp-bold {
  font-weight: bold !important;
}
/* italic */
.hp-italic {
  transform: skewX(-10deg);
}
.hp-uppercase {
  text-transform: uppercase;
}
/* 打ち消し線 */
.hp-strikethrough {
  padding: 0.1875rem 0 0 0.5rem;
  letter-spacing: 0;
  background-image: linear-gradient(#222, #222);
  background-repeat: repeat-x;
  background-position: 0 50%;
  background-size: 100% 0.0625rem;
}
/* opacity1 */
.hp-opacity1 {
  opacity: 1 !important;
}
/* 電話リンク */
.hp-tel {
  pointer-events: none;
}
/* アクセントカラー */
.hp-color{
  font-weight: bold;
}
.hp-color.--orange {
  color: #ffa44a;
}
.hp-color.--d-orange{
  color: #FA5710;
}
.hp-scroll-y {
  overflow-y: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
/* スクロールバー非表示（Chrome・Safari） */
.hp-scroll-y::-webkit-scrollbar {
  display: none;
}
@media screen and (width <= 750px) {
  /* ユニット */
  .hp-unit {
    display: block;
  }
  /* 電話リンク */
  .hp-tel {
    pointer-events: auto;
  }
}

/* =============================
header
============================== */
.ly-main {
  padding-top: 8.75rem;
}
.ly-head {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 110;
  width: 100%;
  background: #f2f8f8;
}
.bl-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}
/* ロゴ */
.bl-head-logo {
  width: 14.25rem;
}
.bl-head-logo > a {
  display: block;
}
.bl-head-logo img {
  vertical-align: top;
}
/* ヘッダー右側エリア */
.bl-head-rightarea {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
/* ボタンエリア */
.bl-head-btnlist {
  display: flex;
  gap: 1.5rem;
  align-items: center;
  justify-content: flex-end;
}
.bl-head-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 12.5rem;
  height: 3rem;
  font-size: 1.125rem;
  font-weight: bold;
  color: #fff;
  background: #ccc;
}

/* ナビ */
.bl-gnav {
  z-index: 100;
  width: 100%;
  background: #fff;
  margin-top: 1.5rem;
  border-top: 2px solid #338484;
  border-bottom: 2px solid #338484;
}
.bl-gnav-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5.875rem;
  width: 64rem;
  margin: 0 auto;
}
.bl-gnav-inner > li > a,
.bl-gnav-inner > li > span {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
}
.bl-gnav-inner > li > span {
  cursor: pointer;
}

/* スマホ用非表示 */
.bl-burger {
  display: none;
}
@media screen and (width >= 751px) {
  .ly-main {
    display: flex;
    flex-direction: column;
    padding-top: min(calc(166 / 1024 * 100vw), 166px);
  }
  .ly-head {
    padding: 1.5rem 0 0;
  }
  .bl-head {
    width: min(calc(1024 / 1024 * 100vw), 1024px);
  }
  /* ロゴ */
  .bl-head-logo {
    width: 28.25rem;
  }
  /* ボタンエリア */
  .bl-head .el-btn {
    width: 13.75rem;
    height: 3.125rem;
    padding-left: 2.25rem;
    margin: 0;
  }
  .bl-head .el-btn::before {
    content: "";
    position: absolute;
    background: url(../images/common/icon-clinic.svg) top center / contain no-repeat;
    width: 2.5rem;
    height: 2.5rem;
    top: 50%;
    left: 1.125rem;
    transform: translateY(-50%);
  }
  .bl-head .el-btn.--reservation {
    width: 15.5rem;
	padding-left: 1.5rem;
  }
	.bl-head .el-btn.--reservation::before {
    background: url(../images/common/icon-calender.svg) top center / contain no-repeat;
    width: 2.5rem;
    height: 2.5rem;
  }
  .bl-gnav-inner {
    width: min(calc(1024 / 1024 * 100vw), 1024px);
    padding: 0.875rem 0;
  }
  .bl-gnav-inner > li > a:hover,
  .bl-gnav-inner > li > span:hover {
    color: #197474;
  }
  .bl-gnav .--subnavi:has(.bl-subnavi-list.--js-active) > span {
    color: #197474;
  }
  .bl-gnav .--subnavi:has(.bl-subnavi-list.--js-active)::after {
    background-color: #197474;
    rotate: -180deg;
  }
  .bl-gnav .--subnavi {
    position: relative;
    display: flex;
  }
  .bl-gnav .--subnavi::before {
    content: "";
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    height: 0.875rem;
  }
  .bl-gnav .--subnavi::after {
    content: "";
    width: 1.5rem;
    aspect-ratio: 1;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    background-color: #222;
    -webkit-mask: url("../images/common/header-to-subnavi-arrow.svg") center/cover no-repeat;
    mask: url("../images/common/header-to-subnavi-arrow.svg") center/cover no-repeat;
    transition-timing-function: ease;
    transition-duration: 0.5s;
    transition-property: background-color rotate;
    will-change: background-color rotate;
  }
  .bl-gnav .bl-subnavi-list {
    padding: 0 1.5rem;
    position: absolute;
    width: max-content;
    top: calc(100% + 0.875rem);
    left: -1rem;
    background-color: #fff;
    border-radius: 0 0 0.625rem 0.625rem;
    border: 2px solid #338484;
    border-top: revert;
    display: grid;
    gap: 0.625rem;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    transition:
      max-height 0.3s ease,
      padding 0.3s ease,
      opacity 0.3s ease,
      visibility 0.3s;
  }
  .bl-gnav .bl-subnavi-list.--js-active {
    max-height: 31.25rem;
    padding-top: 0.625rem;
    padding-bottom: 1rem;
    opacity: 1;
    visibility: visible;
  }
  .bl-gnav .bl-subnavi {
    display: flex;
    gap: 0.625rem;
  }
  .bl-gnav .bl-subnavi::before {
    content: "";
    background-color: #d9e8e8;
    width: 0.5rem;
    align-self: center;
    aspect-ratio: 1;
    border-radius: calc(infinity * 1px);
  }
  .bl-gnav .bl-subnavi:hover {
    color: #197474;
  }
}
@media screen and (width <= 64rem) {
	  .ly-head-inner {
    padding: 0 1.25rem;
  }
}
@media screen and (width <= 750px) {
  .bl-gnav .bl-subnavi-list {
    display: none;
  }
  .ly-main {
    padding-top: 8.125rem;
  }
  .ly-head {
    height: 8.125rem;
    border-bottom: 0.1875rem solid #338484;
  }
  .ly-head-inner {
    z-index: 110;
    width: 100%;
  }
  /* ロゴ */
  .bl-head-logo {
    width: 34.25rem;
  }
  .bl-head-logo > a {
    display: flex;
    align-items: center;
  }
  .bl-head-right .bl-btn-list {
    display: none;
  }
  /* スマホ用非表示 */
  .bl-burger {
    background: #fff;
    border: 0.1875rem solid #338484;
    border-radius: 0.625rem;
    display: grid;
    width: 6.25rem;
    height: 6.25rem;
    transition: all 0.3s ease;
    align-items: center;
  }
  .bl-burger.is-active {
    background: #338484;
  }
  .bl-burger.is-active .bl-burger-bars::before {
    background: #fff;
    top: 50%;
    transform: translate(-50%, -50%) rotate(45deg);
  }
  .bl-burger.is-active .bl-burger-bars::after {
    background: #fff;
    top: 50%;
    transform: translate(-50%, -50%) rotate(-45deg);
  }
  .bl-burger.is-active .bl-burger-bar {
    display: none;
  }
  .bl-burger-bars {
    position: relative;
    display: block;
    width: 3.5rem;
    height: 2.875rem;
    margin: 0 auto;
    transition: all 0.3s ease;
  }
  .bl-burger-bar,
  .bl-burger-bars::before,
  .bl-burger-bars::after {
    content: "";
    position: absolute;
    left: 50%;
    width: 100%;
    height: 0.25rem;
    background: #338484;
    transition: all 0.3s ease;
    transform: translate(-50%, -50%);
  }
  .bl-burger-bars::before {
    top: 0;
  }
  .bl-burger-bars::after {
    top: 100%;
  }
  .bl-burger-bar {
    top: 50%;
    transform: translate(-50%, -50%);
  }
  /* ナビ */
  .bl-gnav {
    width: 100%;
    /* height: 100%; */
    height: calc(100% - 8.125rem);
    background: url(../images/common/nav-bg-sp.jpg) top center / cover no-repeat;
    position: fixed;
    top: 8.125rem;
    left: 0;
    z-index: 110;
    transform: translateX(100%);
    transition: transform 0.3s ease-in-out;
    margin-top: 0;
    border: none;
    overflow-y: auto;
  }
  .bl-gnav.is-active {
    transform: translateX(0);
    transition: transform 0.3s ease-in-out;
  }
  .bl-gnav-inner {
    padding: 9.125rem 0 2.5rem;
    width: 100%;
    height: auto;
    flex-direction: column;
    justify-content: flex-start;
    gap: 2.5rem;
    overflow: scroll;
  }
  .bl-gnav-inner > li > a {
    font-size: 2rem;
  }
  /* 閉じるボタン */
  .el-gnav-btn {
    width: 15rem;
    height: 5rem;
    font-size: 1.875rem;
    background: #197474;
    border-radius: 5rem;
    font-weight: bold;
    color: #fff;
    padding: 0 0 0.0625rem 2.625rem;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
  }
  .el-gnav-btn::before {
    content: "";
    position: absolute;
    background: url(../images/common/cross02.svg) top center / contain no-repeat;
    width: 1.5rem;
    height: 1.5rem;
    top: 52%;
    transform: translateY(-50%);
    left: 2.875rem;
  }
  /* 閉じるボタン */
  .bl-gnav-btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 5rem;
    font-size: 1.875rem;
    background: #fff;
  }
  .bl-gnav-btn::before {
    position: absolute;
    top: 50%;
    left: 2rem;
    width: 1.5rem;
    height: 1.5rem;
    content: "";
    background: url(".../images/common/cross.svg") top center/contain no-repeat;
    transform: translateY(-50%);
  }
}

/* =============================
footer
============================= */
.ly-foot {
  background: #013636;
  padding-bottom: 5rem;
  position: relative;
}
.ly-foot::before {
  content: "";
  position: absolute;
  background: url(../images/common/footer-top.svg) top center / cover no-repeat;
  width: 125rem;
  height: 14.625rem;
  top: calc(-14.625rem + 2px);
  left: 50%;
  transform: translateX(-50%);
}
.ly-foot-inner {
  padding: 1rem 0 7rem;
}
.bl-foot {
  display: flex;
  flex-direction: column;
}
/* ロゴ */
.bl-foot-logo {
  display: block;
  width: min(calc(452 / 1024 * 100vw), 452px);
  margin-bottom: 1.5rem;
}
.bl-foot-cont {
  display: flex;
  justify-content: space-between;
}
.bl-foot-cont .el-txt {
  color: #fff;
	font-size: 0.875rem;
}
/* ナビ */
.bl-foot-gnav {
  width: 30.25rem;
  display: flex;
  justify-content: space-between;
}
.bl-foot .bl-gnav-inner {
  width: fit-content;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 1rem 2.5rem;
  color: #fff;
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 400;
  letter-spacing: 0.1em;
}
.bl-foot .bl-gnav-inner li a {
  position: relative;
  font-weight: 400;
}
.bl-foot .bl-gnav-inner li a:hover{
	color: inherit;
}
.bl-snav-inner {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: -0.5rem;
}
.bl-nav-child::before {
  content: "ー";
}
/* コピーライト */
.bl-foot-copyright {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  width: 100%;
  text-align: center;
  background: #013636;
}
.bl-foot-copyright small {
  font-family: Verdana; /* Android */
  font-size: 0.75rem;
  color: #fff;
}
/* ページトップボタン */
.bl-pagetop {
  position: relative;
  width: 64rem;
  height: 0;
  margin: 0 auto;
  display: flex;
  justify-content: flex-end;
  bottom: 5.5rem;
}
.bl-pagetop span {
  z-index: 900;
  width: 4.125rem;
  height: 4.125rem;
}
.bl-pagetop img {
  cursor: pointer;
}
.bl-pagetop .fade img {
  transition: all 0.5s ease-in-out;
}
/* float btn */
.bl-btn-wrapper.--reservation {
  position: relative;
  width: 85rem;
  height: 0;
  margin: 0 auto;
  display: flex;
  justify-content: flex-end;
}
.bl-btn-wrapper.--reservation .el-btn.--reservation {
  display: block;
  width: 8.25rem;
  height: 8.25rem;
  background: #f57b45;
  border-radius: 8.25rem;
  box-shadow: 0px 3px 6px #00000029;
  border: 3px solid #fff;
  color: #fff;
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: 0.05rem;
  padding-top: 2.75rem;
  margin: 0;
  position: relative;
  z-index: 900;
}
.bl-btn-wrapper.--reservation .el-btn.--reservation::before {
  content: "";
  position: absolute;
  background: url(../images/common/icon-calender.svg) top center / contain no-repeat;
  width: 4rem;
  height: 4rem;
  top: 0.25rem;
  left: 50%;
  transform: translateX(-50%);
}
.bl-btn-wrapper.--reservation .el-btn.--reservation > span {
  color: inherit;
  font-size: 1.25rem;
  letter-spacing: inherit;
  display: inline;
  background: none;
  width: unset;
  height: unset;
  padding-bottom: 0;
  position: unset;
  transform: unset;
}
.bl-btn-wrapper.--reservation .el-btn.--reservation:hover {
  background: #b7420f;
}
@media screen and (width <= 87.5rem) {
  /* ページトップボタン */
  .bl-pagetop {
    width: 100%;
    right: 12rem;
  }
  .bl-btn-wrapper.--reservation {
    width: 100%;
  }
  .bl-btn-wrapper.--reservation .el-btn {
    right: 1.875rem;
  }
}
@media screen and (width <= 750px) {
  /* footer */
  .ly-foot {
    padding: 0.75rem 1.875rem 12.5rem;
  }
  .ly-foot::before {
    background: url(../images/common/footer-top-sp.svg) top center / cover no-repeat;
    width: calc(100% + 2px);
    height: 13.375rem;
    top: calc(-13.375rem + 2px);
  }
  .ly-foot-inner {
    width: 100%;
    height: auto;
	min-height: 68.75rem;
    padding: 0 0 8.5rem;
  }
  /* ロゴ */
  .bl-foot-logo {
    width: 37.25rem;
    margin: 0 0 3.5rem 0;
  }
  .bl-foot-cont {
    flex-direction: column;
    gap: 6.5rem;
  }
  .bl-foot-cont .el-txt {
    font-size: 1.75rem;
  }
  /* ナビ */
  .bl-foot-gnav {
    order: 1;
    width: 100%;
    flex-wrap: wrap;
  }
  .bl-foot .bl-gnav-inner {
    padding-top: 0;
    gap: 2rem;
    width: 21.5rem;
  }
  .bl-foot .bl-gnav-inner:last-of-type {
    margin: -5.25rem 0 0 auto;
    position: absolute;
    top: 50rem;
    right: 0;
  }
  .bl-foot .bl-gnav-inner li,
  .bl-foot .bl-gnav-inner li > a {
    font-size: 1.75rem;
  }
  .bl-foot .bl-gnav-inner .hp-bold {
    font-size: 1.875rem !important;
  }
  .bl-snav-inner {
    gap: 2rem;
    margin-top: 0;
  }
  /* コピーライト */
  .bl-foot-copyright small {
    font-size: 1rem;
  }
  .bl-btn-wrapper.--reservation {
    display: none;
  }
  /* ページトップボタン */
  .bl-pagetop {
    z-index: 90;
    width: 43.125rem;
    right: 0;
    bottom: 8rem;
  }
  .bl-pagetop span {
    right: 0;
    width: 5.625rem;
    height: 5.625rem;
  }
}

/* =============================
CTA
============================= */
.bl-cta {
  padding: 2.5rem 0 3.75rem;
  background: url(".../images/common/cta-bg.jpg") top center/cover no-repeat;
}
.el-cta-ttl {
  margin-bottom: 1.5rem;
  font-size: 1.875rem;
}

/* =============================
新着
============================== */
.bl-vert-posts:not(:first-of-type) {
  margin-top: 1.5rem;
}
.bl-vert-posts > a {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding: 1.5rem;
  border-radius: 0.625rem;
  background: #fff;
}
.bl-vert-posts-header {
  display: flex;
  flex: 0 1 14.125rem;
  gap: 1rem;
  align-items: center;
  margin-right: 1rem;
}
.el-date {
  font-size: 0.875rem;
  letter-spacing: 0.0525rem;
  color: #525252;
}
.el-cat-label {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 6.25rem;
  min-height: 1.75rem;
  padding: 0 1rem 0.0625rem;
  border-radius: 0.25rem;
  font-size: 1rem;
  line-height: 1.5;
  color: #fff;
  background: #6ab7b7;
}
.el-cat-label.all {
  background: #6ab7b7;
}
.el-cat-label.headquarters {
  background: #d05147;
}
.el-cat-label.hachioji {
  background: #00aa89;
}
.el-cat-label.machida {
  background: #ffb100;
}
.el-vert-posts-ttl {
  font-size: 1.0625rem;
  flex: 1;
  overflow: hidden;
  display: -webkit-box;
  font-weight: normal;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}
.bl-post-header{
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.el-post-ttl{
    background: #197474;
	color: #fff;
	font-size: 1.5rem;
	padding: 0.5rem 1.5rem;
	border-radius: 0.625rem;
	margin-bottom: 2rem;
}
@media screen and (width <= 750px) {
  .bl-vert-posts:not(:first-of-type) {
    margin-top: 2rem;
  }
  .bl-vert-posts > a {
    gap: 1.5rem;
    padding: 1.5rem 1.875rem 1.875rem;
  }
  .bl-vert-posts:not(:first-of-type) > a {
    padding-top: 1.5rem;
  }
  .bl-vert-posts-header {
    flex: 100%;
    margin-right: 0;
  }
  .el-date {
    font-size: 1.375rem;
    letter-spacing: 0.0825rem;
  }
  .el-cat-label {
    min-width: 8rem;
    max-width: 30rem;
    min-height: 2.625rem;
    padding: 0 1rem;
    font-size: 1.375rem;
  }
  .el-vert-posts-ttl {
    font-size: 1.75rem;
    -webkit-line-clamp: 2;
  }
  	.el-post-ttl{
		font-size: 2rem;
		padding: 0.5rem 1.5rem;
		border-radius: 0.625rem;
		margin-bottom: 2rem;
	}
}

/* =======================================================
column
======================================================= */
.bl-column-unit {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
}
.bl-column-item {
  width: 20rem;
  border: 0.1875rem solid #197474;
  border-radius: 0.625rem;
}
.bl-column-item > a {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.bl-column-img-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 13.125rem;
  overflow: hidden;
  border-radius: 0.475rem 0.475rem 0 0;
}
.bl-column-body {
  background: #fff;
  padding: 1rem 1rem 1.5rem;
  border-radius: 0 0 0.625rem 0.625rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.bl-column-item .el-cat-label {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: auto;
  max-width: fit-content;
  width: fit-content;
  min-height: 1.5rem;
  padding: 0.125rem 1rem;
  border-radius: 1.5rem;
  font-size: 0.875rem;
  line-height: 1.5;
  color: #fff;
  background: #ccc;
  margin-bottom: 1rem;
}
.el-cat-label.stress-mental {
  background: #3a88e3;
}
.el-cat-label.sleep {
  background: #ffb100;
}
.el-cat-label.disease {
  background: #e2616f;
}
.el-column-ttl {
  font-size: 1.0625rem;
  font-weight: normal;
  line-height: 1.56;
  margin-bottom: 0.5rem;
  overflow: hidden;
  display: -webkit-box;
  font-weight: normal;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
.bl-column-body .el-date {
  margin-top: auto;
}
@media screen and (max-width: 750px) {
  .bl-column-unit {
    gap: 3.5rem;
  }
  .bl-column-item {
    width: 100%;
    border-radius: 0.625rem;
  }
  .bl-column-item > a {
    display: flex;
    flex-direction: column;
    height: 100%;
  }
  .bl-column-img-wrapper {
    height: 25rem;
  }
  .bl-column-body {
    padding: 2.5rem 1.875rem;
    border-radius: 0 0 0.625rem 0.625rem;
    display: flex;
    flex-direction: column;
    flex: 1;
  }
  .bl-column-item .el-cat-label {
    min-height: 2.5rem;
    padding: 0.125rem 1rem 0.1875rem;
    font-size: 1.625rem;
    margin-bottom: 2.125rem;
  }
  .el-column-ttl {
    font-size: 1.75rem;
    line-height: 1.56;
    margin-bottom: 2.5rem;
  }
}

/* =============================
aside
============================== */
.bl-aside {
  padding-bottom: 1.5625rem;
  border: 0.1875rem solid #197474;
  background: #fff;
  border-radius: 0.625rem;
}
.el-aside-ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 3.125rem;
  font-size: 1.375rem;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.055rem;
  background: #197474;
}
.bl-aside-post-list {
  padding: 0 1rem;
}
.bl-aside-post-list > li {
  border-bottom: 0.0625rem solid #d9e8e8;
}
.bl-aside-post-list > li:last-of-type {
  border-bottom: 0;
}
.bl-aside-post-list > li > a {
  padding: 1rem;
  display: block;
  overflow: hidden;
  font-size: 1rem;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.bl-aside-post-list > li:last-of-type > a {
  padding-bottom: 0;
}
.bl-aside .el-btn{
    margin-top: 1.5rem;
    width: 13.125rem;
}
.bl-aside .el-txt{
  margin-top: 1.5rem;
}
@media screen and (width <= 750px) {
  /* aside */
  .bl-aside {
    padding-bottom: 2.5rem;
  }
  .el-aside-ttl {
    height: 4.75rem;
    margin-bottom: 0.9375rem;
    font-size: 1.75rem;
  }
  .bl-aside-post-list {
    margin-bottom: 2.1875rem;
  }
  .bl-aside-post-list > li > a {
    padding: 1.5rem 1.875rem;
    font-size: 1.625rem;
  }
  .bl-aside .el-btn{
	    margin-top: 1.5rem;
	    width: 21rem;
	    height: 5rem;
	}
}

/* =============================
ページナビ
============================== */
/* wp-pagenavi */
.wp-pagenavi {
  display: flex;
  gap: 1rem;
  align-items: center;
  justify-content: center;
  margin-top: 2.5rem;
}
.wp-pagenavi > * {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 1.875rem;
  height: 2rem;
  padding: 0 0.3125rem 0.0625rem;
  font-size: 1.0625rem;
  font-weight: bold;
  color: #7BB7B7;
  letter-spacing: 0;
  border-radius: 0.25rem;
}
.wp-pagenavi a {
  background: #D9E8E8;
}
.wp-pagenavi .current {
  background: #197474;
}
.wp-pagenavi .extend {
  font-size: 1rem;
  color: #545454;
}

/* 詳細ページの前へ 次へ */
.bl-pager {
  position: relative;
  height: 2.625rem;
    margin-top: 2rem;
}
.bl-pager-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.bl-pager-link > a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 13.125rem;
  height: 3.125rem;
  padding-bottom: 0.0625rem;
  font-size: 1.125rem;
  font-weight: bold;
  color: #fff;
  border-radius: 3.125rem;
  background: #197474;
}
.bl-pager-prev > a::before,
.bl-pager-next > a::after {
    content: "";
    position: absolute;
    background: url(../images/common/btn-arrow.svg) top center / contain no-repeat;
    width: 0.75rem;
    height: 0.75rem;
    top: 50%;
    right: 1rem;
    transform: translateY(-50%);
}
.bl-pager-prev > a::before {
  top: 40%;
  right: inherit;
  left:1.5rem;
  transform: translateX(-50%) rotate(-180deg);
}
.bl-pager-link > a:hover{
  background: #125252;
}
/* カテゴリ */
.bl-cat {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	width: 100%;
	min-height: 3.5rem;
	padding: 0.5rem;
	margin-bottom: 1.5rem;
	background: #fff;
	border-radius: 0.625rem;
    border: 0.125rem solid #D9E8E8;
}
.el-cat-ttl {
	flex: 0 1 8.75rem;
	font-size: 1.125rem;
  font-weight: bold;
  text-align: center;
}
.bl-cat-list {
	display: flex;
	flex: 1;
	flex-wrap: wrap;
	gap: 0.5rem 1.5rem;
}
@media screen and (width <= 750px) {
  /* wp-pagenavi */
  .wp-pagenavi {
    margin-top: 3.125rem;
  }
  .wp-pagenavi > * {
    min-width: 2.5rem;
    height: 3rem;
    padding-bottom: 0.125rem;
    font-size: 1.75rem;
  }
  .wp-pagenavi .extend {
    display: none;
  }

  /* 前へ 次へ */
  .bl-pager {
    height: 3.75rem;
    margin-top: 3.75rem;
  }
  .bl-pager-link > a {
    width: 17rem;
    height: 4rem;
    font-size: 1.625rem;
  }
  .bl-pager-prev > a{
    padding-left: 1.5rem;
  }
  .bl-pager-next > a{
    padding-right: 1.5rem;
  }
  .bl-pager-prev > a::before,
  .bl-pager-next > a::after {
  width: 1.5rem;
  height: 1.5rem;
  right: 1.5rem;
  }
  .bl-pager-prev > a::before {
    top: 32%;
    left: 2rem;
  }
  /* カテゴリ */
  .bl-cat {
		gap: 1rem;
		padding: 1.5rem;
		margin-bottom: 2.5rem;
  }
  .el-cat-ttl {
    flex: 100%;
    padding-top: 0;
    font-size: 1.875rem;
	text-align: center;
  }
  .bl-cat-list {
    flex: 100%;
    gap: 1.25rem 1rem;
  }
}

/* =======================================================
popup reservation
======================================================= */
.bl-popup {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(34, 34, 34, 0.75);
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
  z-index: 1000;
}
.bl-popup.is-active {
  opacity: 1;
  visibility: visible;
}
.bl-popup .ly-cont-inner {
  background: #fff;
  border-radius: 0.625rem;
  width: 53rem;
  height: auto;
  padding: 3rem;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.bl-popup .el-close {
  width: 3.5rem;
  height: 3.5rem;
  background: #197474;
  border-radius: 0 0.625rem 0 0.625rem;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 0;
  right: 0;
}
.bl-popup .el-close > img {
  width: 1.125rem;
}
.bl-popup .el-main-ttl {
  text-align: center;
  font-size: 1.5rem;
  margin-bottom: 0.5rem;
}
.bl-popup .el-txt {
  margin-bottom: 3rem;
}
.bl-popup .el-clinic-sttl {
  font-size: 1.25rem;
  margin-bottom: 1rem;
}
.bl-popup .el-clinic-sttl:not(:first-of-type) {
  margin-top: 2rem;
}
.bl-popup .bl-btn-list {
  width: fit-content;
}
.bl-popup .el-btn {
  width: 22.5rem;
  height: 4.75rem;
  border-radius: 39.375rem;
  font-size: 1.25rem;
  flex-direction: column;
  align-items: flex-start;
  padding-left: 6rem;
}
.bl-popup .el-btn > span {
  font-size: 0.9375rem;
  letter-spacing: 0.0375rem;
  display: block;
}
.bl-popup .el-btn.--line {
  background: #06c755;
}
.bl-popup .el-btn.--web::before {
  content: "";
  position: absolute;
  background: url(../images/common/icon-calender.svg) top center / contain no-repeat;
  width: 3.5rem;
  height: 3.5rem;
  top: 50%;
  left: 1.25rem;
  transform: translateY(-50%);
}
.bl-popup .el-btn.--line::before {
  content: "";
  position: absolute;
  background: url(../images/common/icon-line.svg) top center / contain no-repeat;
  width: 3.875rem;
  height: 3.875rem;
  top: 50%;
  left: 1.125rem;
  transform: translateY(-50%);
}
.bl-popup .el-btn.--line::after {
  content: "";
  position: absolute;
  background: rgba(0, 0, 0, 0.1);
  width: 100%;
  height: 100%;
  border-radius: 39.375rem;
  top: 0;
  left: 0;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.bl-popup .el-btn.--line:hover::after {
  opacity: 1;
}
.bl-popup .el-btn.--close {
  width: 8.375rem;
  height: 2.875rem;
  background: #197474;
  padding: 0 0 0 1.5rem;
  align-items: center;
  padding-bottom: 0.0625rem;
  margin: 2.5rem auto 0;
  position: relative;
}
.bl-popup .el-btn.--close::before {
  content: "";
  position: absolute;
  background: url(../images/common/cross02.svg) top center / contain no-repeat;
  width: 0.8125rem;
  height: 0.8125rem;
  top: 51%;
  left: 1.5rem;
  transform: translateY(-50%);
}
/* フッタースマホ用 */
.bl-btn-wrapper-sp {
  display: none;
}
@media screen and (max-width: 750px) {
  .bl-popup .ly-cont-inner {
    width: 43.125rem;
    padding: 8.125rem 1.875rem 4rem;
  }
  .bl-popup .el-close {
    width: 4.75rem;
    height: 4.75rem;
  }
  .bl-popup .el-close > img {
    width: 1.625rem;
  }
  .bl-popup .el-main-ttl {
    font-size: 2.625rem;
    margin-bottom: 1rem;
  }
  .bl-popup .el-txt {
    margin-bottom: 4.5rem;
  }
  .bl-popup .el-clinic-sttl {
    font-size: 2rem;
    margin-bottom: 1.5rem;
  }
  .bl-popup .el-clinic-sttl:not(:first-of-type) {
    margin-top: 3rem;
  }
  .bl-popup .el-btn {
    width: 39.375rem;
    height: 7rem;
    font-size: 1.875rem;
    padding-left: 10.25rem;
  }
  .bl-popup .el-btn > span {
    font-size: 1.5625rem;
    letter-spacing: 0.09375rem;
  }
  .bl-popup .el-btn.--web::before {
    width: 5rem;
    height: 5rem;
    left: 2rem;
  }
  .bl-popup .el-btn.--line::before {
    width: 5rem;
    height: 5rem;
    left: 2rem;
  }
  .bl-popup .el-btn.--close {
    width: 12.125rem;
    height: 4.275rem;
    padding: 0 0 0 2.625rem;
    margin: 5rem auto 0;
  }
  .bl-popup .el-btn.--close::before {
    width: 1.25rem;
    height: 1.25rem;
    top: 52%;
    left: 2.25rem;
  }
  /* フッタースマホ用 */
  .bl-btn-wrapper-sp {
    display: flex;
    position: fixed;
    bottom: 0;
    z-index: 100;
  }
  .bl-btn-wrapper-sp .el-btn {
    width: 23.4375rem;
    height: 6.875rem;
    flex-direction: column;
    border-radius: 0;
    font-size: 1.625rem;
    font-weight: normal;
    line-height: 1.5;
  }
  .bl-btn-wrapper-sp .el-btn.--line {
    display: flex;
    background: #06c755;
  }
  .bl-btn-wrapper-sp .el-btn::before {
    content: "";
    position: absolute;
    width: 6.125rem;
    height: 6.125rem;
    background: inherit;
    border-radius: 6.125rem;
    top: -2.375rem;
    left: 1rem;
  }
  .bl-btn-wrapper-sp .el-btn.--web::after {
    content: "";
    position: absolute;
    width: 5rem;
    height: 5rem;
    background: url(../images/common/icon-calender.svg) top center / contain no-repeat;
    top: -2rem;
    left: 1.5rem;
  }
  .bl-btn-wrapper-sp .el-btn.--line::after {
    content: "";
    position: absolute;
    width: 5rem;
    height: 5rem;
    background: url(../images/common/icon-line.svg) top center / contain no-repeat;
    top: -1.85rem;
    left: 1.55rem;
  }
  .bl-btn-wrapper-sp .el-btn > span {
    font-size: 1.875rem;
  }
  .bl-popup.--sp .bl-btn-list {
    width: auto;
  }
  .bl-popup.--sp .el-btn {
    margin: 0;
    width: 18.5rem;
    min-height: 5rem;
    line-height: 1.4;
    padding: 0.5rem 3rem;
    align-items: center;
  }
  .bl-popup.--sp .el-btn.--close {
    width: 12.125rem;
    height: 4.275rem;
    padding: 0 0 0 2.625rem;
    margin: 5rem auto 0;
  }
}
/*=============================
faq
=============================*/
.bl-faq-list{
  display: grid;
  gap: 2rem;
}
.bl-q {
  display: block;
  padding: 1rem 5rem;
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.055rem;
  background: #197474;
  border-radius: 0.625rem 0.625rem 0 0;
  color: #fff;
  position: relative;
}
.bl-q::before {
  content: "Q";
  position: absolute;
  font-size: 2rem;
  font-weight: 500;
  color: #d9e8e8;
  top: 46.5%;
  left: 2rem;
  transform: translateY(-50%);
}
.bl-q::after {
  content: "";
  position: absolute;
  background: url(../images/common/faq-arrow.svg) top center / contain no-repeat;
  width: 1.5rem;
  height: 0.75rem;
  top: 50%;
  right: 1.5rem;
  transform: translateY(-50%) rotate(180deg);
}
.bl-faq-item[open] .bl-q::after {
  transform: translateY(-50%);
}
.bl-a {
  overflow: hidden;
  position: relative;
  background: #fff;
}
.bl-a > * {
  padding: 2rem 5.25rem;
  border: 3px solid #197474;
  border-radius: 0px 0px 0.625rem 0.625rem;
  position: relative;
}
.bl-a > *:first-of-type::before {
  content: "A";
  position: absolute;
  font-size: 2rem;
  font-weight: 500;
  color: #197474;
  line-height: 1;
  top: 2.75rem;
  left: 2rem;
  transform: translateY(-50%);
}
/* アコーディオン */
.bl-faq details::details-content {
  content-visibility: unset;
  display: block grid;
}
@media (prefers-reduced-motion: no-preference) {
  .bl-faq details::details-content {
    transition-duration: 0.5s;
    transition-property: grid-template-rows;
  }
}
.bl-faq details:not([open])::details-content {
  grid-template-rows: 0fr;
}
.bl-faq details[open]::details-content {
  grid-template-rows: 1fr;
}
@media screen and (max-width: 750px) {
  .bl-q {
    padding: 1.5rem 5rem 1.5rem 4.375rem;
    font-size: 1.75rem;
    letter-spacing: 0.07rem;
  }
  .bl-q::before {
    font-size: 2.5rem;
    top: 47%;
    left: 1.5rem;
  }
  .bl-q::after {
    width: 1.25rem;
    height: 0.8rem;
  }
  .bl-a > * {
    padding: 2.5rem 1.5rem 3.5rem 4.25rem;
  }
  .bl-a > *:first-of-type::before {
    font-size: 2.5rem;
    top: 3.75rem;
    left: 1.5rem;
  }
}

/* =======================================================
disease
======================================================= */
.bl-disease-list {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  margin-top: 3rem;
}
.bl-disease-item {
  width: 14.5rem;
  height: 4.125rem;
}
.bl-disease-item > a {
  width: 100%;
  height: 100%;
  background: #fff;
  box-shadow: 0px 3px 6px #00000029;
  border: 0.2875rem solid #197474;
  border-radius: 0.625rem;
  display: flex;
  align-items: center;
  padding: 0 1rem 0 5rem;
  color: #197474;
  font-size: 0.9375rem;
  font-weight: bold;
  position: relative;
}
.bl-disease-item > a::before {
  content: "";
  position: absolute;
  background: url(../images/common/icon-depression.svg) top center / contain no-repeat;
  width: 3.75rem;
  height: 3.75rem;
  top: 50%;
  left: 1.125rem;
  transform: translateY(-50%);
}
.bl-disease-item.--bipolar-disorder > a::before {
  background: url(../images/common/icon-bipolar-disorder.svg) top center / contain no-repeat;
}
.bl-disease-item.--adjustment-disorder > a::before {
  background: url(../images/common/icon-adjustment-disorder.svg) top center / contain no-repeat;
}
.bl-disease-item.--adjustment-disorder > a::before {
  background: url(../images/common/icon-adjustment-disorder.svg) top center / contain no-repeat;
}
.bl-disease-item.--autonomic-nervous-disorder > a::before {
  background: url(../images/common/icon-autonomic-nervous-disorder.svg) top center / contain no-repeat;
}
.bl-disease-item.--obsessive-compulsive-disorder > a::before {
  background: url(../images/common/icon-obsessive-compulsive-disorder.svg) top center / contain no-repeat;
}
.bl-disease-item.--social-anxiety-disorder > a::before {
  background: url(../images/common/icon-social-anxiety-disorder.svg) top center / contain no-repeat;
}
.bl-disease-item.--agoraphobia > a::before {
  background: url(../images/common/icon-agoraphobia.svg) top center / contain no-repeat;
}
.bl-disease-item.--panic-disorder > a::before {
  background: url(../images/common/icon-panic-disorder.svg) top center / contain no-repeat;
}
.bl-disease-item.--sleep-disorders > a::before {
  background: url(../images/common/icon-sleep-disorders.svg) top center / contain no-repeat;
}
.bl-disease-item.--irritable-bowel-syndrome > a::before {
  background: url(../images/common/icon-irritable-bowel-syndrome.svg) top center / contain no-repeat;
}
.bl-disease-item.--pms-pmdd > a::before {
  background: url(../images/common/icon-pms-pmdd.svg) top center / contain no-repeat;
}
@media screen and (max-width: 750px) {
  .bl-disease-list {
    gap: 2.5rem;
    margin-top: 4.5rem;
  }
  .bl-disease-item {
    width: 20.25rem;
    height: 7.75rem;
  }
  .bl-disease-item > a {
    border: 0.3125rem solid #197474;
    padding: 0 0.75rem 0 7.125rem;
    font-size: 1.75rem;
  }
  .bl-disease-item > a::before {
    width: 6.375rem;
    height: 6.375rem;
    left: 0.75rem;
  }
}

/* =======================================================
doctor
======================================================= */
.bl-doctor-unit {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2.5rem 2rem;
}
.bl-doctor-item {
  width: 20rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.bl-doctor-img-wrapper {
  width: 12.5rem;
  margin: 0 auto 1.5rem;
}
.el-position {
  font-size: 0.8375rem;
  margin-bottom: 0.8rem;
}
.el-doctor-ttl {
  display: flex;
  align-items: center;
  gap: 1rem;
  letter-spacing: 0.05rem;
}
.el-doctor-ttl > span {
  font-size: 0.8375rem;
  font-weight: normal;
  letter-spacing: 0.0375rem;
}
@media screen and (max-width: 750px) {
  .bl-doctor-item {
    width: 20.625rem;
  }
  .bl-doctor-img-wrapper {
    width: 19.375rem;
    margin: 0 auto 1.5rem;
  }
  .el-position {
    font-size: 1.5rem;
  }
  .el-doctor-ttl {
    font-size: 1.875rem;
  }
  .el-doctor-ttl > span {
    font-size: 1.5rem;
  }
}

/* =======================================================
reservation
======================================================= */
.bl-reservation {
  padding: 1.375rem 0 8.875rem;
}
.bl-reservation .ly-cont-inner::before {
  content: "";
  position: absolute;
  background: url(../images/common/illust-reservation01.svg) top center / contain no-repeat;
  width: 16.5rem;
  height: 13.25rem;
  left: 0;
  bottom: -3rem;
}
.bl-reservation .ly-cont-inner::after {
  content: "";
  position: absolute;
  background: url(../images/common/illust-reservation02.svg) top center / contain no-repeat;
  width: 13.25rem;
  height: 12.25rem;
  right: 0;
  bottom: -7.75rem;
}
.bl-reservation .el-main-ttl {
  color: #fff;
}
.bl-reservation .el-txt {
  color: #fff;
  font-weight: bold;
}
@media screen and (max-width: 750px) {
  .bl-reservation {
    padding: 1.25rem 0 26.5rem;
  }
  .bl-reservation .ly-cont-inner::before {
    width: 18.375rem;
    height: 13.5rem;
    left: 4.5rem;
    bottom: -17.25rem;
  }
  .bl-reservation .ly-cont-inner::after {
    width: 13.125rem;
    height: 12.125rem;
    right: 4.5rem;
    bottom: -18.5rem;
  }
}

/* calender */
.bl-calender-table {
  width: 100%;
}
.bl-calender-thead {
  background: #197474;
}
.bl-calender-thead th {
  height: 2.625rem;
  color: #fff;
  font-weight: normal;
  text-align: center;
}
.bl-calender-thead th:first-of-type {
  width: 9rem;
}
.bl-calender-tbody tr:not(:first-of-type) th {
  border-top: 0.0625rem solid #fff;
}
.bl-calender-tbody th {
  height: 2.625rem;
  text-align: center;
  background: #7bb7b7;
  font-weight: normal;
}
.bl-calender-tbody td {
  text-align: center;
  background: #f2f8f8;
}
.bl-calender-tbody > tr:last-of-type td {
  border-top: 0.0625rem solid #f2f2f2;
}
.bl-calender-tbody > tr:last-of-type th {
  border-radius: 0 0 0 0.625rem;
}
.bl-calender-tbody > tr:last-of-type td:last-of-type {
  border-radius: 0 0 0.625rem 0;
}
@media screen and (max-width: 750px) {
  .bl-calender-thead th {
    height: 4.625rem;
  }
  .bl-calender-thead th:first-of-type {
    width: 11.875rem;
    border-radius: 0.625rem 0 0 0;
  }
  .bl-calender-thead th:last-of-type {
    border-radius: 0 0.625rem 0 0;
  }
  .bl-calender-tbody th {
    height: 4.625rem;
  }
}

/* =======================================================
flow
======================================================= */
.bl-flow-list{
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	margin: 3rem 0 0;
}
.bl-flow-item{
	width: 11.6rem;
	padding: 1.5rem 1rem;
	border-radius: 0.625rem;
	background: #fff;
	position: relative;
}
.bl-flow-item::before{
	content: '01';
	position: absolute;
	background: url(../images/common/flow-number-bg.svg) top center / contain no-repeat;
	width: 3.75rem;
	height: 3.25rem;
	font-size: 1.25rem;
	font-weight: bold;
	display: flex;
	justify-content: center;
	padding-top: 0.6rem;
	color: #fff;
	top: -1rem;
	left: 0;
}
.bl-flow-item:nth-of-type(2)::before{
	content: '02';
}
.bl-flow-item:nth-of-type(3)::before{
	content: '03';
}
.bl-flow-item:nth-of-type(4)::before{
	content: '04';
}
.bl-flow-item:nth-of-type(5)::before{
	content: '05';
}
.bl-flow-img-wrapper{
	width: 5.75rem;
	margin: 0 auto;
}
.el-flow-ttl{
	font-size: 1.125rem;
	line-height: 1.5;
	color: #197474;
	text-align: center;
	margin-bottom: 0.625rem;
}
.bl-flow-item .el-txt{
	color: #222!important;
	font-size: 0.9375rem;
}
@media screen and (max-width: 750px) {
.bl-flow-list{
		gap: 4.5rem;
		margin: 5.625rem 0 0;
	}
	.bl-flow-item{
		width: 100%;
		padding: 2.5rem 1.875rem 2.5rem 13.25rem;
		position: relative;
	}
	.bl-flow-item::before{
		width: 5.875rem;
		height: 5.125rem;
		font-size: 1.875rem;
		padding-top: 1rem;
		top: -2rem;
	}
	.bl-flow-img-wrapper{
		width: 10.25rem;
		position: absolute;
		top: 50%;
		left: 1.875rem;
		transform: translateY(-50%);
	}
	.el-flow-ttl{
		font-size: 1.875rem;
		text-align: left;
		margin-bottom: 0.5rem;
	}
	.bl-flow-item .el-txt{
		font-size: 1.75rem;
	}
}

/* =======================================================
doctor
======================================================= */
.bl-doctor-box{
	width: 100%;
	background: #fff;
	padding: 1rem 1.5rem;
	border-radius: 0.625rem;
	margin-top: 1.25rem;
}
.bl-doctor-box .el-s-ttl{
	color: #125252;
	font-weight: bold;
	margin-bottom: 0.5rem;
}
.bl-doctor-box .el-s-ttl:nth-of-type(2){
	margin-top: 1.5rem;
}
.bl-doctor-box .bl-bullet-list > li::before{
	left: 0;
	top: 0.6rem;
	transform: unset;
}
@media screen and (max-width: 750px) {
	.bl-doctor-box{
		padding: 2rem 2.5rem;
		margin-top: 2rem;
	}
	.bl-doctor-box .el-s-ttl{
		margin-bottom: 1rem;
	}
	.bl-doctor-box .el-s-ttl:nth-of-type(2){
		margin-top: 2.5rem;
	}
	.bl-doctor-box .bl-bullet-list > li{
		padding-left: 1em;
	}
	.bl-doctor-box .bl-bullet-list > li::before{
		top: 0.8rem;
	}
}