@charset "UTF-8";
/*--------------------- reset ---------------------*/
html {
  font-size: 62.5%; /* sets the base font to 10px for easier math */
}
body, h1, h2, h3, h4, h5, h6, pre, ul, ol, li, dl, dt, dd, p, img {
  margin: 0;
  padding: 0;
}
body {
  background-color: #fff;
  color: #4d4d4d;
  font-family: "游ゴシック", "Yu Gothic", "游ゴシック体", verdana, Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 400;
  letter-spacing: 0.03em;
  line-height: 1.7;
  position: relative;
}
body * {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
a, a:link, a:hover, a:focus {
  color: #4d4d4d;
  cursor: pointer;
  outline: none;
  text-decoration: none;
  -webkit-transition: all 0.3s linear;
  -moz-transition: all 0.3s linear;
  -o-transition: all 0.3s linear;
  -ms-transition: all 0.3s linear;
  transition: all 0.3s linear;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
  border-color: #000;
}
ul, ol, li {
  list-style-type: none;
}
::selection {
  background-color: #000;
  color: #fff; /* Safari */
}
::-moz-selection {
  background-color: #000;
  color: #fff; /* Firefox */
}
img {
  border: none;
  line-height: 0;
}
/*--------------------- reset_end ---------------------*/


/*▽▽▽▽▽▽---------- contents ----------▽▽▽▽▽▽*/
/*--------------------- .header ---------------------*/
.header {
  background-color: #fff;
  display: flex;
  align-items: center;
  padding-bottom: 4px;
  position: fixed;
  top: 0;
  left: 0;
  transition: all 0.3s linear;
  width: 100%;
  z-index: 50;
}
.header_logo {
  margin: 10px 0 0 20px;
}
.header_logo a {
  display: block;
  width: 300px;
}
.header_logo a:hover {
  opacity: 0.5;
}

/*--------------------- .gnav ---------------------*/
.gnav {
  display: flex;
  align-items: center;
  margin-left: auto;
  transition: all 0.2s linear;
}
.block .gnav {
  padding-right: 80px;
}
.gnav_list {
  display: block;
  margin-left: 15px;
}
.gnav_list a {
  background-color: #29a380;
  border-right: 3px solid #fff;
  border-bottom: 3px solid #fff;
  border-left: 3px solid #fff;
  border-radius: 0 0 10px 10px;
  color: #fff;
  display: inline-block;
  font-weight: bold;
  letter-spacing: 0.3em;
  position: relative;
  padding: 15px;
  text-align: center;
  width: 170px;
}
.gnav_list a:hover {
  background-color: #fff;
  border-color: #29a380;
  color: #29a380;
}

/*--------------------- .hamburger ---------------------*/
.scroll-prevent {
  overflow: hidden;
}

.menu_trigger {
  display: none;
}
.block .menu_trigger {
  display: inline-block;
  cursor: pointer;
  height: 25px;
  position: fixed;
  top: 10px;
  right: 10px;
  width: 25px;
  vertical-align: middle;
  z-index: 111;
}
.menu_trigger::before {
  background-color: #29a380;
  content: "";
  display: block;
  height: 64px;
  position: fixed;
  top: 0;
  right: 0;
  width: 64px;
}
.menu_trigger span {
  background-color: #fff;
  display: inline-block;
  position: absolute;
  right: 9px;
  height: 2px;
  transition: all .5s;
  width: 100%;
}
.menu_trigger span:nth-of-type(1) {
  top: 10px;
}
.menu_trigger.active span:nth-of-type(1) {
  transform: translateY(11px) rotate(-45deg);
}
.menu_trigger span:nth-of-type(2) {
  top: 21px;
  width: 70%;
}
.menu_trigger.active span:nth-of-type(2) {
  opacity: 0;
}
.menu_trigger span:nth-of-type(3) {
  top: 32px;
}
.menu_trigger.active span:nth-of-type(3) {
  transform: translateY(-11px) rotate(45deg);
}

/*--------------------- .ham_menu ---------------------*/
.ham_menu {
  background-color: #fff;
  display: block;
  height: 100%;
  position: fixed;
  top: 0;
  right: 0;
  transform: translate(100%);
  transition: transform 0.5s ease;
  width: 100%;
  z-index: 110;
}
.ham_menu.open {
  right: 0;
  transform: translateZ(0);
  overflow: scroll;
}

/*--------------------- .ham_logo ---------------------*/
.ham_logo {
  margin: 0 auto;
  padding-top: 30px;
  width: 500px;
}

/*--------------------- .ham_menu_list ---------------------*/
.ham_menu_inr {
  margin: 0 auto;
  padding: 40px 15px 30px;
  width: 70%;
}
.ham_menu_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.ham_menu_list li {
  margin-bottom: 2%;
  width: 45%;
}
.ham_menu_list li a, .activity_ttl {
  color: #4d4d4d;
  display: inline-block;
  font-family: 'genjyuu';
  font-size: 24px;
}
.ham_menu_list .next a {
  display: block;
  position: relative;
}
.ham_menu_list li a .en, .activity_ttl .en {
  color: #fff;
  font-size: 54px;
  letter-spacing: 0.15em;
  margin-right: 15px;
  text-shadow: #4d4d4d 1px 1px 0px, #4d4d4d -1px 1px 0px, #4d4d4d 1px -1px 0px, #4d4d4d -1px -1px 0px;
  transition: all 0.3s linear;
}
.ham_menu_list a:hover {
  color: #29a380;
}
.ham_menu_list li a:hover .en {
  text-shadow: #29a380 1px 1px 0px, #29a380 -1px 1px 0px, #29a380 1px -1px 0px, #29a380 -1px -1px 0px;
  transition: all 0.3s linear;
}

/*--------------------- .activity ---------------------*/
.activity_list {
  font-size: 26px;
  position: relative;
}
.activity_list._about_link {
  padding-left: 15px;
}
.activity_list::before {
  content: "\f105";
  color: #4d4d4d;
  font-family: FontAwesome;
  font-size: 20px;
  margin-top: -13px;
  position: absolute;
  top: 50%;
  left: 0;
}
.activity_list small {
  font-size: 18px;
  margin: 0 10px 0 15px;
}
.activity_list.activity01 a {
  color: #29a380;
}
.activity_list.activity02 a {
  color: #edc441;
}
.activity_list.activity03 a {
  color: #e5a1a0;
}
.activity_list.activity04 a {
  color: #92c2d8;
}
.activity_list.activity01 a:hover, .activity_list.activity02 a:hover, .activity_list.activity03 a:hover, .activity_list.activity04 a:hover {
  opacity: 0.3;
}


/*--------------------- .f_acr ---------------------*/
.other_link {
  display: flex;
  flex-wrap: wrap;
  margin-top: 50px;
}
.other_link li {
  margin-right: 30px;
}
.other_link li a {
  color: #4d4d4d;
}
.other_link li a:hover {
  color: #29a380;
  opacity: 0.5;
  text-decoration: underline;
}


/*--------------------- .a_mv ---------------------*/
.mv {
  background: url(/lib/cmn_img/a_mv.jpg) center center no-repeat;
  background-size: cover;
  padding-bottom: 340px;
  position: relative;
  width: 100%;
}
.mv_ttl {
  color: #fff;
  font-family: 'genjyuu bold';
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
}
.ribbon {
  background-color: #29a380;
  display: inline-block;
  font-size: 30px;
  letter-spacing: 0.3em;
  line-height: 1.7;
  padding: 20px;
  position: relative;
  text-align: center;
  width: 400px;
}
.ribbon::before, .ribbon::after {
  content: "";
  border-style: solid;
  border-width: 0;
  height: 0;
  position: absolute;
  top: 0;
  width: 0;
}
.ribbon::before {
  border-color: #29a380 #29a380 #29a380 transparent;
  border-width: 54.5px 0px 54.5px 15px;
  left: -15px;
}
.ribbon::after {
  border-color: #29a380 transparent #29a380 #29a380;
  border-width: 54.5px 15px 54.5px 0px;
  right: -15px;
}
.ribbon .en {
  display: block;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.3em;
  line-height: 1;
}


/*--------------------- .wrap ---------------------*/
.wrap {
  display: block;
}
.wrap.article {
  margin-top: 64px;
}


/*--------------------- .section ---------------------*/
.section {
  padding: 90px 0;
}


/*--------------------- .bg_color ---------------------*/
.bg_color_green {
  background-color: #29a380;
}
.bg_color_thinorange {
  background-color: #fcf6e2;
}


/*--------------------- .inr ---------------------*/
.inr {
  margin: 0 auto;
  width: 1080px;
}
.inr_w {
  margin: 0 auto;
  width: 1200px;
}


/*--------------------- .flex_box ---------------------*/
.flex_box {
  -js-display: flex;
  display: flex;
  justify-content: space-between;
}
.flex_box .flex_txt, .flex_box .flex_img {
  width: 48%;
}
.flex_box .flex_img {
  line-height: 1;
}
.flex_img img {
  width: 100%;
}


/*--------------------- .ttl01 ---------------------*/
.ttl01 {
  color: #4d4d4d;
  font-family: 'genjyuu';
  font-size: 18px;
  letter-spacing: 0.5em;
  margin-bottom: 50px;
  text-align: center;
}
.ttl01::before {
  background: url(/lib/cmn_img/ttl02_ornament.png) center center no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 40px;
  margin: 0 auto;
  width: 80px;
}
.ttl01 .en {
  color: #fff;
  font-size: 50px;
  display: block;
  letter-spacing: 0.15em;
  text-shadow: #4d4d4d 1px 1px 0px, #4d4d4d -1px 1px 0px, #4d4d4d 1px -1px 0px, #4d4d4d -1px -1px 0px;
}
.ttl01.txt_white {
  color: #fff;
}
.ttl01.txt_white::before {
  background: url(/lib/cmn_img/ttl02_ornament_w.png) center center no-repeat;
  background-size: contain;
}

/*--------------------- .ttl02 ---------------------*/
.ttl02 {
  color: #4d4d4d;
  font-family: 'genjyuu';
  font-size: 34px;
  letter-spacing: 0.3em;
  margin-bottom: 40px;
  text-align: center;
}
.ttl02::before {
  background: url(/lib/cmn_img/ttl02_ornament.png) center center no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 30px;
  margin: 0 auto 10px;
  width: 60px;
}

/*--------------------- .ttl03 ---------------------*/
.ttl03 {
  color: #29a380;;
  font-family: 'genjyuu';
  font-size: 28px;
  letter-spacing: 0.3em;
  margin-bottom: 15px;
}


/*--------------------- list ---------------------*/
/*--------------------- .ind_list ---------------------*/
.ind_list li {
  line-height: 1.4;
  margin-bottom: 8px;
  padding-left: 1em;
  text-indent: -0.5em;
}
.ind_list li:before {
  content: "●";
  color: #94d1bf;
  display: inline-block;
}

/*--------------------- .num_list ---------------------*/
.num_list {
  padding-left: 20px;
}
.num_list li {
  line-height: 1.4;
  list-style: decimal outside none;
  margin-bottom: 8px;
}


/*--------------------- .btn ---------------------*/
.btn {
  -webkit-transition: all 0.3s linear;
  -moz-transition: all 0.3s linear;
  -o-transition: all 0.3s linear;
  -ms-transition: all 0.3s linear;
  transition: all 0.3s linear;
}
.btn.center {
  margin: 0 auto;
}

/*--------------------- .basic_btn ---------------------*/
.basic_btn {
  width: 250px;
}
.basic_btn.wide {
  width: 30%;
}
.basic_btn a {
  background: linear-gradient(0deg,#29ab85 0%,#29ab85 50%,#3eb391 50%,#3eb391 100%);
  border-radius: 100px;
  color: #fff;
  display: block;
  font-size: 18px;
  letter-spacing: 0.1em;
  padding: 15px 30px;
  position: relative;
  text-align: center;
}
.basic_btn a:hover {
  opacity: 0.3;
}
.basic_btn a::before {
  content: "\f105";
  font-family: FontAwesome;
  font-size: 24px;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -22px;
}
.basic_btn.yellow a {
  background: linear-gradient(0deg,#edc441 0%,#edc441 50%,#efca54 50%,#efca54 100%);
}

/*--------------------- .btn_clm ---------------------*/
.btn_clm {
  display: flex;
  align-items: center;
  justify-content: center;
}
.btn_clm .basic_btn {
  margin: 0 15px;
}



/*--------------------- .basic_table ---------------------*/
.basic_table01 {
  width: 100%;
}
.basic_table01 tr {
  border-bottom: 2px solid #a4a4a4;
}
.basic_table01 tr.first {
  border-top: 2px solid #a4a4a4;
}
.basic_table01 th {
  background-color: #fcf6e2;
  font-family: 'genjyuu';
  font-size: 22px;
  letter-spacing: 0.3em;
  padding: 15px 20px 12px 20px;
  width: 30%;
}
.basic_table01 td {
  color: #000;
  font-family: 'genjyuu';
  font-size: 22px;
  letter-spacing: 0.1em;
  padding: 15px 20px;
}


/*--------------------- .mail ---------------------*/
.mail {
  padding: 50px 15px;
}
.mail_txt {
  color: #fff;
  font-size: 20px;
  margin-bottom: 40px;
  text-align: center;
}
.mail_txt::before {
  background: url(/img/mail_icon.png) center center no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 50px;
  margin: 0 auto 30px;
  width: 50px;
}


/*▽▽▽▽▽▽---------- access ----------▽▽▽▽▽▽*/
/*--------------------- access ---------------------*/
.access {
  background-color: #fcf6e2;
  padding: 80px 0;
}

/*--------------------- .access_box ---------------------*/
.access_box {
  display: flex;
  justify-content: space-between;
}

/*--------------------- .access_info ---------------------*/
.access_info {
  width: 28%;
}
.access_img {
  border-radius: 20px;
  overflow: hidden;
}
.access_name {
  border-bottom: 2px solid #29a380;
  color: #29a380;
  font-family: 'genjyuu bold';
  letter-spacing: 0.2em;
  margin-bottom: 25px;
  padding: 15px 0;
}
.access_name span {
  font-size: 28px;
  display: inline-block;
  letter-spacing: 0.3em;
  margin-left: 15px;
  vertical-align: sub;
}
.access_info .address, .access_info .fax {
  font-size: 18px;
}
.access_info .tel {
  color: #29a380;
  line-height: 1;
  margin-top: 10px;
  position: relative;
}
.access_info .tel a {
  color: #29a380;
  font-size: 30px;
  letter-spacing: 0.1em;
}
.access_info .tel::before {
  content: "\f095";
  font-family: FontAwesome;
  font-size: 32px;
  vertical-align: sub;
  margin-right: 10px;
}

/*--------------------- .map_area ---------------------*/
.map_area {
  position: relative;
  width: 68%;
}
/*
.map_box_border {
  border: 8px solid #f6e1a0;
  border-radius: 25px;
  display: block;
  height: 450px;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
}
*/
.map_box {
  line-height: 0;
  overflow: hidden;
}


/*--------------------- .tab ---------------------*/
.tab-panel {
  margin-bottom: 50px;
}
.panel {
  display: none;
}
.panel.is-show {
  display: block;
}


/*--------------------- .method_list ---------------------*/
.method_list {
  display: flex;
  margin: 30px -10px 0;
}
.method_list:hover {
  cursor: pointer;
}
.method_list .method {
  padding: 0 10px;
  width: 25%;
}
.method_list .method span {
  border-radius: 100px;
  color: #fff;
  display: block;
  font-family: 'genjyuu';
  font-size: 16px;
  padding: 20px 40px 20px 90px;
  position: relative;
  text-align: center;
  transition: background 0.3s linear;
}
.method_list .method span::after {
  content: "\f105";
  font-family: FontAwesome;
  font-size: 45px;
  margin-top: -39px;
  position: absolute;
  top: 50%;
  right: 15px;
}

.method_list .method.pattern00 span {
  background-color: #29a380;
}
.method_list .method.pattern00 span:hover, .method_list .method.pattern00.is-active span {
  background-color: #fff;
  color: #29a380;
}
.method_list .method.pattern01 span {
  background-color: #edc441;
}
.method_list .method.pattern01 span:hover, .method_list .method.pattern01.is-active span {
  background-color: #fff;
  color: #edc441;
}
.method_list .method.pattern02 span {
  background-color: #e5a1a0;
}
.method_list .method.pattern02 span:hover, .method_list .method.pattern02.is-active span {
  background-color: #fff;
  color: #e5a1a0;
}
.method_list .method.pattern03 span {
  background-color: #92c2d8;
}
.method_list .method.pattern03 span:hover, .method_list .method.pattern03.is-active span {
  background-color: #fff;
  color: #92c2d8;
}

.method_list .method.pattern00 span::before, .method_list .method.pattern01 span::before, .method_list .method.pattern02 span::before, .method_list .method.pattern03 span::before {
  content: "";
  display: block;
  height: 90px;
  margin-top: -45px;
  position: absolute;
  top: 50%;
  left: 0;
  width: 90px;
}
.method_list .method.pattern00 span::before {
  background: url(/lib/cmn_img/access_icon00.png) center center no-repeat;
  background-size: contain;
}
.method_list .method.pattern01 span::before {
  background: url(/lib/cmn_img/access_icon01.png) center center no-repeat;
  background-size: contain;
}
.method_list .method.pattern02 span::before {
  background: url(/lib/cmn_img/access_icon02.png) center center no-repeat;
  background-size: contain;
}
.method_list .method.pattern03 span::before {
  background: url(/lib/cmn_img/access_icon03.png) center center no-repeat;
  background-size: contain;
}


/*--------------------- .sp_tel ---------------------*/
a[href^="tel:"].sp_tel {
  pointer-events: none;
}


/*--------------------- .txt ---------------------*/
.en {
  font-family: 'Roboto Slab', serif;
}
@font-face {
  font-family: 'genjyuu';
  src: url('/lib/text_fonts/GenJyuuGothic-P-Medium.ttf') format('truetype');
  font-style: normal;
}
@font-face {
  font-family: 'genjyuu bold';
  src: url('/lib/text_fonts/GenJyuuGothic-P-Bold.ttf') format('truetype');
  font-style: normal;
}
a.txt_link {
  color: #a50505;
  text-decoration: underline;
}
a.txt_link:hover {
  text-decoration: none;
}
a.blank::after {
  background: url(/lib/cmn_img/blank.png) center center no-repeat;
  background-size: cover;
  content: "";
  display: inline-block;
  height: 15px;
  margin-left: 5px;
  vertical-align: middle;
  width: 15px;
}
.white_txt {
  color: #fff;
}
.center {
  text-align: center;
}
.size14 {
  font-size: 14px;
}
.size16 {
  font-size: 16px;
}
.size18 {
  font-size: 18px;
}
.size20 {
  font-size: 20px;
}

/*--------------------- .mb ---------------------*/
.mb5 {
  margin-bottom: 5px;
}
.mb10 {
  margin-bottom: 10px;
}
.mb15 {
  margin-bottom: 15px;
}
.mb20 {
  margin-bottom: 20px;
}
.mb25 {
  margin-bottom: 25px;
}
.mb30 {
  margin-bottom: 30px;
}
.mb40 {
  margin-bottom: 40px;
}
.mb50 {
  margin-bottom: 50px;
}


/*--------------------- other ---------------------*/
.pc_br {
  display: block;
}
.sp_br {
  display: none;
}
.pc_none {
  display: block;
}
.sp_block {
  display: none;
}
.sp_block img {
  width: 100%;
}
.img {
  line-height: 0;
}
.img img {
  width: 100%;
}


/*--------------------- .footer ---------------------*/
.footer {
  background-color: #fff;
}
.footer_logo {
  margin: 0 auto;
  padding: 40px 15px;
  width: 144px;
}
.copy_txt {
  background-color: #29a380;
  color: #fff;
  font-size: 13px;
  padding: 5px 15px;
}


/*--------------------- #page_top ---------------------*/
#page_top {
  background-color: #edc441;
  height: 50px;
  position: fixed;
  right: 0;
  bottom: 0;
  -webkit-transition: all 0.3s linear;
  -moz-transition: all 0.3s linear;
  -o-transition: all 0.3s linear;
  -ms-transition: all 0.3s linear;
  transition: all 0.3s linear;
  width: 50px;
  z-index: 20;
}
#page_top a {
  display: block;
  padding: 20px 20px 30px;
  position: relative;
}
#page_top a::after {
  content: "\f106";
  color: #fff;
  font-family: FontAwesome;
  font-size: 20px;
  position: absolute;
  top: 7px;
  left: 19px;
}
#page_top:hover {
  transform: scale(1.1);
}