@charset "UTF-8";

/* 共通 ベース base
----------------------------------------------- */
body {
  font-size: 16px;
  font-family: '小塚ゴシック Pro','Kozuka Gothic Pro', "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  background: #F9F9F7;
}
.container {
  max-width: 1300px;
  width: 90%;
  margin: 0 auto;
}
.container_w {
  max-width: 1500px;
  width: 90%;
  margin: 0 auto;
}
h2 {
  font-size: 40px;
  margin-bottom: 30px;
}
.sec_title {
  margin-bottom: 30px;
}
.sec_title h2 {
  font-size: 35px;
  font-weight: 500;
  letter-spacing: 3px;
  border-left: 5px solid #000;
  padding: 3px 0 3px 30px;
  margin-bottom: 0;
}
.sec_title.clr_red h2 {
  border-color: #B12E00;
}
h3 {
  font-size: 32px;
  margin-bottom: 20px;
}
h4 {
  font-size: 20px;
  margin-bottom: 10px;
}
p {
  font-size: 17px;
  line-height: 1.8;
  color: #1D1D19;
}
.sec_p {
  font-size: 17px;
  line-height: 2;
}
.btn_more {
  max-width: 250px;
  width: 90%;
}
.btn_more a {
  font-size: 15px;
  padding: 20px 30px;
  display: block;
  color: #1F1F2E;
  background-color: #fff;
  border: 1px solid #1F1F2E;
  border-radius: 50px;
  position: relative;
}
.arrow {
  position: relative;
}
.btn_more a::before,
.arrow::before {
  content: '';
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  width: 35px;
  height: 1px;
  background: #1F1F2E;
  transition: 0.3s ease;
}
.btn_more a::after,
.arrow::after {
  content: '';
  position: absolute;
  top: 46.5%;
  right: 30px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 4px solid transparent;
  border-right: 0 solid transparent;
  border-bottom: 0 solid transparent;
  border-left: 10px solid #1F1F2E;
  transition: 0.3s ease;
}
.btn_more a:hover {
  color: #fff;
  background-color: #43CC3E;
  border-color: #43CC3E;
}
.btn_more a:hover::before,
.arrow:hover::before {
  right: 20px;
  transition: 0.3s ease;
}
.btn_more a:hover::after,
.arrow:hover::after {
  right: 20px;
  transition: 0.3s ease;
}
.btn_more a:hover::before {
  background: #fff;
}
.btn_more a:hover::after {
  border-left: 10px solid #fff;
}

.noto {
  font-family: 'Noto Sans JP', sans-serif;
}

.bold {
  font-weight: bold;
}
.normal {
  font-weight: normal;
}
.relative {
  position: relative;
}

.a_link {
  margin-top: -135px;
  padding-top: 135px;
}
.a_none {
  pointer-events: none;
}
a img {
  transition: 0.3s ease;
}
a:hover img {
  opacity: 0.8;
  transition: 0.3s ease;
}


@media only screen and (max-width: 1500px) {

}

@media only screen and (max-width: 1280px) {
  h2 {
    font-size: 30px;
  }
  .sec_title h2 {
    font-size: 30px;
  }
}

@media only screen and (max-width: 1024px) {
  h2 {
    font-size: 25px;
  }
  .sec_title h2 {
    font-size: 22px;
    padding: 3px 0 3px 20px;
  }
  h3 {
    font-size: 18px;
  }
  h4 {
    font-size: 16px;
  }
  p {
    font-size: 15px;
  }
  .sec_p {
    font-size: 15px;
  }
  .btn_more {
    max-width: 220px;
  }
  .btn_more a {
    font-size: 14px;
  }
  .a_link {
    margin-top: -100px;
    padding-top: 100px;
  }
}

