@charset "UTF-8";


/* [ var ]
 * -------------------------------------------- */
 :root {
  --green: #14AAA0;
  --blue: #41A5D0;
  --blue-dark: #518297;
  --red: #C63328;
  --black: #000000;
  --gray: #cccccc;
  --gray-dark: #6f6f6f;
  --white: #fff;
  --font-family-mincho: "Zen Old Mincho", serif;
  --font-family-marcellus: "Marcellus", serif;
  /* --breakpoint-sm: 569px; */
  /* --breakpoint-md: 767px; */
  /* --breakpoint-lg: 960px; */
}


/* [ config ]
 * -------------------------------------------- */
img {
  width: 100%;
  height: auto;
}
.cm_pcOnly {
  display: block !important;
}
.cm_spOnly {
  display: none !important;
}
@media screen and (max-width: 569px) {
  .cm_pcOnly {
    display: none !important;
  }
  .cm_spOnly {
    display: block !important;
  }
}

/* 背景グラデーション */
.cm_bgGrd_center{
  position: absolute;
  top: 40%;
  width: 100%;
  height: 30%;
  left: 0;
  transform: translateY(-50%);
  z-index: -1;
  background-color:hsla(192,46%,89%,1);
  background-image:
  radial-gradient(at 6% 49%, hsla(194,50%,83%,1) 0px, transparent 50%),
  radial-gradient(at 22% 49%, hsla(195,51%,90%,1) 0px, transparent 50%),
  radial-gradient(at 37% 49%, hsla(180,100%,93%,1) 0px, transparent 50%),
  radial-gradient(at 51% 49%, hsla(136,100%,98%,1) 0px, transparent 50%),
  radial-gradient(at 65% 49%, hsla(57,100%,96%,1) 0px, transparent 50%),
  radial-gradient(at 92% 49%, hsla(357,96%,91%,1) 0px, transparent 50%),
  radial-gradient(at 78% 49%, hsla(26,100%,94%,1) 0px, transparent 50%);
}
.cm_bgGrd_bottom{
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: -1;
}

/* pdfアイコン */
.cm_pdf{
  position: relative;
  padding: 0 1.4em 0 0;
}
.cm_pdf::before{
  position: absolute;
  content: '';
  width: 1.2em;
  height: 1.2em;
  background: url(../img/common/parts_pdf.png) center/contain no-repeat;
  top: 0;
  right: 0;
}


/* [ font ]
 * -------------------------------------------- */
body {
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN",
    "Hiragino Sans", "Noto Sans", Meiryo, sans-serif;
  background: #D5EAF0;
  color: var(--black);
  letter-spacing: .08em;
  line-height: 2;
  position: relative;
  z-index: 1;
}

.cm_sec p a{
  text-decoration: underline;
  color: var(--green);
}
.breadcrumb{
  font-size: 16px;
}
@media screen and (max-width: 767px){
  body{
    font-size: 14px;
  }
  .breadcrumb{
  font-size: 12px;
  }
}


/* [ layout ]
 * -------------------------------------------- */
.cm_inner {
  max-width: 1360px;
  margin: 0 auto;
  padding-left: 40px;
  padding-right: 40px;
}
.cm_sec{
  margin: 0 0 100px;
}

@media screen and (max-width: 767px) {
  .cm_inner {
    padding-left: 20px;
    padding-right: 20px;
  }
  .cm_sec{
    margin: 0 0 60px;
  }
}


/* [ button ]
 * -------------------------------------------- */
 /* ボタン01 */
.cm_btn01{
  font: 400 18px/1.5 var(--font-family-mincho);
  display: inline-block;
  background: var(--blue);
  color: var(--white);
  padding: 15px 60px 15px 30px;
  position: relative;
  border: 1px solid var(--blue);
  box-shadow: 0px 3px 12px rgba(0, 0, 0, 0.16);
}
.cm_btn01::after{
  content: '';
  position: absolute;
  top: 46%;
  right: 15px;
  transform: translate(-50%, -50%);
  transform-origin: left;
  width: 20px;
  height: 7px;
  background-color: var(--white);
  clip-path: polygon(0 100%, 100% 100%, 70% 40%, 70% 90%, 0% 90%);
  content: '';
  transition: transform .3s;
}
.cm_btn01:hover{
  color: var(--blue);
  background: var(--white);
}
.cm_btn01:hover::after{
  transform: translate(-50%, -50%) scaleX(1.2);
  background-color: var(--blue);
}

