@charset "UTF-8";
/*** 共通設定 ***/
/** 変数 **/
/* カラー設定 */
/* mixin  // includeで呼び出し */
/** タグ設定 **/
html {
  color: #40594e;
  font-family: "Zen Old Mincho", serif;
  font-weight: 500;
  font-style: normal;
  letter-spacing: 0.1em;
  /*** 内部リンク　高さ修正 ***/
  scroll-padding-top: 120px;
}
@media (max-width: 767px) {
  html {
    scroll-padding-top: 100px;
  }
}

img {
  max-width: 100%;
}

/**　共通クラス設定 **/
.hidden {
  overflow: hidden;
}

.eng {
  font-family: "EB Garamond", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.gothic {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
}

.wrap {
  margin-inline: auto;
  width: min(1200px, 95%);
}
@media (max-width: 767px) {
  .wrap {
    width: 90%;
  }
}

.link_btn {
  margin-inline: auto;
  width: 320px;
  display: block;
  text-align: center;
  background-color: #40594e;
  color: #fff;
  font-size: 18px;
  font-weight: 900;
  padding: 20px;
  border-radius: 30px;
  border: 1px solid #40594e;
  box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.5);
  transition: ease all 0.25s;
}
@media (max-width: 1023px) {
  .link_btn {
    font-size: 16px;
    margin-top: 40px;
    width: 60%;
  }
}
@media (max-width: 767px) {
  .link_btn {
    font-size: 3.8vw;
    margin-top: 35px;
    width: 100%;
    padding: 15px 10px;
  }
}
.link_btn span {
  display: inline-block;
  padding-right: 20px;
  position: relative;
}
.link_btn span::after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  content: "";
  width: 6px;
  height: 12px;
  background-image: url(../img/arrow_w_left.svg);
  background-repeat: no-repeat;
  background-position: center center;
  transition: ease all 0.25s;
}
.link_btn:hover {
  background-color: #fff;
  color: #40594e;
  transition: ease all 0.25s;
}
.link_btn:hover span::after {
  background-image: url(../img/arrow_g_left.svg);
  transition: ease all 0.25s;
}

body.open-dropdown .header {
  background-color: #fff;
}
body.open-dropdown .header h1 img.noscroll {
  opacity: 0 !important;
  visibility: hidden !important;
}
body.open-dropdown .header h1 img.scroll_on {
  opacity: 1 !important;
  visibility: visible !important;
}
@media (min-width: 1023px) {
  body.open-dropdown .header .main_nav .menu .menu_item.has_children::before {
    position: absolute;
    display: block;
    bottom: 5px;
    left: 50%;
    transform: translateX(-50%) rotate(180deg);
    content: "";
    width: 8px;
    height: 10px;
    margin-inline: auto;
    background-image: url(../img/arrow_g_top.svg);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center center;
  }
}
body.open-dropdown .header .main_nav .menu .menu_item:hover > a {
  color: #40594e !important;
  opacity: 1;
}
body.non_scroll {
  height: 100%;
  overflow: hidden;
}

/** br **/
@media (max-width: 767px) {
  .br_pc {
    display: none;
  }
}

.br_tb {
  display: none;
}
@media (max-width: 1023px) {
  .br_tb {
    display: block;
  }
}

.br_sp {
  display: none;
}
@media (max-width: 767px) {
  .br_sp {
    display: block;
  }
}

/*** セクション ***/
section.sec_bg_img {
  background-repeat: no-repeat;
  background-size: cover;
}
section .wrap {
  padding: 80px 0 100px 0;
}
@media (max-width: 1023px) {
  section .wrap {
    padding: 65px 0 95px 0;
  }
}
@media (max-width: 767px) {
  section .wrap {
    padding: 50px 0 70px 0;
  }
}

/** セクションタイトル  **/
.sec_title {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 15px;
  margin-bottom: 45px;
}
@media (max-width: 1023px) {
  .sec_title {
    gap: 10px;
    margin-bottom: 30px;
  }
}
@media (max-width: 767px) {
  .sec_title {
    margin-bottom: 25px;
    text-align: center;
    line-height: 1.5;
    gap: 0;
  }
}
.sec_title strong {
  font-size: 36px;
  color: #40594e;
  text-align: center;
}
@media (max-width: 1023px) {
  .sec_title strong {
    font-size: 32px;
  }
}
@media (max-width: 767px) {
  .sec_title strong {
    font-size: 7vw;
  }
}
.sec_title span {
  color: #75887f;
  font-size: 20px;
}
@media (max-width: 1023px) {
  .sec_title span {
    font-size: 18px;
  }
}
@media (max-width: 767px) {
  .sec_title span {
    font-size: 4vw;
  }
}

/* 角丸ボックス */
.round-box {
  border-radius: 10px;
  padding: 90px;
}
@media (max-width: 1023px) {
  .round-box {
    padding: 35px 20px;
  }
}
.round-box .detail_wrap {
  margin-top: 70px;
  padding-top: 45px;
  border-top: #b3b3b3 solid 1px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
}
@media (max-width: 1023px) {
  .round-box .detail_wrap {
    margin-top: 50px;
    padding-top: 35px;
  }
}
@media (max-width: 767px) {
  .round-box .detail_wrap {
    margin-top: 30px;
    padding-top: 25px;
  }
}
.round-box .detail_wrap .detail_title {
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 30px;
}
@media (max-width: 767px) {
  .round-box .detail_wrap .detail_title {
    font-size: 4.2vw;
  }
}
.round-box .detail_wrap ul {
  padding: 0 25px;
}
@media (max-width: 767px) {
  .round-box .detail_wrap ul {
    padding: 0 10px;
  }
}
.round-box .detail_wrap ul li {
  padding-left: 0.5em;
  font-size: 16px;
  margin-bottom: 15px;
  position: relative;
}
@media (max-width: 1023px) {
  .round-box .detail_wrap ul li {
    font-size: 15px;
  }
}
@media (max-width: 767px) {
  .round-box .detail_wrap ul li {
    font-size: 3.5vw;
    padding-left: 0.75em;
  }
}
.round-box .detail_wrap ul li:last-child {
  margin-bottom: 0px;
}
.round-box .detail_wrap ul li::before {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  width: 1px;
  height: 1em;
  background: #40594e;
}
@media (max-width: 1023px) {
  .round-box .detail_wrap ul li::before {
    top: 2px;
  }
}
.round-box .detail_wrap p {
  font-size: 16px;
  line-height: 1.6;
}
@media (max-width: 1023px) {
  .round-box .detail_wrap p {
    font-size: 15px;
  }
}
@media (max-width: 767px) {
  .round-box .detail_wrap p {
    font-size: 3.8vw;
  }
}

/* ---------------------------------- */
/*** ヘッダー ***/
.header {
  position: fixed;
  width: 100%;
  margin-inline: auto;
  z-index: 100;
}
.header a {
  transition: ease color 0.25s, ease background-color 0.25s;
}
.header.change-color {
  background-color: white;
  color: #40594e;
  transition: ease color 0.25s, ease background-color 0.25s;
}
.header.change-color a {
  color: #40594e;
  transition: ease color 0.25s, ease background-color 0.25s;
}
.header.change-color {
  border-bottom: solid 1px #b3b3b3;
}
.header.change-color h1 {
  position: relative;
}
.header.change-color h1 img.noscroll {
  opacity: 0;
  visibility: hidden;
}
.header.change-color h1 img.scroll_on {
  opacity: 1;
  visibility: visible;
}
@media (min-width: 1023px) {
  .header.change-color .main_nav .menu .menu_item.has_children {
    position: relative;
  }
  .header.change-color .main_nav .menu .menu_item.has_children::before {
    position: absolute;
    display: block;
    bottom: 5px;
    left: 50%;
    transform: translateX(-50%) rotate(180deg);
    content: "";
    width: 8px;
    height: 10px;
    margin-inline: auto;
    background-image: url(../img/arrow_g_top.svg);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center center;
  }
}
.header.change-color .main_nav .menu .menu_item.has_children:hover > a {
  color: #40594e;
  opacity: 1;
}
.header.open {
  background-color: #fff;
}
.header.open h1 img.noscroll {
  opacity: 0;
  visibility: hidden;
}
.header.open h1 img.scroll_on {
  opacity: 1;
  visibility: visible;
}

.header_inner {
  display: flex;
  justify-content: flex-start;
  gap: 2%;
  align-items: center;
  margin: 0 auto;
  padding: 0 35px;
  max-width: 100%;
  position: relative;
}
@media (min-width: 1920px) {
  .header_inner {
    gap: 11%;
  }
}
@media (max-width: 1439px) {
  .header_inner {
    padding: 0 25px;
  }
}
@media (max-width: 1023px) {
  .header_inner {
    padding: 15px 20px 15px 20px;
    justify-content: space-between;
  }
}
.header_inner h1 {
  width: 230px;
  width: min(230px, 13%);
  height: 46px;
  position: relative;
  z-index: 25;
  display: flex;
  align-items: center;
}
@media (max-width: 1023px) {
  .header_inner h1 {
    width: 25%;
  }
}
@media (max-width: 767px) {
  .header_inner h1 {
    width: min(200px, 55%);
  }
}
.header_inner h1 img {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: min(230px, 100%);
}
@media (max-width: 1023px) {
  .header_inner h1 img {
    width: 100%;
  }
}
.header_inner h1 img.scroll_on {
  opacity: 0;
  visibility: hidden;
}
.header_inner h1 a {
  display: block;
}
.header_inner h1 a:hover img {
  opacity: 0.8;
}

