@charset "utf-8";
/* CSS Document */

.loading {background:var(--bg_color);display: flex;height: 100%;left: 0;position: fixed;top: 0;width: 100%;z-index: 20000;}
.spinner {margin: auto;max-width: 300px;text-align: center;}
.spinner > div {height: 12px;background-color: #9d3c3c;border-radius: 100%;display: inline-block;-webkit-animation: sk-bouncedelay 1.4s infinite ease-in-out both;animation: sk-bouncedelay 1.4s infinite ease-in-out both;margin: 3px;width: 12px;}
.spinner .bounce1 {
  -webkit-animation-delay: -0.64s;
  animation-delay: -0.64s;
}
.spinner .bounce2 {
  -webkit-animation-delay: -0.48s;
  animation-delay: -0.48s;
}
.spinner .bounce3 {
  -webkit-animation-delay: -0.32s;
  animation-delay: -0.32s;
}
.spinner .bounce4 {
  -webkit-animation-delay: -0.16s;
  animation-delay: -0.16s;
}
@-webkit-keyframes sk-bouncedelay {
  0%, 80%, 100% { -webkit-transform: scale(0) }
  40% { -webkit-transform: scale(1.0) }
}
@keyframes sk-bouncedelay {
  0%, 80%, 100% { 
    -webkit-transform: scale(0);
    transform: scale(0);
  } 40% { 
    -webkit-transform: scale(1.0);
    transform: scale(1.0);
  }
}

/* first */
.firstWrap{width: 100%;height: 100vh;position: relative;overflow: hidden;min-height: 820px;}
.header{position: absolute;top: 0;left: 0;width: 100%;height: 90px;display: flex;justify-content: flex-start;align-items: center;padding: 0 2rem;z-index: 1;}
.logo_area{}
.logo_area img{width: auto;height: 40px;}
.menu_area{display: flex;align-items: center;justify-content: flex-start;gap: 3rem;margin-left: 3.5rem;}
.menu_area > li{color: var(--main_color_txt);font-size: .9em;font-weight: 500;letter-spacing: 2px;}
.first_area{height: 100vh;color:var(--main_color_txt);display: flex;align-items: center;}
.first_area::after {content: "";display: block;width: 100%;height: 100%;background: var(--main_color);position: absolute;top: 0;right: calc(50% - 5%);z-index: -1;clip-path: polygon(0 0, 90% 0, 100% 100%, 0 100%);}
.overlay_area{position: relative;padding-left:6rem;}
.textBox{line-height: 2.5em;padding-bottom: 1rem;font-size:.95em;}
.overlay_logo_area{position: absolute;top: -50%;right: 54%;width: max-content;}
.overlay_logo{}
.overlayCatch{position: absolute;bottom: -2.8vw;font-size: 9.5vw;font-weight: bold;width: 100%;font-family: "Roboto", sans-serif;letter-spacing: .03em;}
.slide{height: 100vh;width: 100%;position: absolute;top: 0;left: 0;z-index: -1;}
.slider_img{width: 100%;height: 100vh;object-fit: cover;object-position: center;}
.slide_list {width: 100%;height: 100%;}
.slick-slide img{min-height: 820px;}
@media screen and (max-height: 820px) and (min-width: 768px) {
.first_area{display:block;}
.overlay_area{padding-top: 9rem;}
}

@media screen and (max-width: 767px) {
.sp_hidden{display:none;}
.firstWrap{height:auto;min-height:inherit;}
.header{justify-content: center;}
.menu_area {display: none;}
.logo_area img{height: 35px;margin-top: 1em;}
.first_area {height: 100%;}
.first_area::after {top: 45vh;right: 0;left: 0;clip-path: polygon(0 6%, 100% 0, 100% 100%, 0 100%);}
.overlay_area {margin-top: calc(62vh);}
.overlay_logo{transform-origin: bottom right;transform: scale(.7);}
.textBox {padding-bottom: 4rem;}
.overlay_logo_area {bottom: 5vw;right: 5vw;top: auto;}
.overlayCatch {bottom: auto;top: 36vh;font-size: 5.5rem;padding-left: 2.5rem;line-height: 1em;}
.slide {height: 50vh;}
.slide_list{height: 60vh;}
.slick-slide img{min-height: inherit;}
}
@media screen and (max-width: 570px) {
.sp_hidden2{display:none;}
.overlay_area{padding: 0 2.5rem;}
.slider_img{object-position: 68% center;}
.textBox{line-height: 2rem;}
.overlayCatch{top: 41vh;font-size: 4rem;}
.overlay_logo{transform: scale(.6);}
}
@media screen and (max-width: 440px) {
.overlayCatch{top: 44vh;font-size: 3.2rem;}
}


/* philosophy */
.contWrap{padding:6rem 3rem 6.2rem;}
.maxwidthWrap {max-width: 1300px;margin: 0 auto;}
.division_area{display: flex;gap: 6rem;}
.left_40 .division_left{width: 40%;position: relative;border-right: 1px var(--border_color) solid;min-width: 470px;/*padding-bottom: 310px;*/}
.left_30 .division_left{width: 40%;}
.left_30 .division_right{width: 100%;text-align: right;background: #fff;border-radius: 15px;}
.titleWrap{}
.title_area{margin-bottom: 3rem;}
.title{font-family: "Roboto", sans-serif;font-size: 3.2rem;font-weight: bold;letter-spacing: 4px;}
.title_sub{display: flex;gap: 1rem;align-items: center;color: #999;letter-spacing: .2em;font-weight: 600;font-size: 1em;margin-top: .3rem;}
.title_sub::before {content: "";display: block;width: 8px;height: 20px;background: var(--main_color);}
.title_txt{margin-bottom: 3rem;line-height: 2rem;font-weight: 500;}
.philos_img{position: absolute;bottom: 0;}
.philos_img img{max-height: 300px;width: auto;border-radius: 15px;}
.philos_cont{}
.philos_cont_li{margin-bottom: 5rem;}
.philos_cont_li:last-child {margin-bottom: 0;}
.philos_label{    background: var(--main_color);display: inline-block;padding: .2em 2rem;color: var(--main_color_txt);border-radius: 50px;font-family: "Roboto", sans-serif;letter-spacing: 2px;font-weight: 600;font-size: 1.2em;margin-bottom: 1rem;}
.philos_ttl{font-size: 2.5rem;font-weight: 600;}
.philos_ttl.jp{font-size: 2.4rem;}
.philos_txt{font-size: 1em;font-weight: 500;margin-top: .3em;}
ul.philos_txt li {margin-bottom: .5em;}
@media screen and (max-width: 1200px) {
.division_area{flex-wrap: wrap;gap: 0;}
.left_40 .division_left,.left_30 .division_left{width:100%;border:none;}
.division_area.left_30{gap: 0;}
.title_area{margin-bottom: 2rem;}
.philos_label{margin-bottom: .5rem;font-size: 1em;}
.philos_cont_li {margin-bottom: 3rem;}
.philos_ttl{font-size: 2rem;}
}
@media screen and (max-width: 767px) {
.maxwidthWrap {max-width:inherit;}
.contWrap {padding: 5rem 3rem;}
.title {font-size: 2.4rem;}
.title_sub{font-size: 1em;letter-spacing: 1.5px;font-weight: 500;color: #666;}
.title_sub::before{height: 16px;}
.division_area{display:block;}
.left_30 .division_left{width:100%;}
.title_area {margin-bottom: 2.2rem;}
.philos_img {margin-bottom: 3rem;position: relative;}
.philos_label {font-size: 1em;}
.philos_ttl {font-size: 2rem;}
.philos_txt{font-size: 1em;}
.philos_cont_li {margin-bottom: 3.5rem;}
.philos_ttl.jp {font-size: 1.7rem;}
.left_40 .division_left{min-width: inherit;padding:0;}
}
@media screen and (max-width: 500px) {
.contWrap {padding: 4rem 2rem;}
.philos_ttl{line-height: 1.2em;margin: .3em 0 .5em;}

}


/* service */
.contWrap_gy{padding: 8rem 3rem;background: var(--bg_color);}
.serv_cont{margin: 4rem 0;display: flex;align-items: stretch;gap: 2rem;}
.serv_cont_li{background: #fff;padding: 2rem;border-radius: 15px;text-align: center;}
.serv_ttl{text-align: center;font-size: 1.2em;font-weight: bold;letter-spacing: 4px;margin-bottom: 1.4rem;display: inline-block;}
.serv_txt{text-align: left;font-size: .95em;}
.serv_detail{text-align: center;}
.serv_detail_ttl{font-size: 1.5em;letter-spacing: 1px;font-weight: 600;margin-bottom: 2rem;}
.serv_detail_cont{display: flex;flex-wrap: wrap;justify-content: flex-start;align-items: center;max-width: calc((300px + 2rem) * 2 + 300px);margin: 0 auto;gap: 1.5rem 2rem;}
.serv_detail_cont_li{background: var(--main_color);color: var(--main_color_txt);padding: .6em 1.5em;border-radius: 50px;width: 300px;font-weight: 600;}
.serv_arrow {text-align: center;margin: 3rem;}
.service_img{height: 100%;width: auto;object-fit: cover;border-radius: 15px;display:block;}
@media screen and (max-width: 1255px) {
.serv_detail_cont{max-width: calc((300px + 2rem) * 1 + 300px);gap: 1rem;}
.serv_cont{flex-wrap: wrap;}
.contWrap_gy{padding: 6rem 3rem;}
.serv_detail_ttl{font-size: 1.4em;}
}
@media screen and (max-width: 767px) {
.contWrap_gy{padding: 5rem 3rem;}
.serv_cont {flex-wrap: wrap;gap: 1.5rem;}
.serv_detail_cont {justify-content: center;gap: 1rem 2rem;}
.serv_detail_cont_li{padding: .3em 1.5em;}
}
@media screen and (max-width: 500px) {
.contWrap_gy {padding: 5rem 2rem;}
}


/* founder */
.fd_cont{display: flex;align-items: stretch;justify-content: center;gap: 4rem;}
.fd_cont_li{width: calc((90% - 5rem) / 2);}
.fd_cont_img_area{width: 200px;height: 200px;border-radius: 200px;background: #eee;overflow: hidden;margin: 0 auto;}
.fd_cont_img{}
.fd_cont_post{text-align: center;margin-top: 1rem;font-weight: 600;letter-spacing: 1px;}
.fd_cont_name{text-align: center;font-weight: 600;font-size: 1.6em;letter-spacing: 1px;}
.fd_cont_txt{border: 2px var(--border_color) solid;border-radius: 15px;padding: 2rem;margin-top: 2rem;}
.fd_cont_txt_box{margin-bottom: 2rem;}
.fd_cont_txt_box:last-child {margin: 0;}
.fd_cont_txt_box_ttl{font-weight: 600;margin-bottom: .5em;}
.fd_cont_txt_box_txt li{font-size: .95em;}

@media screen and (max-width: 1200px) {
.fd_cont{flex-wrap: wrap;gap: 1.5rem;}
.fd_cont_li {width: calc((100% - 1.5rem) / 2);}
}
@media screen and (max-width: 980px) {
.fd_cont{gap: 4rem;}
.fd_cont_li{width:100%;}
}
@media screen and (max-width: 767px) {
.fd_cont_txt_box {margin-bottom: 1rem;}
.fd_cont_name{font-size: 1.5em;}
}
@media screen and (max-width: 500px) {
.fd_cont{gap: 3rem;}
}


/* form */
.contWrap_gy.form_wrap{padding: 5.8rem 3rem 6.2rem;}
form {max-width: 600px;margin: 0 auto;}
label {display: block; margin-top: 15px; font-weight: bold;text-align: left;}
label span {margin-left: .5em;}
input[type="text"],
input[type="email"],
input[type="tel"],
textarea {width: 100%;padding: 8px;box-sizing: border-box;margin-top: 5px;background: #fff;border-radius: 5px;margin-bottom: .5rem;text-align: left;}
textarea { min-height: 150px; }
.actions { margin-top: 20px; }
button {padding: 7px 40px;border: none;cursor: pointer;background: var(--main_color);color: #fff;border-radius: 5rem;font-size: .85em;letter-spacing: 1px;}
@media screen and (max-width: 767px) {
.contWrap_gy.form_wrap{padding: 3.8rem 2rem 4.2rem;}

}



/* footer */
.footer{border-top: 1px var(--border_color) solid;padding: 4rem 2rem 2rem;text-align: center;}
.foot_logo{width: 140px;}
.foot_menu{display: flex;justify-content: center;gap: 2rem;margin: 3rem;font-size:.9em;}
.copyright{font-size: .8em;color: #999;}

@media screen and (max-width: 500px) {
.foot_logo {width: 120px;}
.foot_menu{gap: 1.7rem;margin: 2rem 0;}
}



@media screen and (max-width: 320px) {
.logo_area img{height: 27px;}
.overlay_area{padding: 0 2rem;}
.overlayCatch{font-size: 2.8rem;top: 47vh;padding-left: 2rem;}
.textBox,.title_txt,.philos_txt,.serv_txt{font-size: 13px;line-height: 1.7rem;}
.title{font-size: 1.8rem;}
.title_sub{font-size: .8em;}
.title_sub::before{height: 15px;}
.philos_ttl{font-size: 1.6rem;}
.philos_ttl.jp{font-size: 1.4rem;}
ul.philos_txt li{margin:0;}
.serv_cont_li{padding: 1.5rem;}
.serv_ttl{margin-bottom: .5rem;letter-spacing: 0;font-size: 1em;}
.serv_arrow{transform: scale(.7);margin: 2rem;}
.serv_detail_ttl{font-size: 1.1em;}
.serv_detail_cont_li{font-size: 14px;width: 100%;}
.fd_cont_img_area{width: 130px;height: 130px;}
.fd_cont_post{font-size: .9em;}
.fd_cont_name{font-size: 1.2em;}
.fd_cont_txt{padding: 1.2rem;}
.fd_cont_txt_box{font-size: 13px;}
.fd_cont_txt_box_txt li{line-height: 1.4rem;}
.footer{padding: 4rem 1rem 2rem;}
.foot_logo {width: 100px;}
.foot_menu{font-size: 13px;}
.copyright{font-size:12px;}
label{font-size:13px;}
}