.cm_btn01 + .cm_btn01{
  margin-left: 15px;
}

/* ボタン02 */
.cm_btn02{
  font: 400 18px/1 var(--font-family-mincho);
  display: inline-block;
  position: relative;
  border-bottom: 1px solid var(--green);
  padding: 0 35px 13px 0;
}
.cm_btn02::after{
  content: '';
  position: absolute;
  top: 15%;
  right: 5px;
  transform-origin: left;
  width: 20px;
  height: 7px;
  background-color: var(--green);
  clip-path: polygon(0 100%, 100% 100%, 70% 40%, 70% 90%, 0% 90%);
  content: '';
  transition: transform .3s;
}
.cm_btn02:hover{
  color: var(--green);
}
.cm_btn02:hover::after{
  transform: scaleX(1.2);
}

@media screen and (max-width: 767px){
  /* ボタン01 */
  .cm_btn01{
    font-size: 16px;
    display: block;
    padding: 15px 60px 15px 20px;
    text-align: left;
  }
  .cm_btn01 + .cm_btn01{
    margin-left: 0px;
    margin-top: 10px;
  }

  /* ボタン02 */
  .cm_btn02{
    font-size: 16px;
  }
  .cm_btn02::after{
    top: 12%;
  }
}


/* [ title ]
 * -------------------------------------------- */
/* 見出し01 */
.cm_contentsTtl{
  letter-spacing: .1em;
  font-weight: 400;
  margin: 0 0 40px;
}
.cm_contentsTtl .en{
  font: 400 24px/1 var(--font-family-marcellus);
  color: var(--green);
  display: block;
  position: relative;
  margin: 0 0 10px;
}
.cm_contentsTtl .en::before{
  position: absolute;
  content: '';
  width: 30px;
  height: 1px;
  background: var(--green);
  left: -40px;
  top: 50%;
  transform: translateY(-50%);
}
.cm_contentsTtl .ja{
  font: 400 32px/1.4 var(--font-family-mincho);
}
.cm_contentsTtl .sub{
  font: 400 18px/1.4 var(--font-family-mincho);
  margin: 0 0 0 30px;
}

/* 見出し02 */
.cm_contentsTtl02{
  text-align: center;
  letter-spacing: .1em;
  font-weight: 400;
  margin: 0 0 40px;
}
.cm_contentsTtl02 .en{
  font: 400 24px/1 var(--font-family-marcellus);
  color: var(--green);
  display: inline-block;
  position: relative;
  margin: 0 0 10px;
  padding: 0 48px;
}
.cm_contentsTtl02 .en::before,
.cm_contentsTtl02 .en::after{
  position: absolute;
  content: '';
  width: 28px;
  height: 1px;
  background: var(--green);
  top: 50%;
  transform: translateY(-50%);
}
.cm_contentsTtl02 .en::before{
  left: 0;
}
.cm_contentsTtl02 .en::after{
  right: 0;
}
.cm_contentsTtl02 .ja{
  display: block;
  font: 400 32px/1.4 var(--font-family-mincho);
}

@media screen and (max-width: 767px){
  /* 見出し01 */
  .cm_contentsTtl{
    margin: 0 0 20px;
  }
  .cm_contentsTtl .en{
    font-size: 16px;
    margin: 0 0 5px;
  }
  .cm_contentsTtl .en::before{
    width: 15px;
    left: -20px;
  }
  .cm_contentsTtl .ja{
    font-size: 26px;
  }
  .page .cm_contentsTtl .ja{
    font-size: 22px;
  }
  .cm_contentsTtl .sub{
    font-size: 14px;
    margin: 0;
    display: block;
  }

  /* 見出し02 */
  .cm_contentsTtl02{
    margin: 0 0 30px;
  }
  .cm_contentsTtl02 .en{
    font-size: 20px;
    margin: 0 0 5px;
    padding: 0 48px;
  }
  .cm_contentsTtl02 .ja{
    font-size: 26px;
  }
}


/* [ list ]
 * -------------------------------------------- */
.cm_ul_list01 li{
  padding: 0 0 0 18px;
  margin: 0 0 15px;
  position: relative;
  line-height: 1.6;
}
.cm_ul_list01 li::before{
  position: absolute;
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 100%;
  background: var(--green);
  top: 8px;
  left: 0;
}