.main_nav {
  color: #ffffff;
}
@media (max-width: 1023px) {
  .main_nav {
    opacity: 0;
    visibility: hidden;
    display: none;
    position: fixed;
    top: 100px;
    width: 100%;
    height: 95%;
    overflow-y: scroll;
    background-color: #ffffff;
    top: 78px;
    left: 0;
  }
}
.main_nav.open {
  opacity: 1;
  visibility: visible;
  display: block;
  padding: 20px;
}
.main_nav .menu {
  display: flex;
  justify-content: flex-start;
  z-index: 15;
}
@media (max-width: 1023px) {
  .main_nav .menu {
    padding-bottom: 120px;
    flex-direction: column;
    justify-content: center;
    gap: 0;
  }
}
.main_nav .menu .menu_item {
  text-align: center;
  width: -moz-fit-content;
  width: fit-content;
  padding: 30px 30px 20px 30px;
  cursor: pointer;
  position: relative;
}
@media (min-width: 1440px) {
  .main_nav .menu .menu_item {
    padding: 25px 15px;
  }
}
@media (max-width: 1439px) {
  .main_nav .menu .menu_item {
    padding: 25px 10px;
  }
}
@media (max-width: 1023px) {
  .main_nav .menu .menu_item {
    width: 100%;
    padding: 0;
  }
}
.main_nav .menu .menu_item.has_children {
  position: relative;
}
.main_nav .menu .menu_item.has_children::before {
  position: absolute;
  display: block;
  bottom: 5px;
  left: 50%;
  transform: translateX(-50%) rotate(90deg);
  content: "";
  width: 8px;
  height: 10px;
  margin-inline: auto;
  background-image: url(../img/arrow_w_left.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
}
@media (max-width: 1023px) {
  .main_nav .menu .menu_item.has_children::before {
    content: none;
  }
}
.main_nav .menu .menu_item a {
  font-size: 15px;
  text-align: center;
  position: relative;
  z-index: 20;
}
@media (min-width: 1440px) {
  .main_nav .menu .menu_item a {
    font-size: 18px;
  }
}
@media (max-width: 767px) {
  .main_nav .menu .menu_item a {
    font-size: 4.2vw;
  }
}
.main_nav .menu .menu_item a span {
  font-size: 14px;
  display: block;
  padding-top: 8px;
}
@media (max-width: 1023px) {
  .main_nav .menu .menu_item > a {
    display: flex;
    align-items: center;
    gap: 15px;
    font-size: 18px;
    color: #40594e !important;
    border-bottom: #40594e 1px solid;
    padding: 15px 10px;
  }
}
@media (max-width: 767px) {
  .main_nav .menu .menu_item > a {
    font-size: 4.5vw;
  }
}
@media (max-width: 1023px) {
  .main_nav .menu .menu_item > a::after {
    position: absolute;
    top: 50%;
    right: 15px;
    transform: translateY(-50%);
    content: "";
    width: 10px;
    height: 15px;
    background-image: url(../img/arrow_g_left.svg);
    background-size: contain;
    background-repeat: no-repeat;
    transition: ease 0.2s transform;
    z-index: 5;
  }
}
@media (max-width: 1023px) {
  .main_nav .menu .menu_item > a::after span {
    padding-top: 0;
  }
}
@media (max-width: 767px) {
  .main_nav .menu .menu_item > a::after span {
    font-size: 3.8vw;
  }
}
@media (max-width: 1023px) {
  .main_nav .menu .menu_item > a.unlock::after {
    transform: translateY(-50%) rotate(90deg);
    transition: ease 0.2s transform;
  }
}
.main_nav .menu .menu_item:hover {
  position: relative;
}
@media (min-width: 1023px) {
  .main_nav .menu .menu_item:hover::after {
    position: absolute;
    bottom: 0;
    left: 0;
    content: "";
    width: 100%;
    height: 2px;
    background-color: #40594e;
  }
  .main_nav .menu .menu_item:hover > a {
    opacity: 0.6;
    text-shadow: 1px 1px 5px rgba(255, 255, 255, 0.45) !important;
  }
  .main_nav .menu .menu_item:hover .sub_menu_wrap {
    visibility: visible;
    opacity: 1;
    background-color: #ffffff;
    height: -moz-min-content;
    height: min-content;
    color: #646464;
    z-index: 15;
    transition: ease background-color 0.25s;
  }
  .main_nav .menu .menu_item:hover .sub_menu_wrap .sub_menus li a {
    position: relative;
    z-index: 20;
  }
}
@media (max-width: 1023px) {
  .main_nav .menu .menu_item:hover > a {
    color: rgba(64, 89, 78, 0.6);
  }
}
.main_nav .sub_menu_wrap {
  height: 0;
  opacity: 0;
  position: fixed;
  left: 50%;
  top: 95px;
  transform: translateX(-50%);
  width: 100vw;
  visibility: hidden;
  transition: 0.1s;
  z-index: -1;
  padding: 60px 0;
  transition: ease background-color 0.25s;
}
@media (max-width: 1439px) {
  .main_nav .sub_menu_wrap {
    top: 92px;
    padding: 30px 0;
  }
}
@media (max-width: 1023px) {
  .main_nav .sub_menu_wrap {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    padding: 0;
    height: 0;
    width: 100%;
    z-index: 15;
  }
}
.main_nav .sub_menu_wrap.unlock {
  visibility: visible;
  height: auto;
  opacity: 1;
  padding: 15px 10px;
}
.main_nav .sub_menu_wrap.unlock .sub_menus {
  visibility: inherit;
}
.main_nav .sub_menu_wrap .sub_menus {
  display: flex;
  justify-content: center;
  gap: 5%;
  width: min(970px, 80%);
  margin-inline: auto;
}
@media (max-width: 1023px) {
  .main_nav .sub_menu_wrap .sub_menus {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 20px;
    row-gap: 15px;
    visibility: hidden;
  }
}
@media (max-width: 1023px) {
  .main_nav .sub_menu_wrap .sub_menu {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    -moz-column-gap: 35px;
         column-gap: 35px;
  }
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu {
    width: 100%;
    -moz-column-gap: 20px;
         column-gap: 20px;
  }
}
.main_nav .sub_menu_wrap .sub_menu li {
  margin-bottom: 30px;
  text-align: left;
  font-size: 18px;
  padding-left: 25px;
  position: relative;
}
@media (max-width: 1039px) {
  .main_nav .sub_menu_wrap .sub_menu li {
    margin-bottom: 20px;
  }
}
@media (max-width: 1023px) {
  .main_nav .sub_menu_wrap .sub_menu li {
    padding-left: 0;
    margin-bottom: 0;
  }
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu li {
    font-size: 3.8vw;
    width: 100%;
  }
}
.main_nav .sub_menu_wrap .sub_menu li > a:hover {
  opacity: 0.5;
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu li > a {
    color: #40594e;
  }
}
.main_nav .sub_menu_wrap .sub_menu li::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 18px;
  height: 100%;
  background-image: url(../img/sub_menu_icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
}
@media (max-width: 1023px) {
  .main_nav .sub_menu_wrap .sub_menu li::before {
    content: none;
  }
}
.main_nav .sub_menu_wrap .sub_menu_img {
  margin-top: 110px;
}
@media (max-width: 1023px) {
  .main_nav .sub_menu_wrap .sub_menu_img {
    display: none;
  }
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy {
  flex-direction: column;
  row-gap: 20px;
}
@media (max-width: 1023px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy {
    row-gap: 15px;
  }
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy {
    row-gap: 10px;
  }
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy > * {
  display: flex;
  gap: 4%;
}
@media (max-width: 1023px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy > * {
    flex-wrap: wrap;
    gap: 2%;
  }
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy > * > li {
  padding-left: 0;
  margin-bottom: 0;
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy > * > li {
    width: 100%;
  }
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy > * > li {
    margin-bottom: 10px;
  }
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy > * > li:last-child {
    margin-bottom: 0;
  }
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy > * > li::before {
  content: none;
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy > * > li > a {
  display: block;
  padding: 20px 15px;
  height: 100%;
  display: flex;
  align-items: center;
  line-height: 1.5;
}
@media (max-width: 1023px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy > * > li > a {
    padding: 15px 35px 15px 20px;
    text-align: left;
  }
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy > * > li > a::after {
  position: absolute;
  right: 15px;
  top: 50%;
  content: "";
  width: 8px;
  height: 18px;
  transform: translateY(-50%);
  background-image: url(../img/arrow_w_left.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy > * > li > a:hover {
  opacity: 1;
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy > * > li > a:hover::after {
  right: 10px;
  background-image: url(../img/arrow_g_left.svg);
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .first_hierarchy_menu > li {
  width: 48%;
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy .first_hierarchy_menu > li {
    width: 100%;
  }
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .first_hierarchy_menu > li > a {
  padding: 20px 15px;
  background-color: #40594e;
  color: #fff;
  border: #40594e solid 1px;
  border-radius: 15px;
}
@media (max-width: 1023px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy .first_hierarchy_menu > li > a {
    color: #fff;
    padding: 10px 30px 10px 20px;
  }
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy .first_hierarchy_menu > li > a {
    border-radius: 8px;
  }
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .first_hierarchy_menu > li > a:hover {
  background-color: #fff;
  color: #40594e;
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .first_hierarchy_menu > li > a:hover::after {
  right: 10px;
  background-image: url(../img/arrow_g_left.svg);
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .second_hierarchy_menu > li {
  width: 31.3333333333%;
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy .second_hierarchy_menu > li {
    width: 100%;
  }
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .second_hierarchy_menu > li > a {
  font-size: 16px;
  padding: 20px 40px 20px 15px;
  color: #fff;
  background-color: #4a7c84;
  border: #4a7c84 solid 1px;
  border-radius: 15px;
  text-align: left;
}
@media (max-width: 1023px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy .second_hierarchy_menu > li > a {
    color: #fff;
    padding: 15px 30px 15px 20px;
    text-align: left;
  }
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy .second_hierarchy_menu > li > a {
    border-radius: 8px;
    font-size: 4.2vw;
  }
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .second_hierarchy_menu > li > a:hover {
  background-color: #fff;
  color: #4a7c84;
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .second_hierarchy_menu > li > a:hover::after {
  right: 10px;
  background-image: url(../img/arrow_g_left.svg);
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .other_hierarchy_menu {
  justify-content: center;
}
@media (max-width: 1023px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy .other_hierarchy_menu {
    justify-content: flex-start;
  }
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .other_hierarchy_menu > li {
  width: 23%;
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy .other_hierarchy_menu > li {
    width: 100%;
  }
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .other_hierarchy_menu > li > a {
  display: flex;
  align-items: center;
  font-size: 14px;
  font-weight: 700;
  padding: 15px 35px 15px 15px;
  background-color: #dcf0e9;
  border: #40594e solid 1px;
  border-radius: 10px;
  color: #40594e;
}
@media (max-width: 1023px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy .other_hierarchy_menu > li > a {
    padding: 10px 30px 10px 20px;
    font-size: 12px;
  }
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy .other_hierarchy_menu > li > a {
    font-size: 4.2vw;
  }
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .other_hierarchy_menu > li > a::after {
  background-image: url(../img/arrow_g_left.svg);
  width: 5px;
  height: 10px;
  right: 10px;
}
@media (max-width: 767px) {
  .main_nav .sub_menu_wrap .sub_menu_hierarchy .other_hierarchy_menu > li > a::after {
    right: 15px;
    width: 8px;
    height: 18px;
  }
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .other_hierarchy_menu > li > a:hover {
  background-color: #40594e;
  color: #fff;
}
.main_nav .sub_menu_wrap .sub_menu_hierarchy .other_hierarchy_menu > li > a:hover::after {
  right: 10px;
  background-image: url(../img/arrow_w_left.svg);
}

/* 予約ボタン */
.reservation {
  display: flex;
  flex-direction: column;
  gap: 30px;
  position: fixed;
  right: 35px;
  top: 20px;
  width: min(230px, 15vw);
  z-index: 250;
}
@media (max-width: 1439px) {
  .reservation {
    gap: 35px;
    right: 25px;
  }
}
@media (max-width: 1120px) {
  .reservation {
    width: 12vw;
  }
}
@media (max-width: 1023px) {
  .reservation {
    top: auto;
    flex-direction: row;
    justify-content: center;
    bottom: 0dvh;
    left: 0;
    padding: 20px;
    width: 100%;
    background-color: rgba(255, 255, 255, 0.5);
  }
}
@media (max-width: 767px) {
  .reservation {
    gap: 10px;
  }
}
.reservation.open {
  opacity: 1;
  visibility: visible;
}
.reservation a {
  display: block;
  padding: 20px 10px;
  border-radius: 5px;
  height: 100%;
  font-size: 18px;
  width: 100%;
  text-align: center;
  transition: ease opacity 0.2s;
}
@media (max-width: 767px) {
  .reservation a {
    border-radius: 5px;
  }
}
.reservation a:hover {
  opacity: 0.8;
  transition: ease opacity 0.2s;
}
.reservation .web_reservation {
  width: 100%;
}
@media (max-width: 1023px) {
  .reservation .web_reservation {
    width: 48%;
  }
}
.reservation .web_reservation a {
  color: #ffffff;
  background-color: #40594e;
}
@media (max-width: 1439px) {
  .reservation .web_reservation a {
    font-size: 14px;
    padding: 15px 10px;
  }
}
@media (max-width: 767px) {
  .reservation .web_reservation a {
    font-size: 4.2vw;
  }
}
.reservation .web_reservation a img {
  display: inline-block;
  padding-right: 5px;
  height: 20px;
}
@media (max-width: 1439px) {
  .reservation .web_reservation a img {
    height: 13px;
  }
}
.reservation .phone_reservation {
  width: 100%;
  text-align: center;
}
@media (max-width: 1023px) {
  .reservation .phone_reservation {
    position: relative;
    top: auto;
    left: auto;
    width: 48%;
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  .reservation .phone_reservation {
    width: 48%;
  }
}
.reservation .phone_reservation img {
  display: inline-block;
  transition: ease all 0.25s;
  width: 20px;
  position: relative;
}
@media (min-width: 1441px) {
  .reservation .phone_reservation img {
    width: 19px;
  }
}
@media (max-width: 1439px) {
  .reservation .phone_reservation img {
    width: 12px;
  }
}
@media (max-width: 1023px) {
  .reservation .phone_reservation img {
    width: 20px;
  }
}
@media (max-width: 767px) {
  .reservation .phone_reservation img {
    width: 15px;
  }
}
.reservation .phone_reservation a {
  color: #40594e;
  background-color: #dcf0e9;
  padding: 15px 5px;
  font-size: 18px;
  gap: 5px;
}
@media (min-width: 1440px) {
  .reservation .phone_reservation a {
    font-size: 22px;
  }
}
@media (max-width: 1439px) {
  .reservation .phone_reservation a {
    font-size: 14px;
  }
}
@media (max-width: 1023px) {
  .reservation .phone_reservation a {
    font-size: 20px;
  }
}
@media (max-width: 767px) {
  .reservation .phone_reservation a {
    font-size: 4.2vw;
  }
}

.hamburger {
  display: none;
  color: #fff;
  width: min(0.5714285714vw + 45.8571428571px, 55px);
  height: min(0.5714285714vw + 45.8571428571px, 55px);
  cursor: pointer;
  inline-size: min(0.5714285714vw + 45.8571428571px, 55px);
  position: relative;
  z-index: 1;
}
@media (max-width: 1023px) {
  .hamburger {
    display: block;
  }
}
.hamburger.open span {
  background-color: #40594e !important;
}
.hamburger.open span:first-child {
  top: 45%;
  transform: rotate(135deg);
}
.hamburger.open span:last-child {
  top: 45%;
  transform: rotate(-135deg);
}
.hamburger span {
  background-color: #fff;
  block-size: 2px;
  content: "";
  inline-size: 67%;
  left: 50%;
  position: absolute;
  transition: all 0.6s ease;
  translate: -50% 0;
}
.hamburger span:first-child {
  top: 40%;
}
.hamburger span:last-child {
  bottom: 40%;
}

/* ---------------------------------- */
/*** ファーストビュー ***/
.fv_bg {
  background-image: url(../img/fv.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  position: relative;
  padding: 0 35px;
  z-index: 1;
}
@media (max-width: 767px) {
  .fv_bg {
    background-image: url(../img/fv_sp.png);
  }
}
.fv_bg::after {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  width: 100%;
  height: 100%;
  background-color: rgba(79, 87, 97, 0.2);
}

.fv_inner {
  position: relative;
  padding: 15.9vw 0 12.3vw 0;
  z-index: 50;
}
@media (max-width: 1439px) {
  .fv_inner {
    padding: 18vw 0 22vw 0;
  }
}
@media (max-width: 1023px) {
  .fv_inner {
    padding: 20vw 0 28vw 0;
  }
}
@media (max-width: 767px) {
  .fv_inner {
    padding: 44.5vw 0 55.2vw 0;
  }
}

.fv_catchcopy {
  text-align: center;
}
.fv_catchcopy .fv_title {
  width: min(680px, 40vw);
  margin-inline: auto;
}
@media (max-width: 1439px) {
  .fv_catchcopy .fv_title {
    width: 50vw;
  }
}
@media (max-width: 767px) {
  .fv_catchcopy .fv_title {
    width: 74vw;
  }
}
.fv_catchcopy .fv_text {
  font-size: 34px;
  color: #ffffff;
  font-weight: 900;
  line-height: 1.75;
  margin-top: 50px;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.45);
}
@media (min-width: 1440px) {
  .fv_catchcopy .fv_text {
    font-size: 28px;
  }
}
@media (max-width: 1023px) {
  .fv_catchcopy .fv_text {
    font-size: 22px;
    margin-top: 35px;
  }
}
@media (max-width: 767px) {
  .fv_catchcopy .fv_text {
    font-size: 4.2vw;
    margin-top: 30px;
  }
}

/* ---------------------------------- */
/*** メインコンテンツ ***/
/** お知らせ **/
.news_wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 4%;
}
@media (max-width: 1023px) {
  .news_wrap {
    flex-direction: column;
  }
}
.news_wrap .news_item {
  border-bottom: solid #b3b3b3 1px;
  width: 48%;
}
@media (max-width: 1023px) {
  .news_wrap .news_item {
    width: 100%;
  }
}
.news_wrap .news_item .news_item_inner {
  display: block;
  padding: 25px 20px;
}
@media (max-width: 767px) {
  .news_wrap .news_item .news_item_inner {
    padding: 15px 10px;
  }
}
.news_wrap .news_item .news_item_inner strong {
  display: block;
  margin-bottom: 20px;
}
@media (max-width: 767px) {
  .news_wrap .news_item .news_item_inner strong {
    margin-bottom: 15px;
  }
}
.news_wrap .news_item .news_item_inner .normal_title {
  font-size: 20px;
  margin-bottom: 15px;
  font-weight: 700;
}
@media (max-width: 1023px) {
  .news_wrap .news_item .news_item_inner .normal_title {
    font-size: 18px;
  }
}
@media (max-width: 767px) {
  .news_wrap .news_item .news_item_inner .normal_title {
    font-size: 3.8vw;
    margin-bottom: 10px;
  }
}
.news_wrap .news_item .news_item_inner .big_title {
  font-size: 24px;
}
@media (max-width: 1023px) {
  .news_wrap .news_item .news_item_inner .big_title {
    font-size: 22px;
  }
}
@media (max-width: 767px) {
  .news_wrap .news_item .news_item_inner .big_title {
    font-size: 4.6vw;
  }
}
.news_wrap .news_item .news_item_inner .biggest_title {
  font-size: 28px;
}
@media (max-width: 1023px) {
  .news_wrap .news_item .news_item_inner .biggest_title {
    font-size: 26px;
  }
}
@media (max-width: 767px) {
  .news_wrap .news_item .news_item_inner .biggest_title {
    font-size: 5vw;
  }
}
.news_wrap .news_item .news_date {
  font-size: 16px;
  display: block;
  color: #919b8d;
  margin-bottom: 15px;
}
@media (max-width: 1023px) {
  .news_wrap .news_item .news_date {
    font-size: 14px;
    margin-bottom: 10px;
  }
}
@media (max-width: 767px) {
  .news_wrap .news_item .news_date {
    font-size: 3.4vw;
    margin-bottom: 5px;
  }
}
.news_wrap .news_item .news_title {
  font-size: 22px;
  letter-spacing: 0.2em;
  margin-bottom: 20px;
}
@media (max-width: 1023px) {
  .news_wrap .news_item .news_title {
    font-size: 20px;
    margin-bottom: 10px;
  }
}
@media (max-width: 767px) {
  .news_wrap .news_item .news_title {
    font-size: 4.8vw;
  }
}
.news_wrap .news_item h3 {
  font-size: 28px;
}
@media (max-width: 1023px) {
  .news_wrap .news_item h3 {
    font-size: 20px;
    margin-bottom: 10px;
  }
}
@media (max-width: 767px) {
  .news_wrap .news_item h3 {
    font-size: 5.4vw;
  }
}
.news_wrap .news_item p {
  color: #666666;
  line-height: 1.6;
  font-size: 18px;
  letter-spacing: 0;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
}
@media (max-width: 1023px) {
  .news_wrap .news_item p {
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  .news_wrap .news_item p {
    font-size: 3.8vw;
  }
}

/** 医師の予定 **/
.schedule_wrap {
  display: flex;
  flex-direction: column;
}
.schedule_wrap .schedule_item {
  border-bottom: solid #b3b3b3 1px;
}
.schedule_wrap .schedule_item .schedule_item_inner {
  padding: 20px;
}
@media (max-width: 1023px) {
  .schedule_wrap .schedule_item .schedule_item_inner {
    padding: 15px 20px;
  }
}
.schedule_wrap .schedule_item .schedule_date {
  font-size: 16px;
  display: block;
  color: #919b8d;
  margin-bottom: 15px;
}
@media (max-width: 1023px) {
  .schedule_wrap .schedule_item .schedule_date {
    font-size: 14px;
    margin-bottom: 10px;
  }
}
@media (max-width: 767px) {
  .schedule_wrap .schedule_item .schedule_date {
    font-size: 3.4vw;
    margin-bottom: 5px;
  }
}
.schedule_wrap .schedule_item .schedule_title {
  font-size: 22px;
  letter-spacing: 0.2em;
  margin-bottom: 20px;
}
@media (max-width: 1023px) {
  .schedule_wrap .schedule_item .schedule_title {
    font-size: 20px;
    margin-bottom: 10px;
  }
}
@media (max-width: 767px) {
  .schedule_wrap .schedule_item .schedule_title {
    font-size: 4.8vw;
  }
}
.schedule_wrap .schedule_item .schedule_txt {
  color: #666666;
  line-height: 1.6;
  font-size: 18px;
  letter-spacing: 0;
}
@media (max-width: 1023px) {
  .schedule_wrap .schedule_item .schedule_txt {
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  .schedule_wrap .schedule_item .schedule_txt {
    font-size: 3.8vw;
  }
}

/** 診察のご案内 **/
.care.sec_bg_img {
  background-image: url(../img/care_sec_bg.png);
}
@media (max-width: 767px) {
  .care.sec_bg_img {
    background-image: url(../img/care_sec_bg_sp.png);
  }
}

.care_wrap {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 50px;
  -moz-column-gap: 60px;
       column-gap: 60px;
}
@media (max-width: 1023px) {
  .care_wrap {
    gap: 20px;
    -moz-column-gap: 25px;
         column-gap: 25px;
  }
}
.care_wrap .care_item {
  color: #ffffff;
  border-radius: 10px;
  box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.5);
  mix-blend-mode: multiply;
  position: relative;
  overflow: hidden;
}
.care_wrap .care_item a {
  background-color: #40594e;
  background-image: none;
  display: block;
  padding: 55px 50px 75px;
  height: 100%;
}
@media (max-width: 1023px) {
  .care_wrap .care_item a {
    padding: 40px 35px 60px;
  }
}
@media (max-width: 767px) {
  .care_wrap .care_item a {
    padding: 25px 20px 45px;
  }
}
.care_wrap .care_item a::before {
  background-image: url(../img/care_item01_hover_bg.png);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  width: 100%;
  height: 100%;
  transition: background-image linear 0.25s;
  opacity: 0;
  z-index: 5;
  transition: opacity linear 0.25s;
}
.care_wrap .care_item a::after {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  background-repeat: no-repeat;
  background-position: center center;
  opacity: 0;
  z-index: 10;
}
.care_wrap .care_item a:hover::before {
  opacity: 1;
  transition: opacity linear 0.4s;
}
.care_wrap .care_item a:hover::after {
  opacity: 1;
  transition: opacity linear 0.4s;
}
.care_wrap .care_item .care_item_title {
  font-size: 28px;
  font-weight: 900;
  margin-bottom: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 25;
}
@media (max-width: 1023px) {
  .care_wrap .care_item .care_item_title {
    font-size: 24px;
  }
}
@media (max-width: 767px) {
  .care_wrap .care_item .care_item_title {
    font-size: 6.2vw;
  }
}
.care_wrap .care_item .care_item_txt {
  font-size: 18px;
  text-align: left;
  line-height: 2;
  position: relative;
  z-index: 25;
}
@media (max-width: 1023px) {
  .care_wrap .care_item .care_item_txt {
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  .care_wrap .care_item .care_item_txt {
    font-size: 4.2vw;
  }
}
.care_wrap .care_item::after {
  position: absolute;
  bottom: 35px;
  right: 60px;
  content: "";
  width: 11px;
  height: 20px;
  background-image: url(../img/arrow_w_left.svg);
  background-repeat: no-repeat;
  z-index: 20;
}
@media (max-width: 1023px) {
  .care_wrap .care_item::after {
    right: 35px;
    bottom: 40px;
  }
}
.care_wrap .care_item.two_column {
  grid-column: span 3;
  text-align: center;
}
@media (max-width: 767px) {
  .care_wrap .care_item.two_column {
    grid-column: span 6;
  }
}
.care_wrap .care_item.three_column {
  grid-column: span 2;
  text-align: center;
}
@media (max-width: 767px) {
  .care_wrap .care_item.three_column {
    grid-column: span 6;
  }
}
.care_wrap .care_item.three_column a {
  background-color: #4a7c84;
  display: block;
  padding: 30px 35px 50px;
  height: 100%;
}
@media (max-width: 1023px) {
  .care_wrap .care_item.three_column a {
    padding: 25px 25px 40px;
  }
}
@media (max-width: 767px) {
  .care_wrap .care_item.three_column a {
    padding: 20px 20px 35px;
  }
}
.care_wrap .care_item.three_column a .care_item_title {
  font-size: 20px;
  line-height: 1.75;
  margin-bottom: 20px;
  min-height: 84px;
  font-size: 24px;
}
@media (max-width: 1439px) {
  .care_wrap .care_item.three_column a .care_item_title {
    font-size: 18px;
    min-height: 60px;
  }
}
@media (max-width: 1023px) {
  .care_wrap .care_item.three_column a .care_item_title {
    min-height: 55px;
  }
}
@media (max-width: 767px) {
  .care_wrap .care_item.three_column a .care_item_title {
    font-size: 5.8vw;
    min-height: auto;
    margin-bottom: 15px;
  }
}
.care_wrap .care_item.three_column a .care_item_txt {
  font-size: 16px;
}
@media (max-width: 767px) {
  .care_wrap .care_item.three_column a .care_item_txt {
    font-size: 3.8vw;
  }
}
.care_wrap .care_item.three_column::after {
  bottom: 20px;
  right: 45px;
  width: 10px;
  height: 20px;
}
@media (max-width: 767px) {
  .care_wrap .care_item.three_column::after {
    bottom: 15px;
    right: 25px;
  }
}
.care_wrap .care_item.glaucoma a::before {
  background-image: url(../img/care_item02_hover_bg.png);
}
.care_wrap .care_item.pterygium a::before {
  background-image: url(../img/care_item03_hover_bg.png);
}
.care_wrap .care_item.convulsion a::before {
  background-image: url(../img/care_item04_hover_bg.png);
}
.care_wrap .care_item.chirdren a::before {
  background-image: url(../img/care_item05_hover_bg.png);
}

.care_other_link_wrap {
  margin-top: 55px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 50px;
  row-gap: 30px;
}
@media (max-width: 1023px) {
  .care_other_link_wrap {
    margin-top: 45px;
    gap: 30px;
    row-gap: 20px;
  }
}
@media (max-width: 767px) {
  .care_other_link_wrap {
    gap: 15px;
  }
}
.care_other_link_wrap .care_link_item {
  width: calc(50% - 25px);
}
@media (max-width: 1023px) {
  .care_other_link_wrap .care_link_item {
    width: calc(50% - 15px);
  }
}
@media (max-width: 767px) {
  .care_other_link_wrap .care_link_item {
    width: 100%;
  }
}
.care_other_link_wrap .care_link_item a {
  display: block;
  font-size: 24px;
  font-weight: 900;
  padding: 40px 20px;
  text-align: center;
  background-color: #dcf0e9;
  box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.5);
  border-radius: 6px;
  overflow: hidden;
  transition: ease background-color 0.2s, ease color 0.2s;
}
@media (max-width: 1023px) {
  .care_other_link_wrap .care_link_item a {
    font-size: 20px;
    padding: 30px 15px;
  }
}
@media (max-width: 767px) {
  .care_other_link_wrap .care_link_item a {
    font-size: 4.8vw;
    padding: 20px 15px;
  }
}
.care_other_link_wrap .care_link_item a span {
  position: relative;
}
.care_other_link_wrap .care_link_item a span::after {
  position: absolute;
  left: calc(100% + 40px);
  top: 50%;
  transform: translateY(-50%);
  width: 9px;
  height: 18px;
  content: "";
  background-image: url(../img/arrow_g_left.svg);
  background-repeat: no-repeat;
  background-position: center center;
}
.care_other_link_wrap .care_link_item a:hover {
  background-color: #40594e;
  color: #ffffff;
  transition: ease background-color 0.2s, transition, ease color 0.2s;
}
.care_other_link_wrap .care_link_item a:hover span::after {
  background-image: url(../img/arrow_w_left.svg);
  z-index: 5;
}

/** ご案内 **/
.information .wrap {
  display: flex;
  flex-direction: column;
  gap: 60px;
}
.information .reservation_wrap {
  background-color: #e0f0da;
  box-shadow: rgba(0, 0, 0, 0.5) 3px 3px 2px;
}
.information .reservation_wrap .contents_wrap {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
  display: flex;
  justify-content: space-between;
}
@media (max-width: 767px) {
  .information .reservation_wrap .contents_wrap {
    flex-direction: column;
    gap: 50px;
  }
}
.information .reservation_wrap .reservation_contents {
  display: flex;
  flex-direction: column;
  gap: 100px;
}
@media (max-width: 1023px) {
  .information .reservation_wrap .reservation_contents {
    gap: 55px;
  }
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents {
    gap: 30px;
  }
}
.information .reservation_wrap .reservation_contents .reservation_block .block_title {
  font-size: 24px;
  font-weight: 500;
  letter-spacing: 0.25em;
  text-align: center;
}
@media (max-width: 1023px) {
  .information .reservation_wrap .reservation_contents .reservation_block .block_title {
    font-size: 20px;
  }
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents .reservation_block .block_title {
    font-size: 4.6vw;
  }
}
.information .reservation_wrap .reservation_contents .reservation_block .important {
  display: block;
  text-align: center;
  margin-top: 10px;
}
@media (max-width: 1023px) {
  .information .reservation_wrap .reservation_contents .reservation_block .important {
    font-size: 14px;
  }
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents .reservation_block .important {
    font-size: 3.4vw;
  }
}
.information .reservation_wrap .reservation_contents .reservation_block .reservation_btn {
  margin-top: 25px;
  display: block;
  font-size: 24px;
  font-weight: 500;
  padding: 40px 20px;
  text-align: center;
  background-color: #fff;
  box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.5);
  border-radius: 6px;
  overflow: hidden;
  transition: ease background-color 0.2s, ease color 0.2s;
}
@media (max-width: 1023px) {
  .information .reservation_wrap .reservation_contents .reservation_block .reservation_btn {
    padding: 25px 15px;
    font-size: 18px;
    margin-bottom: 15px;
  }
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents .reservation_block .reservation_btn {
    margin-top: 15px;
    margin-bottom: 0;
    padding: 20px 15px;
    font-size: 4.2vw;
  }
}
.information .reservation_wrap .reservation_contents .reservation_block .reservation_btn.today {
  background-color: #f3f3da;
  transition: ease background-color 0.2s;
}
.information .reservation_wrap .reservation_contents .reservation_block .reservation_btn.today:hover {
  background-color: #cecece;
  color: inherit;
  transition: ease background-color 0.2s;
}
.information .reservation_wrap .reservation_contents .reservation_block .reservation_btn.today:hover span::after {
  z-index: 5;
}
.information .reservation_wrap .reservation_contents .reservation_block .reservation_btn.tommorrow {
  background-color: #e1ffff;
  transition: ease background-color 0.2s;
}
.information .reservation_wrap .reservation_contents .reservation_block .reservation_btn.tommorrow:hover {
  background-color: #cecece;
  color: inherit;
  transition: ease background-color 0.2s;
}
.information .reservation_wrap .reservation_contents .reservation_block .reservation_btn.tommorrow:hover span::after {
  z-index: 5;
}
.information .reservation_wrap .reservation_contents .reservation_block .reservation_btn span {
  position: relative;
}
.information .reservation_wrap .reservation_contents .reservation_block .reservation_btn span::after {
  position: absolute;
  left: calc(100% + 40px);
  top: 50%;
  transform: translateY(-50%);
  width: 9px;
  height: 18px;
  content: "";
  background-image: url(../img/arrow_g_left.svg);
  background-repeat: no-repeat;
  background-position: center center;
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents .reservation_block .reservation_btn span::after {
    left: calc(100% + 15px);
    width: 7px;
  }
}
.information .reservation_wrap .reservation_contents.left_box {
  width: min(530px, 52%);
}
@media (max-width: 1023px) {
  .information .reservation_wrap .reservation_contents.left_box {
    width: 50%;
  }
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents.left_box {
    width: 100%;
  }
}
.information .reservation_wrap .reservation_contents.right_box {
  width: min(350px, 40%);
}
@media (max-width: 1023px) {
  .information .reservation_wrap .reservation_contents.right_box {
    width: 42%;
  }
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents.right_box {
    width: 100%;
  }
}
.information .reservation_wrap .reservation_contents.order_contents {
  gap: 0px;
}
.information .reservation_wrap .reservation_contents.order_contents .order_btn {
  border: 2px solid #40594e;
}
.information .reservation_wrap .reservation_contents.order_contents .order_btn span {
  padding-left: 45px;
  font-size: 18px;
  text-align: center;
  display: inline-block;
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents.order_contents .order_btn span {
    font-size: 4.5vw;
    padding-left: 35px;
  }
}
.information .reservation_wrap .reservation_contents.order_contents .order_btn span::after {
  background-image: url(../img/phone.png);
  height: 55px;
  width: 26px;
  left: 0;
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents.order_contents .order_btn span::after {
    height: 50px;
    width: 22px;
    background-size: contain;
  }
}
.information .reservation_wrap .reservation_contents.order_contents .order_btn:hover {
  background-color: #40594e;
  color: #ffffff;
  transition: ease background-color 0.2s, transition, ease color 0.2s;
}
.information .reservation_wrap .reservation_contents.order_contents .order_btn:hover span::after {
  z-index: 5;
  background-image: url(../img/phone_w.png);
}
.information .reservation_wrap .reservation_contents {
  /* 3Bees */
}
.information .reservation_wrap .reservation_contents .confirmation_wrap {
  background-color: #ebeced;
  border: solid 2px #999999;
  border-radius: 6px;
  padding: 30px 0 0;
}
@media (max-width: 1023px) {
  .information .reservation_wrap .reservation_contents .confirmation_wrap {
    padding: 20px 25px 0px;
  }
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents .confirmation_wrap {
    padding: 15px 20px 0px;
  }
}
.information .reservation_wrap .reservation_contents .confirmation_wrap .time {
  display: block;
  text-align: center;
  margin-bottom: 40px;
}
@media (max-width: 1023px) {
  .information .reservation_wrap .reservation_contents .confirmation_wrap .time {
    margin-bottom: 20px;
  }
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents .confirmation_wrap .time {
    margin-bottom: 15px;
  }
}
.information .reservation_wrap .reservation_contents .confirmation_wrap .time time {
  font-family: "Inter", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}
.information .reservation_wrap .reservation_contents .confirmation_wrap iframe {
  width: 100%;
}
.information .reservation_wrap .reservation_contents .confirmation_wrap .order_number_wrap {
  width: 100%;
  background-color: #ffffff;
  margin-bottom: 50px;
  border-radius: 6px;
  padding: 15px 35px 10px;
  color: #000000;
}
@media (max-width: 1023px) {
  .information .reservation_wrap .reservation_contents .confirmation_wrap .order_number_wrap {
    margin-bottom: 25px;
    padding: 15px 30px 10px;
  }
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents .confirmation_wrap .order_number_wrap {
    margin-bottom: 15px;
  }
}
.information .reservation_wrap .reservation_contents .confirmation_wrap .order_number_wrap:last-child {
  margin-bottom: 0;
}
.information .reservation_wrap .reservation_contents .confirmation_wrap .order_number_wrap .your_order_number {
  display: block;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 10px;
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents .confirmation_wrap .order_number_wrap .your_order_number {
    font-size: 3.6vw;
  }
}
.information .reservation_wrap .reservation_contents .confirmation_wrap .order_number_wrap .order_number_check {
  display: flex;
  justify-content: center;
  align-items: last baseline;
  gap: 5px;
}
.information .reservation_wrap .reservation_contents .confirmation_wrap .order_number_wrap .order_number {
  font-family: "Inter", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  font-size: 38px;
}
@media (max-width: 1023px) {
  .information .reservation_wrap .reservation_contents .confirmation_wrap .order_number_wrap .order_number {
    font-size: 32px;
  }
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents .confirmation_wrap .order_number_wrap .order_number {
    font-size: 7.8vw;
  }
}
.information .reservation_wrap .reservation_contents .confirmation_wrap .order_number_wrap .order_number_unit {
  font-size: 20px;
}
@media (max-width: 1023px) {
  .information .reservation_wrap .reservation_contents .confirmation_wrap .order_number_wrap .order_number_unit {
    font-size: 18px;
  }
}
@media (max-width: 767px) {
  .information .reservation_wrap .reservation_contents .confirmation_wrap .order_number_wrap .order_number_unit {
    font-size: 4.5vw;
  }
}
.information .information_wrap {
  background-color: #fff;
  box-shadow: rgba(0, 0, 0, 0.3) 2px 2px 6px;
}

/** 担当医のご案内 **/
.doctor_table_wrap table {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
  border-spacing: 8px;
  border: 1px solid #fff;
  width: 1047px;
  max-width: 100%;
}
@media (max-width: 767px) {
  .doctor_table_wrap table {
    max-width: none;
    width: 800px;
  }
}
.doctor_table_wrap table tr th,
.doctor_table_wrap table tr td {
  text-align: center;
  vertical-align: middle;
  padding: 20px 10px 20px 10px;
  border: 8px solid #fff;
  font-weight: 500;
}
.doctor_table_wrap table tr th span,
.doctor_table_wrap table tr td span {
  display: block;
  font-size: 16px;
}
@media (max-width: 767px) {
  .doctor_table_wrap table tr th span,
  .doctor_table_wrap table tr td span {
    font-size: 3.8vw;
  }
}
.doctor_table_wrap table tr th span .only_week,
.doctor_table_wrap table tr td span .only_week {
  display: block;
  font-size: 14px;
  padding: 5px;
  width: 100px;
  letter-spacing: 0;
  border: 1px solid #40594e;
  background-color: #fff;
  border-radius: 15px;
  margin-bottom: 8px;
  margin-inline: auto;
}
@media (max-width: 1023px) {
  .doctor_table_wrap table tr th span .only_week,
  .doctor_table_wrap table tr td span .only_week {
    font-size: 13px;
    width: 85px;
  }
}
@media (max-width: 767px) {
  .doctor_table_wrap table tr th span .only_week,
  .doctor_table_wrap table tr td span .only_week {
    font-size: 3.2vw;
  }
}
.doctor_table_wrap table tr th span:nth-child(n+2),
.doctor_table_wrap table tr td span:nth-child(n+2) {
  margin-top: 20px;
}
.doctor_table_wrap table tr th {
  background-color: #40594e;
  padding: 20px 5px 20px;
}
.doctor_table_wrap table tr th span {
  display: block;
  color: #fff;
  font-size: 16px;
}
@media (max-width: 1023px) {
  .doctor_table_wrap table tr th span {
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  .doctor_table_wrap table tr th span {
    font-size: 4vw;
  }
}
.doctor_table_wrap table tr th .d_of_w {
  font-size: 12px;
}
@media (max-width: 767px) {
  .doctor_table_wrap table tr th .d_of_w {
    font-size: 3.8vw;
  }
}
.doctor_table_wrap table tr th.afternoon {
  background-color: #4a7c84;
}
.doctor_table_wrap table tr td {
  color: #40594e;
  background-color: #e0f0da;
}
.doctor_table_wrap table tr td.noDoc {
  background-color: #d5dbd8;
}
.doctor_table_wrap table thead tr th {
  padding: 10px 10px;
}
@media (max-width: 767px) {
  .doctor_table_wrap table thead tr th {
    padding: 5px 10px;
  }
}
@media (max-width: 767px) {
  .doctor_table_wrap table thead tr th {
    width: 23.5%;
  }
}
.doctor_table_wrap table thead tr th.days {
  padding: 10px 5px;
}
@media (max-width: 1023px) {
  .doctor_table_wrap table thead tr th.days {
    width: 13.1428571429%;
  }
}
@media (max-width: 767px) {
  .doctor_table_wrap table thead tr th.days {
    padding: 5px 8px;
  }
}
@media (max-width: 1023px) {
  .doctor_table_wrap table thead tr th.days_week {
    width: 8%;
  }
}
@media (max-width: 767px) {
  .doctor_table_wrap table thead tr th.days_week {
    padding: 5px 8px;
  }
}

/** お願い **/
.request.sec_bg {
  background-color: #91a099;
}
.request .sec_title > * {
  color: #ffffff;
}
.request .round-box {
  margin-bottom: 50px;
  background-color: #fff;
  padding: 55px 50px 45px;
}
@media (max-width: 1023px) {
  .request .round-box {
    padding: 35px 25px;
  }
}
@media (max-width: 767px) {
  .request .round-box {
    margin-bottom: 30px;
    padding: 30px 20px;
  }
}
.request .round-box .round_title {
  text-align: center;
  font-size: 24px;
  margin-bottom: 40px;
}
@media (max-width: 767px) {
  .request .round-box .round_title {
    font-size: 5.2vw;
    line-height: 1.4;
    margin-bottom: 30px;
  }
}
.request .round-box p {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.8em;
}
@media (max-width: 767px) {
  .request .round-box p {
    font-size: 3.8vw;
  }
}
.request .round-box p a {
  text-decoration: underline;
  font-weight: 700;
  text-decoration-thickness: 2px;
  text-underline-offset: 5px;
}
.request .round-box:last-child {
  margin-top: 0;
}
.request .request_flex_wrap {
  display: flex;
  align-items: center;
  gap: 60px;
}
@media (max-width: 767px) {
  .request .request_flex_wrap {
    flex-direction: column;
    gap: 30px;
  }
}
.request .request_flex_wrap .mask_img {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 20%;
  line-height: 1.6;
}
@media (max-width: 767px) {
  .request .request_flex_wrap .mask_img {
    width: 100%;
    line-height: 1.4;
  }
}
.request .request_flex_wrap .mask_img span {
  font-size: 20px;
  display: block;
  margin-bottom: 20px;
}
@media (max-width: 767px) {
  .request .request_flex_wrap .mask_img span {
    font-size: 5vw;
    margin-bottom: 10px;
  }
}
.request .request_flex_wrap .request_wear_txt {
  flex: 1;
}

/** 当院の特徴 **/
.feature {
  display: none;
}
.feature.sec_bg_img {
  background-image: url(../img/sec_bg.png);
}
@media (max-width: 767px) {
  .feature.sec_bg_img {
    background-image: url(../img/sec_bg_sp.png);
  }
}
.feature .sec_title {
  margin-bottom: 100px;
}
@media (max-width: 1023px) {
  .feature .sec_title {
    margin-bottom: 60px;
  }
}
@media (max-width: 767px) {
  .feature .sec_title {
    margin-bottom: 40px;
  }
}

.feature_flex_wrap {
  width: min(998px, 90%);
  margin-inline: auto;
}
.feature_flex_wrap .feature_column {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 60px;
}
@media (max-width: 1023px) {
  .feature_flex_wrap .feature_column {
    margin-bottom: 50px;
  }
}
@media (max-width: 767px) {
  .feature_flex_wrap .feature_column {
    margin-bottom: 25px;
  }
}
.feature_flex_wrap .feature_column:nth-child(2n) {
  justify-content: flex-end;
}
.feature_flex_wrap .feature_column:last-child {
  margin-bottom: 0;
}
.feature_flex_wrap .feature_item {
  position: relative;
  background: linear-gradient(to top, #ffffff 40%, #d4e5da 100%);
  width: 660px;
  border-radius: 8px;
  padding: 20px 60px 40px;
  background-blend-mode: multiply;
  box-shadow: 2px 2px 1px rgba(0, 0, 0, 0.3);
}
@media (max-width: 1023px) {
  .feature_flex_wrap .feature_item {
    width: min(550px, 100%);
    padding: 15px 40px 30px;
  }
}
@media (max-width: 767px) {
  .feature_flex_wrap .feature_item {
    padding: 20px 15px;
  }
}
.feature_flex_wrap .feature_item .feature_txt {
  width: 60%;
}
@media (max-width: 1023px) {
  .feature_flex_wrap .feature_item .feature_txt {
    width: 50%;
  }
}
@media (max-width: 767px) {
  .feature_flex_wrap .feature_item .feature_txt {
    width: 80%;
  }
}
.feature_flex_wrap .feature_item .feature_txt .feature_num {
  display: flex;
  align-items: last baseline;
  gap: 15px;
  margin-bottom: 25px;
}
@media (max-width: 1023px) {
  .feature_flex_wrap .feature_item .feature_txt .feature_num {
    margin-bottom: 15px;
    gap: 10px;
  }
}
.feature_flex_wrap .feature_item .feature_txt .feature_num .features {
  font-size: 20px;
}
@media (max-width: 1023px) {
  .feature_flex_wrap .feature_item .feature_txt .feature_num .features {
    font-size: 18px;
  }
}
.feature_flex_wrap .feature_item .feature_txt .feature_num .bigNum {
  font-size: 55px;
}
@media (max-width: 1023px) {
  .feature_flex_wrap .feature_item .feature_txt .feature_num .bigNum {
    font-size: 48px;
  }
}
@media (max-width: 767px) {
  .feature_flex_wrap .feature_item .feature_txt .feature_num .bigNum {
    font-size: 8.4vw;
  }
}
.feature_flex_wrap .feature_item .feature_txt .feature_title {
  font-size: 26px;
  line-height: 1.6em;
}
@media (max-width: 1023px) {
  .feature_flex_wrap .feature_item .feature_txt .feature_title {
    font-size: 22px;
  }
}
@media (max-width: 767px) {
  .feature_flex_wrap .feature_item .feature_txt .feature_title {
    font-size: 4.2vw;
    font-weight: 700;
  }
}
.feature_flex_wrap .feature_item .feature_img {
  width: 345px;
  box-shadow: 2px 2px 1px rgba(0, 0, 0, 0.3);
  position: absolute;
  border-radius: 10px;
  bottom: 30px;
  right: -50px;
}
@media (max-width: 1023px) {
  .feature_flex_wrap .feature_item .feature_img {
    bottom: 20px;
    right: -25px;
    width: 52%;
  }
}
@media (max-width: 767px) {
  .feature_flex_wrap .feature_item .feature_img {
    bottom: 15px;
    right: -25px;
    width: 50%;
  }
}

/** 各診察について **/
.about {
  margin-bottom: 85px;
}
.about .wrap {
  padding-bottom: 0;
}

.about_contents_wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 50px;
}
@media (max-width: 1023px) {
  .about_contents_wrap {
    gap: 30px;
  }
}
.about_contents_wrap .about_item {
  width: calc(50% - 25px);
  border: #40594e solid 1px;
  border-radius: 4px;
  background-color: #f2f2f2;
  padding: 40px 30px;
}
@media (max-width: 1023px) {
  .about_contents_wrap .about_item {
    width: calc(50% - 15px);
    padding: 35px 25px;
  }
}
@media (max-width: 767px) {
  .about_contents_wrap .about_item {
    width: 100%;
    padding: 30px 20px;
  }
}
.about_contents_wrap .about_item .item_title {
  text-align: center;
  margin-bottom: 35px;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.5;
}
@media (max-width: 1023px) {
  .about_contents_wrap .about_item .item_title {
    font-size: 20px;
  }
}
@media (max-width: 767px) {
  .about_contents_wrap .about_item .item_title {
    font-size: 5.2vw;
    margin-bottom: 25px;
  }
}
.about_contents_wrap .about_item p {
  font-size: 18px;
  line-height: 1.8em;
}
@media (max-width: 1023px) {
  .about_contents_wrap .about_item p {
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  .about_contents_wrap .about_item p {
    font-size: 3.8vw;
  }
}

/** 施設基準について **/
.standard {
  margin-top: 80px;
  background-color: #e6e6e6;
  padding: 80px 60px 60px;
}
@media (max-width: 1023px) {
  .standard {
    padding: 40px 30px 30px;
  }
}
@media (max-width: 767px) {
  .standard {
    margin-top: 50px;
    padding: 30px 15px 30px;
  }
}

.standard_contents_wrap {
  display: grid;
  grid-template-columns: repeat(2, auto);
  row-gap: 55px;
  -moz-column-gap: 50px;
       column-gap: 50px;
}
@media (max-width: 1023px) {
  .standard_contents_wrap {
    row-gap: 35px;
    -moz-column-gap: 30px;
         column-gap: 30px;
  }
}
@media (max-width: 767px) {
  .standard_contents_wrap {
    gap: 25px;
  }
}
.standard_contents_wrap .standard_item {
  background-color: #fff;
  border-radius: 6px;
  padding: 50px 45px 40px 45px;
}
@media (max-width: 1023px) {
  .standard_contents_wrap .standard_item {
    padding: 40px 30px 30px;
  }
}
@media (max-width: 767px) {
  .standard_contents_wrap .standard_item {
    padding: 30px 20px 30px;
    grid-column: span 2;
  }
}
.standard_contents_wrap .standard_item.full_column {
  grid-column: span 2;
}
.standard_contents_wrap .standard_item .standard_item_title {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 35px;
  line-height: 1.6em;
  gap: 15px;
}
@media (max-width: 1023px) {
  .standard_contents_wrap .standard_item .standard_item_title {
    margin-bottom: 25px;
    gap: 10px;
  }
}
@media (max-width: 767px) {
  .standard_contents_wrap .standard_item .standard_item_title {
    margin-bottom: 20px;
    gap: 5px;
  }
}
.standard_contents_wrap .standard_item .standard_item_title strong {
  font-size: 22px;
}
@media (max-width: 1023px) {
  .standard_contents_wrap .standard_item .standard_item_title strong {
    font-size: 20px;
  }
}
@media (max-width: 767px) {
  .standard_contents_wrap .standard_item .standard_item_title strong {
    font-size: 5vw;
    text-align: center;
  }
}
.standard_contents_wrap .standard_item .standard_item_title span {
  font-size: 16px;
}
@media (max-width: 767px) {
  .standard_contents_wrap .standard_item .standard_item_title span {
    font-size: 4.2vw;
  }
}
.standard_contents_wrap .standard_item p {
  font-size: 16px;
  line-height: 1.8em;
}
@media (max-width: 767px) {
  .standard_contents_wrap .standard_item p {
    font-size: 3.8vw;
  }
}
.standard_contents_wrap .standard_item .link_btn {
  margin-inline: auto;
  margin-top: 45px;
  width: 320px;
  display: block;
  text-align: center;
  background-color: #40594e;
  color: #fff;
  font-size: 18px;
  font-weight: 900;
  padding: 20px;
  border-radius: 30px;
  border: 1px solid #40594e;
  box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.5);
  transition: ease all 0.25s;
}
@media (max-width: 1023px) {
  .standard_contents_wrap .standard_item .link_btn {
    font-size: 16px;
    margin-top: 40px;
    width: 60%;
  }
}
@media (max-width: 767px) {
  .standard_contents_wrap .standard_item .link_btn {
    font-size: 3.8vw;
    margin-top: 35px;
    width: 100%;
    padding: 15px 10px;
  }
}
.standard_contents_wrap .standard_item .link_btn span {
  display: inline-block;
  padding-right: 20px;
  position: relative;
}
.standard_contents_wrap .standard_item .link_btn span::after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  content: "";
  width: 6px;
  height: 12px;
  background-image: url(../img/arrow_w_left.svg);
  background-repeat: no-repeat;
  background-position: center center;
  transition: ease all 0.25s;
}
.standard_contents_wrap .standard_item .link_btn:hover {
  background-color: #fff;
  color: #40594e;
  transition: ease all 0.25s;
}
.standard_contents_wrap .standard_item .link_btn:hover span::after {
  background-image: url(../img/arrow_g_left.svg);
  transition: ease all 0.25s;
}

/* ---------------------------------- */
/*** フッター ***/
/** フッター上コンテンツ（店舗の情報） **/
.footer_above .f_above_contents {
  border-top: solid #808080 1px;
}
.footer_above .niwa_logo_hour {
  display: flex;
  justify-content: space-between;
  margin-bottom: 90px;
}
@media (max-width: 767px) {
  .footer_above .niwa_logo_hour {
    flex-wrap: wrap;
    gap: 35px;
    margin-bottom: 45px;
  }
}
.footer_above .niwa_logo_hour .f_above_logo {
  width: min(357px, 35%);
}
@media (max-width: 767px) {
  .footer_above .niwa_logo_hour .f_above_logo {
    width: 75%;
    margin-inline: auto;
  }
}
.footer_above .niwa_logo_hour .f_above_hour {
  display: flex;
  flex-direction: column;
  gap: 25px;
  font-weight: 900;
  width: min(553px, 40%);
  text-align: end;
}
@media (max-width: 767px) {
  .footer_above .niwa_logo_hour .f_above_hour {
    width: 90%;
    margin-inline: auto;
    text-align: center;
  }
}
.footer_above .niwa_logo_hour .f_above_hour span {
  font-size: 18px;
}
@media (max-width: 1023px) {
  .footer_above .niwa_logo_hour .f_above_hour span {
    font-size: 14px;
  }
}
@media (max-width: 767px) {
  .footer_above .niwa_logo_hour .f_above_hour span {
    text-align: right;
    font-size: 3.8vw;
    font-weight: 700;
  }
}
.footer_above .niwa_information {
  margin-bottom: 45px;
  display: flex;
  justify-content: space-between;
  gap: 50px;
}
@media (max-width: 767px) {
  .footer_above .niwa_information {
    flex-wrap: wrap;
    gap: 25px;
  }
}
.footer_above .niwa_information .niwa_data {
  flex: 1;
}
@media (max-width: 767px) {
  .footer_above .niwa_information .niwa_data {
    width: 100%;
  }
}
.footer_above .niwa_information .niwa_data dl {
  display: flex;
  justify-content: flex-start;
  gap: 30px;
  font-size: 18px;
  line-height: 2;
}
@media (max-width: 1023px) {
  .footer_above .niwa_information .niwa_data dl {
    font-size: 15px;
  }
}
@media (max-width: 767px) {
  .footer_above .niwa_information .niwa_data dl {
    flex-wrap: wrap;
    flex-direction: column;
    gap: 5px;
    line-height: 1.5;
    margin-bottom: 15px;
    font-size: 3.8vw;
    padding-bottom: 10px;
    border-bottom: rgba(128, 128, 128, 0.4) 1px solid;
  }
}
.footer_above .niwa_information .niwa_data dl dt {
  width: 12%;
}
@media (max-width: 1439px) {
  .footer_above .niwa_information .niwa_data dl dt {
    width: 15%;
  }
}
@media (max-width: 1023px) {
  .footer_above .niwa_information .niwa_data dl dt {
    width: 18%;
  }
}
@media (max-width: 767px) {
  .footer_above .niwa_information .niwa_data dl dt {
    width: 100%;
    font-weight: 700;
  }
}
.footer_above .niwa_information .niwa_data dl dd {
  flex: 1;
}
@media (max-width: 767px) {
  .footer_above .niwa_information .niwa_data dl dd {
    width: 100%;
  }
}
@media (max-width: 767px) {
  .footer_above .niwa_map_img_wrap {
    width: 100%;
    text-align: center;
  }
}
.footer_above .parking {
  font-size: 16px;
  line-height: 2;
}
@media (max-width: 1023px) {
  .footer_above .parking {
    font-size: 15px;
  }
}
@media (max-width: 767px) {
  .footer_above .parking {
    font-size: 3.5vw;
  }
}

/** フッター本体 **/
.footer {
  background-color: #40594e;
  color: #ffffff;
}
.footer .wrap {
  padding: 65px 0 45px 0;
}
@media (max-width: 1023px) {
  .footer .wrap {
    padding: 45px 0 115px 0;
  }
}
@media (max-width: 767px) {
  .footer .wrap {
    padding: 35px 0 140px 0;
  }
}
.footer .copyright {
  font-size: 14px;
}
@media (max-width: 767px) {
  .footer .copyright {
    font-size: 3.2vw;
  }
}

.f_contents_wrap {
  display: flex;
  justify-content: space-between;
}
@media (max-width: 1023px) {
  .f_contents_wrap {
    flex-direction: column;
    margin-bottom: 25px;
  }
}

.f_nav_wrap {
  display: flex;
  gap: 40px;
  margin-bottom: 55px;
}
@media (max-width: 1023px) {
  .f_nav_wrap {
    gap: 25px;
    margin-bottom: 35px;
  }
}
@media (max-width: 767px) {
  .f_nav_wrap {
    gap: 40px;
    margin-bottom: 40px;
    justify-content: space-between;
    flex-wrap: wrap;
  }
}
.f_nav_wrap .f_nav {
  width: auto;
}
.f_nav_wrap .f_nav li {
  margin-bottom: 30px;
}
@media (max-width: 767px) {
  .f_nav_wrap .f_nav li {
    margin-bottom: 20px;
  }
}
.f_nav_wrap .f_nav li a {
  font-size: 18px;
}
@media (max-width: 1023px) {
  .f_nav_wrap .f_nav li a {
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  .f_nav_wrap .f_nav li a {
    font-size: 3.8vw;
  }
}
.f_nav_wrap .f_nav li:last-child {
  margin-bottom: 0;
}

/* 関連リンク集 */
@media (max-width: 767px) {
  .gakkai_links_wrap {
    width: 100%;
  }
}
.gakkai_links_wrap strong {
  display: block;
  font-size: 18px;
  font-weight: normal;
  padding-bottom: 10px;
  margin-bottom: 15px;
  border-bottom: 1px solid #fff;
}
@media (max-width: 767px) {
  .gakkai_links_wrap strong {
    font-size: 4.2vw;
  }
}
.gakkai_links_wrap span {
  display: block;
  font-size: 1rem;
  margin-bottom: 15px;
  padding-left: 1.3rem;
  position: relative;
}
@media (max-width: 767px) {
  .gakkai_links_wrap span {
    font-size: 3.8vw;
  }
}
.gakkai_links_wrap span::after {
  position: absolute;
  left: 0;
  top: 2px;
  content: "■";
  font-size: 12px;
}
.gakkai_links_wrap .gakkai_links li {
  margin-bottom: 15px;
}
@media (max-width: 767px) {
  .gakkai_links_wrap .gakkai_links li {
    margin-bottom: 12px;
  }
}
.gakkai_links_wrap .gakkai_links li a {
  font-size: 1rem;
  transition: ease border-bottom 0.25s, ease opacity 0.25s;
}
@media (max-width: 767px) {
  .gakkai_links_wrap .gakkai_links li a {
    font-size: 3.8vw;
  }
}
.gakkai_links_wrap .gakkai_links li a:hover {
  opacity: 0.9;
  border-bottom: rgba(255, 255, 255, 0.9) solid 1px;
}

/* フッター内の営業時間 */
.hour {
  width: -moz-fit-content;
  width: fit-content;
}
@media (max-width: 1023px) {
  .hour {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: end;
  }
}
@media (max-width: 1023px) {
  .hour {
    width: min(320px, 100%);
    margin: 0 auto;
  }
}
.hour .hour_block {
  display: flex;
  flex-direction: column;
  justify-content: left;
  gap: 15px;
  padding: 20px 30px 15px 30px;
  background-color: rgba(255, 255, 255, 0.7);
  border-radius: 5px;
  box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.75);
}
@media (max-width: 1439px) {
  .hour .hour_block {
    padding: 15px 25px 15px 25px;
  }
}
@media (max-width: 1023px) {
  .hour .hour_block {
    padding: 10px 15px 10px 15px;
    width: -moz-fit-content;
    width: fit-content;
  }
}
@media (max-width: 767px) {
  .hour .hour_block {
    gap: 10px;
    padding: 20px;
    width: 100%;
  }
}
@media (max-width: 767px) {
  .hour .hour_block img {
    width: 100%;
  }
}
.hour .hour_block span {
  display: block;
  text-align: right;
  font-size: 14px;
  font-weight: 900;
  color: #40594e;
}
@media (max-width: 767px) {
  .hour .hour_block span {
    font-size: 3vw;
  }
}
.hour .doctor_hour {
  margin-top: 25px;
  color: #ffffff;
  text-align: right;
}
@media (max-width: 1439px) {
  .hour .doctor_hour {
    margin-top: 10px;
  }
}
.hour .doctor_hour a {
  width: -moz-fit-content;
  width: fit-content;
  display: inline-block;
  border-bottom: #ffffff solid 1px;
  font-size: 18px;
  padding-bottom: 7px;
  padding-right: 20px;
  position: relative;
}
@media (max-width: 1439px) {
  .hour .doctor_hour a {
    font-size: 16px;
  }
}
@media (max-width: 1023px) {
  .hour .doctor_hour a {
    font-size: 14px;
    padding-bottom: 5px;
    padding-right: 15px;
  }
}
@media (max-width: 767px) {
  .hour .doctor_hour a {
    font-size: 3.2vw;
  }
}
.hour .doctor_hour a::after {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  content: "";
  width: 8px;
  height: calc(100% - 7px);
  background-image: url(../img/arrow_w_left.svg);
  background-repeat: no-repeat;
}
@media (max-width: 1023px) {
  .hour .doctor_hour a::after {
    height: calc(100% - 5px);
    width: 6px;
  }
}

/* ---------------------------------- */
/*** PAGE-TOPボタン ***/
.page_top {
  position: fixed;
  bottom: 2dvh;
  right: 20px;
  z-index: 50;
  opacity: 0;
  visibility: hidden;
  transition: linear 0.2s all;
}
@media (max-width: 1023px) {
  .page_top {
    right: 15px;
    bottom: 12dvh;
  }
}
@media (max-width: 767px) {
  .page_top {
    bottom: 15dvh;
    right: 10px;
  }
}
.page_top a {
  text-align: center;
  display: block;
  width: 75px;
  height: 75px;
  border: solid 1px #9aa8a1;
  border-radius: 50%;
  padding-top: 25px;
  font-size: 16px;
  background-color: #ffffff;
  position: relative;
}
@media (max-width: 767px) {
  .page_top a {
    width: 65px;
    height: 65px;
    font-size: 12px;
  }
}
.page_top a::before {
  position: absolute;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
  content: "";
  background-image: url(../img/arrow_g_top.svg);
  background-repeat: no-repeat;
  background-position: center center;
  width: 15px;
  height: 10px;
  transition: ease 0.25s top;
}
@media (max-width: 767px) {
  .page_top a::before {
    width: 13px;
    height: 8px;
  }
}
.page_top a:hover::before {
  top: 8px;
  transition: ease 0.25s top;
}
.page_top.is-active {
  opacity: 1;
  visibility: visible;
  transition: linear 0.2s all;
}

/* ---------------------------------- */
/*** 下層ページ ***/
.header.page_header {
  background-color: white;
  color: #40594e;
  border-bottom: solid 1px #b3b3b3;
}
.header.page_header .main_nav {
  color: rgb(0, 0, 0);
}
.header.page_header .main_nav .has_children::before {
  background-image: url(../img/arrow_g_left.svg);
}
.header.page_header .phone_reservation {
  border-color: #40594e;
}
.header.page_header .phone_reservation a {
  color: #40594e;
}
.header.page_header .hamburger span {
  background-color: #40594e;
}

/** パンくずリスト **/
.breadcrumb {
  padding: 35px 0 80px;
}
@media (max-width: 767px) {
  .breadcrumb {
    padding: 25px 0 70px;
  }
}
.breadcrumb ul {
  display: flex;
  gap: 10px;
}
.breadcrumb ul li {
  font-size: 16px;
}
@media (max-width: 767px) {
  .breadcrumb ul li {
    font-size: 3.6vw;
  }
}
.breadcrumb ul li a {
  transition: linear 0.2s text-decoration;
}
.breadcrumb ul li a:hover {
  text-decoration: underline;
  transition: linear 0.2s text-decoration;
}
.breadcrumb ul li + li {
  padding-left: 1em;
  position: relative;
}
.breadcrumb ul li + li::before {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  content: " 〉";
  font-size: inherit;
  width: 1em;
  height: 100%;
}

.page > article {
  padding-top: 170px;
}
@media (max-width: 1023px) {
  .page > article {
    padding-top: 100px;
  }
}
@media (max-width: 767px) {
  .page > article {
    padding-top: 90px;
  }
}
.page .wrap {
  width: min(1200px, 95%);
}
@media (max-width: 767px) {
  .page .wrap {
    width: 90%;
  }
}

.page_contents {
  margin-bottom: 90px;
}
@media (max-width: 767px) {
  .page_contents {
    margin-bottom: 75px;
  }
}
.page_contents .page_title_wrap {
  width: min(1780px, 95%);
  margin-inline: auto;
  background-image: url(../img/page/page_title_bg.jpg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 20px;
  font-weight: 700;
}
@media (max-width: 767px) {
  .page_contents .page_title_wrap {
    width: 90%;
    border-radius: 10px;
  }
}
.page_contents .page_title_wrap .wrap {
  padding: 95px 0;
}
@media (max-width: 1023px) {
  .page_contents .page_title_wrap .wrap {
    padding: 80px 25px;
  }
}
@media (max-width: 767px) {
  .page_contents .page_title_wrap .wrap {
    padding: 45px 0;
  }
}
.page_contents .page_title_wrap h1 {
  font-size: 36px;
  color: #fff;
  text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.5);
}
@media (max-width: 1023px) {
  .page_contents .page_title_wrap h1 {
    font-size: 32px;
    text-shadow: 3px 1px 3px rgba(0, 0, 0, 0.5);
  }
}
@media (max-width: 767px) {
  .page_contents .page_title_wrap h1 {
    font-size: 5.8vw;
  }
}
.page_contents .article_contents_wrap .wrap *:first-child {
  margin-top: 0;
}
.page_contents .article_contents_wrap .wrap {
  /* 求人募集用 Article */
}
.page_contents .article_contents_wrap .wrap > article {
  margin-top: 65px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .wrap > article {
    margin-top: 55px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .wrap > article {
    margin-top: 45px;
  }
}
.page_contents .article_contents_wrap .wrap > article h3,
.page_contents .article_contents_wrap .wrap > article h4,
.page_contents .article_contents_wrap .wrap > article h5,
.page_contents .article_contents_wrap .wrap > article h6 {
  margin-top: 30px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .wrap > article h3,
  .page_contents .article_contents_wrap .wrap > article h4,
  .page_contents .article_contents_wrap .wrap > article h5,
  .page_contents .article_contents_wrap .wrap > article h6 {
    margin-top: 20px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .wrap > article h3,
  .page_contents .article_contents_wrap .wrap > article h4,
  .page_contents .article_contents_wrap .wrap > article h5,
  .page_contents .article_contents_wrap .wrap > article h6 {
    margin-top: 15px;
  }
}
.page_contents .article_contents_wrap .wrap > article h3 + h4 {
  margin-top: 45px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .wrap > article h3 + h4 {
    margin-top: 35px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .wrap > article h3 + h4 {
    margin-top: 30px;
  }
}
.page_contents .article_contents_wrap {
  /* ヘディング */
}
.page_contents .article_contents_wrap h2 {
  font-size: 28px;
  color: #40594e;
  font-weight: 700;
  padding-bottom: 20px;
  border-bottom: solid 1px #b3b3b3;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap h2 {
    font-size: 26px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap h2 {
    font-size: 5.2vw;
  }
}
.page_contents .article_contents_wrap h2 + * {
  margin-top: 40px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap h2 + * {
    margin-top: 35px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap h2 + * {
    margin-top: 20px;
  }
}
.page_contents .article_contents_wrap h2:nth-child(n+2) {
  margin-top: 75px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap h2:nth-child(n+2) {
    margin-top: 60px;
  }
}
.page_contents .article_contents_wrap h3 {
  font-size: 24px;
  font-weight: 700;
  padding-top: 2px;
  padding-left: 15px;
  margin-top: 50px;
  position: relative;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap h3 {
    font-size: 22px;
    margin-top: 40px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap h3 {
    font-size: 4.8vw;
    margin-top: 30px;
  }
}
.page_contents .article_contents_wrap h3::before {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  width: 5px;
  height: 1.35em;
  background-color: #40594e;
  border-radius: 4px;
}
.page_contents .article_contents_wrap h3 + * {
  margin-top: 30px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap h3 + * {
    margin-top: 25px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap h3 + * {
    margin-top: 20px;
  }
}
.page_contents .article_contents_wrap h4 {
  font-size: 24px;
  font-weight: 700;
  margin-top: 45px;
  padding-left: 1em;
  position: relative;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap h4 {
    margin-top: 35px;
    font-size: 20px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap h4 {
    margin-top: 30px;
    font-size: 4.5vw;
  }
}
.page_contents .article_contents_wrap h4::before {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  content: "";
  width: 12px;
  height: 12px;
  background-color: #40594e;
  border-radius: 4px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap h4::before {
    width: 8px;
    height: 8px;
    border-radius: 3px;
  }
}
.page_contents .article_contents_wrap h4 + * {
  margin-top: 20px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap h4 + * {
    margin-top: 15px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap h4 + * {
    margin-top: 15px;
  }
}
.page_contents .article_contents_wrap h5 {
  font-size: 22px;
  font-weight: 700;
  margin-top: 40px;
  width: -moz-fit-content;
  width: fit-content;
  background: linear-gradient(transparent 70%, #dcf0e9 70%);
}
.page_contents .article_contents_wrap h5 + * {
  margin-top: 25px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap h5 + * {
    margin-top: 20px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap h5 + * {
    margin-top: 15px;
  }
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap h5 {
    font-size: 20px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap h5 {
    font-size: 4.4vw;
  }
}
.page_contents .article_contents_wrap {
  /* テキスト */
}
.page_contents .article_contents_wrap p {
  font-size: 16px;
  line-height: 1.8;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap p {
    font-size: 3.8vw;
  }
}
.page_contents .article_contents_wrap p {
  /* テキスト内 強調 */
}
.page_contents .article_contents_wrap p strong {
  color: #f15a24;
}
.page_contents .article_contents_wrap p span {
  font-weight: 700;
}
.page_contents .article_contents_wrap p {
  /* 署名 */
}
.page_contents .article_contents_wrap p.signature {
  text-align: right;
  font-size: 16px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap p.signature {
    font-size: 3.8vw;
  }
}
.page_contents .article_contents_wrap p {
  /* ※ */
}
.page_contents .article_contents_wrap p.rice_mark {
  margin-top: 15px;
  text-indent: -1em;
  padding-left: 1em;
  font-size: 15px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap p.rice_mark {
    font-size: 3.6vw;
  }
}
.page_contents .article_contents_wrap p + p {
  margin-top: 25px;
}
.page_contents .article_contents_wrap p + figure {
  margin-top: 30px;
}
.page_contents .article_contents_wrap p + ul, .page_contents .article_contents_wrap p + ol {
  margin-top: 15px;
}
.page_contents .article_contents_wrap strong.big_text {
  display: block;
  font-weight: 900;
  line-height: 1.75;
  font-size: 32px;
  margin-top: 80px;
  text-align: center;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap strong.big_text {
    font-size: 24px;
    margin-top: 60px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap strong.big_text {
    font-size: 5.8vw;
  }
}
.page_contents .article_contents_wrap {
  /* リンク */
}
.page_contents .article_contents_wrap .link_btn {
  width: -moz-fit-content;
  width: fit-content;
  padding: 20px 25px;
}
.page_contents .article_contents_wrap a {
  font-size: 1em;
  font-weight: 700;
  cursor: pointer;
  color: #40594e;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: ease 0.25s text-decoration, ease 0.25s color;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap a {
    font-size: 3.8vw;
  }
}
.page_contents .article_contents_wrap a:hover {
  color: #919b8d;
  text-decoration: none;
  transition: ease 0.25s text-decoration, ease 0.25s color;
}
.page_contents .article_contents_wrap {
  /* 画像 / 画像キャプション */
}
.page_contents .article_contents_wrap figure {
  max-width: 100%;
}
.page_contents .article_contents_wrap figure figcaption {
  font-size: 16px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap figure figcaption {
    font-size: 12px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap figure figcaption {
    font-size: 3.5vw;
  }
}
.page_contents .article_contents_wrap figure figcaption + img {
  margin-top: 15px;
}
.page_contents .article_contents_wrap figure img {
  max-width: 100%;
}
.page_contents .article_contents_wrap figure img + figcaption {
  margin-top: 15px;
}
.page_contents .article_contents_wrap figure + figure {
  margin-top: 35px;
}
.page_contents .article_contents_wrap {
  /* リスト */
}
.page_contents .article_contents_wrap ul,
.page_contents .article_contents_wrap ol {
  line-height: 1.75;
}
.page_contents .article_contents_wrap ul li,
.page_contents .article_contents_wrap ol li {
  padding-left: 1.2em;
  position: relative;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: 16px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap ul li,
  .page_contents .article_contents_wrap ol li {
    font-size: 3.8vw;
  }
}
.page_contents .article_contents_wrap ul li::before,
.page_contents .article_contents_wrap ol li::before {
  position: absolute;
  left: 0;
  top: 0;
  font-weight: 700;
  width: 1em;
  height: 1em;
}
.page_contents .article_contents_wrap ul + p,
.page_contents .article_contents_wrap ol + p {
  margin-top: 15px;
}
.page_contents .article_contents_wrap ul + figure,
.page_contents .article_contents_wrap ol + figure {
  margin-top: 30px;
}
.page_contents .article_contents_wrap ul + ul, .page_contents .article_contents_wrap ul + ol,
.page_contents .article_contents_wrap ol + ul,
.page_contents .article_contents_wrap ol + ol {
  margin-top: 15px;
}
.page_contents .article_contents_wrap ul li::before {
  content: "・";
}
.page_contents .article_contents_wrap ol li {
  list-style-type: decimal;
  list-style-position: inside;
  text-indent: -1.2em;
}
.page_contents .article_contents_wrap ol li::before {
  content: none;
}
.page_contents .article_contents_wrap ol.alphabet li {
  list-style-type: upper-alpha;
}
.page_contents .article_contents_wrap {
  /* テーブル */
}
.page_contents .article_contents_wrap table {
  margin-top: 35px;
  font-size: 18px;
  width: min(800px, 100%);
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap table {
    margin-top: 25px;
    font-size: 3.6vw;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap table.w400 {
    width: 400px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap table.w500 {
    width: 500px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap table.w600 {
    width: 600px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap table.w700 {
    width: 700px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap table.w800 {
    width: 800px;
  }
}
.page_contents .article_contents_wrap table thead th {
  background-color: #dcf0e9;
  text-align: center;
}
.page_contents .article_contents_wrap table th,
.page_contents .article_contents_wrap table td {
  padding: 15px 30px;
  border: #40594e solid 1px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap table th,
  .page_contents .article_contents_wrap table td {
    padding: 10px 15px;
  }
}
.page_contents .article_contents_wrap table th span,
.page_contents .article_contents_wrap table td span {
  font-size: 15px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap table th span,
  .page_contents .article_contents_wrap table td span {
    font-size: 15px;
  }
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap table th span,
  .page_contents .article_contents_wrap table td span {
    font-size: 3.2vw;
  }
}
.page_contents .article_contents_wrap table tbody th.center,
.page_contents .article_contents_wrap table tbody td.center {
  text-align: center;
}
.page_contents .article_contents_wrap * + .column {
  margin-top: 30px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap * + .column {
    margin-top: 25px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap * + .column {
    margin-top: 20px;
  }
}
.page_contents .article_contents_wrap {
  /* 2カラム */
}
.page_contents .article_contents_wrap .column {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  row-gap: 35px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .column {
    gap: 30px;
    row-gap: 25px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column {
    flex-direction: column;
    gap: 25px;
  }
}
.page_contents .article_contents_wrap .column > * {
  width: 48%;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column > * {
    width: 100%;
  }
}
.page_contents .article_contents_wrap .column > p {
  flex: 1;
}
.page_contents .article_contents_wrap .column .no_half {
  width: auto;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column .no_half {
    max-width: 100%;
    margin-inline: auto;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column .no_half img {
    max-width: 100%;
    width: auto;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column .no_half figcaption {
    text-align: center;
  }
}
.page_contents .article_contents_wrap .column > .figure_box,
.page_contents .article_contents_wrap .column > figure {
  width: 48%;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column > .figure_box,
  .page_contents .article_contents_wrap .column > figure {
    width: 100%;
  }
}
.page_contents .article_contents_wrap .column > figure img {
  width: 100%;
}
.page_contents .article_contents_wrap .column .figure_box strong,
.page_contents .article_contents_wrap .column .figure_box h3,
.page_contents .article_contents_wrap .column .figure_box h4,
.page_contents .article_contents_wrap .column .figure_box h5 {
  text-align: center;
}
.page_contents .article_contents_wrap .column .figure_box figcaption {
  margin-top: 15px;
}
.page_contents .article_contents_wrap .column .figure_box > figure {
  width: 100%;
}
.page_contents .article_contents_wrap .column .figure_box > figure > img {
  width: 100%;
}
.page_contents .article_contents_wrap .column .figure_box.device_box .device_info {
  margin-top: 15px;
  border: #666666 solid 1px;
  padding: 15px 20px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column .figure_box.device_box .device_info {
    margin-top: 10px;
    padding: 15px;
  }
}
.page_contents .article_contents_wrap .column .figure_box.device_box .device_info strong {
  font-size: 18px;
  font-weight: 900;
  color: #f15a24;
  display: block;
  margin-bottom: 15px;
  text-align: left;
  line-height: 1.5;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column .figure_box.device_box .device_info strong {
    font-size: 4.2vw;
    margin-bottom: 10px;
  }
}
.page_contents .article_contents_wrap .column .figure_box.device_box .device_info dl dt {
  font-size: 16px;
  font-weight: 900;
  padding-bottom: 8px;
  border-bottom: #666666 solid 1px;
  margin-bottom: 10px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column .figure_box.device_box .device_info dl dt {
    font-size: 3.8vw;
  }
}
.page_contents .article_contents_wrap .column .figure_box.device_box .device_info dl dd {
  position: relative;
  font-weight: 600;
  line-height: 1.6em;
  padding-left: 1.2em;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column .figure_box.device_box .device_info dl dd {
    font-size: 3.8vw;
  }
}
.page_contents .article_contents_wrap .column .figure_box.device_box .device_info dl dd::before {
  position: absolute;
  left: 0;
  top: 0;
  width: 1em;
  height: 1em;
  content: "・";
}
.page_contents .article_contents_wrap .column figure + figure {
  margin-top: 0;
}
.page_contents .article_contents_wrap .column > .to_under {
  width: calc(50% - 15px);
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column > .to_under {
    width: 100%;
  }
}
.page_contents .article_contents_wrap .column {
  /* 3カラム */
}
.page_contents .article_contents_wrap .column.three {
  gap: 30px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .column.three {
    gap: 20px;
  }
}
.page_contents .article_contents_wrap .column.three > * {
  width: calc(33.3333333333% - 20px);
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .column.three > * {
    width: calc(33.3333333333% - 10px);
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column.three > * {
    width: 100%;
  }
}
.page_contents .article_contents_wrap .column.three > .to_under {
  width: calc(33.3333333333% - 20px);
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .column.three > .to_under {
    width: calc(50% - 15px);
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column.three > .to_under {
    width: 100%;
  }
}
.page_contents .article_contents_wrap .column.three .height_align figure {
  text-align: center;
}
.page_contents .article_contents_wrap .column.three .height_align figure img {
  width: auto;
  height: 250px;
}
.page_contents .article_contents_wrap .column.three .height_align figure figcaption {
  text-align: left;
}
.page_contents .article_contents_wrap .column {
  /* 4カラム */
}
.page_contents .article_contents_wrap .column.four {
  gap: 10px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .column.four {
    gap: 20px;
  }
}
.page_contents .article_contents_wrap .column.four > * {
  width: calc(25% - 7.5px);
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .column.four > * {
    width: calc(50% - 10px);
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column.four > * {
    width: 100%;
  }
}
.page_contents .article_contents_wrap .column + p, .page_contents .article_contents_wrap .column + .column, .page_contents .article_contents_wrap .column + div, .page_contents .article_contents_wrap .column + table, .page_contents .article_contents_wrap .column + dl, .page_contents .article_contents_wrap .column + ol, .page_contents .article_contents_wrap .column + ul, .page_contents .article_contents_wrap .column + img, .page_contents .article_contents_wrap .column + figure {
  margin-top: 30px;
}
.page_contents .article_contents_wrap .column {
  /* 下層ページへの動線 */
}
.page_contents .article_contents_wrap .column.to_under_wrap {
  gap: 30px;
  row-gap: 30px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .column.to_under_wrap {
    gap: 20px;
  }
}
.page_contents .article_contents_wrap .column.to_under_wrap .to_under {
  display: block;
  padding: 25px 20px;
  border-radius: 5px;
  font-size: 18px;
  text-decoration: none;
  text-align: center;
  background-color: #dcf0e9;
  box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.5);
  position: relative;
  transition: ease background-color 0.2s, ease color 0.2s;
}
.page_contents .article_contents_wrap .column.to_under_wrap .to_under::after {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 9px;
  height: 12px;
  content: "";
  background-image: url(../img/arrow_g_left.svg);
  background-repeat: no-repeat;
  background-position: center center;
  transition: ease right 0.2s;
}
.page_contents .article_contents_wrap .column.to_under_wrap .to_under:hover {
  background-color: #40594e;
  color: #ffffff;
  transition: ease background-color 0.2s, ease color 0.2s;
}
.page_contents .article_contents_wrap .column.to_under_wrap .to_under:hover::after {
  right: 17px;
  background-image: url(../img/arrow_w_left.svg);
  transition: ease right 0.2s;
}
.page_contents .article_contents_wrap {
  /* ボックス */
}
.page_contents .article_contents_wrap .box {
  width: calc(50% - 20px);
  padding: 50px;
  background-color: #f2f2f2;
  display: flex;
  flex-direction: column;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .box {
    padding: 40px 25px;
    width: calc(50% - 15px);
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .box {
    width: 100%;
    padding: 35px 20px;
  }
}
.page_contents .article_contents_wrap .box h3,
.page_contents .article_contents_wrap .box h4,
.page_contents .article_contents_wrap .box h5 {
  text-align: center;
  font-size: 22px;
  padding-left: 0;
  border-bottom: #40594e solid 1px;
  padding: 0 0 15px 0;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .box h3,
  .page_contents .article_contents_wrap .box h4,
  .page_contents .article_contents_wrap .box h5 {
    font-size: 20px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .box h3,
  .page_contents .article_contents_wrap .box h4,
  .page_contents .article_contents_wrap .box h5 {
    font-size: 4.8vw;
  }
}
.page_contents .article_contents_wrap .box h3::before, .page_contents .article_contents_wrap .box h3::after,
.page_contents .article_contents_wrap .box h4::before,
.page_contents .article_contents_wrap .box h4::after,
.page_contents .article_contents_wrap .box h5::before,
.page_contents .article_contents_wrap .box h5::after {
  content: none;
}
.page_contents .article_contents_wrap .box h3 + *,
.page_contents .article_contents_wrap .box h4 + *,
.page_contents .article_contents_wrap .box h5 + * {
  margin-top: 20px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .box h3 + *,
  .page_contents .article_contents_wrap .box h4 + *,
  .page_contents .article_contents_wrap .box h5 + * {
    margin-top: 15px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .box h3 + *,
  .page_contents .article_contents_wrap .box h4 + *,
  .page_contents .article_contents_wrap .box h5 + * {
    margin-top: 15px;
  }
}
.page_contents .article_contents_wrap .box h3 + strong,
.page_contents .article_contents_wrap .box h4 + strong,
.page_contents .article_contents_wrap .box h5 + strong {
  font-size: 20px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .box h3 + strong,
  .page_contents .article_contents_wrap .box h4 + strong,
  .page_contents .article_contents_wrap .box h5 + strong {
    font-size: 18px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .box h3 + strong,
  .page_contents .article_contents_wrap .box h4 + strong,
  .page_contents .article_contents_wrap .box h5 + strong {
    font-size: 4.2vw;
  }
}
.page_contents .article_contents_wrap .box strong {
  text-align: center;
  font-size: 22px;
  line-height: 1.7em;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  flex-grow: 1;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .box strong {
    font-size: 20px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .box strong {
    font-size: 4.6vw;
  }
}
.page_contents .article_contents_wrap .box strong::before, .page_contents .article_contents_wrap .box strong::after {
  content: none;
}
.page_contents .article_contents_wrap .box figure {
  margin-top: 25px;
  width: 100%;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .box figure {
    margin-top: 20px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .box figure {
    margin-top: 15px;
  }
}
.page_contents .article_contents_wrap .box figure img {
  width: 100%;
  border-radius: 6px;
}
.page_contents .article_contents_wrap .box figure + figure {
  margin-top: 30px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .box figure + figure {
    margin-top: 25px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .box figure + figure {
    margin-top: 20px;
  }
}
.page_contents .article_contents_wrap .box {
  /* 担当医 */
}
.page_contents .article_contents_wrap .box.charge {
  padding: 35px 25px;
}
.page_contents .article_contents_wrap .box.charge .name_block {
  border-top: none;
}
.page_contents .article_contents_wrap .box.charge .name_block:nth-child(n+3) {
  margin-top: 20px;
  padding-top: 15px;
  border-top: #b3b3b3 solid 1px;
}
.page_contents .article_contents_wrap .box.charge .name_block strong {
  font-size: 28px;
  text-align: center;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .box.charge .name_block strong {
    font-size: 26px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .box.charge .name_block strong {
    font-size: 6.6vw;
    margin-top: 25px;
  }
}
.page_contents .article_contents_wrap .box.charge .name_block strong + span {
  font-size: 16px;
  margin-top: 5px;
}
.page_contents .article_contents_wrap .box.charge .name_block span {
  display: block;
  text-align: center;
  font-size: 16px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .box.charge .name_block span {
    font-size: 3.8vw;
  }
}
.page_contents .article_contents_wrap .box.charge h3,
.page_contents .article_contents_wrap .box.charge h4,
.page_contents .article_contents_wrap .box.charge h5,
.page_contents .article_contents_wrap .box.charge h6 {
  font-size: 24px;
  padding-bottom: 25px;
  margin-bottom: 25px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .box.charge h3,
  .page_contents .article_contents_wrap .box.charge h4,
  .page_contents .article_contents_wrap .box.charge h5,
  .page_contents .article_contents_wrap .box.charge h6 {
    font-size: 18px;
  }
}
.page_contents .article_contents_wrap .box.charge h3 + *,
.page_contents .article_contents_wrap .box.charge h4 + *,
.page_contents .article_contents_wrap .box.charge h5 + *,
.page_contents .article_contents_wrap .box.charge h6 + * {
  margin-top: 0;
}
.page_contents .article_contents_wrap .link_btn {
  margin-top: 65px;
  color: #ffffff;
}
.page_contents .article_contents_wrap {
  /* STEP */
}
.page_contents .article_contents_wrap .step {
  display: flex;
  flex-direction: column;
  margin-top: 30px;
}
.page_contents .article_contents_wrap .step > div strong {
  display: block;
  background-color: #f2f2f2;
  border: #40594e solid 1px;
  padding: 18px;
  text-align: center;
  font-size: 22px;
  font-weight: 700;
  border-radius: 10px;
  line-height: 1.5em;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .step > div strong {
    padding: 15px;
    font-size: 5vw;
  }
}
.page_contents .article_contents_wrap .step > div p {
  font-size: 16px;
  margin: 20px 20px 10px 20px;
  line-height: 1.7em;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .step > div p {
    font-size: 3.5vw;
    margin: 15px 15px 5px 15px;
  }
}
.page_contents .article_contents_wrap .step > div + div {
  margin-top: 35px;
  position: relative;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .step > div + div {
    margin-top: 25px;
  }
}
.page_contents .article_contents_wrap .step > div + div::before {
  position: absolute;
  bottom: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%) rotate(180deg);
  content: "";
  width: 18px;
  height: 15px;
  background-image: url(../img/arrow_g_top.svg);
  background-repeat: no-repeat;
  background-position: center center;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .step > div + div::before {
    width: 15px;
    height: 10px;
    bottom: calc(100% + 8px);
  }
}
.page_contents .article_contents_wrap {
  /* チェックリスト */
}
.page_contents .article_contents_wrap .check {
  padding: 35px 30px;
  border-radius: 8px;
  border: #40594e solid 2px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .check {
    padding: 30px 25px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .check {
    padding: 20px 15px;
  }
}
.page_contents .article_contents_wrap .check li {
  padding-left: 40px;
  position: relative;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: 18px;
  line-height: 1.5em;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .check li {
    font-size: 4vw;
    padding-left: 30px;
  }
}
.page_contents .article_contents_wrap .check li span {
  color: #f15a24;
}
.page_contents .article_contents_wrap .check li::before {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  height: 100%;
  width: 25px;
  background-image: url(../img/page/check_icon.svg);
  background-repeat: no-repeat;
  background-position: center;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .check li::before {
    width: 20px;
  }
}
.page_contents .article_contents_wrap .check li + li {
  margin-top: 25px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .check li + li {
    margin-top: 20px;
  }
}
.page_contents .article_contents_wrap {
  /* 価格テーブル */
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .price_table {
    width: 600px;
  }
}
.page_contents .article_contents_wrap .price_table .number {
  width: 15%;
  text-align: center;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .price_table .number {
    width: auto;
  }
}
.page_contents .article_contents_wrap .price_table th,
.page_contents .article_contents_wrap .price_table td {
  vertical-align: middle;
  text-wrap-mode: nowrap;
}
@media (max-width: 1439px) {
  .page_contents .article_contents_wrap .price_table th,
  .page_contents .article_contents_wrap .price_table td {
    padding: 15px 20px;
  }
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .price_table th,
  .page_contents .article_contents_wrap .price_table td {
    padding: 15px 10px;
  }
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .price_table th span {
    font-size: 14px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .price_table th span {
    font-size: 3.2vw;
  }
}
.page_contents .article_contents_wrap .price_table td {
  width: auto;
}
.page_contents .article_contents_wrap .price_table td.price {
  text-align: right;
}
.page_contents .article_contents_wrap {
  /* スタッフ　ボックス */
}
.page_contents .article_contents_wrap .staff {
  display: flex;
  gap: 40px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .staff {
    gap: 25px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .staff {
    flex-wrap: wrap;
    flex-direction: column;
    gap: 30px;
  }
}
.page_contents .article_contents_wrap .staff figure {
  width: 320px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .staff figure {
    width: 300px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .staff figure {
    width: 100%;
  }
}
.page_contents .article_contents_wrap .staff figure img {
  -o-object-fit: contain;
     object-fit: contain;
  width: 100%;
  height: 300px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .staff figure img {
    height: 200px;
  }
}
.page_contents .article_contents_wrap .staff .staff_text {
  flex: 1;
}
.page_contents .article_contents_wrap .staff .staff_text * {
  font-family: inherit;
}
.page_contents .article_contents_wrap .staff .staff_text > p, .page_contents .article_contents_wrap .staff .staff_text > ul, .page_contents .article_contents_wrap .staff .staff_text > ol, .page_contents .article_contents_wrap .staff .staff_text > strong {
  margin-top: 15px;
  padding-top: 15px;
  position: relative;
  border-top: #666666 solid 1px;
}
.page_contents .article_contents_wrap .staff .staff_text > table {
  margin-top: 15px;
}
.page_contents .article_contents_wrap .staff .staff_text p {
  line-height: 1.8;
}
.page_contents .article_contents_wrap .staff .staff_text span {
  display: block;
  font-size: 16px;
  line-height: 1.8;
  font-weight: 700;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .staff .staff_text span {
    font-size: 3.5vw;
  }
}
.page_contents .article_contents_wrap .staff .staff_text span + h3 {
  margin-top: 10px;
}
.page_contents .article_contents_wrap .staff .staff_text h3 {
  font-size: 24px;
  padding: 0;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .staff .staff_text h3 {
    font-size: 5.2vw;
  }
}
.page_contents .article_contents_wrap .staff .staff_text h3::before {
  content: none;
}
.page_contents .article_contents_wrap .staff .staff_text h3 + span {
  margin-top: 10px;
}
.page_contents .article_contents_wrap .staff .staff_text h4 {
  font-size: 20px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .staff .staff_text h4 {
    font-size: 4.2vw;
  }
}
.page_contents .article_contents_wrap .staff .staff_text h4::before {
  width: 8px;
  height: 8px;
  border-radius: 2px;
}
.page_contents .article_contents_wrap .staff .staff_text h4 + span {
  margin-top: 10px;
}
.page_contents .article_contents_wrap .staff .staff_text strong {
  font-size: 18px;
  display: block;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .staff .staff_text strong {
    font-size: 4vw;
  }
}
.page_contents .article_contents_wrap .staff .staff_text strong + * {
  margin-top: 10px;
}
.page_contents .article_contents_wrap .staff .staff_text strong + p, .page_contents .article_contents_wrap .staff .staff_text strong + ul, .page_contents .article_contents_wrap .staff .staff_text strong + ol {
  padding-top: 0;
  border-top: none;
}
.page_contents .article_contents_wrap .staff .staff_text ul,
.page_contents .article_contents_wrap .staff .staff_text ol {
  line-height: 2em;
}
.page_contents .article_contents_wrap .staff .staff_text ul li,
.page_contents .article_contents_wrap .staff .staff_text ol li {
  margin-top: 0;
}
.page_contents .article_contents_wrap .staff .staff_text table {
  width: auto;
  font-size: 16px;
}
.page_contents .article_contents_wrap .staff .staff_text table th,
.page_contents .article_contents_wrap .staff .staff_text table td {
  border: none;
  padding: 0;
  color: #666666;
  line-height: 2em;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .staff .staff_text table th,
  .page_contents .article_contents_wrap .staff .staff_text table td {
    font-size: 3.8vw;
    line-height: 2em;
  }
}
.page_contents .article_contents_wrap .staff .staff_text table th {
  width: 90px;
}
.page_contents .article_contents_wrap .staff .staff_text.message_text > p {
  margin-top: 0;
  padding-top: 0;
  position: relative;
  border-top: none;
}
.page_contents .article_contents_wrap .staff + .staff {
  margin-top: 45px;
}
.page_contents .article_contents_wrap {
  /* Google MAP */
}
.page_contents .article_contents_wrap .google_map_wrap {
  position: relative;
  aspect-ratio: 16/9;
  max-width: 600px;
  width: 100%;
  height: auto;
}
.page_contents .article_contents_wrap .google_map_wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.page_contents .article_contents_wrap {
  /** 担当医のご案内 **/
}
.page_contents .article_contents_wrap .doctor_table_wrap table {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
  border-spacing: 8px;
  border: 1px solid #fff;
  width: 1047px;
  max-width: 100%;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .doctor_table_wrap table {
    max-width: none;
    width: 800px;
  }
}
.page_contents .article_contents_wrap .doctor_table_wrap table tr th,
.page_contents .article_contents_wrap .doctor_table_wrap table tr td {
  text-align: center;
  vertical-align: middle;
  padding: 20px 10px 20px 10px;
  border: 8px solid #fff;
  font-weight: 500;
}
.page_contents .article_contents_wrap .doctor_table_wrap table tr th span,
.page_contents .article_contents_wrap .doctor_table_wrap table tr td span {
  display: block;
  font-size: 18px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .doctor_table_wrap table tr th span,
  .page_contents .article_contents_wrap .doctor_table_wrap table tr td span {
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .doctor_table_wrap table tr th span,
  .page_contents .article_contents_wrap .doctor_table_wrap table tr td span {
    font-size: 4.2vw;
  }
}
.page_contents .article_contents_wrap .doctor_table_wrap table tr th span .only_week,
.page_contents .article_contents_wrap .doctor_table_wrap table tr td span .only_week {
  display: block;
  font-size: 14px;
  padding: 5px;
  width: 100px;
  letter-spacing: 0;
  border: 1px solid #40594e;
  background-color: #fff;
  border-radius: 15px;
  margin-bottom: 8px;
  margin-inline: auto;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .doctor_table_wrap table tr th span .only_week,
  .page_contents .article_contents_wrap .doctor_table_wrap table tr td span .only_week {
    font-size: 13px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .doctor_table_wrap table tr th span .only_week,
  .page_contents .article_contents_wrap .doctor_table_wrap table tr td span .only_week {
    font-size: 3.2vw;
  }
}
.page_contents .article_contents_wrap .doctor_table_wrap table tr th span:nth-child(n+2),
.page_contents .article_contents_wrap .doctor_table_wrap table tr td span:nth-child(n+2) {
  margin-top: 20px;
}
.page_contents .article_contents_wrap .doctor_table_wrap table tr th {
  background-color: #40594e;
  padding: 20px 5px 20px;
}
.page_contents .article_contents_wrap .doctor_table_wrap table tr th span {
  display: block;
  color: #fff;
  font-size: 18px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .doctor_table_wrap table tr th span {
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .doctor_table_wrap table tr th span {
    font-size: 4.2vw;
  }
}
.page_contents .article_contents_wrap .doctor_table_wrap table tr th .d_of_w {
  font-size: 12px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .doctor_table_wrap table tr th .d_of_w {
    font-size: 3.8vw;
  }
}
.page_contents .article_contents_wrap .doctor_table_wrap table tr td {
  color: #40594e;
  background-color: #e0f0da;
}
.page_contents .article_contents_wrap .doctor_table_wrap table tr td.noDoc {
  background-color: #d5dbd8;
}
.page_contents .article_contents_wrap .doctor_table_wrap table thead tr th {
  padding: 10px 10px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .doctor_table_wrap table thead tr th {
    padding: 5px 10px;
    width: 23.5%;
  }
}
.page_contents .article_contents_wrap .doctor_table_wrap table thead tr th.days {
  padding: 10px 5px;
  width: 6%;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .doctor_table_wrap table thead tr th.days {
    padding: 5px 8px;
  }
}
.page_contents .article_contents_wrap .doctor_table_wrap table thead tr th.afternoon {
  background-color: #4a7c84;
}

.inspection_contents .page_title_wrap {
  background-image: url(../img/page/inspection_dammy_image.jpg);
}

/*** error page ***/
.error_wrap {
  padding-top: 35px !important;
  margin-bottom: 120px;
}
@media (max-width: 767px) {
  .error_wrap {
    margin-bottom: 80px;
  }
}
.error_wrap .breadcrumb {
  padding: 35px 0 45px 0;
}
@media (max-width: 767px) {
  .error_wrap .breadcrumb {
    padding: 30px 0 35px 0;
  }
}
.error_wrap .error_title_wrap {
  margin-top: 65px;
  text-align: center;
}
@media (max-width: 767px) {
  .error_wrap .error_title_wrap {
    margin-top: 30px;
  }
}
.error_wrap .error_title_wrap h1 {
  display: flex;
  justify-content: center;
  flex-direction: column;
  gap: 20px;
}
@media (max-width: 767px) {
  .error_wrap .error_title_wrap h1 {
    gap: 10px;
  }
}
.error_wrap .error_title_wrap h1 strong {
  font-size: 72px;
}
@media (max-width: 767px) {
  .error_wrap .error_title_wrap h1 strong {
    font-size: 15.2vw;
  }
}
.error_wrap .error_title_wrap h1 span {
  font-size: 32px;
}
@media (max-width: 767px) {
  .error_wrap .error_title_wrap h1 span {
    font-size: 6.8vw;
  }
}
.error_wrap .error_title_wrap h1.ja_heading strong {
  font-size: 52px;
}
@media (max-width: 767px) {
  .error_wrap .error_title_wrap h1.ja_heading strong {
    font-size: 7.8vw;
  }
}
.error_wrap > * {
  margin-top: 50px;
}
@media (max-width: 767px) {
  .error_wrap > * {
    margin-top: 40px;
  }
}
.error_wrap .error_contents {
  text-align: center;
}
.error_wrap .error_contents h2 {
  font-size: 22px;
  line-height: 1.5;
}
@media (max-width: 767px) {
  .error_wrap .error_contents h2 {
    font-size: 4.8vw;
  }
}
.error_wrap .error_contents p {
  line-height: 1.75;
}
@media (max-width: 767px) {
  .error_wrap .error_contents p {
    font-size: 3.8vw;
  }
}

/*** 小児眼科ページ ***/
.page_pediatric {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  font-style: normal;
}
.page_pediatric .lp_eng {
  font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}
.page_pediatric .sec_title strong {
  color: #00cc99;
  font-size: 26px;
}
@media (max-width: 767px) {
  .page_pediatric .sec_title strong {
    font-size: 6.2vw;
  }
}
.page_pediatric .wrap {
  width: min(1000px, 95%);
  padding: 85px 0 0 0;
}
@media (max-width: 767px) {
  .page_pediatric .wrap {
    width: 90%;
  }
}
@media (max-width: 1295px) {
  .page_pediatric .hamburger {
    display: block;
  }
}
.page_pediatric .header.page_header {
  border-bottom: none;
}
.page_pediatric .header .header_inner {
  justify-content: space-between;
}
@media (max-width: 1295px) {
  .page_pediatric .header .header_inner {
    padding-top: 10px;
    padding-bottom: 10px;
  }
}
.page_pediatric .header .header_main {
  display: flex;
  align-items: center;
  width: auto;
  flex: 1;
  gap: 35px;
}
.page_pediatric .header .header_main h1 {
  width: 188px;
}
.page_pediatric .header .header_main .main_nav {
  width: auto;
}
@media (max-width: 1295px) {
  .page_pediatric .header .header_main .main_nav {
    width: 100%;
  }
}
.page_pediatric .header .phone_number {
  color: #4664dc;
  width: min(290px, 90%);
}
@media (max-width: 1295px) {
  .page_pediatric .header .phone_number {
    position: fixed;
    left: 50%;
    bottom: 6.5dvh;
    transform: translateX(-50%);
  }
}
@media (max-width: 1023px) {
  .page_pediatric .header .phone_number {
    bottom: 5dvh;
  }
}
@media (max-width: 767px) {
  .page_pediatric .header .phone_number {
    bottom: 5.3dvh;
    left: 5%;
    transform: none;
  }
}
.page_pediatric .header .phone_number .phone_inner {
  border: solid 1px #4664dc;
  border-radius: 30px;
  display: flex;
  align-items: center;
  padding: 10px 20px;
  background-color: #ffffff;
  transition: ease background-color 0.25s;
}
.page_pediatric .header .phone_number .phone_inner span {
  transition: ease color 0.25s;
}
.page_pediatric .header .phone_number .phone_inner span.phone_title {
  font-size: 12px;
  font-weight: 700;
  width: -moz-max-content;
  width: max-content;
  padding-right: 15px;
}
.page_pediatric .header .phone_number .phone_inner span.number {
  font-size: 18px;
  padding-left: 15px;
  border-left: solid 1px #4664dc;
}
.page_pediatric .header .phone_number .phone_inner:hover {
  transition: ease background-color 0.25s;
  background-color: #4664dc;
}
.page_pediatric .header .phone_number .phone_inner:hover span {
  color: #fff;
  transition: ease color 0.25s;
}
.page_pediatric .header .phone_number .phone_inner:hover span.number {
  border-left: #fff 1px solid;
}
@media (max-width: 1295px) {
  .page_pediatric .main_nav {
    opacity: 0;
    visibility: hidden;
    display: none;
    position: fixed;
    top: 100px;
    width: 100%;
    height: 95%;
    overflow-y: scroll;
    background-color: #ffffff;
    top: 65px;
    left: 0;
  }
}
@media (max-width: 1295px) {
  .page_pediatric .main_nav .menu {
    width: 80%;
    margin-inline: auto;
    padding-top: 25px;
    padding-bottom: 35px;
    flex-direction: column;
    justify-content: center;
    gap: 0;
  }
}
@media (max-width: 1023px) {
  .page_pediatric .main_nav .menu {
    width: 80%;
    margin-inline: auto;
    padding-top: 25px;
    flex-direction: column;
    justify-content: center;
    gap: 0;
  }
}
@media (max-width: 1295px) {
  .page_pediatric .main_nav .menu .menu_item {
    width: 100%;
    text-align: center;
    padding: 15px 10px;
    border-bottom: #00cc99 solid 1px;
  }
}
@media (max-width: 1023px) {
  .page_pediatric .main_nav .menu .menu_item {
    padding: 15px 10px;
  }
}
.page_pediatric .main_nav .menu .menu_item a {
  font-size: 15px;
  color: #00cc99;
  font-weight: 700;
  transition: ease color 0.25s;
}
@media (max-width: 1295px) {
  .page_pediatric .main_nav .menu .menu_item a {
    display: inline-block;
    font-size: 18px;
    color: #00cc99;
  }
}
@media (max-width: 1023px) {
  .page_pediatric .main_nav .menu .menu_item a {
    display: inline-block;
    font-size: 18px;
    color: #00cc99 !important;
    padding: 0;
    border-bottom: none;
  }
}
@media (max-width: 767px) {
  .page_pediatric .main_nav .menu .menu_item a {
    font-size: 4.2vw;
  }
}
@media (max-width: 1295px) {
  .page_pediatric .main_nav .menu .menu_item a::after {
    content: none;
  }
}
.page_pediatric .main_nav .menu .menu_item:hover a {
  color: #808080;
  transition: ease color 0.25s;
}
@media (max-width: 1295px) {
  .page_pediatric .main_nav .menu .menu_item:hover a {
    color: #808080 !important;
  }
}
@media (max-width: 1295px) {
  .page_pediatric .main_nav .menu .menu_item:hover::after {
    content: none;
  }
}
.page_pediatric .main_nav .menu .menu_item.has_children {
  position: relative;
}
.page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap {
  position: absolute;
  top: 68px;
  padding: 25px 15px 15px;
  width: 230px;
}
@media (max-width: 1295px) {
  .page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap {
    position: static;
    width: 100%;
    height: auto;
    opacity: 1;
    visibility: visible;
    transform: none;
  }
}
@media (max-width: 767px) {
  .page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap {
    padding: 20px 0 0;
  }
}
.page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap .sub_menus {
  width: 100%;
}
@media (max-width: 1295px) {
  .page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap .sub_menus {
    justify-content: center;
    visibility: visible;
  }
}
@media (max-width: 767px) {
  .page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap .sub_menus {
    -moz-column-gap: 15px;
         column-gap: 15px;
  }
}
.page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap .sub_menus .sub_menu {
  gap: 0;
}
.page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap .sub_menus li {
  width: 100%;
  padding-bottom: 15px;
  border-bottom: 1px solid #00cc99;
  margin-bottom: 15px;
  padding-left: 23px;
}
@media (max-width: 1295px) {
  .page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap .sub_menus li {
    padding: 0;
    text-align: center;
    border-bottom: none;
  }
}
.page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap .sub_menus li::before {
  background: url(../img/lp/sub_menu_icon_b.svg);
  background-repeat: no-repeat;
  width: 16px;
  height: 16px;
  top: 4px;
}
@media (max-width: 1295px) {
  .page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap .sub_menus li::before {
    content: none;
  }
}
.page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap .sub_menus li:last-child {
  margin-bottom: 0;
}
.page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap .sub_menus li a {
  font-size: 14px;
}
@media (max-width: 1295px) {
  .page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap .sub_menus li a {
    color: #808080 !important;
  }
}
@media (max-width: 767px) {
  .page_pediatric .main_nav .menu .menu_item.has_children .sub_menu_wrap .sub_menus li a {
    font-size: 3.8vw;
  }
}
@media (max-width: 1295px) {
  .page_pediatric .main_nav .menu .menu_item.has_children::before {
    content: none;
  }
}
.page_pediatric .main_nav.open {
  opacity: 1;
  visibility: visible;
  display: block;
  padding: 20px;
}
.page_pediatric .fv {
  margin: 0 auto;
  max-width: 92.2vw;
}
@media (max-width: 767px) {
  .page_pediatric .fv {
    padding: 20vw 0 0 0;
  }
}
.page_pediatric .fv + section .wrap {
  padding: 85px 0 85px 0;
}
@media (max-width: 767px) {
  .page_pediatric .fv + section .wrap {
    padding: 45px 0 45px 0;
  }
}
.page_pediatric .fv_inner {
  padding: 0;
  margin: 70px 0 0 0;
  position: relative;
}
@media (max-width: 767px) {
  .page_pediatric .fv_inner {
    border-radius: 25px;
    overflow: hidden;
    margin-top: 0;
  }
}
.page_pediatric .fv_inner picture img {
  width: 100%;
}
@media (max-width: 767px) {
  .page_pediatric .fv_inner picture img {
    width: 100%;
    height: 60vh;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.page_pediatric .fv_inner .main_catch {
  font-size: 32px;
  font-weight: 700;
  line-height: 2em;
  letter-spacing: 0.3em;
  writing-mode: vertical-rl;
  color: #ffffff;
  text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.2);
  position: absolute;
  top: 75px;
  left: 75px;
}
@media (max-width: 1023px) {
  .page_pediatric .fv_inner .main_catch {
    top: 40px;
    left: 40px;
    font-size: 28px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .fv_inner .main_catch {
    top: 30px;
    left: auto;
    right: 20px;
    font-size: 6.8vw;
    line-height: 1.8em;
    text-shadow: 2px 2px 2px rgba(0, 0, 0, 0.3);
  }
}
.page_pediatric .fv_inner .main_catch span {
  display: inline-block;
  text-indent: -0.3em;
}
.page_pediatric section .center_text {
  text-align: center;
  font-size: 18px;
  font-weight: 400;
  line-height: 2.25em;
}
@media (max-width: 767px) {
  .page_pediatric section .center_text {
    font-size: 4.2vw;
    text-align: left;
  }
}
.page_pediatric #guide .wrap {
  padding-top: 0;
  margin-bottom: 15px;
}
.page_pediatric .circle_wrap {
  display: flex;
  justify-content: center;
}
.page_pediatric .circle_wrap .circle {
  border-radius: 50%;
  background-color: #ededea;
  border: 1px solid #333333;
  width: 300px;
  height: 300px;
  box-shadow: rgba(128, 128, 128, 0.75) 7px 9px;
  position: relative;
  top: -50%;
}
@media (max-width: 767px) {
  .page_pediatric .circle_wrap .circle {
    width: 68vw;
    height: 68vw;
  }
}
.page_pediatric .circle_wrap .circle::before {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  content: "";
  width: 100%;
  height: 2px;
  background-color: #ededea;
  z-index: 20;
}
@media (max-width: 767px) {
  .page_pediatric .circle_wrap .circle::before {
    height: 3px;
  }
}
.page_pediatric .circle_wrap .circle .sec_title {
  position: absolute;
  left: 50%;
  top: 25%;
  transform: translateX(-50%);
  z-index: 20;
}
@media (max-width: 767px) {
  .page_pediatric .circle_wrap .circle .sec_title {
    gap: 5px;
    top: 20%;
  }
}
.page_pediatric .circle_wrap .circle .sec_title span {
  font-size: 18px;
  color: #4664dc;
  font-weight: 700;
  line-height: 1.7em;
}
@media (max-width: 767px) {
  .page_pediatric .circle_wrap .circle .sec_title span {
    font-size: 4.2vw;
  }
}
.page_pediatric .bord {
  margin-top: -150px;
  background-color: #ededea;
  border: 1px solid #333333;
  box-shadow: rgba(128, 128, 128, 0.75) 7px 9px;
  border-radius: 30px;
  padding: 40px 90px 45px 90px;
  z-index: 15;
  position: relative;
}
@media (max-width: 1023px) {
  .page_pediatric .bord {
    padding: 30px 50px 35px 50px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .bord {
    margin-top: -34vw;
    padding: 25px 20px 30px 20px;
  }
}
.page_pediatric .bord .chirdren {
  text-align: center;
}
@media (max-width: 767px) {
  .page_pediatric .bord .chirdren {
    width: 80%;
    margin-inline: auto;
  }
}
.page_pediatric .bord .check_list li {
  padding: 20px 25px;
  border-top: solid 1px #999999;
}
@media (max-width: 767px) {
  .page_pediatric .bord .check_list li {
    padding: 20px 10px 20px 10px;
  }
}
.page_pediatric .bord .check_list li:last-child {
  border-bottom: solid 1px #999999;
}
.page_pediatric .bord .check_list li span {
  display: inline-block;
  padding-left: 60px;
  position: relative;
  font-size: 20px;
  line-height: 1.4em;
  font-weight: 700;
}
@media (max-width: 1023px) {
  .page_pediatric .bord .check_list li span {
    padding-left: 50px;
    font-size: 18px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .bord .check_list li span {
    padding-left: 35px;
    font-size: 4.5vw;
  }
}
.page_pediatric .bord .check_list li span::before {
  position: absolute;
  left: 0;
  top: 2px;
  width: 30px;
  height: 25px;
  content: "";
  background-image: url(../img/lp/checkbox.svg);
  background-position: center center;
  background-repeat: no-repeat;
}
@media (max-width: 767px) {
  .page_pediatric .bord .check_list li span::before {
    width: 25px;
    height: 20px;
    top: 3px;
  }
}
.page_pediatric .bord .sign {
  display: block;
  text-align: center;
  font-size: 24px;
  font-weight: 700;
  margin-top: 45px;
  color: #4664dc;
}
@media (max-width: 1023px) {
  .page_pediatric .bord .sign {
    font-size: 22px;
    margin-top: 35px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .bord .sign {
    font-size: 4.8vw;
    margin-top: 25px;
  }
}
.page_pediatric {
  /* 診察の流れ */
}
.page_pediatric #flow .wrap {
  padding: 85px 0 75px 0;
}
@media (max-width: 767px) {
  .page_pediatric #flow .wrap {
    padding: 75px 0 45px 0;
  }
}
.page_pediatric .step_list {
  display: flex;
  flex-direction: column;
  gap: 75px;
}
@media (max-width: 767px) {
  .page_pediatric .step_list {
    gap: 50px;
  }
}
.page_pediatric .step_item {
  flex-grow: 1;
  display: flex;
  justify-content: flex-end;
  position: relative;
}
@media (max-width: 767px) {
  .page_pediatric .step_item {
    padding-top: 10vw;
  }
}
.page_pediatric .step_item::after {
  position: absolute;
  top: calc(100% + 30px);
  right: 45%;
  transform: translateX(-50%);
  width: 35px;
  height: 18px;
  content: "";
  background-image: url(../img/lp/flow_arrow.svg);
  background-repeat: no-repeat;
}
@media (max-width: 767px) {
  .page_pediatric .step_item::after {
    right: auto;
    left: 50%;
    top: calc(100% + 20px);
    width: 25px;
    height: 15px;
  }
}
.page_pediatric .step_item:nth-child(2n) .step_item_inner {
  background-color: #ededea;
}
.page_pediatric .step_item:last-child::after {
  content: none;
}
.page_pediatric .step_item figure {
  width: min(280px, 32%);
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 15;
}
@media (max-width: 767px) {
  .page_pediatric .step_item figure {
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 50%;
  }
}
.page_pediatric .step_item .step_item_inner {
  width: 90%;
  background-color: #e7f5f7;
  display: flex;
  justify-content: space-between;
  padding: 30px 60px 30px 20%;
  position: relative;
  border-radius: 30px;
  border: solid 1px #333333;
}
@media (max-width: 1023px) {
  .page_pediatric .step_item .step_item_inner {
    padding: 25px 30px 25px 25%;
  }
}
@media (max-width: 767px) {
  .page_pediatric .step_item .step_item_inner {
    width: 100%;
    flex-direction: column;
    padding: 35vw 25px 20px 25px;
  }
}
.page_pediatric .step_item .step_item_inner .step_number {
  width: 20%;
  display: flex;
  align-items: center;
  gap: 5px;
  color: #666666;
  margin-right: 25px;
}
@media (max-width: 1023px) {
  .page_pediatric .step_item .step_item_inner .step_number {
    width: 13%;
    flex-direction: column;
    justify-content: center;
    gap: 0;
    margin-right: 15px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .step_item .step_item_inner .step_number {
    flex-direction: row;
    width: 100%;
    justify-content: flex-start;
    margin-right: 0;
    margin-bottom: 5px;
    gap: 5px;
  }
}
.page_pediatric .step_item .step_item_inner .step_number span {
  font-size: 20px;
  color: inherit;
}
@media (max-width: 1023px) {
  .page_pediatric .step_item .step_item_inner .step_number span {
    font-size: 18px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .step_item .step_item_inner .step_number span {
    font-size: 4.8vw;
  }
}
.page_pediatric .step_item .step_item_inner .step_number strong {
  font-size: 52px;
  font-weight: 600;
  color: inherit;
}
@media (max-width: 1023px) {
  .page_pediatric .step_item .step_item_inner .step_number strong {
    font-size: 48px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .step_item .step_item_inner .step_number strong {
    font-size: 9.2vw;
  }
}
.page_pediatric .step_item .step_item_inner .step_text {
  width: 75%;
  flex: 1;
  padding-left: 25px;
  border-left: solid 3px #ffffff;
}
@media (max-width: 1023px) {
  .page_pediatric .step_item .step_item_inner .step_text {
    padding-left: 15px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .step_item .step_item_inner .step_text {
    width: 100%;
    border-left: none;
    padding-left: 0;
    padding-top: 15px;
    border-top: solid 2px #ffffff;
  }
}
.page_pediatric .step_item .step_item_inner .step_text h3 {
  font-size: 26px;
  font-weight: 700;
  color: #4664dc;
  margin-bottom: 25px;
}
@media (max-width: 1023px) {
  .page_pediatric .step_item .step_item_inner .step_text h3 {
    font-size: 22px;
    margin-bottom: 15px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .step_item .step_item_inner .step_text h3 {
    font-size: 4.8vw;
  }
}
.page_pediatric .step_item .step_item_inner .step_text p {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.75em;
  color: #4d4d4d;
}
@media (max-width: 1023px) {
  .page_pediatric .step_item .step_item_inner .step_text p {
    font-size: 15px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .step_item .step_item_inner .step_text p {
    font-size: 3.5vw;
  }
}
.page_pediatric {
  /* よくある症状 */
}
.page_pediatric .symptoms_contents .radius_box {
  background-color: #eceffb;
  border-radius: 30px;
  padding: 80px 70px;
}
@media (max-width: 1023px) {
  .page_pediatric .symptoms_contents .radius_box {
    padding: 50px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .symptoms_contents .radius_box {
    padding: 40px 25px;
  }
}
.page_pediatric .symptoms_contents .radius_box h3 {
  font-size: 26px;
  color: #4664dc;
  font-weight: 700;
  padding-bottom: 15px;
  margin-bottom: 60px;
  text-align: center;
  position: relative;
}
@media (max-width: 1023px) {
  .page_pediatric .symptoms_contents .radius_box h3 {
    font-size: 24px;
    padding-bottom: 10px;
    margin-bottom: 50px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .symptoms_contents .radius_box h3 {
    font-size: 5.6vw;
    margin-bottom: 30px;
  }
}
.page_pediatric .symptoms_contents .radius_box h3::after {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  content: "";
  height: 1px;
  width: 250px;
  background: #4664dc;
}
@media (max-width: 1023px) {
  .page_pediatric .symptoms_contents .radius_box h3::after {
    width: 210px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .symptoms_contents .radius_box h3::after {
    width: 55%;
  }
}
.page_pediatric .symptoms_contents .radius_box + .radius_box {
  margin-top: 60px;
}
@media (max-width: 1023px) {
  .page_pediatric .symptoms_contents .radius_box + .radius_box {
    margin-top: 40px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .symptoms_contents .radius_box + .radius_box {
    margin-top: 35px;
  }
}
.page_pediatric .symptoms_contents .radius_box strong {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.2em;
  display: block;
  text-align: center;
  color: #4664dc;
  margin-top: 30px;
}
@media (max-width: 1023px) {
  .page_pediatric .symptoms_contents .radius_box strong {
    font-size: 18px;
    margin-top: 25px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .symptoms_contents .radius_box strong {
    font-size: 5.2vw;
  }
}
.page_pediatric #symptoms .wrap {
  padding: 85px 0 110px 0;
}
@media (max-width: 1023px) {
  .page_pediatric #symptoms .wrap {
    padding: 55px 0 85px;
  }
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .wrap {
    padding: 45px 0 65px;
  }
}
.page_pediatric #symptoms .flex_box {
  display: flex;
  gap: 12%;
}
@media (max-width: 1023px) {
  .page_pediatric #symptoms .flex_box {
    gap: 5%;
  }
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .flex_box {
    flex-direction: column-reverse;
    gap: 25px;
  }
}
.page_pediatric #symptoms .flex_box .flex_left {
  width: 48%;
  flex: 1;
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .flex_box .flex_left {
    width: 100%;
  }
}
.page_pediatric #symptoms .flex_box .flex_left p {
  font-size: 16px;
  line-height: 1.65em;
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .flex_box .flex_left p {
    font-size: 4.2vw;
  }
}
.page_pediatric #symptoms .flex_box .flex_right {
  width: 40%;
  text-align: center;
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .flex_box .flex_right {
    width: 100%;
  }
}
.page_pediatric #symptoms .flex_box h4 {
  font-size: 18px;
  font-weight: 700;
  color: #4664dc;
  margin-top: 45px;
}
@media (max-width: 1023px) {
  .page_pediatric #symptoms .flex_box h4 {
    margin-top: 40px;
  }
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .flex_box h4 {
    margin-top: 35px;
    font-size: 4.8vw;
  }
}
.page_pediatric #symptoms .flex_box h4 + ul, .page_pediatric #symptoms .flex_box h4 + p {
  margin-top: 10px;
}
.page_pediatric #symptoms .flex_box ul li {
  font-size: 16px;
  line-height: 1.55em;
  padding-left: 1.5em;
  position: relative;
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .flex_box ul li {
    font-size: 4.2vw;
  }
}
.page_pediatric #symptoms .flex_box ul li::before {
  position: absolute;
  left: 0;
  top: 0;
  content: "◇";
  width: 1em;
  height: 1em;
  color: #4664dc;
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .flex_box ul li + li {
    margin-top: 5px;
  }
}
.page_pediatric #symptoms .points_box {
  margin-top: 70px;
  border-radius: 20px;
  background-color: #ffffff;
  padding: 55px 50px 20px;
  position: relative;
}
@media (max-width: 1023px) {
  .page_pediatric #symptoms .points_box {
    padding: 45px 35px 20px;
    margin-top: 60px;
  }
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .points_box {
    padding: 35px 20px 15px;
    margin-top: 45px;
  }
}
.page_pediatric #symptoms .points_box .points_box_title {
  width: 180px;
  padding: 10px;
  font-size: 18px;
  font-weight: 700;
  color: #ffffff;
  text-align: center;
  background-color: #4664dc;
  border-radius: 18px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -18px;
  letter-spacing: 0.1em;
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .points_box .points_box_title {
    width: 160px;
    font-size: 4.2vw;
    padding: 5px;
    top: -15px;
  }
}
.page_pediatric #symptoms .points_box ul li {
  padding-bottom: 25px;
  border-bottom: 1px solid #b3b3b3;
}
@media (max-width: 1023px) {
  .page_pediatric #symptoms .points_box ul li {
    padding-bottom: 20px;
  }
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .points_box ul li {
    padding-bottom: 15px;
  }
}
.page_pediatric #symptoms .points_box ul li .point_inner {
  padding: 0 15px 0 65px;
  position: relative;
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .points_box ul li .point_inner {
    padding: 0;
  }
}
.page_pediatric #symptoms .points_box ul li .point_inner::before {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  content: "";
  width: 53px;
  height: 53px;
  background: url(../img/lp/points.svg);
  background-repeat: no-repeat;
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .points_box ul li .point_inner::before {
    content: none;
  }
}
.page_pediatric #symptoms .points_box ul li h5 {
  color: #4664dc;
  font-size: 20px;
  font-weight: 700;
}
@media (max-width: 1023px) {
  .page_pediatric #symptoms .points_box ul li h5 {
    font-size: 18px;
  }
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .points_box ul li h5 {
    padding-left: 50px;
    font-size: 4.6vw;
    position: relative;
  }
}
.page_pediatric #symptoms .points_box ul li h5 + p {
  margin-top: 10px;
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .points_box ul li h5 + p {
    margin-top: 15px;
    font-size: 3.8vw;
  }
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .points_box ul li h5::before {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    content: "";
    background: url(../img/lp/points.svg);
    background-repeat: no-repeat;
    width: 42px;
    height: 42px;
  }
}
.page_pediatric #symptoms .points_box ul li p {
  font-size: 16px;
  line-height: 1.65em;
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .points_box ul li p {
    font-size: 3.8vw;
  }
}
.page_pediatric #symptoms .points_box ul li + li {
  margin-top: 25px;
}
@media (max-width: 1023px) {
  .page_pediatric #symptoms .points_box ul li + li {
    margin-top: 20px;
  }
}
.page_pediatric #symptoms .points_box ul li:last-child {
  border-bottom: none;
}
.page_pediatric #symptoms .amblyopia_bottom {
  background-color: #4664dc;
  color: #ffffff;
}
.page_pediatric #symptoms .amblyopia_bottom .flex_box {
  gap: 0;
}
@media (max-width: 1023px) {
  .page_pediatric #symptoms .amblyopia_bottom .flex_box {
    gap: 25px;
  }
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .amblyopia_bottom .flex_box {
    flex-direction: column;
  }
}
.page_pediatric #symptoms .amblyopia_bottom h3 {
  font-size: 26px;
  font-weight: 700;
  padding-bottom: 0;
  margin-bottom: 60px;
  text-align: center;
}
@media (max-width: 1023px) {
  .page_pediatric #symptoms .amblyopia_bottom h3 {
    font-size: 24px;
    margin-bottom: 50px;
  }
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .amblyopia_bottom h3 {
    font-size: 5.6vw;
    margin-bottom: 30px;
  }
}
.page_pediatric #symptoms .amblyopia_bottom .flex_left {
  width: 55%;
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .amblyopia_bottom .flex_left {
    width: 100%;
  }
}
.page_pediatric #symptoms .amblyopia_bottom ul li {
  padding-bottom: 15px;
  padding-left: 30px;
  border-bottom: 1px solid #ffffff;
  font-size: 22px;
  font-weight: 700;
}
@media (max-width: 1023px) {
  .page_pediatric #symptoms .amblyopia_bottom ul li {
    padding-left: 15px;
    font-size: 18px;
  }
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .amblyopia_bottom ul li {
    font-size: 4.2vw;
    padding: 0 10px;
    padding-bottom: 10px;
  }
}
.page_pediatric #symptoms .amblyopia_bottom ul li + li {
  margin-top: 15px;
}
.page_pediatric #symptoms .amblyopia_bottom ul li::before {
  content: none;
}
.page_pediatric #symptoms .amblyopia_bottom strong {
  margin-top: 65px;
  display: block;
  text-align: center;
  font-size: 20px;
  line-height: 1.65em;
}
@media (max-width: 1023px) {
  .page_pediatric #symptoms .amblyopia_bottom strong {
    margin-top: 50px;
    font-size: 18px;
  }
}
@media (max-width: 767px) {
  .page_pediatric #symptoms .amblyopia_bottom strong {
    font-size: 4.5vw;
    margin-top: 35px;
  }
}
.page_pediatric {
  /* よくある質問 */
}
.page_pediatric #faq .wrap {
  padding: 80px 0 60px 0;
}
@media (max-width: 767px) {
  .page_pediatric #faq .wrap {
    padding: 45px 0;
  }
}
.page_pediatric .faq_list {
  display: flex;
  flex-direction: column;
  gap: 50px;
  width: min(900px, 100%);
  margin-inline: auto;
}
.page_pediatric .faq_list .faq_item {
  padding: 50px 70px;
  border: 1px solid #4664dc;
  border-radius: 75px;
  box-shadow: 0 15px 0 #4664dc;
}
@media (max-width: 1023px) {
  .page_pediatric .faq_list .faq_item {
    padding: 20px 35px 20px 35px;
    border-radius: 60px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .faq_list .faq_item {
    padding: 20px 25px;
    border-radius: 40px;
  }
}
.page_pediatric .faq_list .question_wrap {
  display: flex;
  align-items: center;
  gap: 50px;
  cursor: pointer;
  position: relative;
}
@media (max-width: 1023px) {
  .page_pediatric .faq_list .question_wrap {
    gap: 20px;
  }
}
.page_pediatric .faq_list .question_wrap span {
  font-size: 44px;
  color: #4664dc;
  font-weight: 600;
}
@media (max-width: 1023px) {
  .page_pediatric .faq_list .question_wrap span {
    font-size: 38px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .faq_list .question_wrap span {
    font-size: 7.5vw;
  }
}
.page_pediatric .faq_list .question_wrap strong {
  font-size: 24px;
  font-weight: 500;
  padding-right: 25px;
  line-height: 1.4em;
}
@media (max-width: 1023px) {
  .page_pediatric .faq_list .question_wrap strong {
    font-size: 20px;
    padding-right: 20px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .faq_list .question_wrap strong {
    font-size: 4.2vw;
  }
}
.page_pediatric .faq_list .question_wrap::before {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 15px;
  height: 3px;
  content: "";
  background-color: #4664dc;
}
@media (max-width: 767px) {
  .page_pediatric .faq_list .question_wrap::before {
    height: 2px;
    width: 12px;
  }
}
.page_pediatric .faq_list .question_wrap::after {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 15px;
  height: 3px;
  background-color: #4664dc;
  content: "";
  transition: ease 0.25s transform;
}
@media (max-width: 767px) {
  .page_pediatric .faq_list .question_wrap::after {
    width: 12px;
    height: 2px;
  }
}
.page_pediatric .faq_list .question_wrap.clicked::after {
  transform: translateY(-50%) rotate(90deg);
  transition: ease 0.25s transform;
}
.page_pediatric .faq_list .answer_wrap {
  height: 0;
  opacity: 0;
  line-height: 1.4em;
  transition: ease 0.25s height;
  font-size: 16px;
}
@media (max-width: 767px) {
  .page_pediatric .faq_list .answer_wrap {
    font-size: 3.8vw;
  }
}
.page_pediatric .faq_list .answer_wrap.opened {
  height: auto;
  opacity: 1;
  margin-top: 50px;
  transition: ease 0.25s height;
}
@media (max-width: 1023px) {
  .page_pediatric .faq_list .answer_wrap.opened {
    margin-top: 30px;
  }
}
@media (max-width: 767px) {
  .page_pediatric .faq_list .answer_wrap.opened {
    margin-top: 20px;
  }
}
.page_pediatric {
  /* 医院紹介 */
}
.page_pediatric .footer_above {
  background-color: #00cc99;
  color: #ffffff;
}
.page_pediatric .footer_above .wrap {
  margin-top: 60px;
}
@media (max-width: 767px) {
  .page_pediatric .footer_above .wrap {
    margin-top: 40px;
    padding-top: 35px;
  }
}
.page_pediatric .footer_above .sec_title strong {
  color: #ffffff;
}
.page_pediatric .footer_above .f_above_contents {
  border-top: none;
  padding-bottom: 45px;
}
@media (max-width: 767px) {
  .page_pediatric .footer_above .niwa_logo_hour {
    width: 100%;
  }
}
.page_pediatric .footer_above .niwa_logo_hour .f_above_logo {
  width: min(280px, 35%);
}
@media (max-width: 767px) {
  .page_pediatric .footer_above .niwa_logo_hour .f_above_logo {
    width: 55%;
  }
}
.page_pediatric .footer_above .niwa_information {
  margin-bottom: 0;
}
@media (max-width: 767px) {
  .page_pediatric .footer_above .niwa_information {
    flex-direction: column;
    justify-content: center;
  }
}
.page_pediatric .footer_above .niwa_information .niwa_data {
  font-size: 15px;
}
.page_pediatric .footer_above .niwa_information .niwa_data dl {
  font-size: inherit;
}
@media (max-width: 767px) {
  .page_pediatric .footer_above .niwa_information .niwa_data dl {
    border-bottom: solid 1px #fff;
  }
}
.page_pediatric .footer_above .niwa_information .niwa_data dl dt {
  font-weight: inherit;
}
@media (max-width: 767px) {
  .page_pediatric .footer_above .niwa_information .niwa_data dl dt {
    font-size: 4.2vw;
    font-weight: 500;
  }
}
.page_pediatric .footer_above .niwa_information .niwa_data .parking {
  margin-top: 15px;
  font-size: inherit;
}
.page_pediatric .footer_above .niwa_information .niwa_map_img_wrap {
  width: min(290px, 70%);
}
@media (max-width: 767px) {
  .page_pediatric .footer_above .niwa_information .niwa_map_img_wrap {
    width: 100%;
  }
}
@media (max-width: 767px) {
  .page_pediatric .footer_above .niwa_information .niwa_map_img_wrap figure {
    width: 100%;
    text-align: center;
  }
}
@media (max-width: 767px) {
  .page_pediatric .footer_above .niwa_information .niwa_map_img_wrap figure img {
    width: 70%;
  }
}
.page_pediatric {
  /* footer */
}
.page_pediatric .footer {
  background-color: #ffffff;
  color: #00cc99;
}
.page_pediatric .footer .wrap {
  padding: 30px 0;
  width: min(1010px, 95%);
}
@media (max-width: 767px) {
  .page_pediatric .footer .wrap {
    width: 90%;
    padding: 30px 0 60px 0;
  }
}
.page_pediatric .f_contents_wrap {
  align-items: center;
}
@media (max-width: 1023px) {
  .page_pediatric .f_contents_wrap {
    gap: 20px;
  }
}
.page_pediatric .f_nav_wrap {
  margin-bottom: 0;
  width: 70%;
}
@media (max-width: 1023px) {
  .page_pediatric .f_nav_wrap {
    width: 100%;
  }
}
.page_pediatric .f_nav_wrap nav {
  width: 100%;
}
.page_pediatric .f_nav_wrap .f_nav {
  display: flex;
  gap: 2%;
}
@media (max-width: 1023px) {
  .page_pediatric .f_nav_wrap .f_nav {
    justify-content: center;
  }
}
@media (max-width: 767px) {
  .page_pediatric .f_nav_wrap .f_nav {
    flex-direction: column;
    gap: 15px;
  }
}
.page_pediatric .f_nav_wrap .f_nav li {
  margin-bottom: 0;
}
.page_pediatric .f_nav_wrap .f_nav li > a {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.03em;
}
@media (max-width: 767px) {
  .page_pediatric .f_nav_wrap .f_nav li > a {
    font-size: 3.8vw;
  }
}
.page_pediatric .copyright {
  font-size: 10px;
}
@media (max-width: 767px) {
  .page_pediatric .copyright {
    font-size: 3.5vw;
  }
}
.page_pediatric {
  /* page_top */
}
@media (max-width: 1295px) {
  .page_pediatric .page_top {
    bottom: 5dvh;
  }
}
@media (max-width: 1023px) {
  .page_pediatric .page_top {
    bottom: 3dvh;
  }
}
@media (max-width: 767px) {
  .page_pediatric .page_top {
    bottom: 4dvh;
  }
}

/* device_grid - subgridによる高さ揃えレイアウト */
.page_contents .article_contents_wrap .device_grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto; /* subgrid用：行はdevice_boxが span 2 で決定 */
  gap: 30px;
  margin-top: 30px;
  margin-bottom: 30px;
}
@media (max-width: 1023px) {
  .page_contents .article_contents_wrap .device_grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    margin-top: 25px;
  }
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .device_grid {
    grid-template-columns: 1fr;
    margin-top: 20px;
  }
}
.page_contents .article_contents_wrap .device_grid .device_box {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3; /* 1: figure, 2: strong, 3: dl */
}
.page_contents .article_contents_wrap .device_grid .device_box figure {
  width: 100%;
  text-align: center;
}
.page_contents .article_contents_wrap .device_grid .device_box figure img {
  -o-object-fit: contain;
     object-fit: contain;
  width: 100%;
  height: 250px;
}
.page_contents .article_contents_wrap .device_grid .device_box .device_info {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2; /* 1: strong, 2: dl */
  margin-top: 15px;
  border: #666666 solid 1px;
  padding: 15px 20px;
  gap: 0;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .device_grid .device_box .device_info {
    margin-top: 10px;
    padding: 15px;
  }
}
.page_contents .article_contents_wrap .device_grid .device_box .device_info strong {
  font-size: 18px;
  font-weight: 900;
  color: #f15a24;
  display: block;
  margin-bottom: 15px;
  text-align: left;
  line-height: 1.5;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .device_grid .device_box .device_info strong {
    font-size: 4.2vw;
    margin-bottom: 10px;
  }
}
.page_contents .article_contents_wrap .device_grid .device_box .device_info dl {
  /* dlはブロックのまま（dd数が可変のため） */
}
.page_contents .article_contents_wrap .device_grid .device_box .device_info dl dt {
  font-size: 16px;
  font-weight: 900;
  padding-bottom: 8px;
  border-bottom: #666666 solid 1px;
  margin-bottom: 10px;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .device_grid .device_box .device_info dl dt {
    font-size: 3.8vw;
  }
}
.page_contents .article_contents_wrap .device_grid .device_box .device_info dl dd {
  position: relative;
  font-weight: 600;
  line-height: 1.6em;
  padding-left: 1.2em;
}
@media (max-width: 767px) {
  .page_contents .article_contents_wrap .device_grid .device_box .device_info dl dd {
    font-size: 3.8vw;
  }
}
.page_contents .article_contents_wrap .device_grid .device_box .device_info dl dd::before {
  position: absolute;
  left: 0;
  top: 0;
  width: 1em;
  height: 1em;
  content: "・";
}/*# sourceMappingURL=style.css.map */