@charset "UTF-8";
/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - https://richclarkdesign.com 
Twitter: @rich_clark
*/

/*HP-css*/
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  margin: 0;
  outline: 0;
  font-size: 100%;
  /*vertical-align: baseline;*/
  padding-top: 0px;
  height: auto;
  width: auto;
  background: transparent;
}
.loader_icon img {
  width: 25px;
  height: 25px;
	animation:2.5s linear infinite rotation;
}
.loader_box .loader_inner {
  width: 100vw;
  height: 100vh;
}
.loader_box {
  height: 100%;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 300;
  background-color: #909090;
}
.loader_icon {
  position: absolute;
  left: 50%;
  top: 50%;
  margin-top: -40px;
  text-align: center;
  margin-left: -28px;
}
.service_box .slick .slick1 .slide_img {
	height: 250px;
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}
.service_box .slick .slick1 {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
}
.info .scroll_box .scroll_text p span {
  color: #ADADAD;
  font-weight: normal;
  margin-right: 12px;
}
.info .scroll_box .scroll_text {
  overflow: auto;
  height: 150px;
  padding-top: 0px;
  padding-bottom: 10px;
  margin-top: 15px;
  margin-left: auto;
  margin-right: auto;
  display: inline-block;
  padding-left: 5px;
  padding-right: 8px;
  width: 92%;
}
/*ラインアニメーション上から*/
/* 画面外にいる状態 */
.move_down {
  opacity : 0;
  transform : translate(0, -100px);/*フェードする距離*/
  transition : all 600ms;
}
/* 画面内に入った状態 */
.move_down.scrollin {
  opacity : 1;
  transform : translate(0, 0);
}
/*---------------*/
.flow_box .overflow {
	overflow-y: hidden;
}
.flow_box .overflow .number_line {
	width: 5px;
  height: 45px;
  background-color: #112D56;
  margin-left: auto;
  margin-right: auto;
}
.sv_box_B {
  padding-top: 45px;
	padding-bottom: 45px;
}
.sv_box_A {
  padding-top: 30px;
}
.service_box .number {
  position: absolute;
  color: #EAF1F6;
  font-size: 56px;
  z-index: -1;
  top: -22px;
  font-weight: normal;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
}
.table_back_gray .table_back_img .black_filter {
  background-color: rgba(0,0,0,0.10);
  width: 100%;
  height: 100%;
}
.voice_box .vo-list dd .vo_split_box .vo_img {
  width: 100%;
  height: 60vw;
  background-color: #518BDF;
  margin-top: 15px;
}
.faq_link .faq_link_box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.works_link .works_link_box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.faq_link .container {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
.works_link .container {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
.staff_space {
  margin-top: 18px;
}
.staff_box_B .container {
  width: 100vw;
  margin-left: auto;
  margin-right: auto;
  max-width: 1300px;
}
.staff_box_B .message_box p {
  font-size: 13px;
  margin-top: 10px;
}
.staff_box_A {
  padding-top: 30px;
  padding-bottom: 30px;
}
.staff_box {
  width: 92.5%;
  margin-left: auto;
  margin-right: auto;
}
.outline_content {
  margin-right: auto;
  margin-left: auto;
  margin-bottom: 0;
	margin-top: 20px;
  width: 94%;
  border-left: none;
  border-right: none;
  border-top: 1px solid #DCDCDC;
  border-bottom: 1px solid #DCDCDC;
  border-collapse: separate;
  border-spacing: 0 8px;
  letter-spacing: 0.04em;
}
.client_content {
  margin-right: auto;
  margin-left: auto;
  margin-bottom: 0;
	margin-top: 20px;
  width: 94%;
  border-left: none;
  border-right: none;
  border-top: 1px solid #DCDCDC;
  border-bottom: 1px solid #DCDCDC;
  border-collapse: separate;
  border-spacing: 0 8px;
  letter-spacing: 0.04em;
}
.works_content {
  margin-right: auto;
  margin-left: auto;
  margin-bottom: 0;
	margin-top: 20px;
  width: 94%;
  border-left: none;
  border-right: none;
  border-top: 1px solid #DCDCDC;
  border-bottom: 1px solid #DCDCDC;
  border-collapse: separate;
  border-spacing: 0 8px;
  letter-spacing: 0.04em;
}
table.outline_content th {
  vertical-align: middle;
  border-right: 1px solid #DCDCDC;
  margin: 0;
  text-align: center;
  color: #212121;
  font-size: 13px;
  font-weight: normal;
}
table.outline_content td.data {
  margin: 0;
  height: 40px;
  width: 80%;
  border: none;
  color: #212121;
  font-size: 12px;
  line-height: 2;
  text-align: left;
  vertical-align: middle;
  overflow: hidden;
  padding-left: 15px;
  padding-top: 5px;
  padding-bottom: 5px;
}
 table.outline_content td:fst-child {
 padding: 0 0 0 10px;
 vertical-align: middle;
}
table.outline_content td.bar {
	height: 1px;
	width: 100%;
	border-top: solid 1px #DCDCDC;
}
table.client_content th {
  vertical-align: middle;
  border-right: 1px solid #DCDCDC;
  margin: 0;
  text-align: justify;
  color: #212121;
  font-size: 13px;
  font-weight: normal;
  width: 50%;
  padding-left: 10px;
  padding-right: 10px;
}
table.client_content td.data {
  vertical-align: middle;
  margin: 0;
  text-align: left;
  color: #212121;
  font-size: 13px;
  font-weight: normal;
  width: 50%;
  padding-left: 10px;
  padding-right: 10px;
  height: 40px;
  padding-top: 5px;
  padding-bottom: 5px;
}
 table.client_content td:fst-child {
 padding: 0 0 0 10px;
 vertical-align: middle;
}
table.client_content td.bar {
	height: 1px;
	width: 100%;
	border-top: solid 1px #DCDCDC;
}
table.works_content th {
  vertical-align: middle;
  border-right: 1px solid #DCDCDC;
  margin: 0;
  text-align: center;
  color: #212121;
  font-size: 13px;
  font-weight: normal;
}
table.works_content td.data {
  margin: 0;
  height: 40px;
  width: 60%;
  border: none;
  color: #212121;
  font-size: 12px;
  line-height: 2;
  text-align: left;
  vertical-align: middle;
  overflow: hidden;
  padding-left: 15px;
  padding-top: 5px;
  padding-bottom: 5px;
}
 table.works_content td:fst-child {
 padding: 0 0 0 10px;
 vertical-align: middle;
}
table.works_content td.bar {
	height: 1px;
	width: 100%;
	border-top: solid 1px #DCDCDC;
}
.principle section h3 span {
	font-size: 18px;
}
.principle section {
  background-color: #112D56;
  border-radius: 8px;
  display: block;
  position: relative;
  text-align: center;
  padding-top: 10px;
  padding-bottom: 10px;
  margin-bottom: 15px;
}
.principle section p {
  color: #3D6DB3;
  position: absolute;
  font-size: 18px;
  left: 10px;
}
.principle section h3 {
  color: #FFFFFF;
  font-weight: normal;
  font-size: 13px;
}
.principle {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 20px;
}
.com_sub_text img {
  width: 150px;
  height: auto;
  display: block;
  margin-left: auto;
}
.back_img_box img {
  display: none;
}
.mail_form {
  margin-top: 50px;
  padding-top: 25px;
  padding-bottom: 25px;
  border: 1px solid #031020;
  width: 92%;
  margin-left: auto;
  margin-right: auto;
}
form p {
  border-bottom: 1px solid #C7C7C7;
  padding-bottom: 17px;
  padding-top: 12px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
form .textfield_label {
  font-size: 13px;
  display: inline-block;
  width: 115px;
  color: #191919;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  font-weight: bold;
}
form .icon_any {
  font-size: 11px;
  background-color: #8E8E8E;
  font-weight: normal;
  padding-left: 10px;
  padding-right: 10px;
  padding-top: 4px;
  padding-bottom: 5px;
	border-radius: 100vw;
  color: #FFFFFF;
}
form .icon_require {
  font-size: 11px;
  background-color: #FFF532;
  font-weight: normal;
  padding-left: 10px;
  padding-right: 10px;
  padding-top: 4px;
  padding-bottom: 5px;
  border-radius: 100vw;
  color: #000000;
}
form .content_box .radio {
  width: 12px;
  height: 12px;
  top: 1px;
  position: relative;
}
form .content_box {
  font-size: 12px;
  margin-top: 5px;
  font-family: 'Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
  color: #191919;
  font-weight: normal;
}
form #fullname {
  padding: 8px;
  width: 95%;
  font-size: 12px;
  border: none;
  margin-top: 10px;
  border-radius: 3px;
  background-color: #F3F3F3;
}
form #tel {
	padding: 8px;
  width: 95%;
  font-size: 12px;
  border: none;
  margin-top: 10px;
  border-radius: 3px;
  background-color: #F3F3F3;
}
form #company {
	padding: 8px;
  width: 95%;
  font-size: 12px;
  border: none;
  margin-top: 10px;
  border-radius: 3px;
  background-color: #F3F3F3;
}
form #mail {
	padding: 8px;
  width: 95%;
  font-size: 12px;
  border: none;
  margin-top: 10px;
  border-radius: 3px;
  background-color: #F3F3F3;
}
form #area {
	padding: 8px;
  width: 95%;
  font-size: 12px;
  border: none;
  margin-top: 10px;
  border-radius: 3px;
  background-color: #F3F3F3;
}
form #message {
	padding: 8px;
  width: 95%;
  font-size: 12px;
  border: none;
  margin-top: 10px;
  border-radius: 3px;
  background-color: #F3F3F3;
	height: 160px;
}
form .submit {
  border: none;
  text-align: center;
}
form .submit input {
  font-size: 14px;
  background-color: #FFFFFF;
  color: #353535;
  padding-top: 10px;
  padding-bottom: 10px;
  padding-left: 20px;
  padding-right: 20px;
  transition: all 0.3s;
  border-radius: 100vw;
  margin-top: 10px;
  border: 2px solid #112D56;
}
form .submit input:hover  {
  cursor: pointer;
  background-color: #112D56;
  color: #FFFFFF;
}