@media only screen and (max-width: 768px) {
  .sp_r {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
  .btn_more a {
    padding: 15px 30px;
  }
  .a_link {
    margin-top: -85px;
    padding-top: 85px;
  }
}

@media only screen and (max-width: 479px) {
  h2 {
    font-size: 20px;
  }
  .sec_title {
    margin-bottom: 20px;
  }
  .sec_title h2 {
    font-size: 18px;
    padding: 3px 0 3px 15px;
    border-width: 3px;
  }
  .sec_title .h2_ja {
    font-size: 12px;
  }
  h3 {
    font-size: 16px;
  }
  h4 {
    font-size: 14px;
  }
  p {
    font-size: 13px;
    line-height: 1.5;
  }
  .sec_p {
    font-size: 14px;
  }
  .btn_more {
    max-width: 180px;
  }
  .btn_more a {
    font-size: 13px;
    padding: 15px 25px;
  }
  .btn_more a::before,
  .arrow::before {
    width: 25px;
    right: 20px;
  }
  .btn_more a::after,
  .arrow::after {
    right: 20px;
  }
  .a_link {
    margin-top: -65px;
    padding-top: 65px;
  }
}

@media only screen and (max-width: 370px) {
  h2 {
    font-size: 17px;
  }
  .sec_title h2 {
    font-size: 16px;
  }
  h3 {
    font-size: 15px;
  }
  p {
    font-size: 12px;
  }
  .sec_p {
    font-size: 13px;
  }
  .btn_more a {
    font-size: 12px;
    padding: 13px 25px;
  }
}



/* -----------------------------------------------

	 トップページ

----------------------------------------------- */

/* top_main
----------------------------------------------- */
#top .top_main {
	padding: 150px 0 6vw;
	margin-bottom: 5vw;
}
#top .top_maincontainer {
  max-width: 1500px;
  width: 90%;
  height: 600px;
  margin: 0 auto;
  position: relative;
}

#top .top_main .mainimg01 {
  position: absolute;
  top: 50%;
  left: 18%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  /*width: 669px;
  width: 34.8vw;*/
}
#top .top_main .mainimg02 {
  position: absolute;
  top: 40%;
  right: 0;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  /*width: 389px;
  width: 20.2vw;*/
}
#top .top_main .mainimg_sp {
  display: none;
}
#top .top_main .main_text {
  position: absolute;
  bottom: 8%;
  right: 0;
  text-shadow: 2px 2px 3px #fff;
}
#top .top_main .main_text p {
  font-size: 28px;
  /*font-size: 1.4vw;*/
  font-weight: bold;
  letter-spacing: 5px;
  line-height: 2;
}
#top .top_main .main_text h1 {
	font-size: 15px;
  /*font-size: 0.8vw;*/
}
#top .top_main .main_text02 {
  font-size: 60px;
  /*font-size: 3.2vw;*/
  font-weight: 500;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  position: absolute;
  top: 45%;
  left: 0;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  z-index: 2;
  height: 100%;
  text-align: center;
  letter-spacing: 10px;
  line-height: 1.6;
}
#top .top_main img {
  width: unset;
}



@media only screen and (max-width: 1280px) {
  #top .top_main {
    padding: 100px 0;
  }
  #top .top_main .main_text02 {
    font-size: 55px;
    text-shadow: 2px 2px 5px #fff;
  }
  #top .top_main .mainimg01 {
    left: 5%;
  }
}

@media only screen and (max-width: 1024px) {
  #top .top_maincontainer {
    height: 450px;
  }
  #top .top_main .main_text02 {
    font-size: 40px;
    top: 35%;
  }
  #top .top_main .mainimg01 {
    top: 45%;
    width: 500px;
  }
  #top .top_main .mainimg02 {
    top: 30%;
    width: 300px;
  }
  #top .top_main .main_text {
    bottom: 15%;
  }
  #top .top_main .main_text p {
    font-size: 22px;
  }
  #top .top_main .main_text h1 {
    font-size: 14px;
  }
}

@media only screen and (max-width: 768px) {
  #top .top_main {

  }
  #top .top_maincontainer {
    height: auto;
    padding-bottom: 100px;
  }
  #top .top_main .mainimg01,
  #top .top_main .mainimg02 {
    display: none;
  }
  #top .top_main .mainimg_sp {
    display: block;
    width: 95%;
  }
  #top .top_main .main_text {
    bottom: -2%;
    left: 2%;
  }
  #top .top_main .main_text p {
    font-size: 3.5vw;
    line-height: 1.8;
  }
  #top .top_main .main_text h1 {
    font-size: 2.3vw;
  }
  #top .top_main .main_text02 {
    left: unset;
    right: 3%;
    transform: unset;
    top: 0;
    height: auto;
    font-size: 6vw;
  }
}

@media only screen and (max-width: 479px) {
  #top .top_main {
    padding: 80px 0;
  }
  #top .top_maincontainer {
    padding-bottom: 120px;
  }
  #top .top_main .mainimg_sp {
    width: 100%;
  }
	#top .top_main .main_text {
    bottom: 9%;
    left: 2%;
  }
  #top .top_main .main_text p {
    font-size: 14px;
  }
  #top .top_main .main_text h1 {
    font-size: 12px;
    line-height: 1.5;
	font-weight: 500;
  }
  #top .top_main .main_text02 {
    letter-spacing: 6px;
  }
}