.cm_ul_list01 li a{
  text-decoration: underline;
  color: var(--green);
}

.c-list_02 li{
  margin: 0 0 15px;
  position: relative;
  line-height: 1.6;
  list-style-type: none;
  counter-increment: cnt;
}
.c-list_02 p  {
  margin-bottom: 10px;
}
.c-list_02 li::before{
  font-family: var(--font-family-mincho);
  content: counter(cnt)". ";
  color: var(--green);
  font-size: 110%;
}
.c-list.link-list li {
  display: block;
}
.c-list.link-list li a {
  word-break: break-all;
}
.c-list.link-list li::before {
  margin-right: 8px;
}
.c-list.link-list li a:hover {
  color: inherit;
}

@media screen and (max-width: 767px){
  .cm_ul_list01 li{
    padding: 0 0 0 15px;
  }
}


/* [ メニューボタン ]
 * -------------------------------------------- */
.cm_menuList{
  display: flex;
  flex-wrap: wrap;
  margin: 0 -10px;
}
.cm_menuList li{
  width: 25%;
  padding: 0 10px;
  margin: 0 0 20px;
}
.cm_menuList li a{
  display: block;
  background: var(--white);
  border: 1px solid var(--green);
  padding: 30px 20px;
  text-align: center;
  height: 100%;
}
.cm_menuList li a img{
  width: 85px;
  margin: 0 0 15px;
}
.cm_menuList li a:hover{
  opacity: .6;
}
.cm_menuList_ttl{
  font: 400 17px/1.4 var(--font-family-mincho);
}

@media screen and (max-width: 767px){
  .cm_menuList{
    margin: 0 -5px;
  }
  .cm_menuList li{
    width: 50%;
    padding: 0 5px;
    margin: 0 0 10px;
  }
  .cm_menuList li a{
    padding: 15px 10px;
  }
  .cm_menuList li a img{
    width: 55px;
    margin: 0 0 10px;
  }
  .cm_menuList_ttl{
    font-size: 16px;
  }
}


/* [ ニュースリスト ]
 * -------------------------------------------- */
.cm_newsList li{
  margin: 0 0 10px;
}
.cm_newsList li a{
  display: block;
  background: linear-gradient(90deg,var(--white) 0%, rgba(255, 255, 255, 0.31) 100%);
  border: 1px solid var(--green);
  padding: 15px 30px 20px;
}
.cm_newsList li a:hover{
  opacity: .7;
}
.cm_newsList_item{
  margin: 0 0 5px;
	display:flex;
	align-items:center;
}
.cm_newsList_item .date{
  font: 400 15px var(--font-family-marcellus);
  color: var(--green);
  margin: 0 10px 0 0;
}
.cm_newsList_item .cate{
  font-size: 13px;
  color: var(--gray-dark);
  border: 1px solid var(--gray);
  background: var(--white);
  padding: 3px 8px;
}
.cm_newsList_ttl{
  font: 400 18px/1.4 var(--font-family-mincho);
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}

@media screen and (max-width: 767px){
  .cm_newsList li a{
    padding: 15px 20px 20px;
  }
  .cm_newsList_item{
    margin: 0 0 5px;
  }
  .cm_newsList_item .date{
    font-size: 12px;
    margin: 0 7px 0 0;
  }
  .cm_newsList_item .cate{
    font-size: 12px;
    padding: 3px 7px;
  }
  .cm_newsList_ttl{
    font-size: 18px;
    -webkit-line-clamp: 2;
  }
}


/* [ 記事リスト ]
 * -------------------------------------------- */