.privacy_box .text {
  margin-bottom: 25px;
}
.privacy_box .text h3 img {
  width: 16px;
  height: auto;
  margin-bottom: -2px;
}
.privacy_box .container {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
.sub_hero_title .sub_small_title img {
  width: 16px;
  height: auto;
  display: inline-block;
  margin-right: 5px;
  animation: 2.5s linear infinite rotation;
  margin-top: -1px;
}
.sub_hero video {
  width: 94.1%;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  height: 300px;
  object-fit: fill;
  top: 12px;
}
.hero video {
  width: 94.1%;
  height: 96.5%;
  overflow: hidden;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
	object-fit: cover;
}
.staff_hero .staff_hero_img {
  width: 94.1%;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  height: 300px;
  object-fit: fill;
  top: 12px;
}
.copyright {
  display: none;
}
footer .footC .under_flex {
  width: 95%;
  max-width: 280px;
  margin-left: auto;
  margin-right: auto;
}
footer .footC {
  background-color: #112D56;
  margin-top: 35px;
  padding-top: 18px;
  padding-bottom: 18px;
}
footer .footC .privacy {
  color: #FFFFFF;
  font-size: 12px;
}
footer .footB {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
footer .container {
  width: 95%;
  margin-left: auto;
  margin-right: auto;
  max-width: 280px;
}
footer .footB section {
  width: 40%;
}
footer .footA {
  margin-top: 35px;
}
footer .footA img {
  width: 140px;
  height: auto;
}
.qa-list dl {
  position: relative;
  margin-top: 20px;
  margin-right: 0;
  margin-left: 0;
  cursor: pointer;
  margin-bottom: 10px;
}
.voice-list dl {
  position: relative;
  margin-top: 20px;
  margin-right: 0;
  margin-left: 0;
  cursor: pointer;
  margin-bottom: 10px;
}
.qa-list dl dt {
  position: relative;
  margin: 0;
  padding-top: 18px;
  padding-left: 55px;
  padding-bottom: 15px;
  padding-right: 35px;
  color: #112D56;
  font-size: 13px;
  border-bottom: 1px solid #112D56;
  transition: all 0.3s;
}
.qa-list dl dd {
  position: relative;
  margin: 0;
  padding-top: 9px;
  padding-right: 10px;
  padding-left: 55px;
  padding-bottom: 10px;
  background-color: #FBFBFB;
  border-right: 1px solid #112D56;
  border-bottom: 1px solid #112D56;
  border-left: 1px solid #112D56;
}
.qa-list dl dd p {
  margin: 8px 0 0;
  color: #000000;
  font-size: 13px;
}
.qa-list dl dt::before {
		width: 35px;
		height: 35px;
		justify-content: center;
		display: flex;
		align-items: center;
		border-radius: 100vh;
		position: absolute;
    top: 50%;
    left: 10px;
    transform: translateY(-50%);
    font-size: 20px;
    line-height: 1;
    content: 'Q';
    color: #FFFFFF;
		background-color: #112D56;
}
.qa-list dl dd::before {
		width: 35px;
		height: 35px;
		justify-content: center;
		display: flex;
		align-items: center;
		border-radius: 100vh;
    font-size: 20px;
    line-height: 1;
    position: absolute;
    left: 10px;
    content: 'A';
    color: #FFFFFF;
		background-color: #FF6C48;
}
.qa-list dl::after {
    position: absolute;
    top: 24px;
    right: 15px;
    transform: translateY(-50%) rotate(135deg);
    display: block;
    width: 7px;
    height: 7px;
    margin: auto;
    content: '';
    border-top: 1px solid #112D56;
    border-right: 1px solid #112D56;
}
.qa-list .open::after {
    transform: rotate(-45deg);
}
.voice-list dl dt {
  position: relative;
  margin: 0;
  padding-top: 18px;
  padding-left: 55px;
  padding-bottom: 15px;
  padding-right: 35px;
  color: #112D56;
  font-size: 13px;
  border-bottom: 1px solid #112D56;
  transition: all 0.3s;
}
.voice-list dl dd {
  position: relative;
  margin: 0;
  padding-top: 9px;
  padding-right: 10px;
  padding-left: 55px;
  padding-bottom: 10px;
  background-color: #FBFBFB;
  border-right: 1px solid #112D56;
  border-bottom: 1px solid #112D56;
  border-left: 1px solid #112D56;
}
.voice-list dl dd p {
  margin: 8px 0 0;
  color: #000000;
  font-size: 13px;
}
.voice-list dl dt::before {
		width: 35px;
		height: 35px;
		justify-content: center;
		display: flex;
		align-items: center;
		border-radius: 100vh;
		position: absolute;
		top: 50%;
		left: 10px;
		transform: translateY(-50%);
		background-color: #E4E4E4;
		content: '';
		background-image: url(img/person_icon.png);
		background-position: center center;
		background-size: cover;
		background-repeat: no-repeat;
}
.voice-list dl dd::before {
		width: 35px;
		height: 35px;
		justify-content: center;
		display: flex;
		align-items: center;
		position: absolute;
		left: 10px;
		content: '';
		background-image: url("img/comment_icon.png");
		background-position: center center;
		background-size: cover;
		background-repeat: no-repeat;
}
.voice-list dl::after {
    position: absolute;
    top: 24px;
    right: 15px;
    transform: translateY(-50%) rotate(135deg);
    display: block;
    width: 7px;
    height: 7px;
    margin: auto;
    content: '';
    border-top: 1px solid #112D56;
    border-right: 1px solid #112D56;
}
.voice-list .open::after {
    transform: rotate(-45deg);
}
.vo-list dl {
  position: relative;
  margin-top: 5px;
  margin-right: 0;
  margin-left: 0;
  cursor: pointer;
  margin-bottom: 0px;
  border-bottom: 1px solid #CACACA;
}
.vo-list dl dt {
  position: relative;
  margin: 0;
  padding-top: 18px;
  padding-left: 15px;
  padding-bottom: 15px;
  padding-right: 35px;
  transition: all 0.3s;
}
.vo-list dl dd {
  position: relative;
  margin: 0;
  padding-top: 14px;
  padding-right: 15px;
  padding-left: 15px;
  padding-bottom: 15px;
  background-color: #F4F4F4;
}
.vo-list dl dd p {
  margin: 8px 0 0;
  color: #000000;
  font-size: 13px;
}
.vo-list dl::after {
    position: absolute;
    top: 54px;
    right: 15px;
    transform: translateY(-50%) rotate(135deg);
    display: block;
    width: 7px;
    height: 7px;
    margin: auto;
    content: '';
    border-top: 1px solid #112D56;
    border-right: 1px solid #112D56;
}
.vo-list .open::after {
    transform: rotate(-45deg);
}
.common_company_box {
  background-image: url(img/info_back.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  width: 100vw;
  padding-top: 45px;
  padding-bottom: 25px;
}
.common_faq_box {
  width: 100vw;
}
.common_voice_box {
  width: 100vw;
}
.swiper-container {
  width: 100vw;
  height: 180px;
  margin-top: 30px;
}
.swiper-container .swiper-wrapper .slide_A {
  background-image: url(img/corporate_sv.jpg);
  background-position: left center;
  background-size: cover;
  background-repeat: no-repeat;
}
.swiper-container .swiper-wrapper .slide_B {
  background-image: url(img/corporate_sv.jpg);
  background-position: left center;
  background-size: cover;
  background-repeat: no-repeat;
}
.swiper-container .swiper-wrapper .slide_C {
  background-image: url(img/corporate_sv.jpg);
  background-position: left center;
  background-size: cover;
  background-repeat: no-repeat;
}
.swiper-container .swiper-wrapper .slide_D {
  background-image: url(img/corporate_sv.jpg);
  background-position: left center;
  background-size: cover;
  background-repeat: no-repeat;
}
.conD {
  padding-top: 30px;
  padding-bottom: 30px;
}
.conC {
  padding-top: 30px;
}
.middle_contact_box .tel_button {
  margin-bottom: 25px;
}
.middle_contact_box .tel_button a img {
  width: 22px;
  height: auto;
  margin-right: 8px;
}
.middle_contact_box .mail_button a img {
  width: 22px;
  height: auto;
  margin-right: 8px;
}
.middle_contact_box {
  background-color: #F8F8EF;
  width: 100vw;
  text-align: center;
  padding-top: 30px;
  padding-bottom: 30px;
}
.link_btn_box_w {
  width: 100vw;
  text-align: center;
  padding-top: 30px;
}
.link_btn_box_t {
  text-align: center;
  padding-top: 30px;
}
.link_btn_box_y {
  text-align: center;
  padding-top: 30px;
}
.service_box .service_link .service_title {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 20px;
}
.service_box .service_link .service_title_B {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 20px;
}
.service_box .service_link .service_text {
  background-color: #112D56;
  width: 100vw;
  text-align: left;
}
.service_box .service_link .case_sv_text {
  background-color: #112D56;
  width: 100vw;
  text-align: left;
}
.service_box .service_link .service_text_B {
  background-color: #112D56;
  width: 100vw;
  text-align: left;
}
.service_box .service_link .case_sv_text_B {
  background-color: #112D56;
  width: 100vw;
  text-align: left;
}
.conB {
  padding-top: 20px;
}
.com_box_C {
  padding-top: 0px;
}
.variable_box .variable_text .text_box {
  padding-top: 30px;
  padding-bottom: 30px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
.variable_box .variable_text_blue .text_box {
  padding-top: 25px;
  padding-bottom: 25px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.variable_box {
  padding-top: 15px;
}
.variable_box .img_box {
  width: 90%;
  height: 250px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 25px;
}
.variable_box .google_map {
  width: 90%;
  height: 250px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 25px;
}
.service_box .img_box {
  width: 90%;
  height: 250px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 25px;
  margin-top: 15px;
}
.variable_box .variable_text {
  width: 100vw;
  background-color: #F8F8EF;
}
.variable_box .variable_text_blue {
  width: 100vw;
  background-color: #112D56;
  padding-top: 10px;
  padding-bottom: 20px;
}
.move_back_A .flex .info {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 10px;
}
.move_back_A .flex .box {
  position: relative;
}
.jp_main_title {
  margin-top: 10px;
}
.conA {
  position: relative;
  padding-top: 50px;
  padding-bottom: 35px;
}
.com_box_A {
  position: relative;
  padding-top: 10px;
  padding-bottom: 35px;
}
.com_box_B {
  position: relative;
  padding-top: 10px;
  padding-bottom: 35px;
}
.com_box_D {
  position: relative;
  padding-top: 30px;
  padding-bottom: 35px;
}
.works_box_A {
  position: relative;
  padding-top: 30px;
  padding-bottom: 35px;
}
.case_box {
  padding-top: 25px;
  padding-bottom: 30px;
}
.privacy_box {
  position: relative;
  padding-top: 30px;
  padding-bottom: 35px;
}
.js-scroll .motion-txt .small_title img {
  width: 16px;
  height: auto;
  display: inline-block;
  margin-right: 4px;
	animation:2.5s linear infinite rotation;
}
@keyframes rotation{
  0%{ transform:rotate(0);}
  100%{ transform:rotate(360deg); }
}
.js-scroll .motion-txt .jp_small_title img {
  width: 16px;
  height: auto;
  display: inline-block;
  margin-right: 4px;
	animation:2.5s linear infinite rotation;
}
h1, h2, h3, p, a {
  /*font-family: 'Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;*/
  line-height: 1.7;
  letter-spacing: 0.04em;
  color: #191919;
	font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
}
.mail_form .jp_main_title p {
  font-size: 13px;
  text-align: center;
  letter-spacing: 0.01em;
  margin-top: 15px;
}

.loader_icon p {
  font-size: 12px;
  color: #FFFFFF;
}
.service_box .slick .slick1 .slide_img .before {
  background-color: #FF5128;
  color: #FFFFFF;
  font-size: 14px;
  display: inline-block;
  padding-left: 8px;
  padding-right: 8px;
  padding-top: 4px;
  padding-bottom: 3px;
  margin-top: 15px;
  margin-left: 15px;
  letter-spacing: 0.12em;
  width: 70px;
  text-align: center;
}
.service_box .slick .slick1 .slide_img .after {
  background-color: #112D56;
  color: #FFFFFF;
  font-size: 14px;
  display: inline-block;
  padding-left: 8px;
  padding-right: 8px;
  padding-top: 4px;
  padding-bottom: 3px;
  margin-top: 15px;
  margin-left: 15px;
  letter-spacing: 0.12em;
  width: 70px;
  text-align: center;
}
.info .scroll_box .scroll_text p {
  font-size: 12px;
  text-align: justify;
  color: #FFFFFF;
  margin-bottom: 5px;
}
.flow_box .flow_text .second_title {
  font-size: 17px;
  text-align: center;
  margin-bottom: 10px;
}
.flow_box .flow_text .main_text {
  font-size: 13px;
}
.flow_box section {
  background-color: #FDFDF2;
  padding-left: 15px;
  padding-top: 20px;
  padding-bottom: 20px;
  padding-right: 15px;
  position: relative;
}
.flow_box {
  width: 94%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 20px;
}
.voice_box .vo-list .qa dt p {
  font-size: 16px;
  margin-top: 5px;
}
.faq_link .faq_link_box a {
  text-decoration: none;
  border-radius: 100vw;
  background-color: #112D56;
  color: #FFFFFF;
  font-size: 13px;
  width: 46.5%;
  text-align: center;
  padding-top: 10px;
  padding-bottom: 10px;
  margin-top: 15px;
}
.works_link .works_link_box a {
  text-decoration: none;
  border-radius: 100vw;
  background-color: #112D56;
  color: #FFFFFF;
  font-size: 13px;
  width: 46.5%;
  text-align: center;
  padding-top: 10px;
  padding-bottom: 10px;
  margin-top: 15px;
}
.staff_box a p {
  font-size: 17px;
  line-height: 1.5;
}
.staff_hero h1 {
  font-size: 17px;
  line-height: 1.5;
  color: #FFFFFF;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  font-weight: normal;
}
.staff_box a p span {
  font-size: 13px;
}
.staff_hero h1 span {
  font-size: 13px;
}
.staff_box a {
  text-decoration: none;
  transition: all 0.3s;
  margin-top: 15px;
	margin-bottom: 15px;
  display: block;
}
.js-scroll .motion-txt .motion-inner .back_img_box p {
  display: none;
}
.privacy_box .text p {
  font-size: 13px;
}
.privacy_box .text h3 {
  font-size: 16px;
  margin-bottom: 5px;
}
footer a {
  text-decoration: none;
}
footer .footC .deepxi {
  font-size: 12px;
  color: #2C5BA1;
  display: block;
  margin-top: 5px;
}
footer .footC small {
  color: #FFFFFF;
  font-size: 12px;
  text-align: left;
  margin-top: 10px;
  display: flex;
  align-items: center;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
}
footer small span {
  font-size: 14px;
  margin-right: 3px;
  display: block;
  margin-top: 3px;
}
footer .footB .link_A {
  color: #FFFFFF;
  display: block;
  margin-top: 15px;
  font-size: 15px;
}
footer .footB .link_B {
  color: #FFFFFF;
  display: block;
  font-size: 13px;
  margin-top: 5px;
}
footer .footA p {
  color: #FFFFFF;
  font-size: 13px;
  margin-top: 10px;
}
.middle_contact_box .tel_button a {
  border-radius: 100vh;
  width: 280px;
  border: 2px solid #112D56;
  text-decoration: none;
  color: #112D56;
  display: flex;
  align-items: center;
  margin-left: auto;
  margin-right: auto;
  justify-content: center;
  font-size: 19px;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  height: 45px;
  background-color: #FFFFFF;
}
.link_btn_box_w a {
  border-radius: 100vh;
  width: 280px;
  border: 2px solid #112D56;
  text-decoration: none;
  color: #112D56;
  display: flex;
  align-items: center;
  margin-left: auto;
  margin-right: auto;
  justify-content: center;
  font-size: 16px;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  background-color: #FFFFFF;
  height: 45px;
  margin-bottom: 10px;
  margin-top: 20px;
}
.link_btn_box_t a {
  border-radius: 100vh;
  width: 280px;
  border: 2px solid #FFFFFF;
  text-decoration: none;
  color: #FFFFFF;
  display: flex;
  align-items: center;
  margin-left: auto;
  margin-right: auto;
  justify-content: center;
  font-size: 19px;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  height: 45px;
}
.link_btn_box_y a {
  border-radius: 100vh;
  width: 280px;
  text-decoration: none;
  color: #112D56;
  display: flex;
  align-items: center;
  margin-left: auto;
  margin-right: auto;
  justify-content: center;
  font-size: 16px;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  background-color: #FFF532;
  height: 45px;
  border: 2px solid #FFF532;
}

.middle_contact_box .mail_button a {
  border-radius: 100vh;
  width: 280px;
  border: 2px solid #112D56;
  text-decoration: none;
  color: #FFFFFF;
  display: flex;
  align-items: center;
  margin-left: auto;
  margin-right: auto;
  justify-content: center;
  font-size: 16px;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  background-color: #112D56;
  height: 45px;
}
.middle_contact_box p {
  font-size: 13px;
  margin-bottom: 5px;
}
.service_link a {
  text-decoration: none;
}
.service_box .service_link h2 {
  color: #112D56;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: 23px;
  font-weight: normal;
  display: flex;
  align-items: center;
  margin-bottom: 10px;
  justify-content: center;
}
.variable_text .text_box p {
  font-size: 13px;
  margin-top: 10px;
}
.variable_text_blue .text_box p {
  font-size: 13px;
  margin-top: 15px;
  color: #FFFFFF;
}
.js-scroll .motion-txt .motion-inner .back_title {
  color: #EAF1F6;
  font-size: 56px;
  letter-spacing: 0.07em;
  text-align: center;
}
.js-scroll .motion-txt .motion-inner .back_img_box {
  width: 92.5vw;
  height: 65vw;
  background-image: url(img/ceo_s.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.js-scroll .motion-txt .motion-inner .staff_list_img {
  width: 92.5vw;
  height: 60vw;
  background-color: #B9B9B9;
}
.js-scroll .motion-txt .motion-inner .sub_back_title {
  color: #EAF1F6;
  font-size: 62px;
  letter-spacing: 0.07em;
  text-align: center;
  line-height: 1;
}
.jp_sub_text p {
  font-size: 13px;
  text-align: justify;
  line-height: 2;
  margin-top: 10px;
}
.com_sub_text p {
  font-size: 13px;
  text-align: justify;
  margin-bottom: 10px;
}
.jp_sub_text p .pc_br {
  display: none;
}
.jp_sub_text {
  margin-top: 20px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
.com_sub_text {
  margin-top: 20px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
/*------------フェードイン----------*/
/* 画面外にいる状態 */
.fade-in {
  opacity : 0.05;
  transform : translate(0, 0);/*フェードする距離*/
  transition : all 800ms;
}
.service_box .slick {
  background-color: #727272;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 15px;
  margin-bottom: 25px;
}
.info .scroll_box {
  text-align: center;
  border: 1px solid #FFFFFF;
  background-color: rgba(0,0,0,0.15);
}
.mail_form form {
  margin-top: 20px;
}
/* 画面内に入った状態 */
.fade-in.scrollin {
  opacity : 1;
  transform : translate(0, 0);
}
/*------------フェードアップ----------*/
/* 画面外にいる状態 */
.fade-up {
  opacity : 0;
  transform : translate(0, 30px);/*フェードする距離*/
  transition : all 800ms;
}
/* 画面内に入った状態 */
.fade-up.scrollin {
  opacity : 1;
  transform : translate(0, 0);
}
/*------------タイトルフェードアップ----------*/
/* 画面外にいる状態 */
.title_fade-up {
  opacity : 0;
  transform : translate(0, 40px);/*フェードする距離*/
	
  transition : all 800ms;
}
/* 画面内に入った状態 */
.title_fade-up.scrollin {
  opacity : 1;
  transform : translate(0, 0);
}
/*-------2段階アニメーション左から-------*/
.motion-txt {
	display: inline-block;
	position: relative;
	overflow: hidden;
}
.motion-txt.blue:after {
  content: '';
  position: absolute;
  opacity: 1;
  left: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  background-color: #112D56;
  transform: translate3d(-101%, 0, 0);
}
.motion-txt.gray:after {
  content: '';
  position: absolute;
  opacity: 1;
  left: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  background-color: #F8F8EF;
  transform: translate3d(-101%, 0, 0);
}
.js-scroll.show .motion-txt:after {
  transition-property: transform, opacity;
  transition-duration: 1s;
  transition-delay: 0s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  transform: translate3d(0, 0, 0);
}
.js-scroll.done .motion-txt:after {
  transition-property: transform;
  transition-duration: 1s;
  transition-delay: 0s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  transform: translate3d(103%, 0, 0);
}
.motion-txt .motion-inner {
  display: inline-block;
  opacity: 0;
}
.js-scroll.done .motion-txt .motion-inner {
  opacity: 1;
}
.js-scroll.done .motion-txt .small_title {
  opacity: 1;
}
.js-scroll {
  
  position: relative;
}
.loader_box .js-scroll {
  position: fixed;
}
.js-scroll.center_title {
  text-align: center;
}
.js-scroll.right_title {
  text-align: right;
}
.js-scroll.com_center_title {
  text-align: center;
  margin-top: 15px;
}
.js-scroll.sub_hero_title {
  text-align: center;
  padding-top: 120px;
}
.staff_hero_title {
  text-align: left;
  padding-top: 220px;
  left: 30px;
  position: absolute;
}
.js-scroll.sub_hero_title.privacy {
  text-align: center;
  padding-top: 100px;
}
.move_back_A {
  width: 100vw;
  background-color: #112D56;
  padding-top: 20px;
  padding-bottom: 50px;
}
.js-scroll .motion-txt .small_title {
  font-size: 15px;
  opacity: 0;
  position: absolute;
  top: 49%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  margin: auto;
  text-align: center;
  display: flex;
  align-items: center;
  letter-spacing: 0.08em;
  width: 100%;
  justify-content: center;
}
.js-scroll .motion-txt .jp_small_title {
  font-size: 15px;
  position: absolute;
  top: 49%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  margin: auto;
  text-align: center;
  display: flex;
  align-items: center;
  letter-spacing: 0.08em;
  width: 100%;
  justify-content: center;
  color: #191919;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  font-weight: normal;
}
.js-scroll .motion-txt .sub_small_title {
  font-size: 15px;
  text-align: center;
  display: flex;
  align-items: center;
  letter-spacing: 0.08em;
  width: 100%;
  justify-content: center;
  color: #FFFFFF;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  margin-bottom: 10px;
  font-weight: normal;
}
.hero .pop a {
	animation: hero_pop_fade 0.8s 1.8s forwards;
	opacity: 0;
}
@keyframes hero_pop_fade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.hero .blue_line {
  position: absolute;
  left: 50%;
  bottom: -27px;
  height: 40px;
  width: 2px;
  background-color: #112D56;
}
/*スクロールダウン全体の場所*/
.scrolldown{
  position:absolute;
  left:50%;
  bottom:13px;
    /*全体の高さ*/
  height:50px;
}
/*Scrollテキストの描写*/
.scrolldown span{
    /*描画位置*/
  position: absolute;
  left:-25px;
  top: -22px;
    /*テキストの形状*/
  color: #eee;
  font-size: 12px;
  letter-spacing: 0.05em;
}
/* 線の描写 */
.scrolldown::after{
  content: "";
    /*描画位置*/
  position: absolute;
  top: 0;
    /*線の形状*/
  width: 2px;
  height: 50px;
  background: #FFFFFF;
    /*線の動き1.4秒かけてループ*/
  animation: pathmove 2s ease-in-out infinite;
  opacity:0;
}
/*高さ・位置・透過が変化して線が上から下に動く*/
@keyframes pathmove{
  0%{
    height:0;
    top:0;
    opacity: 0;
  }
  30%{
    height:30px;
    opacity: 1;
  }
  100%{
    height:0;
    top:50px;
    opacity: 0;
  }
}

.page_top {
	position: fixed;
	z-index: 25;
	margin-bottom: 10px;
	right: 10px;
}
.page_top img {
  transition: all 0.3s;
  width: 43px;
  height: auto;
}
.page_top img:hover {
	cursor: pointer;
	opacity: 0.8;
}
.pc_nav .menu_tel .tel_button img {
  width: 18px;
  height: auto;
  margin-right: 5px;
}
.pc_nav .menu_tel .mail_button img {
  width: 21px;
  height: auto;
}
footer {
  background-image: url(img/footer_back.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  padding-top: 20px;
  margin-top: -6px;
}
body {
  overflow-x: hidden;
  height: 100vh;
}
header {
  height: 70px;
  position: fixed;
  z-index: 20;
  width: 100vw;
	animation: menu_fade 0.8s 1.7s forwards;
	opacity: 0;
}
@keyframes menu_fade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
header .menu_filter {
  width: 100%;
  height: 70px;
  background-color: rgba(0,0,0,0.55);
  position: absolute;
  display: none;
}
header .pc_nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
header .pc_nav .headA a {
  text-decoration: none;
  color: #FFFFFF;
  transition: all 0.3s;
}
header .pc_nav .headA a:hover {
  opacity: 0.7;
}
/*ハンバーガーメニュースタイル*/
header .phone_back {
  background-color: rgba(0,0,0,0.55);
  width: 100vw;
  height: 100vh;
  position: absolute;
  top: 0px;
  visibility: hidden;
  left: 0px;
  z-index: 10;
}
.phone_menu {
  background-color: #112D56;
  height: 80vh;
  position: fixed;
  z-index: 80;
  width: 235px;
  overflow-y: auto;
  padding-bottom: 170px;
  transition: all 0.3s;
  transform: translate(100%);
  opacity: 0.3;
  top: 70px;
  left: auto;
  right: 0px;
}
.phone_menu .sns_button {
  display: block;
  /* [disabled]text-align: center; */
  margin-top: 17px;
  margin-left: 15px;
}
.phone_menu .sns_button img {
  width: 190px;
  height: auto;
}
header .phone_menu.open {/*クラス変更でメニューを開く*/
	transform: translate(0);
	opacity: 1;
}
header .phone_back.open {/*クラス変更で背景暗転*/
	visibility: visible;
	animation-duration: .2s;
	animation-name: fade-in;
}
@keyframes fade-in {
  0% {
    visibility: hidden;
    opacity: 0;
  }
	30% {
    visibility: visible;
    opacity: .3;
  }
  50% {
    visibility: visible;
    opacity: .5;
  }
	70% {
    visibility: visible;
    opacity: .7;
  }
  100% {
    visibility: visible;
    opacity: 1;
  }
}
.phone_menu ul {
	list-style-type: none;
	margin-left: 0px;
	padding-left: 0px;
}
.phone_menu ul li {
  border-bottom: 1px solid #518BDF;
  align-items: center;
}
.phone_menu ul li .acd_btn {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-left: 25px;
	padding-right: 33px;
}

.phone_menu ul li .acd_btn:hover {
	cursor: pointer;
}
.phone_menu ul li a {
	text-decoration: none;
}
.phone_menu ul li .acd_btn a {
  color: #FFF532;
  font-size: 13px;
  transition: all 0.3s;
  width: 100%;
  padding-top: 12px;
  padding-bottom: 10px;
  line-height: 1.4;
}
.phone_menu ul li .acd_btn:hover a {
  opacity: 0.7;
}
.phone_menu ul li .acd_btn .arrow {
  display: block;
  width: 6px;
  height: 6px;
  margin: 0 0 6px 8px;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transition: all 0.3s;
}
.phone_menu ul li .acd_btn:hover .arrow {
	opacity: 0.6;
}
.phone_menu ul li .acd_content {
  display: none;
  background-color: #FFFFFF;
}
.phone_menu .acd_content li  {
	border-bottom: 1px solid #D0D0D0;
	display: flex;
	align-items: center;
	padding-right: 15px;
}
.phone_menu .acd_content li a {
  font-size: 13px;
  color: #292929;
  width: 100%;
  transition: all 0.3s;
  padding-bottom: 4px;
  padding-top: 6px;
  padding-left: 33px;
}
.phone_menu .acd_content li a:hover  {
  color: #518BDF;

}
/*メガメニュースタイル*/
.megamenu {
  position: relative;
  margin: 0;
  padding: 0;
  display: none;
	*zoom: 1
}
.megamenu > li {
  float: left;
  list-style-type: none;
  transition: all 0.3s;
}
.no_link {
	pointer-events: none;
}
.megamenu > li a {
  color: #FFFFFF;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 65px;
  font-size: 13px;
  padding-left: 17px;
  padding-right: 17px;
  letter-spacing: 0.1em;
  margin-top: 20px;
}
header .headA img {
	width: 70px;
}
.pc_nav .menu_tel .tel_button {
  color: #FFFFFF;
  font-size: 17px;
  text-decoration: none;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  transition: all 0.3s;
  margin-right: 15px;
  display: flex;
  align-items: center;
}
.pc_nav .menu_tel .tel_button:hover {
  color: #FFF532;
}
.pc_nav .menu_tel .mail_button {
  margin-right: 18px;
  display: flex;
  align-items: center;
  transition: all 0.3s;
}
.pc_nav .menu_tel .mail_button:hover {
  opacity: 0.7;
}
header .pc_nav .menu_tel {
  display: flex;
  position: relative;
  height: 90px;
  align-items: center;
  justify-content: space-between;
  z-index: 15;
}
header .hero_btn {
  height: 26px;
}
/*ハンバーガーメニュースタイル*/
.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all 0.3s;
	-webkit-transition: -webkit-transform 0.3s;
	-moz-transition: -moz-transform 0.3s;
	box-sizing: border-box;
}
.menu-trigger {
	position: relative;
	width: 25px;
	height: 26px;
	transition: 0.3s;
	margin-top: 4px;
	margin-right: 25px;
}
.menu-trigger:hover {
	cursor: pointer;
	-moz-cursor: pointer;
	opacity: 0.7;
}
.menu-trigger span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 2px;
	background-color: #FFFFFF;
}
.menu-trigger span:nth-of-type(1) {
  top: 0;
}
.menu-trigger span:nth-of-type(2) {
  top: 8px;
}
.menu-trigger span:nth-of-type(3) {
  bottom: 8px;
}
/*ハンバーガーメニューアニメーション*/
.menu-trigger.active span:nth-of-type(1) {
  -webkit-transform: translateY(8px) rotate(-45deg);
  transform: translateY(8px) rotate(-45deg);
}
.menu-trigger.active span:nth-of-type(2) {
  opacity: 0;
}
.menu-trigger.active span:nth-of-type(3) {
  -webkit-transform: translateY(-8px) rotate(45deg);
  transform: translateY(-8px) rotate(45deg);
}
.pc_nav .headA {
  position: relative;
  margin-left: 25px;
  z-index: 15;
}
.pop img:hover {
	opacity: 0.8;
}
/*フォント明朝*/
h1, h2, h3 {
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
  letter-spacing: 0.04em;
  font-weight: normal;
}
.flow_box section h3 {
  font-size: 24px;
  color: #112D56;
  text-align: center;
  margin-bottom: 15px;
}
.voice_box .vo-list .qa dt h3 {
  font-size: 12px;
  font-weight: normal;
	font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
}
.staff_box_B .message_box h3 {
  font-size: 24px;
  font-weight: normal;
  color: #202020;
}
.staff_box a h3 {
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  font-size: 20px;
  color: #112D56;
  margin-top: -8px;
  line-height: 1.4;
}
.staff_hero p {
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  font-size: 20px;
  color: #FFFFFF;
  line-height: 1.4;
  font-weight: bold;
}
.privacy_box h2 {
  font-size: 15px;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  font-weight: normal;
  margin-bottom: 30px;
}
.common_company_box section a h3 {
  color: #FFFFFF;
  font-size: 15px;
  font-weight: normal;
}
.common_company_box section a p {
  color: #FFFFFF;
  font-size: 18px;
}
.service_box .service_link .service_text p {
  color: #FFFFFF;
  font-size: 13px;
  margin-top: 10px;
}
.service_box .service_link .case_sv_text p {
  color: #FFFFFF;
  font-size: 13px;
  margin-top: 10px;
}
.service_box .service_link p span{
  background-color: #FFFFFF;
  color: #112D56;
  width: 85px;
  display: inline-block;
  text-align: center;
  padding-top: 1px;
  margin-bottom: 10px;
  margin-right: 5px;
}
.service_box .service_link .service_text_B p {
  color: #FFFFFF;
  font-size: 13px;
  margin-top: 10px;
}
.service_box .service_link .case_sv_text_B p {
  color: #FFFFFF;
  font-size: 13px;
  margin-top: 10px;
}
.variable_text .text_box h2 {
  color: #202020;
  font-size: 23px;
  font-weight: normal;
}
.variable_text .text_box h3 {
  color: #202020;
  font-size: 24px;
  font-weight: normal;
}
.variable_text_blue .text_box h2 {
  color: #FFFFFF;
  font-size: 24px;
  font-weight: normal;
}
.jp_main_title h2 {
  font-size: 24px;
  color: #112D56;
  font-weight: normal;
  text-align: center;
  letter-spacing: 0.06em;
}
.hero .hero_text h1 {
  position: absolute;
  z-index: 4;
  top: 58%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  color: #FFFFFF;
  text-align: center;
  font-size: 17px;
  width: 100%;
  font-weight: normal;
  line-height: 1.8;
	animation: hero_text_fade 0.8s 1.7s forwards;
	opacity: 0;
}
@keyframes hero_text_fade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

.hero {
  position: relative;
  width: 100vw;
  height: 100vh;
}
.sub_hero {
  position: relative;
  width: 100vw;
  height: 324px;
}
.staff_hero {
  position: relative;
  width: 100vw;
  height: 324px;
}
.hero_logo img {
  position: absolute;
  z-index: 4;
  top: 42.5%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 175px;
  height: auto;
	animation: appear 0.8s 1.7s forwards;
	opacity: 0;
}
@keyframes appear {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
		top: 41%;/*フェードダウンした後の位置*/
  }
}
.pop img {
  position: absolute;
  z-index: 4;
  right: 23px;
  width: 100px;
  height: 100px;
  bottom: 30px;
	animation: logo1 3s ease infinite;
	transition: 0.3s;
}
@keyframes logo1 {
50% {
transform:translateY(-12px)
}
}

.hero .hero_filter {
  width: 94.1%;
  height: 96.5%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  margin: auto;
  background-color: rgba(0,0,0,0.35);
}
.sub_hero .hero_filter {
  width: 94.1%;
  height: 300px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  margin: auto;
  background-color: rgba(0,0,0,0.30);
  top: 12px;
}
.staff_hero .hero_filter {
  width: 94.1%;
  height: 300px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  margin: auto;
  background-color: rgba(0,0,0,0.40);
  top: 12px;
}
.pc_nav .phone_menu .acd_btn .jp_title {
  font-size: 10px;
  color: #FFFFFF;
}
.js-scroll .motion-txt .motion-inner .navy {
  color: #15376A;
}
.js-scroll .motion-txt .motion-inner .white {
  color: #FFFFFF;
}
.variable_box .img_box.anniversary {
  background-image: url(img/anniversary.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.variable_box .img_box.com_contact {
  background-image: url(img/com_contact.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.variable_box .img_box.sv_co_top {
  background-image: url(img/sv_co_top.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.variable_box .img_box.sv_in_top {
  background-image: url(img/sv_in_top.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.variable_box .img_box.staff_A_02 {
  background-image: url(img/staff_A_02.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.variable_box .img_box.staff_B_02 {
  background-image: url(img/staff_B_02.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.variable_box .img_box.staff_C_02 {
  background-image: url(img/staff_C_02.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.corporate {
  background-image: url(img/corporate_sv.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.award {
  background-image: url(img/award.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.sv_co_01 {
  background-image: url(img/sv_co_01.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.sv_co_02 {
  background-image: url(img/sv_co_02.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.sv_co_03 {
  background-image: url(img/sv_co_03.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.sv_co_04 {
  background-image: url(img/sv_co_04.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.sv_co_05 {
  background-image: url(img/sv_co_05.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.sv_in_01 {
  background-image: url(img/sv_in_01.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.sv_in_02 {
  background-image: url(img/sv_in_02.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.sv_in_03 {
  background-image: url(img/sv_in_03.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.sv_in_04 {
  background-image: url(img/sv_in_04.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.sv_in_05 {
  background-image: url(img/sv_in_05.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.value {
  background-image: url(img/value_s.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .img_box.individual {
  background-image: url(img/individual_sv.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.service_box .service_link .service_text .text_inner {
  padding-top: 25px;
  padding-bottom: 30px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
.service_box .service_link .case_sv_text .case_text_inner {
  padding-top: 25px;
  padding-bottom: 30px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
.service_box .service_link .service_text_B .text_inner {
  padding-top: 25px;
  padding-bottom: 30px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
.service_box .service_link .case_sv_text_B .case_text_inner {
  padding-top: 25px;
  padding-bottom: 30px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
.js-scroll.contact_margin {
  margin-top:30px;
}
.js-scroll.company_margin {
  margin-top:40px;
}
.conE {
  padding-top: 30px;
}
.common_company_box section a {
  text-decoration: none;
  border: 1px solid #FFFFFF;
  display: block;
  text-align: center;
  border-radius: 15px;
  width: 280px;
  padding-top: 20px;
  padding-bottom: 20px;
  margin-bottom: 20px;
  margin-left: auto;
  margin-right: auto;
}
.common_company_box a span {
  border-bottom: 1px solid #FFFFFF;
  width: 50px;
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-top: 12px;
  margin-bottom: 14px;
}
.variable_text_blue .text_box img {
  width: 140px;
  height: auto;
  margin-top: 20px;
	margin-bottom: 10px;
}
.variable_box .google_map iframe {
  width: 100%;
  height: 100%;
  filter: grayscale(45%);
}
.common_faq_box .qa-list {
  width: 92%;
  margin-left: auto;
  margin-right: auto;
}
.common_voice_box .voice-list {
  width: 92%;
  margin-left: auto;
  margin-right: auto;
}
.voice_box .vo-list {
  width: 92%;
  margin-left: auto;
  margin-right: auto;
}
.variable_text_blue .text_box .link_btn_box_y a img {
  width: 22px;
  height: auto;
  margin-right: 8px;
  margin-top: 0px;
  margin-bottom: 0px;
}
.variable_text_blue .text_box .link_btn_box_t a img {
  width: 22px;
  height: auto;
  margin-right: 8px;
  margin-top: 0px;
  margin-bottom: 0px;
}
.variable_text_blue .text_box .link_btn_box_t p {
  margin-top: 0px;
  margin-bottom: 5px;
  text-align: center;
}
.variable_text_blue .text_box .link_btn_box_y p {
  margin-top: 0px;
  margin-bottom: 5px;
  text-align: center;
}
.message_title h2 {
  color: #112D56;
  font-size: 24px;
  font-weight: normal;
}

.staff_box a .staff_list_img.staff_A {
  background-image: url(img/staff_A.jpg);
  background-position: left top;
  background-size: cover;
  background-repeat: no-repeat;
}
.staff_box a .staff_list_img.staff_B {
  background-image: url(img/staff_B.jpg);
  background-position: left top;
  background-size: cover;
  background-repeat: no-repeat;
}
.staff_box a .staff_list_img.staff_C {
  background-image: url(img/staff_C.jpg);
  background-position: left top;
  background-size: cover;
  background-repeat: no-repeat;
}
.staff_hero .staff_hero_img.staff_A {
  background-image: url(img/staff_A.jpg);
  background-position: left top;
  background-size: cover;
  background-repeat: no-repeat;
}
.staff_hero .staff_hero_img.staff_B {
  background-image: url(img/staff_B.jpg);
  background-position: left top;
  background-size: cover;
  background-repeat: no-repeat;
}
.staff_hero .staff_hero_img.staff_C {
  background-image: url(img/staff_C.jpg);
  background-position: left top;
  background-size: cover;
  background-repeat: no-repeat;
}
.staff_box_B .message_box section {
  background-color: #F6F6F6;
  padding-top: 20px;
  padding-bottom: 20px;
  padding-left: 5%;
  padding-right: 5%;
  margin-bottom: 5px;
}
.staff_box_B .message_box section.single_box {
  margin-top: 20px;
}

.staff_box_B .message_box section:first-child {
  margin-bottom: 20px;
}
.voice_box .vo-list dd p span {
  display: block;
  margin-top: 10px;
}
.voice_box .vo-list dd .vo_split_box .vo_img.kamosika {
  background-image: url(img/kamosika.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.table_back_img {
  height: 230px;
  margin-left: auto;
  margin-right: auto;
}
.table_back_img.education {
  background-image: url(img/education.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  padding-bottom: 0px;
}
.table_back_img.hotel {
  background-image: url(img/hotel.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  padding-bottom: 0px;
}
.table_back_img.medical {
  background-image: url(img/medical.jpg);
  background-position: center bottom;
  background-size: cover;
  background-repeat: no-repeat;
  padding-bottom: 0px;
}
.table_back_img.complex {
  background-image: url(img/complex.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  padding-bottom: 0px;
}
.table_back_img.other {
  background-image: url(img/other.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  padding-bottom: 0px;
}
.table_back_gray {
  width: 94%;
  margin-left: auto;
  margin-right: auto;
}
.table_back_gray .box {

}
.flow_box section .flow_number {
  position: absolute;
	top: -3px;
  color: #DFDFD7;
  font-size: 56px;
  font-weight: normal;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
}
.case_box .container {
	margin-right: auto;
  margin-left: auto;
  width: 94%;
}
.case_box section {
	margin-left: auto;
	margin-right: auto;
	position: relative;
	margin-bottom: 20px;
	background-color: #F4F4F4;
	padding-top: 10px;
	padding-bottom: 5px;
}
.case_box .case_slick {
  background-color: #9A9A9A;
  width: 95%;
  margin-left: auto;
  margin-right: auto;
}
.case_box .case_slick .slick1 {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
}
.case_box .case_slick .slick1 .slide_img {
	height: 280px;
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}
.case_box .case_slick .slide_img .before {
	background-color: #353535;
	color: #FFFFFF;
	font-size: 14px;
	display: inline-block;
	padding-left: 13px;
	padding-right: 13px;
	padding-top: 3px;
	padding-bottom: 3px;
	letter-spacing: 0.12em;
	position: absolute;
	border-radius: 30px;
	left: 5px;
	top: 8px;
	text-align: center;
	border: 1px solid #FFFFFF;
}
.case_box .case_slick .slide_img .after {
  background-color: #FF6200;
  color: #FFFFFF;
  font-size: 14px;
  display: inline-block;
  padding-left: 13px;
  padding-right: 13px;
  padding-top: 3px;
  padding-bottom: 3px;
  letter-spacing: 0.12em;
  position: absolute;
	border-radius: 30px;
	left: 5px;
	top: 8px;
	text-align: center;
	border: 1px solid #FFFFFF;
}
.case_box .text_box {
  margin-top: 15px;
  width: 93%;
  margin-left: auto;
  margin-right: auto;
}
.case_box .text_box h3{
	margin-bottom: 8px;
	font-size: 15px;
	font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
	font-weight: bold;
}
.case_box .text_box h2{
	margin-bottom: 8px;
	font-size: 15px;
	font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
	font-weight: bold;
}
.case_box .text_box p{
	margin-bottom: 8px;
	border-top: 1px solid #CCCCCC;
	padding-top: 10px;
	font-size: 13px;
}

.case_box .case_slick .case_A_01{
	background-image: url(case_list_img/case_A_01.jpg);
}
.case_box .case_slick .case_A_02{
	background-image: url(case_list_img/case_A_02.jpg);
}
.case_box .case_slick .case_A_03{
	background-image: url(case_list_img/case_A_03.jpg);
}

.case_box .case_slick .case_B_01{
	background-image: url(case_list_img/case_B_01.jpg);
}
.case_box .case_slick .case_B_02{
	background-image: url(case_list_img/case_B_02.jpg);
}
.case_box .case_slick .case_B_03{
	background-image: url(case_list_img/case_B_03.jpg);
}
.case_box .case_slick .case_B_04{
	background-image: url(case_list_img/case_B_04.jpg);
}
.case_box .case_slick .case_B_05{
	background-image: url(case_list_img/case_B_05.jpg);
}
.case_box .case_slick .case_B_06{
	background-image: url(case_list_img/case_B_06.jpg);
}
.case_box .case_slick .case_B_07{
	background-image: url(case_list_img/case_B_07.jpg);
}
.case_box .case_slick .case_B_08{
	background-image: url(case_list_img/case_B_08.jpg);
}

.case_box .case_slick .case_C_01{
	background-image: url(case_list_img/case_C_01.jpg);
}
.case_box .case_slick .case_C_02{
	background-image: url(case_list_img/case_C_02.jpg);
}
.case_box .case_slick .case_C_03{
	background-image: url(case_list_img/case_C_03.jpg);
}
.case_box .case_slick .case_C_04{
	background-image: url(case_list_img/case_C_04.jpg);
}
.case_box .case_slick .case_C_05{
	background-image: url(case_list_img/case_C_05.jpg);
}
.case_box .case_slick .case_C_06{
	background-image: url(case_list_img/case_C_06.jpg);
}
.case_box .case_slick .case_C_07{
	background-image: url(case_list_img/case_C_07.jpg);
}
.case_box .case_slick .case_C_08{
	background-image: url(case_list_img/case_C_08.jpg);
}

.case_box .case_slick .case_D_01{
	background-image: url(case_list_img/case_D_01.jpg);
}
.case_box .case_slick .case_D_02{
	background-image: url(case_list_img/case_D_02.jpg);
}
.case_box .case_slick .case_D_03{
	background-image: url(case_list_img/case_D_03.jpg);
}
.case_box .case_slick .case_D_04{
	background-image: url(case_list_img/case_D_04.jpg);
}
.case_box .case_slick .case_D_05{
	background-image: url(case_list_img/case_D_05.jpg);
}
.case_box .case_slick .case_D_06{
	background-image: url(case_list_img/case_D_06.jpg);
}

.case_box .case_slick .case_E_01{
	background-image: url(case_list_img/case_E_01.jpg);
}
.case_box .case_slick .case_E_02{
	background-image: url(case_list_img/case_E_02.jpg);
}
.case_box .case_slick .case_E_03{
	background-image: url(case_list_img/case_E_03.jpg);
}
.case_box .case_slick .case_E_04{
	background-image: url(case_list_img/case_E_04.jpg);
}
















































@media (min-width:600px) and (max-width:1059px){

.hero_logo img {
	width: 240px;
	height: auto;
}

.hero .hero_filter {
  width: 96.5%;
  height: 96.5%;
}
.mail_form {
  max-width: 550px;
}
.jp_sub_text {
  max-width: 550px;
}
.move_back_A .flex .info {
  max-width: 550px;
}
.variable_box .img_box {
  max-width: 550px;
  height: 350px;
}
.variable_box .variable_text .text_box {
  max-width: 550px;
}
.service_box .service_link .service_text .text_inner {
  max-width: 550px;
}
.service_box .img_box {
  max-width: 550px;
  height: 350px;
}
.service_box .service_link .service_text_B .text_inner {
  max-width: 550px;
}
.swiper-container {
  height: 250px;
}
.common_voice_box section .text {
  width: 50%;
}
.common_company_box .flex {
  display: flex;
  justify-content: space-between;
  max-width: 650px;
  margin-left: auto;
  margin-right: auto;
  width: 90%;
}
.common_company_box section a {
  width: 175px;
}
.variable_box .google_map {
  max-width: 550px;
  height: 350px;
}
footer .flex {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
}
footer .footB {
  display: flex;
  flex-wrap: no-wrap;
  width: 48%;
}
footer .footA {
  margin-top: 35px;
  width: 48%;
}
footer .container {
  width: 95%;
  max-width: 550px;
}
.qa-list {
  max-width: 550px;
  margin-left: auto;
  margin-right: auto;
}
.voice-list {
  max-width: 550px;
  margin-left: auto;
  margin-right: auto;
}
footer .footC .under_flex {
  width: 95%;
  max-width: 550px;
  display: flex;
  justify-content: space-between;
}
footer .footC small {
  margin-top: 0px;
}
footer .footC .deepxi {
  margin-top: 0px;
}
footer .footC {
  padding-top: 20px;
  padding-bottom: 70px;
}
.sub_hero video {
  width: 96.5%;
  height: 300px;
  object-fit: fill;
  top: 12px;
}
.hero video {
  width: 96.5%;
  height: 96.5%;
}
.sub_hero .hero_filter {
  width: 96.5%;
  height: 300px;
  top: 12px;
}
.service_box .service_link .service_title {
  width: 90%;
  max-width: 550px;
}
.service_box .service_link .case_sv_text .case_text_inner {
  width: 90%;
  max-width: 550px;
}
.service_box .service_link .case_sv_text_B .case_text_inner {
  width: 90%;
  max-width: 550px;
}
.service_box .slick {
  width: 90%;
  max-width: 550px;
}
.service_box .service_link .service_title_B {
  width: 90%;
  max-width: 550px;
}
.service_box .slick .slick1 .slide_img {
  height: 350px;
}
.js-scroll .motion-txt .motion-inner .back_img_box {
  width: 92.5vw;
  height: 400px;
  max-width: 550px;
}
.com_sub_text {
  width: 90%;
  max-width: 550px;
}
.principle {
  width: 90%;
  max-width: 550px;
}
.outline_content {
  width: 94%;
  max-width: 550px;
}
table.outline_content td.data {
  margin: 0;
  width: 78%;
}
.faq_link .container {
  width: 90%;
  max-width: 550px;
}
.works_link .container {
  width: 90%;
  max-width: 550px;
}
.privacy_box .container {
  width: 92%;
  max-width: 550px;
}
.js-scroll .motion-txt .motion-inner .staff_list_img {
  width: 260px;
  height: 180px;
}
.staff_box {
  width: 90%;
  max-width: 550px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.staff_hero .staff_hero_img {
  width: 96.5%;
  height: 400px;
}
.staff_hero .hero_filter {
  width: 96.5%;
  height: 400px;
}
.staff_box_A {
  padding-top: 120px;
  padding-bottom: 30px;
}
.staff_hero_title {
  padding-top: 315px;
}
.staff_box_B .message_box section {
  width: 550px;
  margin-left: auto;
  margin-right: auto;
}
.client_content {
  width: 94%;
  max-width: 550px;
}
.works_content {
  width: 94%;
  max-width: 550px;
}
.flow_box {
  width: 94%;
  max-width: 550px;
}
.voice_box .vo-list {
  width: 92%;
  max-width: 550px;
}
.table_back_gray {
  width: 94%;
  max-width: 550px;
}
.table_back_img {
  height: 300px;
}

.case_box .case_slick .slick1 .slide_img {
  height: 330px;
}
.case_box .container {
	max-width: 550px;
}
.case_box section {
	padding-top: 14px;
	padding-bottom: 5px;
}














































}
























@media (min-width:1060px){

.hero_logo img {
	width: 270px;
	height: auto;
	top: 43%;
}
header {
  height: 90px;
}
header .menu_filter {
	height: 85px;
}
header .pc_nav .menu_left {
  display: flex;
  align-items: center;
}
.pc_nav .headA {
  margin-top: 20px;
  margin-left: 40px;
}
.megamenu {
  display: inline;
}
.megamenu > li:hover {
  -webkit-transition: all .3s;
  transition: all .3s;
  background-color: #112D56;
}
.megamenu > li:hover .jp_title {
  display: inline;
}
.megamenu .menu_box .acd_content {
  background-color: #112D56;
  width: 100vw;
  display: none;
  position: fixed;
  top: 85px;
  z-index: 100;
  left: 50%;
  transform: translateX(-50%);
  padding-bottom: 60px;
	padding-top: 20px;
  padding-left: 0px;
}
.megamenu .menu_box .acd_content .flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 92%;
  margin-left: auto;
  margin-right: auto;
  max-width: 1300px;
}
.megamenu .menu_box .acd_content li {
  width: 30%;
  list-style-type: none;
  margin-left: 0px;
  padding: 0;
  text-decoration: none;
  margin-top: 40px;
  float: none;
}
.megamenu .menu_box .acd_content .space_box {
  width: 30%;
}
.megamenu .menu_box .acd_content a {
  display: flex;
  margin: 0;
  justify-content: space-between;
  height: 110px;
  padding-left: 0px;
  padding-right: 0px;
  align-items: flex-start;
  transition: all 0.3s;
}
.megamenu .menu_box .acd_content a:hover {
  background-color: #0C213F;
}
.megamenu .acd_content .menu_img  {
  width: 42%;
  height: 110px;
  transition: all 0.6s;
  background-color: #D6D6D6;
}
.megamenu .menu_box .acd_content a:hover .menu_img {
  opacity: 0.8;
}
.megamenu .menu_img.menu_A {
  background-image: url(menu_img/corporate.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.megamenu .menu_img.menu_B {
  background-image: url(menu_img/individual.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.megamenu .menu_img.menu_C {
  background-image: url(menu_img/faq.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.megamenu .menu_img.menu_D {
  background-image: url(menu_img/case.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.megamenu .menu_img.menu_E {
  background-image: url(menu_img/works.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.megamenu .menu_img.menu_F {
  background-image: url(menu_img/company.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.megamenu .menu_img.menu_G {
  background-image: url(menu_img/staff.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.megamenu .menu_img.menu_H {
  background-image: url(menu_img/recruit.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.megamenu .menu_img.menu_I {
  background-image: url(menu_img/access.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.megamenu .menu_img.menu_J {
  background-image: url(menu_img/facebook.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.megamenu .menu_box .acd_content a p {
  width: 58%;
  padding-left: 15px;
  padding-right: 15px;
  text-align: justify;
  font-size: 18px;
  line-height: 1.5;
  padding-top: 10px;
  display: block;
  transition: all 0.3s;
  color: #FFFFFF;
  letter-spacing: 0.1em;
}
.megamenu .acd_content a p span  {
  font-size: 13px;
  font-weight: normal;
  margin-top: 7px;
  display: block;
  color: #FFFFFF;
  letter-spacing: 0.04em;
  border-top: 1px solid #FFF532;
  padding-top: 10px;
  line-height: 1.8;
}
header .headA img {
  width: 90px;
}
.pc_nav .menu_tel .tel_button {
  font-size: 23px;
  letter-spacing: 0.1em;
  margin-right: 25px;
}
header .pc_nav .menu_tel {
  height: 70px;
  margin-top: 15px;
}
.menu-trigger {
  width: 34px;
  height: 29px;
  margin-top: 0px;
  margin-right: 40px;
}
.menu-trigger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 3px;
  background-color: #FFFFFF;
}
.menu-trigger span:nth-of-type(1) {
  top: 0;
}
.menu-trigger span:nth-of-type(2) {
  top: 12px;
}
.menu-trigger span:nth-of-type(3) {
  bottom: 2px;
}
/*ハンバーガーメニューアニメーション*/
.menu-trigger.active span:nth-of-type(1) {
  -webkit-transform: translateY(12px) rotate(-45deg);
  transform: translateY(12px) rotate(-45deg);
}
.menu-trigger.active span:nth-of-type(2) {
  opacity: 0;
}
.menu-trigger.active span:nth-of-type(3) {
  -webkit-transform: translateY(-12px) rotate(45deg);
  transform: translateY(-12px) rotate(45deg);
}
.pop img {
  right: 50px;
  width: 145px;
  height: 145px;
  bottom: 50px;
}
/*-------------------------------*/

.hero .hero_filter {
  width: 97.7%;
  height: 96.5%;
}
.sub_hero .hero_filter {
  width: 97.7%;
  height: 550px;
	top: 18px;
}
.staff_hero .hero_filter {
  width: 97.7%;
  height: 550px;
  top: 18px;
  background-color: rgba(0,0,0,0.30);
  left: 50%;
}
.pc_nav .menu_tel .mail_button img {
  width: 28px;
  height: auto;
}
.pc_nav .menu_tel .mail_button {
  margin-right: 28px;
}
.pc_nav .menu_tel .tel_button img {
  width: 26px;
  margin-right: 8px;
}
.megamenu > li .jp_title {
  font-size: 10px;
  position: absolute;
  top: 28px;
  color: #FFF532;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  display: none;
  transition: all 0.3s;
}
/*ハンバーガーメニュースタイル*/
header .phone_back {
	top: 0px;
	left: 0px;
}
.phone_menu {
	height: 80vh;
	position: fixed;
	z-index: 80;
	width: 300px;
	overflow-y: auto;
	padding-bottom: 170px;
	transition: all 0.4s;
	transform: translate(100%);
	opacity: 0.3;
	top: 85px;
	left: auto;
	right: 0px;
}
.phone_menu ul li .acd_btn {
  padding-left: 30px;
  padding-right: 52px;
}
.phone_menu .acd_content li a {
  padding-bottom: 8px;
  padding-top: 10px;
  padding-left: 38px;
}
.page_top {
	margin-bottom: 20px;
	right: 25px;
}
.page_top img {
  width: 55px;
  height: auto;
}
.hero .hero_text h1 {
  top: 63.5%;
  left: 50%;
  font-size: 29px;
}
.hero .blue_line {
  left: 50%;
  bottom: -24px;
}
/*-------2段階アニメーション-------*/
.motion-txt {
	display: inline-block;
	position: relative;
	overflow: hidden;
}
.js-scroll {
  
}
.js-scroll.right {
  text-align: right;
}
.js-scroll .motion-txt .small_title {
  font-size: 22px;
  letter-spacing: 0.25em;
  top: 50%;
}
.js-scroll .motion-txt .jp_small_title {
  font-size: 22px;
  letter-spacing: 0.25em;
  top: 50%;
}
.js-scroll .motion-txt .sub_small_title {
  font-size: 22px;
  letter-spacing: 0.25em;
  margin-bottom: 20px;
}
.js-scroll .motion-txt .small_title img {
  width: 24px;
  margin-right: 8px;
  margin-top: -2px;
}
.js-scroll .motion-txt .jp_small_title img {
  width: 24px;
  margin-right: 8px;
  margin-top: -2px;
}
.jp_main_title h2 {
  font-size: 40px;
}
.jp_main_title {
  margin-top: 40px;
}
.jp_sub_text p .pc_br {
  display: inline;
}
.jp_sub_text p {
  font-size: 15px;
  text-align: center;
  margin-top: 15px;
}
.com_sub_text p {
}
.jp_sub_text {
  margin-top: 50px;
}
.com_sub_text {
  display: none;
}
.conA {
  padding-top: 60px;
  padding-bottom: 110px;
}
.com_box_A {
  padding-top: 40px;
  padding-bottom: 40px;
}
.com_box_B {
  padding-top: 40px;
  padding-bottom: 40px;
}
.com_box_D {
  padding-top: 60px;
  padding-bottom: 30px;
}
.works_box_A {
  padding-top: 60px;
  padding-bottom: 40px;
}
.case_box {
  padding-top: 60px;
  padding-bottom: 10px;
}
.privacy_box {
  padding-top: 90px;
  padding-bottom: 100px;
}
.motion-txt .motion-inner {
}
.js-scroll .motion-txt .motion-inner .back_title {
  font-size: 155px;
  letter-spacing: 0.1em;
}
.js-scroll .motion-txt .motion-inner .sub_back_title {
  font-size: 155px;
  letter-spacing: 0.1em;
}
.move_back_A .flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.move_back_A .flex .box {
  width: 48%;
}
.move_back_A .flex .info {
  width: 47%;
}
.variable_box .img_box {
  width: 100%;
  height: 550px;
  margin-bottom: 0px;
}
.service_box .img_box {
  width: 100%;
  height: 480px;
  margin-top: 0px;
  margin-right: auto;
  margin-left: auto;
  margin-bottom: auto;
}
.variable_box .variable_text {
  width: 75vw;
  height: 750px;
  display: flex;
  align-items: center;
}
.variable_box .variable_text_blue {
  width: 75vw;
  height: 750px;
  display: flex;
  align-items: center;
}
.variable_box .variable_text .text_box {
  padding-top: 0px;
  padding-bottom: 0px;
  width: 50%;
  margin-left: auto;
  margin-right: 10%;
  text-align: left;
}
.variable_box .variable_text_blue .text_box {
  padding-top: 0px;
  padding-bottom: 0px;
  width: 48%;
  margin-left: auto;
  margin-right: 10%;
  text-align: left;
}
.variable_text .text_box h2 {
  font-size: 34px;
}
.variable_text .text_box h3 {
  font-size: 34px;
}
.variable_text_blue .text_box h2 {
  font-size: 34px;
}
.variable_text .text_box p {
  font-size: 15px;
  margin-top: 20px;
}
.variable_text_blue .text_box p {
  font-size: 15px;
  margin-top: 30px;
}
.variable_text_blue .link_btn_box_y {
  margin-left: 0px;
  margin-top: -10px;
}
.variable_box {
  padding-top: 0px;
  position: relative;
  margin-top: 110px;
}
.conB {
  padding-top: 100px;
}
.com_box_C {
  padding-top: 30px;
}
.move_back_A {
  padding-top: 50px;
  padding-bottom: 50px;
}
.service_box .service_link h2 {
  font-size: min(2.5vw,34px);/*（基本サイズ、最大サイズ）*/
  justify-content: flex-start;
}
.service_box .service_link .service_text {
  width: 75vw;
  height: 465px;
  display: flex;
  align-items: center;
}
.service_box .service_link .case_sv_text {
  width: 75vw;
  display: flex;
  align-items: center;
}
.service_box .service_link .service_text_B {
  width: 75vw;
  height: 465px;
  display: flex;
  align-items: center;
}
.service_box .service_link .case_sv_text_B {
  width: 75vw;
  display: flex;
  align-items: center;
}
.service_box .service_link .service_text p {
  font-size: 15px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 20px;
}
.service_box .service_link .case_sv_text p {
  font-size: 15px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 20px;
}
.service_box .service_link .service_text_B p {
  font-size: 15px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 20px;
}
.service_box .service_link .case_sv_text_B p {
  font-size: 15px;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 20px;
}
.service_box {
  position: relative;
  margin-top: 100px;
  margin-bottom: 130px;

}
.service_box .service_link .service_title {
  width: 78%;
  margin-bottom: 25px;
}
.service_box .service_link .service_title_B {
  width: 45%;
  margin-bottom: 25px;
  margin-left: auto;
	margin-right: 0px;
}
.service_box .service_link .service_text .text_inner {
  padding-top: 0px;
  padding-bottom: 25px;
  width: 55%;
  margin-left: 12%;
}
.service_box .service_link .case_sv_text .case_text_inner {
  padding-top: 50px;
  padding-bottom: 70px;
  width: 55%;
  margin-left: 12%;
}
.service_box .service_link .service_text_B .text_inner {
  padding-top: 0px;
  padding-bottom: 25px;
  width: 55%;
  margin-left: 37.5%;
}
.service_box .service_link .case_sv_text_B .case_text_inner {
  padding-top: 50px;
  padding-bottom: 70px;
  width: 55%;
  margin-left: 37.5%;
}
/*------------フェードアップ----------*/
/* 画面外にいる状態 */
.fade-up {
  opacity : 0;
  transform : translate(0, 40px);/*フェードする距離*/
  transition : all 800ms;
}
/* 画面内に入った状態 */
.fade-up.scrollin {
  opacity : 1;
  transform : translate(0, 0);
}
/*------------タイトルフェードアップ----------*/
/* 画面外にいる状態 */
.title_fade-up {
  opacity : 0;
  transform : translate(0, 65px);/*フェードする距離*/
  transition : all 850ms;
}
/* 画面内に入った状態 */
.title_fade-up.scrollin {
  opacity : 1;
  transform : translate(0, 0);
}
.variable_box .img_back {
  background-color: #E9E9E9;
  width: 48%;
  height: 550px;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  z-index: 1;
}
.variable_box .img_back.right {
  margin-left: auto;
	margin-right: 0px;
}
.variable_box .google_map {
  background-color: #112D56;
  width: 48%;
  height: 550px;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  z-index: 1;
}
.service_box .img_back {
  width: 47%;
  height: 480px;
  margin-top: -20px;
  margin-right: auto;
  margin-left: auto;
  margin-bottom: auto;
  position: absolute;
  bottom: 0;
  right: 0px;
  left: auto;
  top: 0px;
  background-color: #F5F5F5;
  z-index: 1;
}
.service_box .img_back_B {
  width: 47%;
  height: 480px;
  margin-top: -20px;
  margin-right: auto;
  margin-left: auto;
  margin-bottom: auto;
  position: absolute;
  bottom: 0;
  right: auto;
  left: 0px;
  top: 0px;
  background-color: #F5F5F5;
  z-index: 1;
}
.middle_contact_box {
  padding-top: 90px;
  padding-bottom: 90px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.link_btn_box_w {
  padding-top: 90px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 70%;
  margin-left: auto;
  margin-right: auto;
}
.link_btn_box_t {
  padding-top: 70px;
  width: 70%;
  margin-left: 0px;
  margin-right: auto;
}
.link_btn_box_y {
  padding-top: 60px;
  width: 70%;
  margin-right: auto;
  margin-left: 5%;
}
.middle_contact_box .tel_button {
  margin-bottom: 0px;
  width: 35%;
}
.middle_contact_box .mail_button {
  width: 35%;
}
.middle_contact_box p {
  font-size: 15px;
  margin-bottom: 20px;
}
.middle_contact_box .tel_button a {
  width: 350px;
  font-size: 24px;
  height: 60px;
}
.middle_contact_box .mail_button a:hover  {
  background-color: #031020;
}
.middle_contact_box .tel_button a:hover  {
  background-color: #FFF532;
}
.middle_contact_box a  {
  transition: all 0.3s;
}
.link_btn_box_w a {
  width: 350px;
  font-size: 19px;
  height: 60px;
  transition: all 0.3s;
  margin-top: 0px;
  margin-bottom: 0px;
}
.link_btn_box_t a {
  width: 350px;
  font-size: 24px;
  height: 60px;
  transition: all 0.3s;
  margin-right: auto;
  margin-left: 0pt;
}
.link_btn_box_t a:hover  {
  background-color: #031020;

}
.link_btn_box_w a:hover  {
  background-color: #112D56;
  color: #FFFFFF;

}
.link_btn_box_y a {
  width: 350px;
  font-size: 19px;
  height: 60px;
  transition: all 0.3s;
  margin-right: auto;
  margin-left: 0px;
}
.link_btn_box_y a:hover  {
  background-color: #FFFFFF;
  border: 2px solid #FFFFFF;
}
.link_btn_box a:hover  {
  background-color: #112D56;
  color: #FFFFFF;
}
.middle_contact_box .mail_button a {
  width: 350px;
  font-size: 19px;
  height: 60px;
}
.js-scroll.contact_margin {
  margin-top: 90px;
}
.js-scroll.company_margin {
  margin-top: 100px;
}
.middle_contact_box .tel_button a img {
  width: 30px;
  height: auto;
  margin-right: 15px;
}
.middle_contact_box .mail_button a img {
  width: 30px;
  height: auto;
  margin-right: 15px;
}
.conC {
  padding-top: 0px;
}
.conD {
  padding-top: 110px;
}
.swiper-container {
  width: 100vw;
  height: 450px;
  margin-top: 90px;
}
.conE {
  padding-top: 100px;
}
.common_company_box .flex {
  display: flex;
  justify-content: space-between;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  width: 95%;
}
.common_company_box {
  padding-top: 120px;
  padding-bottom: 120px;
}
.common_faq_box {
  margin-top: 40px;
}
.common_voice_box {
  margin-top: 40px;
}
.common_company_box section a p {
  font-size: 26px;
}
.common_company_box section a h3 {
  font-size: 19px;
}
.common_company_box section a {
  border: 1px solid #FFFFFF;
  border-radius: 20px;
  width: 300px;
  padding-top: 50px;
  padding-bottom: 50px;
  margin-bottom: 0px;
  margin-left: 0px;
  margin-right: 0px;
  transition: all 0.3s;
}
.common_company_box section a:hover  {
  background-color: #112D56;
}
.common_company_box a span {
  width: 70px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 22px;
  margin-bottom: 25px;
  transition: all 0.3s;
}
.common_company_box a:hover span {
  width: 120px;
}
.variable_text_blue .text_box img {
  width: 210px;
  height: auto;
  margin-top: 30px;
  margin-bottom: 20px;
}
.qa-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  max-width: 1300px;
  margin-left: auto;
  margin-right: auto;
}
.voice-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  max-width: 1300px;
  margin-left: auto;
  margin-right: auto;
}
.qa-list dl {
  margin-top: 55px;
  margin-right: 0;
  margin-left: 0;
  width: 47.5%;
  margin-bottom: 15px;
}
.voice-list dl {
  margin-top: 55px;
  margin-right: 0;
  margin-left: 0;
  width: 47.5%;
  margin-bottom: 15px;
}
.qa-list dl dt {
  padding-top: 25px;
  padding-right: 35px;
  padding-left: 80px;
  padding-bottom: 25px;
  font-size: 15px;
}
.qa-list dl dt:hover {
  opacity: 0.7;
}
.qa-list dl dd {
  margin: 0;
  padding-top: 14px;
  padding-right: 15px;
  padding-left: 80px;
  padding-bottom: 23px;
}
.qa-list dl dd p {
    margin: 12px 0 0;
	font-size: 15px;
}
.qa-list dl dt::before {
		width: 47px;
		height: 47px;
    font-size: 29px;
    left: 15px;
}
.qa-list dl dd::before {
		width: 47px;
		height: 47px;
    font-size: 29px;
    left: 15px;
    margin-top: 0px;
}
.qa-list dl::after {
    top: 33px;
    right: 15px;
    width: 10px;
    height: 10px;
}
.voice-list dl dt {
  padding-top: 25px;
  padding-right: 35px;
  padding-left: 80px;
  padding-bottom: 25px;
  font-size: 15px;
}
.voice-list dl dt:hover {
  opacity: 0.7;
}
.voice-list dl dd {
  margin: 0;
  padding-top: 14px;
  padding-right: 15px;
  padding-left: 80px;
  padding-bottom: 23px;
}
.voice-list dl dd p {
    margin: 12px 0 0;
	font-size: 15px;
}
.voice-list dl dt::before {
		width: 47px;
		height: 47px;
    font-size: 29px;
    left: 15px;
}
.voice-list dl dd::before {
		width: 47px;
		height: 47px;
    font-size: 29px;
    left: 15px;
    margin-top: 0px;
}
.voice-list dl::after {
    top: 33px;
    right: 15px;
    width: 10px;
    height: 10px;
}
.vo-list dl {
  margin-top: 30px;
  margin-right: 0;
  margin-left: 0;
  margin-bottom: 15px;
}
.vo-list dl dt {
  padding-top: 25px;
  padding-right: 35px;
  padding-left: 50px;
  padding-bottom: 50px;
  font-size: 15px;
}
.vo-list dl dt:hover {
  opacity: 0.7;
}
.vo-list dl dd {
  margin: 0;
  padding-top: 39px;
  padding-right: 50px;
  padding-left: 50px;
  padding-bottom: 50px;
}
.vo-list dl dd p {
    margin: 15px 0 0;
	font-size: 15px;
}
.vo-list dl::after {
    top: 60px;
    right: 50px;
    width: 10px;
    height: 10px;
}
.variable_text_blue .text_box .link_btn_box_y a img {
  width: 30px;
  height: auto;
  margin-right: 15px;
  margin-top: 0px;
  margin-bottom: 0px;
}
.variable_text_blue .text_box .link_btn_box_t a img {
  width: 30px;
  height: auto;
  margin-right: 15px;
  margin-top: 0px;
  margin-bottom: 0px;
}
.variable_text_blue .text_box .link_btn_box_t p {
  margin-top: 0px;
  margin-bottom: 8px;
	margin-left: -60px;
}
.variable_text_blue .text_box .link_btn_box_y p {
  margin-top: 0px;
  margin-bottom: 8px;
	margin-left: -60px;
}
footer small span {
  font-size: 15px;
  margin-right: 4px;
  margin-top: -1px;
}
footer .footC small {
  margin-top: 0px;
  font-size: 13px;
  margin-right: 3.5%;
}
footer .flex {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
}
footer .container {
  width: 90%;
  max-width: 1300px;
}
footer .footA p {
  font-size: 15px;
  margin-top: 15px;
}
footer .footB {
  display: flex;
  flex-wrap: no-wrap;
  width: 55%;
}
footer .footB section {
  width: 30%;
}
footer .footB .link_B {
  font-size: 15px;
  margin-top: 7px;
  transition: all 0.3s;
}
footer .footB .link_B:hover  {
  color: #FFF532;
}
footer .footA img {
  width: 210px;
  height: auto;
}
footer .footB .link_A {
  margin-top: 20px;
  font-size: 17px;
  transition: all 0.3s;
}
footer .footB .link_A:hover  {
  color: #FFF532;
}
footer {
  padding-top: 90px;
  margin-top: 110px;
}
footer .footC {
  margin-top: 100px;
  padding-top: 40px;
  padding-bottom: 40px;
}
footer .footA {
  margin-top: 20px;
}
footer .footC .under_flex {
  width: 90%;
  max-width: 1300px;
  display: flex;
  justify-content: space-between;
}
footer .footC .privacy {
  font-size: 13px;
  transition: all 0.3s;
}
footer .footC .privacy:hover  {
  color: #FFF532;
}
footer .footC .deepxi {
  font-size: 13px;
  margin-top: 0px;
}
/*Scrollテキストの描写*/
.scrolldown span {
  font-size: 14px;
	left:-29px;
  top: -25px;
}
.copyright {
  position: fixed;
  z-index: 20;
  display: inline;
  font-size: 11px;
  color: #AFAFAF;
  top: 46%;
  left: -90px;
  transform: rotate(90deg)translateY(-50%);
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  letter-spacing: 0.35em;
  animation: menu_fade 0.8s 1.7s forwards;
  opacity: 0;
}
.sub_hero_title .sub_small_title img {
  width: 24px;
  margin-right: 8px;
  margin-top: -2px;
}
.sub_hero video {
  width: 97.7%;
  height: 550px;
  top: 18px;
	object-fit: fill;
}
.hero video {
  width: 97.7%;
  height: 96.5%;
}
.staff_hero .staff_hero_img {
  width: 68%;
  height: 550px;
  top: 18px;
  object-fit: fill;
  left: 64.8%;
}
.sub_hero {
  position: relative;
  width: 100vw;
  height: 588px;
}
.staff_hero {
  position: relative;
  width: 100vw;
  height: 588px;
}
.privacy_box .container {
  width: 90%;
  max-width: 1200px;
}
.privacy_box .text {
  margin-bottom: 0px;
  width: 46%;
}
.privacy_box .text p {
  font-size: 15px;
}
.privacy_box .container .flex {
  display: flex;
  justify-content: space-between;
  margin-bottom: 65px;
}
.privacy_box .text h3 {
  font-size: 22px;
  margin-bottom: 10px;
}
.privacy_box .text h3 img {
  width: 20px;
  height: auto;
  margin-bottom: -2px;
}
.privacy_box h2 {
  font-size: 18px;
  margin-bottom: 90px;
}
.js-scroll.sub_hero_title {
  padding-top: 180px;
}
.staff_hero_title {
  padding-top: 225px;
  margin-left: 8%;
}
.js-scroll.sub_hero_title.privacy {
  padding-top: 135px;
}
.mail_form {
  margin-top: 110px;
  padding-top: 60px;
  padding-bottom: 40px;
  margin-bottom: 70px;
  max-width: 1300px;
}
form p {
  padding-bottom: 30px;
  padding-top: 30px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 68%;
}
form .textfield_label {
  font-size: 16px;
  width: 155px;
  font-weight: bold;
}
form .icon_any {
	padding-left: 15px;
	padding-right: 15px;
	padding-top: 6px;
	padding-bottom: 5px;
	font-size: 13px;
}
form .content_box .radio {
  width: 14px;
  height: 14px;
  top: 2px;
  margin-top: 8px;
  margin-bottom: 11px;
	margin-right: 6px;
}
form .content_box {
	font-size: 14px;
	margin-top: 0px;
	width: 345px;
}
form #fullname {
	padding-top: 10px;
	padding-right: 15px;
	padding-left: 15px;
	padding-bottom: 10px;
	width: 60%;
	font-size: 15px;
	margin-top: 0px;
	max-width: 450px;
}
form .icon_require {
	padding-left: 15px;
	padding-right: 15px;
	padding-top: 6px;
	padding-bottom: 5px;
	font-size: 13px;
}
form #tel {
	padding-top: 10px;
	padding-right: 15px;
	padding-left: 15px;
	padding-bottom: 10px;
	width: 60%;
	font-size: 15px;
	margin-top: 0px;
	max-width: 450px;
}
form #company {
	padding-top: 10px;
	padding-right: 15px;
	padding-left: 15px;
	padding-bottom: 10px;
	width: 60%;
	font-size: 15px;
	margin-top: 0px;
	max-width: 450px;
}
form #mail {
  padding-top: 10px;
	padding-right: 15px;
	padding-left: 15px;
	padding-bottom: 10px;
	width: 60%;
	font-size: 15px;
	margin-top: 0px;
	max-width: 450px;
}
form #area {
  padding-top: 10px;
	padding-right: 15px;
	padding-left: 15px;
	padding-bottom: 10px;
	width: 60%;
	font-size: 15px;
	margin-top: 0px;
	max-width: 450px;
}
form #message {
  padding-top: 10px;
	padding-right: 15px;
	padding-left: 15px;
	padding-bottom: 10px;
	width: 60%;
	font-size: 15px;
	margin-top: 0px;
	max-width: 450px;
  height: 140px;
}
form .submit {
	margin-top: 0px;
	display: block;
}
form .submit input {
	font-size: 19px;
	padding-top: 15px;
	padding-bottom: 15px;
	padding-left: 60px;
	padding-right: 60px;
	margin-top: 30px;
}
.mail_form form {
  margin-top: 60px;
}
.js-scroll .motion-txt .motion-inner .back_img_box p {
  display: block;
  color: #FFFFFF;
  width: 700px;
  margin-left: 65px;
  margin-bottom: 20px;
  font-size: 15px;
	text-shadow: 1px 1px 4px #000000;
}
.js-scroll .motion-txt .motion-inner .back_img_box {
  width: 90vw;
  max-width: 1300px;
  height: 600px;
  text-align: left;
  background-image: url(img/ceo_l.jpg);
  background-position: left top;
  background-size: cover;
  background-repeat: no-repeat;
  padding-top: 80px;
  position: relative;
}
.js-scroll .motion-txt .motion-inner .staff_list_img {
  width: 28vw;
  max-width: 400px;
  height: 20vw;
  max-height: 300px;
}
.back_img_box img {
  display: block;
  width: 200px;
  height: auto;
  position: absolute;
  right: 65px;
  bottom: 60px;
}
.principle {
  width: 90%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 1200px;
  margin-top: 40px;
}
.principle section {
  border-radius: 100vw;
  padding-top: 0px;
  padding-bottom: 0px;
  margin-bottom: 35px;
  width: 230px;
  height: 230px;
  margin-right: 50px;
  margin-left: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.principle section h3 {
  font-size: 20px;
  position: relative;
}
.principle section h3 span {
  font-size: 28px;
}
.principle section p {
  color: #1D457B;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  font-size: 100px;
}
.js-scroll.com_center_title {
  margin-top: 40px;
}
table.works_content th {
	font-size: 17px;
}
table.works_content td.data {
  font-size: 15px;
  width: 60%;
	padding-left: 55px;
  padding-top: 15px;
  padding-bottom: 15px;
}
table.outline_content th {
	font-size: 17px;
}
table.outline_content th br {
	display: none;
}
table.outline_content td.data {
  font-size: 15px;
  width: 68%;
	padding-left: 45px;
  padding-top: 15px;
  padding-bottom: 15px;
}
.outline_content {
	width: 90%;
  max-width: 1300px;
  margin-top: 40px;
}
.client_content {
	width: 90%;
  max-width: 1300px;
  margin-top: 40px;
}
table.client_content th {
  font-size: 16px;
  text-align: center;
}
table.client_content td.data {
  font-size: 16px;
  padding-top: 15px;
  padding-bottom: 15px;
  text-align: center;
}
.works_content {
	width: 90%;
  max-width: 1300px;
  margin-top: 40px;
}
.staff_box {
	width: 90%;
	max-width: 1300px;
	display: flex;
	margin-top: 40px;
	justify-content: space-between;
	flex-wrap: wrap;
}

.staff_box:after{
  content:"";
  display:block;
  width: 31%;
  height:0;
}
.staff_box a h3 {
  font-size: 24px;
  margin-top: 0px;
  line-height: 1.3;
}
.staff_hero p {
  font-size: 48px;
  margin-top: 5px;
  line-height: 1.3;
}
.staff_box a p {
  font-size: 20px;
  line-height: 1.7;
}
.staff_hero h1 {
  font-size: 24px;
  line-height: 1.8;
}
.staff_box a p span {
  font-size: 14px;
}
.staff_hero h1 span {
  font-size: 16px;
}
.staff_box a:hover {
	opacity: 0.7;
}
.message_title h2 {
  font-size: 45px;
}
.staff_box_A {
  padding-top: 70px;
  padding-bottom: 80px;
}
.staff_box_B .container {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}
.staff_box_B .message_box p {
  font-size: 15px;
  margin-top: 20px;
}
.staff_box_B .message_box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.staff_box_B .message_box section {
  padding-top: 50px;
  padding-bottom: 55px;
  padding-left: 40px;
  padding-right: 40px;
  margin-bottom: 0px;
  width: 41%;
}
.staff_box_B .message_box h3 {
  font-size: 34px;
}
.staff_box_B .message_box section:first-child {
  margin-bottom: 0px;
}
.staff_space {
  margin-top: 90px;
}
.staff_box_B .message_box section.single_box {
  margin-top: 70px;
  width: 100%;
}
.faq_link .faq_link_box a {
  font-size: 15px;
  width: 28%;
  padding-top: 20px;
  padding-bottom: 20px;
  margin-top: 80px;
  transition: all 0.3s;
}
.works_link .works_link_box a {
  font-size: 15px;
  width: 17.5%;
  padding-top: 20px;
  padding-bottom: 20px;
  margin-top: 80px;
  transition: all 0.3s;
}
.faq_link .faq_link_box a:hover {
  opacity: 0.7;
}
.works_link .works_link_box a:hover {
  opacity: 0.7;
}
.faq_link .container {
  width: 90%;
  max-width: 1200px;
}
.works_link .container {
  width: 90%;
  max-width: 1300px;
}
.voice_box .vo-list .qa dt h3 {
  font-size: 15px;
}
.voice_box .vo-list .qa dt p {
  font-size: 23px;
  margin-top: 10px;
}
.voice_box .vo-list {
  width: 90%;
  max-width: 1300px;
}
.voice_box .vo-list dd p span {
  margin-top: 25px;
}
.voice_box .vo-list dd .vo_split_box .vo_text {
  width: 47.5%;
}
.voice_box .vo-list dd .vo_split_box .vo_img {
  width: 47.5%;
  height: 400px;
  margin-top: 10px;
}
.voice_box .vo-list dd .vo_split_box {
  display: flex;
  justify-content: space-between;
}
.voice_box {
  padding-top: 40px;
}
.table_back_img {
  height: 450px;
  margin-left: 0px;
  margin-right: auto;
}
.table_back_gray {
  width: 97.7%;
  background-color: #F3F3F3;
  margin-left: auto;
  margin-right: auto;
  padding-top: 60px;
  margin-top: 30px;
  margin-bottom: 190px;
  height: 350px;
}
.table_back_gray .box {
  width: 92%;
  margin-left: auto;
  margin-right: auto;
  max-width: 1300px;
}
.service_box .number {
  font-size: 115px;
  top: -100px;
  left: -75px;
}
.flow_box .overflow .number_line {
  width: 8px;
  height: 90px;
}
.flow_box {
  width: 90%;
  max-width: 1300px;
  margin-top: 70px;
}
.flow_box section {
  padding-left: 25px;
  padding-top: 0px;
  padding-bottom: 0px;
  padding-right: 25px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 180px;
}
.flow_box section h3 {
  font-size: 34px;
  text-align: center;
  margin-bottom: 0px;
  width: 37%;
}
.flow_box .flow_text {
  width: 63%;
}
.flow_box .flow_text .main_text {
  font-size: 15px;
}
.flow_box .flow_text .second_title {
  font-size: 24px;
  text-align: left;
  margin-bottom: 10px;
}
.flow_box section .flow_number {
  top: -86px;
  font-size: 115px;
}
.sv_box_B {
  padding-top: 0px;
  padding-bottom: 80px;
}
.sv_box_A {
  padding-top: 60px;
}
.info .scroll_box {
  width: 92%;
  max-width: 680px;
  margin-bottom: 10px;
  padding-bottom: 15px;
}
.info .scroll_box .scroll_text {
  height: 160px;
	padding-top: 0px;
	padding-bottom: 10px;
	margin-top: 20px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 10px;
	padding-right: 10px;
	width: 90%;
}
.info .scroll_box .scroll_text p {
  font-size: 15px;
  margin-bottom: 10px;
}
.service_box .service_link p span {
  width: 95px;
  padding-top: 1px;
  margin-bottom: 15px;
  margin-right: 10px;
}
.service_box .slick {
  width: 47%;
  position: absolute;
  z-index: 1;
  margin-top: -20px;
}
.service_box .slick.right {
  left: auto;
  right: 0px;
}
.service_box .slick .slick1 {
  width: 100%;
	margin-left: auto;
	margin-right: auto;
}
.service_box .slick .slick1 .slide_img {
  height: 480px;
	background-position: center center;
}
.service_box .slick .slick1 .slide_img .before {
  font-size: 18px;
  padding-left: 18px;
  padding-right: 18px;
  padding-top: 7px;
  padding-bottom: 6px;
  margin-top: 35px;
  margin-left: 35px;
  width: 90px;
}
.service_box .slick .slick1 .slide_img .after {
  font-size: 18px;
  padding-left: 18px;
  padding-right: 18px;
  padding-top: 7px;
  padding-bottom: 6px;
  margin-top: 35px;
  margin-left: 35px;
	width: 90px;
}
.staff_box a {
	margin-top: 0px;
	margin-bottom: 0px;
	/* [disabled]width: 33%; */
	max-width: 400px;
}
.sv_con_C {
  padding-bottom: 60px;
}
.faq_link .faq_link_box {
  justify-content: space-around;
}
.works_link .works_link_box {
  justify-content: space-around;
}
.common_margin {
  height: 100px;
}
.mail_form .jp_main_title p {
  font-size: 15px;
  letter-spacing: 0.04em;
  margin-top: 50px;
}
.phone_menu .sns_button {
  margin-top: 20px;
  margin-left: 25px;
	transition: all 0.3s;
}
.phone_menu .sns_button:hover {
  opacity: 0.7;
}
.phone_menu .sns_button img {
  width: 235px;
  height: auto;
}
.works_link {
  margin-bottom: 40px;
}
.case_box .container {
	width: 90%;
  max-width: 1300px;
}
.case_box section {
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 45px;
	display: flex;
	justify-content: space-between;
	padding-top: 20px;
	padding-left: 20px;
	padding-bottom: 20px;
	padding-right: 20px;
	align-items: center;
	flex-wrap: wrap;
}
.case_box .case_slick {
  width: 48.5%;
  margin-right: auto;
	margin-left:0px;
}
.case_box .case_slick .slick1 {
  width: 100%;
	margin-left: auto;
	margin-right: auto;
}
.case_box .case_slick .slick1 .slide_img {
  height: 490px;
}
.case_box .case_slick .slide_img .before {
	font-size: 18px;
	padding-left: 23px;
	padding-right: 23px;
	padding-top: 5px;
	padding-bottom: 5px;
	left: 15px;
	top: 18px;
}
.case_box .case_slick .slide_img .after {
	font-size: 18px;
	padding-left: 23px;
	padding-right: 23px;
	padding-top: 5px;
	padding-bottom: 5px;
	left: 15px;
	top: 18px;
}
.case_box .text_box {
  width: 46%;
  margin-top: 0px;
  margin-right: auto;
  margin-left: auto;
}
.case_box .text_box h3 {
  margin-bottom: 11px;
  font-size: 22px;
  font-weight: bold;
}
.case_box .text_box h2 {
  margin-bottom: 11px;
  font-size: 22px;
  font-weight: bold;
}
.case_box .text_box p {
	margin-bottom: 10px;
	padding-top: 12px;
	font-size: 15px;
}
.case_box .text_box p:last-child {
	margin-bottom: 0px;
}





















































































































































}