@media only screen and (max-width: 370px) {

}



/* top_info
----------------------------------------------- */
#top .top_info {
  padding: 0 0 100px;
}
#top .top_info .top_info_wrap {
  gap: 50px;
}
#top .top_info .info_box {
  width: calc( 100% / 2 - 25px );
  border: 3px solid #E3E2DD;
  border-radius: 10px;
  background-color: #fff;
  position: relative;
}
#top .top_info .info_box.first::before {
  content: '';
  position: absolute;
  left: -40px;
  top: -140px;
  width: 132px;
  height: 148px;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../images/first-time.png);
}
#top .top_info .info_box::after {
  content: '';
  position: absolute;
  right: 15px;
  bottom: 0;
  width: 120px;
  height: 246px;
  background-repeat: no-repeat;
  background-size: contain;
}
#top .top_info .info_box.first::after {
  background-image: url(../images/info_man.png);
}
#top .top_info .info_box.news::after {
  background-image: url(../images/info_woman.png);
}
#top .top_info .info_box a {
  display: block;
  padding: 20px 30px;
  width: 78%;
}
#top .top_info .info_box p {
  line-height: 1.5;
  /*text-align: justify;*/
}
.news_title {
  font-weight: 500;
  line-height: 1.4;
}
.news_img {
  width: 15%;
}
.news_date {
  font-weight: 500;
  line-height: 1.4;
}
#top .top_info .info_box .news_title {
  font-size: 19px;
  margin-bottom: 10px;
}
#top .top_info .info_box .news_text {
  /*width: 80%;*/
  z-index: 1;
}
#top .top_info .info_box .news_date {
  margin-bottom: 5px;
}



@media only screen and (max-width: 1024px) {
  #top .top_info .top_info_wrap {
    gap: 20px;
  }
  #top .top_info .info_box {
    width: calc(100% / 2 - 15px);
  }
  #top .top_info .info_box::after {
    right: 5px;
    width: 100px;
    height: 205px;
  }
  #top .top_info .info_box.first::before {
    left: 0;
    top: -100px;
    width: 100px;
    height: 112px;
  }
  #top .top_info .info_box a {
    padding: 15px 20px;
  }
  #top .top_info .info_box .news_title {
    font-size: 17px;
  }
}

@media only screen and (max-width: 768px) {
  #top .top_info {
    padding: 0 0 80px;
  }
  #top .top_info .info_box {
    width: 100%;
  }
  #top .top_info .info_box::after {
    right: 10px;
    width: 80px;
    height: 160px;
  }
  #top .top_info .info_box.first::before {
    top: -80px;
    width: 80px;
    height: 90px;
  }
  #top .top_info .info_box a {
    width: 85%;
  }
}

@media only screen and (max-width: 479px) {
  #top .top_info {
    padding: 0 0 50px;
  }
  #top .top_info .info_box .news_title {
    font-size: 15px;
  }
  .news_img {
    display: none;
  }
  #top .top_info .info_box .news_text {
    width: 90%;
  }
}

@media only screen and (max-width: 370px) {
  #top .top_info .info_box::after {
    right: 0;
  }
  #top .top_info .info_box .news_title {
    font-size: 13px;
  }
}



/* top_consultation
----------------------------------------------- */
.top_consultation {
  padding: 50px 0 0;
  position: relative;
}
.top_consultation::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
	background-image: url("../images/top_gaikan_img.jpg");
  background-repeat: no-repeat;
  background-position: top left;
  background-size: contain;
  width: 727px;
  width: 38vw;
  height: 517px;
  height: 28.5vw;
  z-index: -1;
}
.top_consultation .gaikan {
  display: none;
}
.top_consultation .imgtext_r {
  width: 60%;
  margin-left: auto;
}
.top_consultation .imgtext_r .note_erea {
  background-color: #fff;
  width: 100%;
  padding: 30px 40px;
  margin-top: 20px;
}
.top_consultation .imgtext_r .note_erea p {
  font-size: 14px;
}




@media only screen and (max-width: 1024px) {
  .top_consultation {
    padding: 10px 0 0;
  }
  .top_consultation::before {
    width: 43vw;
    height: 30.5vw;
  }
  .top_consultation .imgtext_r {
    width: 55%;
  }
  .top_consultation .imgtext_r .note_erea {
    padding: 20px;
  }
}

@media only screen and (max-width: 768px) {
  .top_consultation::before {
    display: none;
  }
  .top_consultation .gaikan {
    display: block;
    max-width: 100%;
    margin: 0 auto 30px;;
  }
  .top_consultation .imgtext_r {
    width: 100%;
  }
}