.cm_artList{
  margin: 0 -15px;
}
.cm_artList li{
  width: calc(100% / 3);
  padding: 0 15px;
}
.cm_artList li a{
  display: block;
  background: linear-gradient(#fff 0%, rgba(255, 255, 255, 0.61) 100%);
  border: 1px solid var(--green);
  padding: 25px;
  height: 100%;
  position: relative;
}
.cm_artList li a:hover{
  opacity: .6;
}
.cm_artList_tmb{
  width: 100%;
  height: 0;
  padding-top: calc(2/3*100%);
  position: relative;
  overflow: hidden;
  margin: 0 0 20px;
}
.cm_artList_tmb img{
  position: absolute;
  width: 100%;
  height: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  object-fit: cover;
  transition: .3s;
}
.cm_artList li a:hover img{
  transform: translate(-50%, -50%) scale(1.1) ;
}
.cm_artList_item{
  margin: 0 0 8px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
.cm_artList_item .date{
  font: 400 16px var(--font-family-marcellus);
  color: var(--green);
}
.cm_artList_item .pickup{
  font-size: 12px;
  background: var(--red);
  color: var(--white);
  display: inline-block;
  padding: 0 10px;
  border-radius: 100px;
}
.cm_artList_ttl{
  font: 400 20px/1.4 var(--font-family-mincho);
}
.cm_artList li .cate{
  display: inline-block;
  margin: 20px 0 0;
  font-size: 13px;
  color: var(--gray-dark);
  border: 1px solid var(--gray);
  background: var(--white);
  padding: 0 8px;
}
.cm_artList .memberonly{
  position: absolute;
  display: block;
  width: 42px;
  height: 42px;
  background: url(../img/common/parts_lock.png) center/contain no-repeat;
  top: 15px;
  left: 15px;
  z-index: 1;
}
.cm_newsList .memberonly {
    display: inline-block;
    width: 20px;
    height: 20px;
    background: url(../img/common/parts_lock.png) center / contain no-repeat;
    z-index: 1;
	margin-right:10px;
}

/* [ テーブル ]
 * -------------------------------------------- */

 .cm_table_wrap  {
  width: 100%;
  overflow-x: auto;
}
table.cm_table {
  margin:40px auto;
  width:100%;
  min-width:700px;
  border-top:1px solid var(--white);
  border-right:1px solid var(--white);
}
table.cm_table th,table.cm_table td{
  border-left:1px solid var(--white);
  border-bottom:1px solid var(--white);
  padding:15px;
}
table.cm_table th{
  background-color: rgba(65, 165, 208, 0.5);
}
table.cm_table tr{
  background-color: rgba(246, 248, 251, 0.4) ;
}
table.cm_table tr:nth-child(odd){
  background-color: rgba(65, 165, 208, 0.10);
}
table.cm_table .sub_head:nth-child(odd){
  background-color: rgba(65, 165, 208, 0.20);
}
@media screen and (max-width: 767px){
  .cm_artList{
    margin: 0 -10px;
  }
  .cm_artList li{
    width: 100%;
    margin: 0 0 20px;
    padding: 0 10px;
  }
  .cm_artList li a{
    padding: 20px;
  }
  .cm_artList_tmb{
    margin: 0 0 12px;
  }
  .cm_artList_item{
    margin: 0 0 5px;
  }
  .cm_artList_item .date{
    font-size: 12px;
  }
  .cm_artList_ttl{
    font-size: 17px;
  }
  .cm_artList li .cate{
    font-size: 12px;
    padding: 0 7px;
  }
  .cm_artList .memberonly{
    width: 36px;
    height: 36px;
    top: 10px;
    left: 10px;
  }
}


/* [ バナーリスト ]
 * -------------------------------------------- */
.cm_bnList{
  margin: 40px 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.cm_bnList.member{
  /* justify-content: start; */
  align-items: center;
}
.cm_bnList li{
  margin: 0 10px 20px;
} 
.cm_bnList li a:hover{
  opacity: .6;
}
@media screen and (max-width: 767px){
  .cm_bnList{
    margin: 30px 0;
    justify-content: space-between;
  }
  .cm_bnList.member{
    justify-content: space-between;
  }
  .cm_bnList li{
    width: 48%;
    margin: 0 0 4%;
  }
}


/* [ 病院リスト ]
 * -------------------------------------------- */
 .cm_clinicList li{
  margin: 0 0 20px;
}
.cm_clinicList li a{
  display: block;
  background: linear-gradient(90deg,var(--white) 0%, rgba(255, 255, 255, 0.31) 100%);
  border: 1px solid var(--green);
  padding: 20px 30px;
}
.cm_clinicList li a:hover{
  opacity: .6;
}
.cm_clinicList_ttl{
  font: 400 24px/1.4 var(--font-family-mincho);
}
.cm_clinicList_item{
  margin: 10px 0 0;
  line-height: 1.4;
  display: flex;
  flex-wrap: wrap;
}
.cm_clinicList_item dl{
  display: flex;
  margin: 0 20px 0 0;
}
.cm_clinicList_item dl dt{
  font-weight: 400;
  color: var(--green);
  border: 1px solid var(--green);
  padding: 2px 10px;
  margin: 0 7px 0 0;
  font-size: 13px;
}
.cm_clinicList_item dl dd{
  padding: 2px 0;
  font-size: 15px;
}
@media screen and (max-width: 767px){
  .cm_clinicList li a{
    padding: 20px;
  }
  .cm_clinicList_ttl{
    font-size: 20px;
  }
  .cm_clinicList_item{
    margin: 15px 0 0;
    display: block;
  }
  .cm_clinicList_item dl{
    margin: 0 0 10px;
  }
  .cm_clinicList_item dl:last-of-type{
    margin: 0;
  }
  .cm_clinicList_item dl dt{
    width: 25%;
    padding: 2px 5px;
    margin: 0 10px 0 0;
    font-size: 12px;
    text-align: center;
    height: fit-content;
  }
  .cm_clinicList_item dl dd{
    width: 75%;
    padding: 2px 0 0;
    font-size: 13px;
  }
}


/* [ キーワード検索ボックス ]
 * -------------------------------------------- */
.cm_searchKeyword form{
  display: flex;
  justify-content: space-between;
  align-items: center;
  overflow: hidden;
  border: 1px solid var(--gray);
  border-radius: 6px;
  text-align: left;
  margin: 20px 0;
  background: var(--white);
  color: var(--black);
}
.cm_searchKeyword form label{
  width: 100%;
}
.cm_searchKeyword form input{
  width: 100%;
  height: 57px;
  padding: 0.5em 1em;
  border: none;
  box-sizing: border-box;
  font-size: 1em;
  outline: none;
}
.cm_searchKeyword form input::placeholder{
  color: #9f9f9f;
}
.cm_searchKeyword form button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 50px;
  height: 57px;
  border: none;
  background-color: transparent;
  cursor: pointer;
}
.cm_searchKeyword form button::after {
  width: 24px;
  height: 24px;
  background: url(../img/common/parts_search.png) center/contain no-repeat;
  content: '';
}

@media screen and (max-width: 767px){
  .cm_searchKeyword form{
    margin: 10px 0;
  }
  .cm_searchKeyword form input{
    height: 52px;
  }
  .cm_searchKeyword form button {
    height: 52px;
  }
  .cm_searchKeyword form button::after {
    width: 20px;
    height: 20px;
  }
}


/* [ ページネーション ]
 * -------------------------------------------- */
.cm_pagination{
  margin: 40px 0 0;
}
.cm_pagination .nav-links{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.cm_pagination .nav-links .page-numbers {
  display: inline-block;
  font: 400 14px/1 var(--font-family-mincho);
  line-height: 40px;
  width: 40px;
  margin: 0 5px;
  text-align: center;
  background: var(--white);
  color: var(--blue-dark);
  border-radius: 50%;
}
.cm_pagination .nav-links .page-numbers.current{
  background: var(--blue-dark);
  color: var(--white);
}
.cm_pagination .nav-links .page-numbers.dots{
  background: transparent;
  width: 25px;
  margin: 0;
}
.cm_pagination .nav-links .page-numbers.prev,
.cm_pagination .nav-links .page-numbers.next{
  position: relative;
  background: var(--green);
  height: 40px;
  line-height: 0;
  padding: 0;
}
.cm_pagination .nav-links .page-numbers.prev::before,
.cm_pagination .nav-links .page-numbers.next::before{
  position: absolute;
  content: '';
  display: block;
  width: 17px;
  height: 5px;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}
.cm_pagination .nav-links .page-numbers.prev::before{
  background: url(../img/common/parts_arrowLeft.png) center/contain no-repeat;
}
.cm_pagination .nav-links .page-numbers.next::before{
  background: url(../img/common/parts_arrowRight.png) center/contain no-repeat;
}
@media screen and (max-width: 767px){
  .cm_pagination{
    margin: 30px 0 0;
  }
  .cm_pagination .nav-links .page-numbers {
    font-size: 13px;
    width: 30px;
    margin: 0 5px;
    border-radius: 4px;
  }
  .cm_pagination .nav-links .page-numbers.dots{
    background: transparent;
    width: 20px;
  }
  .cm_pagination .nav-links .page-numbers.prev,
  .cm_pagination .nav-links .page-numbers.next{
    width: 40px;
    border-radius: 50%;
  }
}
 

/* [ header ]
 * -------------------------------------------- */
/* pc　ヘッダー */
.pc_header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 30px 40px;
  position: fixed;
  z-index: 99;
  top: 0;
  left: 0;
  width: 100%;
}
/* pc　ロゴ */
.pc_header_logo{
  width: 217px;
}
/* pc　グロナビ */
.pc_header_gnav{
  display: flex;
  align-items: center;
}
.pc_header_gnav_item{
  display: flex;
}
.pc_header_gnav_item li {
  margin: 0 30px 0 0;
}
.pc_header_gnav_item li a{
  font-weight: 300;
  font-size: 14px;
  letter-spacing: 0;
}
.pc_header_gnav_item li a:hover{
  opacity: .6;
}
/* 会員ページボタン */
.pc_header_gnav_link{
  font: 400 13px var(--font-family-mincho);
  background: var(--blue);
  color: var(--white);
  padding: 10px 25px;
}
.pc_header_gnav_link:hover{
  opacity: .7;
  color: var(--white);
}
/* pc　ヘッダー固定ver */
.pc_header.fixed {
  padding: 15px 40px;
  background: rgba(255,255,255,0.6);
  -webkit-animation-name: hdDownAnime;
          animation-name: hdDownAnime;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
}
/* sp　ヘッダー */
.sp_header {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 99;
  height: 60px;
}
.sp_header_logo{
  width: 135px;
}
.sp_header_inner{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  height: 100%;
  padding-left: 15px;
  padding-right: 75px;
}
.sp_header_gnav_link{
  font: 400 13px var(--font-family-mincho);
  background: var(--white);
  color: var(--blue);
  border: 1px solid var(--blue);
  font-size: 12px;
  padding: 8px 15px;
}
.sp_header_gnav_link:hover{
  color: var(--blue);
}
.sp_header_toggle {
  position: absolute;
  width: 60px;
  height: 60px;
  right: 0;
  top: 0;
  background: linear-gradient(var(--green) 0%, #4ca79f 100%);
  z-index: 100;
}
.sp_header_toggle::before{
  position: absolute;
  content: 'MENU';
  left: 50%;
  bottom: 6px;
  transform: translateX(-50%);
  color: var(--white);
  font-size: 11px;
}
.sp_header_toggle.active::before{
  content: 'CLOSE';
}
.sp_header_toggle .bar {
  width: 40%;
  left: 30%;
  height: 2px;
  background-color: var(--white);
  position: relative;
  transition: ease 0.4s;
  display: block;
}
.sp_header_toggle .bar:nth-child(1) {
  top: -10px;
}
.sp_header_toggle .bar:nth-child(2) {
  top: -3px;
}
.sp_header_toggle.active .bar:nth-child(1) {
  top: -5px;
  transform: rotate(45deg);
}
.sp_header_toggle.active .bar:nth-child(2) {
  top: -7px;
  transform: rotate(-45deg);
}
.sp_header_gnav {
  position: absolute;
  right: 0;
  left: 0;
  top: 0;
  width: 100%;
  height: 105vh;
  transform: translateX(100%);
  background-color: #D5EAF0;
  transition: ease 0.4s;
  padding: 80px 25px 25px;
  z-index: -1;
}
.sp_header_gnav::before{
  position: absolute;
  content: '';
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-color:hsla(192,46%,89%,1);
  background-image:
  radial-gradient(at 89% 76%, hsla(194,50%,83%,1) 0px, transparent 50%),
  radial-gradient(at 83% 27%, hsla(195,51%,90%,1) 0px, transparent 50%),
  radial-gradient(at 56% 68%, hsla(180,100%,93%,1) 0px, transparent 50%),
  radial-gradient(at 74% 41%, hsla(136,100%,98%,1) 0px, transparent 50%),
  radial-gradient(at 42% 40%, hsla(57,100%,96%,1) 0px, transparent 50%),
  radial-gradient(at 0% 21%, hsla(357,96%,91%,1) 0px, transparent 50%),
  radial-gradient(at 28% 60%, hsla(26,100%,94%,1) 0px, transparent 50%);
}
.sp_header_gnav.active {
  transform: translateX(0);
}
.sp_header_gnav li a{
  display: block;
  padding: 15px 0;
  position: relative;
  border-bottom: 1px solid #6AC3BC;
  letter-spacing: 0;
}
.sp_header_gnav .search{
  position: relative;
  background: linear-gradient(#72c9c2 0%, #10baab 100%);
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  color: var(--white);
  padding: 20px;
  text-align: center;
  margin: 40px 0 0;
}
.sp_header_gnav .search .ttl .en{
  display: inline-block;
  font: 400 16px var(--font-family-marcellus);
  letter-spacing: .2em;
  padding: 0 40px;
  position: relative;
}
.sp_header_gnav .search .ttl .en::before,
.sp_header_gnav .search .ttl .en::after{
  position: absolute;
  content: '';
  width: 30px;
  height: 1px;
  background: #fff;
  top: 50%;
  transform: translateY(-50%);
}
.sp_header_gnav .search .ttl .en::before{
  left: 0;
}
.sp_header_gnav .search .ttl .en::after{
  right: 0;
}
.sp_header_gnav .search .ttl .ja{
  font: 400 22px var(--font-family-mincho);
}
.sp_header_gnav .search .link a{
  text-decoration: underline;
}
.sp_header_gnav .search .link a:hover{
  opacity: .6;
}

@-webkit-keyframes hdDownAnime {
  from {
    transform: translateY(-100px);
  }
  to {
    transform: translateY(0);
  }
}
@keyframes hdDownAnime {
  from {
    transform: translateY(-100px);
  }
  to {
    transform: translateY(0);
  }
}

@media screen and (max-width: 360px){
  .sp_header .sp_header_inner{
    padding-left: 10px;
    padding-right: 65px;
  }
  .sp_header_logo{
    width: 120px;
  }
}
@media screen and (max-width: 1280px) {
  .pc_header {
    display: none;
  }
  .sp_header {
    display: block;
    height: 60px;
  }
}



/* [ footer ]
 * -------------------------------------------- */
.footer{
  padding: 50px 0;
}
.footer a:hover{
  opacity: .6;
}
.footer_navi{
  display: flex;
  flex-wrap: wrap;
  margin: 0 -20px 40px;
  line-height: 1.4;
}
.footer_navi_box{
  width: 20%;
  padding: 0 20px;
}
.footer_navi_box .parent{
  font: 400 17px var(--font-family-mincho);
  color: var(--green);
  margin: 0 0 20px;
}
.footer_navi_box .child{
  font-size: 14px;
  margin: 0 0 10px;
  padding: 0 0 0 15px;
  position: relative;
}
.footer_navi_box .child::before{
  position: absolute;
  content: '';
  width: 7px;
  height: 1px;
  background: var(--black);
  top: 9px;
  left: 0;
}
.footer_navi_box .link{
  display: inline-block;
  margin: 20px 0 0;
  font: 400 13px var(--font-family-mincho);
  background: var(--blue);
  font-size: 13px;
  padding: 13px 25px;
  color: var(--white);
}
.footer_navi_box .link:hover{
  opacity: 0.6;
}
.footer_bottom_sns{
  text-align: center;
  margin: 0 0 20px;
}
.footer_bottom_sns a{
  display: inline-block;
}
.footer_bottom_sns a img{
  width: 32px;
}
.footer_bottom_kiyaku{
  text-align: center;
}
.footer_bottom_kiyaku li{
  display: inline-block;
  font-size: 13px;
  position: relative;
  padding: 0 30px 0 0;
}
.footer_bottom_kiyaku li::before{
  position: absolute;
  content: "|";
  right: 8px;
  top: -1px;
}
.footer_bottom_kiyaku li:last-of-type{
  padding: 0;
}
.footer_bottom_kiyaku li:last-of-type::before{
  content: none;
}
.footer_bottom .copy{
  font: 400 12px var(--font-family-marcellus);
  color: var(--gray-dark);
  text-align: center;
  margin: 20px 0 0;
}

@media screen and (max-width: 767px){
  .footer{
    padding: 30px 0;
  }
  .footer_navi{
    margin: 0 -20px 20px;
  }
  .footer_navi_box{
    width: 100%;
    margin: 0 0 30px;
  }
  .footer_navi_box .link{
    display: block;
    max-width: 250px;
    margin: 40px auto 0;
    text-align: center;
    padding: 15px;
  }
}