@media only screen and (max-width: 479px) {
  .top_consultation .imgtext_r .note_erea {
    padding: 15px;
  }
  .top_consultation .imgtext_r .note_erea p {
    font-size: 13px;
  }
}

@media only screen and (max-width: 370px) {
  .top_consultation .imgtext_r .note_erea p {
    font-size: 12px;
  }
}


/* top_medical
----------------------------------------------- */
.top_medical{
  padding: 50px 0;
}
.top_medical_list{
	gap: 20px;
}
.top_medical_list li{
	width: calc(100% / 4 - 15px);
}
.top_medical_list li a {
  display: block;
  background: #0096e0;
  padding: 30px 0;
  text-align: center;
  color: #fff;
  border-radius: 10px;
  font-size: 25px;
}

.top_medical_list li a:hover {
    color: #0096e0;
    background-color: #fff;
	border: 1px solid #0096e0;
    transition: 0.3s ease;
}

@media only screen and (max-width: 1024px) {
  .top_medical{
    padding: 30px 0;
  }
  .top_medical_list li a {
    padding: 25px 0;
    font-size: 20px;
  }
}

@media only screen and (max-width: 768px) {
  .top_medical_list li{
  	width: calc(100% / 2 - 10px);
  }
  .top_medical_list li a {
    font-size: 18px;
  }
}

@media only screen and (max-width: 479px) {
  .top_medical{
    padding: 10px 0 30px;
  }
  .top_medical_list{
  	gap: 15px;
  }
  .top_medical_list li{
  	width: calc(100% / 2 - 7.5px);
  }
  .top_medical_list li a {
    font-size: 16px;
    padding: 22px 0;
  }
}




/* top_news
----------------------------------------------- */
#top .top_news {
  margin: 100px 0;
}
#top .top_news .top_news_area .top_news_list {
  gap: 30px;
}
#top .top_news .top_news_area .top_news_list li {
  width: calc( 100% / 3 - 20px );
  /*border: 3px solid #E3E2DD;*/
  border-radius: 10px;
  line-height: 0;
  background-color: #fff;
}
#top .top_news .top_news_area .top_news_list li a {
  display: block;
  padding: 20px 30px;
}
#top .top_news .top_news_area .top_news_list li a .news_date {
  margin-right: 10px;
}
#top .top_news .top_news_area .top_news_list li a .news_title_wrap {
  margin-bottom: 10px;
}
#top .top_news .top_news_area .top_news_list li a > p {
  font-size: 15px;
  /*text-align: justify;*/
}
#top .top_news .ichiran {
  margin-left: 50px;
  text-decoration: underline;
  text-underline-offset: 5px;
}
#top .top_news .ichiran:hover {
  color: #e50050;
}


@media only screen and (max-width: 1024px) {
  #top .top_news {
    margin: 80px 0 100px;
  }
  #top .top_news .top_news_area .top_news_list li {
    width: calc( 100% / 2 - 15px )
  }
  #top .top_news .top_news_area .top_news_list li:nth-child(n+3) {
    display: none;
  }
  #top .top_news .ichiran {
    font-size: 14px;
  }
}

@media only screen and (max-width: 768px) {
  #top .top_news {
    margin: 50px 0 80px;
  }
  #top .top_news .top_news_area .top_news_list li {
    width: 100%;
  }
}

@media only screen and (max-width: 479px) {
  #top .top_news {
    margin: 30px 0 60px;
  }
  #top .top_news .ichiran {
    font-size: 13px;
  }
  #top .top_news .top_news_area .top_news_list {
    gap: 20px;
  }
  #top .top_news .top_news_area .top_news_list li a {
    padding: 20px;
  }
  #top .top_news .top_news_area .top_news_list li a .news_title_wrap p {
    font-size: 15px;
  }
  #top .top_news .top_news_area .top_news_list li a > p {
    font-size: 13px;
  }
  #top .top_news .ichiran {
    font-size: 13px;
  }
}

@media only screen and (max-width: 370px) {
  #top .top_news .top_news_area .top_news_list li a .news_title_wrap p {
    font-size: 13px;
  }
  #top .top_news .top_news_area .top_news_list li a > p {
    font-size: 12px;
  }
  #top .top_news .ichiran {
    font-size: 12px;
  }
}





/*
----------------------------------------------- */



@media only screen and (max-width: 1400px) {

}

@media only screen and (max-width: 1024px) {

}

@media only screen and (max-width: 768px) {

}

@media only screen and (max-width: 479px) {

}
