@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;900&display=swap");
@import url('https://fonts.googleapis.com/icon?family=Material+Icons');
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

img {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
}

/* border-box */
*, *:before, *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

html, body {
  height: 100%;
}

html {
  font-size: 62.5%;
}

@media screen and (max-width: 767px) {
  html {
    font-size: calc(45% + 0.5vw);
  }
}
body {
  color: #1c1c1c;
  font-size: 1.5rem;
  /*font-family: 'Noto Sans JP', sans-serif;*/
  font-weight: 400;
  line-height: 1.5;
/*  min-width: 1040px;*/
	min-width: 1000px;
  word-wrap: break-word;
  -webkit-text-size-adjust: none;
}
@media screen and (max-width: 767px) {
  body {
    font-size: 3.2vw;
  }
}
a {
  color: inherit;
  transition: opacity 0.3s;
  text-decoration: none;
}

@media screen and (min-width: 768px) {
  a:hover {
    opacity: 0.6;
  }
}
/* helper */
._spOnly {
  display: none;
}

@media screen and (max-width: 767px) {
  ._spOnly {
    display: block;
  }

  ._pcOnly {
    display: none;
  }
}
._wf-montserrat {
  font-family: 'Montserrat', sans-serif;
}

._wf-noto {
  /*font-family: 'Noto Sans JP', sans-serif;*/
}
/*
@font-face {
	font-family: 'SC';
	src:
		url('./fonts/NotoSansSC-Regular.woff2') format('woff2'),
		url('./fonts/NotoSansSC-Regular.woff') format('woff'),
		url('./fonts/NotoSansSC-Regular.otf') format('opentype')
	;
	font-weight: 400;
}
@font-face {
	font-family: 'SC';
	src:
		url('./fonts/NotoSansSC-Medium.woff2') format('woff2'),
		url('./fonts/NotoSansSC-Medium.woff') format('woff'),
		url('./fonts/NotoSansSC-Medium.otf') format('opentype')
	;
	font-weight: 500;
}
@font-face {
	font-family: 'SC';
	src:
		url('./fonts/NotoSansSC-Bold.woff2') format('woff2'),
		url('./fonts/NotoSansSC-Bold.woff') format('woff'),
		url('./fonts/NotoSansSC-Bold.otf') format('opentype')
	;
	font-weight: 700;
}
@font-face {
	font-family: 'SC';
	src:
		url('./fonts/NotoSansSC-Black.woff2') format('woff2'),
		url('./fonts/NotoSansSC-Black.woff') format('woff'),
		url('./fonts/NotoSansSC-Black.otf') format('opentype')
	;
	font-weight: 900;
}

body.zh-CN,
body.zh-CN ._wf-noto {
	font-family: 'SC', 'Microsoft YaHei', 微软雅黑, sans-serif;
}
body.zh-CN ._wf-montserrat {
	font-family: 'Montserrat', 'SC', 'Microsoft YaHei', 微软雅黑, sans-serif;
}
*/
body.zh-CN,
body.zh-CN ._wf-noto,
body.zh-CN ._wf-montserrat {
	font-family: 'Microsoft YaHei', 微软雅黑, sans-serif;
}

body.en-US,
body.en-US ._wf-noto,
body.en-US ._wf-montserrat {
  /*font-family: 'Microsoft YaHei', 微软雅黑, sans-serif;*/
  font-family: 'Calibri', Arial, Arial Unicode MS, Times New Roman;
  /*font-family: 'Calibri', Segoe UI,SegoeUI, "Helvetica Neue", Helvetica, Arial, Arial Unicode MS, Times New Roman;*/
}

body.ja,
body.ja ._wf-noto,
body.ja ._wf-montserrat {
  font-family: 'Microsoft YaHei', 微软雅黑, sans-serif;
  /*font-family: 'Noto Sans JP', sans-serif;*/
}

._anime-blinking {
  -webkit-animation: blink .8s ease-in-out infinite alternate;
  -moz-animation: blink .8s ease-in-out infinite alternate;
  animation: blink .8s ease-in-out infinite alternate;
}

._anime-blinking-hukidashi {
  -webkit-animation: blinkBorder01 .8s ease-in-out infinite alternate;
  -moz-animation: blinkBorder01 .8s ease-in-out infinite alternate;
  animation: blinkBorder01 .8s ease-in-out infinite alternate;
}
._anime-blinking-hukidashi::before, ._anime-blinking-hukidashi::after {
  -webkit-animation: blink .8s ease-in-out infinite alternate;
  -moz-animation: blink .8s ease-in-out infinite alternate;
  animation: blink .8s ease-in-out infinite alternate;
}

@-webkit-keyframes blink {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-moz-keyframes blink {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes blink {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes blinkBorder01 {
  0% {
    border-color: #fff;
  }
  100% {
    border-color: #f68d31;
  }
}
@-moz-keyframes blinkBorder01 {
  0% {
    border-color: #fff;
  }
  100% {
    border-color: #f68d31;
  }
}
@keyframes blinkBorder01 {
  0% {
    border-color: #fff;
  }
  100% {
    border-color: #f68d31;
  }
}
#wraper {
  position: relative;
}

.inner {
/*  width: 1040px;*/
	width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
}
.inner.-w100 {
  width: 100%;
}

.animated {
  opacity: 0;
}

/* header
-----------------------*/
#header {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  align-items: center;
/*  min-width: 1040px;*/
	min-width: 1000px;
  height: 120px;
}
#header .site-logo {
  width: 129px;
  margin-left: 136px;
}

.nav-button {
  display: block;
  width: 50px;
  margin-left: 55px;
  cursor: pointer;
}
.nav-button span {
  display: inline-block;
  position: relative;
  width: 50px;
  height: 5px;
  margin: 10px 0;
  background-color: #fff;
}
.nav-button span::before, .nav-button span::after {
  position: absolute;
  left: 0;
  display: inline-block;
  width: 100%;
  height: 5px;
  background-color: #fff;
  transition: all .4s;
  content: '';
}
.nav-button span::before {
  top: -10px;
}
.nav-button span::after {
  bottom: -10px;
}
.nav-button.is-open span {
  margin: 20px 0;
  background: none;
}
.nav-button.is-open span::before {
  background-color: #05161d;
  -webkit-transform: translateY(10px) rotate(45deg);
  transform: translateY(10px) rotate(45deg);
}
.nav-button.is-open span::after {
  background-color: #05161d;
  -webkit-transform: translateY(-10px) rotate(-45deg);
  transform: translateY(-10px) rotate(-45deg);
}

@media screen and (max-width: 1400px) {
  #header {
    height: 100px;
  }
  #header .site-logo {
    width: 100px;
    margin-left: 60px;
  }
}
/* glnavi
-----------------------*/
#global-navi .link-list {
  display: -webkit-flex;
  display: flex;
  height: 120px;
}
#global-navi .link-list a {
  display: block;
  height: 100%;
  font-size: 1.5rem;
  font-weight: 700;
}
#global-navi .link-item {
  margin: 0 23px;
  line-height: 120px;
}
#global-navi .btn-language {
  position: relative;
  margin-left: 35px;
}
#global-navi .btn-language span {
  display: block;
  width: 120px;
  height: 100%;
  padding: 35px 0;
  color: #fff;
  font-size: 1.3rem;
  text-align: center;
  background-color: #448ad2;
}
#global-navi .btn-language span::before {
  display: block;
  width: 30px;
  height: 30px;
  margin: 0 auto 5px auto;
  background: url(../images/common/icn_earth.png) no-repeat;
  background-size: contain;
  content: '';
}
#global-navi .btn-language > ul {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  z-index: 100;
}
#global-navi .btn-language > ul li {
  border-top: 1px solid #fff;
}
#global-navi .btn-language > ul li a {
  display: block;
  height: 40px;
  line-height: 40px;
  color: #fff;
  text-align: center;
  background-color: #448ad2;
}
#global-navi .btn-contact a {
  width: 120px;
  padding: 35px 0;
  color: #fff;
  font-size: 1.3rem;
  text-align: center;
  background-color: #004ea2;
}
#global-navi .btn-contact a::before {
  display: block;
  width: 30px;
  height: 25px;
  margin: 0 auto 10px auto;
  background: url(../images/common/icn_mail.png) no-repeat;
  background-size: contain;
  content: '';
}

@media screen and (max-width: 1400px) {
  #global-navi .link-list {
    height: 100px;
  }
  #global-navi .link-item {
    margin: 0 15px;
    line-height: 100px;
  }
  #global-navi .btn-language {
    margin-left: 15px;
  }
  #global-navi .btn-language span {
    width: 100px;
    padding: 20px 0;
  }
  #global-navi .btn-contact a {
    width: 100px;
    padding: 20px 0;
  }
}
/* footer
-----------------------*/
#footer .footer-01 {
  padding: 120px 0 60px 0;
}
#footer .footer-01 .inner {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  max-width: 1720px;
  width: 100%;
}
#footer .footer-01 .site-author {
  width: 400px;
  margin-right: 115px;
}
#footer .footer-01 .site-author .logo {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-end;
  align-items: flex-end;
  margin-bottom: 32px;
}
#footer .footer-01 .site-author .logo img {
  width: 145px;
}
#footer .footer-01 .site-author .logo span {
  margin-left: 17px;
  font-size: 1.6rem;
  letter-spacing: 0.09em;
}
#footer .footer-01 .site-author .logo span::before {
  content: '/ ';
}
#footer .footer-01 .site-author .description {
  font-size: 1.5rem;
  line-height: 1.75;
}
#footer .footer-01 .footer-navi {
  margin-right: auto;
  padding-top: 8px;
	width: 380px;
}
#footer .footer-01 .footer-navi .navi-01 {
  display: -webkit-flex;
  display: flex;
  flex-wrap: wrap;
  writing-mode: vertical-lr;
  height: 150px;
  font-size: 1.6rem;
}
#footer .footer-01 .footer-navi .navi-01 li {
  width: 190px;
  margin-bottom: 24px;
  font-weight: 700;
  writing-mode: horizontal-tb;
}
#footer .footer-01 .footer-navi .navi-02 {
  position: relative;
  display: -webkit-flex;
  display: flex;
  padding: 57px 0 0 0;
}
#footer .footer-01 .footer-navi .navi-02::before {
  position: absolute;
  top: 15px;
  left: 0;
  display: block;
  width: 120px;
  height: 1px;
  background-color: #1c1c1c;
  content: '';
}
#footer .footer-01 .footer-navi .navi-02 li {
  margin-right: 28px;
  letter-spacing: 0.07em;
}
#footer .footer-01 .author-info {
  position: relative;
  text-align: right;
}
#footer .footer-01 .author-info .tel {
  margin-bottom: 9px;
  padding-left: 35px;
  font-size: 3.2rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  background: url(../images/common/ico_tel.png) no-repeat left center;
}
#footer .footer-01 .author-info .tel a {
  display: block;
}
#footer .footer-01 .author-info .address {
  font-size: 1.4rem;
  line-height: 1.7;
}
#footer .footer-01 .author-info .copyright {
  position: absolute;
  right: 0;
  bottom: 0;
  font-size: 1.4rem;
  white-space: nowrap;
}
#footer .footer-02 {
  padding: 50px 0 110px 0;
  color: #fff;
  background-color: #004ea2;
}
#footer .footer-02 .inner {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  max-width: 1720px;
  width: 100%;
}
#footer .footer-02 .footer-content-wrap {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  width: calc(100% - 430px);
  margin-left: auto;
}
#footer .footer-02 .footer-content-01 {
  display: -webkit-flex;
  display: flex;
  width: calc(100% - 350px);
  padding-right: 2%;
}
#footer .footer-02 .footer-content-01 > .title {
  width: 111px;
  margin-right: 30px;
  font-size: 2.0rem;
  font-weight: bold;
  white-space: nowrap;
  border-right: 1px solid #4974a1;
}
#footer .footer-02 .footer-content-01 .text-area {
  width: calc(100% - 111px);
}
#footer .footer-02 .footer-content-01 .text-area .item {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  margin-bottom: 27px;
}
#footer .footer-02 .footer-content-01 .text-area .item:last-child {
  margin-bottom: 0;
}
#footer .footer-02 .footer-content-01 .text-area .item .item-title {
  width: 99px;
  font-size: 1.6rem;
  font-weight: bold;
  white-space: nowrap;
}
#footer .footer-02 .footer-content-01 .text-area .item .item-text {
  width: calc(100% - 99px);
  font-size: 1.4rem;
  line-height: 1.7;
}
#footer .footer-02 .footer-content-02 {
  display: -webkit-flex;
  display: flex;
}
#footer .footer-02 .footer-content-02 > .title {
  width: 111px;
  margin-right: 30px;
  padding-right: 30px;
  font-size: 2.0rem;
  font-weight: bold;
  border-right: 1px solid #4974a1;
  white-space: nowrap;
}
#footer .footer-02 .footer-content-02 .list {
  width: calc(100% - 111px);
  font-size: 1.6rem;
}
#footer .footer-02 .footer-content-02 .list .item {
  margin-bottom: 30px;
  padding-left: 70px;
  line-height: 1.3;
  font-weight: bold;
  white-space: nowrap;
  background-repeat: no-repeat;
  background-position: left center;
}
#footer .footer-02 .footer-content-02 .list .item:last-child {
  margin-bottom: 0;
}
#footer .footer-02 .footer-content-02 .list .list-item-01 {
  background-image: url(../images/common/ico_footer-01.png);
}
#footer .footer-02 .footer-content-02 .list .list-item-02 {
  background-image: url(../images/common/ico_footer-02.png);
}
#footer .footer-02 .footer-content-02 .list .list-item-03 {
  background-image: url(../images/common/ico_footer-03.png);
}
#footer .footer-02 .footer-content-03 {
  margin-left: 90px;
}
#footer .footer-02 .footer-content-03 .address {
  margin-bottom: 40px;
}
#footer .footer-02 .footer-content-03 .address .item {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  margin-bottom: 8px;
  font-size: 1.4rem;
}
#footer .footer-02 .footer-content-03 .address .item:last-child {
  margin-bottom: 0;
}
#footer .footer-02 .footer-content-03 .address .item .item-title {
  width: 85px;
  font-weight: bold;
}
#footer .footer-02 .footer-content-03 .address .item .item-text {
  width: calc(100% - 85px);
}
#footer .footer-02 .footer-content-03 .button a {
  display: inline-block;
  width: 170px;
  color: #004ea2;
  text-align: center;
  font-weight: bold;
  line-height: 37px;
  border-radius: 37px;
  background-color: #fff;
}

@media screen and (max-width: 1400px) {
  #footer .footer-01 .site-author {
    width: 340px;
    margin-right: 50px;
    padding-left: 0;
  }
  #footer .footer-01 .footer-navi {
    margin-right: auto;
  }
  #footer .footer-01 .footer-navi .navi-01 {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    writing-mode: vertical-lr;
    height: 150px;
    font-size: 1.6rem;
  }
  #footer .footer-01 .footer-navi .navi-01 li {
    width: 185px;
    margin-bottom: 15px;
    font-weight: 700;
    writing-mode: horizontal-tb;
  }
  #footer .footer-01 .footer-navi .navi-02 {
    position: relative;
    display: -webkit-flex;
    display: flex;
    padding: 60px 0 0 0;
  }
  #footer .footer-01 .footer-navi .navi-02::before {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 120px;
    margin: 50px 0;
    height: 1px;
    background-color: #1c1c1c;
    content: '';
  }
  #footer .footer-01 .footer-navi .navi-02 li {
    margin-right: 15px;
  }
  #footer .footer-01 .author-info {
    white-space: nowrap;
  }
  #footer .footer-02 .inner {
    display: block;
  }
  #footer .footer-02 .footer-content-wrap {
    width: 100%;
  }
  #footer .footer-02 .footer-content-01 {
    padding: 0;
    margin-bottom: 50px;
  }
  #footer .footer-02 .footer-content-03 {
    margin: 0;
  }
}
/* investor
-----------------------*/
#investor {
  position: relative;
  margin-bottom: 90px;
  color: #fff;
  text-align: center;
  z-index: 10;
}
#investor a {
  position: relative;
  display: block;
  height: 200px;
  padding: 56px 0;
  background: url(../images/common/bg_investor.png) no-repeat;
  background-size: cover;
  box-shadow: 0px 12px 15.2px 0.8px rgba(42, 61, 85, 0.2);
}
#investor a::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #093059;
  opacity: 0;
  transition: opacity 0.3s;
  content: '';
}
#investor a:hover {
  opacity: 1;
}
#investor a:hover::before {
  opacity: 1;
}
#investor .sec-title {
  position: relative;
  display: inline-block;
  margin-bottom: 15px;
  padding-right: 75px;
  font-size: 4.6rem;
  font-weight: 500;
  background: url(../images/common/ico_arrow-02.png) no-repeat right center;
}
#investor .text {
  position: relative;
  font-size: 1.8rem;
}

/* contact
-----------------------*/
#contact a {
  position: relative;
  display: block;
  height: 320px;
  padding: 116px 0 120px 0;
  color: #fff;
  text-align: center;
  background: url(../images/common/bg_contact.png) no-repeat;
  background-size: cover;
}
#contact a::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #144c86;
  opacity: 0;
  transition: opacity 0.3s;
  content: '';
}
#contact a:hover {
  opacity: 1;
}
#contact a:hover::before {
  opacity: 1;
}
#contact .sec-title {
  position: relative;
  display: inline-block;
  margin-bottom: 15px;
  padding-right: 75px;
  font-size: 4.6rem;
  font-weight: 500;
  background: url(../images/common/ico_arrow-02.png) no-repeat right center;
}
#contact .text {
  position: relative;
  font-size: 1.8rem;
}

/* topicpath
------------------------ */
#topicpath {
  padding: 45px 20px 50px 20px;
}
#topicpath .topicpath-inner {
  max-width: 1340px;
  margin: 0 auto;
}
#topicpath ul {
  display: -webkit-flex;
  display: flex;
}
#topicpath ul li {
  font-size: 1.6rem;
}
#topicpath ul li + li::before {
  display: inline-block;
  padding: 0 10px;
  content: '＞';
}

/* common parts
--------------------------------------------------------------------------------------------------------*/
.nav-button {
	display: none;
}
.pc-block { display: block!important;}
.sp-block { display: none!important;}
.pc-inlineblock { display: inline-block!important;}
.sp-inlineblock { display: none!important;}

/*
	less than 767px;
---------------------------------------------------------------------------------------------------------------------------------------------*/
@media (max-width: 767px) {

	.pc-block { display: none!important;}
	.sp-block { display: block!important;}
	.pc-inlineblock { display: none!important;}
	.sp-inlineblock { display: inline-block!important;}

/* common parts
--------------------------------------------------------------------------------------------------------*/
	body {
		min-width: 100%;
	}
	#wrapper {
		position: relative;
	}
/* header
--------------------------------------------------------------------------------------------------------*/
	#header {
		padding: calc(40 / 750 * 100vw);
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: auto;
		min-width: auto;
		z-index: 101;
		background-color: #fff;
		-webkit-align-items: flex-start;
		align-items: flex-start;
	}
	#header .site-logo {
		width: auto;
		margin-left: 0;
	}
	#header .site-logo img {
		width: calc(132 / 750 * 100vw);
	}
	#header.is-open {
		height: 100%;
		overflow: auto;
	}

/* nav-button
--------------------------------------------------------------------------------------------------------*/
	.nav-button,
	.nav-button span {
		display: -webkit-flex;
		display: flex;
		-webkit-justify-content: center;
		justify-content: center;
		-webkit-align-items: center;
		align-items: center;
		width: calc(100 / 750 * 100vw);
	}
	.nav-button {
		margin-left: 0;
		cursor: auto;
	}
	.nav-button span {
		height: calc(100 / 750 * 100vw);
		margin: 0;
		background-color: transparent;
	}
	.nav-button.is-open span {
		margin: 0;
	}
	.nav-button span::before,
	.nav-button span::after {
		position: static;
		width: auto;
		height: auto;
		display: block;
		background-color: transparent;
		top: initial;
		font-size: calc(60 / 750 * 100vw);
		color: #000;
		transition: none;
	}
	.nav-button span::before {
		content: '\e5d2';
		font-family: 'Material Icons';
		font-weight: normal;
		background-color: transparent;
		transform: none;
	}
	.nav-button.is-open span::before {
		content: '\e5cd';
		font-family: 'Material Icons';
		font-weight: normal;
		background-color: transparent;
		transform: none;
	}
/* global-navi
--------------------------------------------------------------------------------------------------------*/
	#global-navi .link-list {
		display: none;
		position: absolute;
		left: 0;
		width: 100%;
		height: auto;
		background-color: rgba(255, 255, 255, 0.9);
	}
	#global-navi.is-show .link-list {
		display: block;
	}
	#global-navi .link-item {
		line-height: 1.0;
		margin: 0;
		text-align: center;
	}
	#global-navi .link-list a {
		font-size: calc(28 / 750 * 100vw);
		height: auto;
		padding-top: calc(42 / 750 * 100vw);
		padding-bottom: calc(42 / 750 * 100vw);
	}
	#global-navi .btn-language {
		margin-top: calc(65 / 750 * 100vw);
		margin-left: 0;
	}
	#global-navi .btn-language span {
		width: 100%;
		font-family: 'Montserrat', sans-serif;
		font-size: calc(30 / 750 * 100vw);
		font-weight: 700;
		display: -webkit-flex;
		display: flex;
		-webkit-align-items: center;
		align-items: center;
		padding-top: calc(40 / 750 * 100vw);
		padding-bottom: calc(40 / 750 * 100vw);
		padding-left: calc(245 / 750 * 100vw);
	}
	#global-navi .btn-language span::before {
		margin: 0 calc(45 / 750 * 100vw) 0 0;
		width: calc(60 / 750 * 100vw);
		height: calc(60 / 750 * 100vw);
	}
	#global-navi .btn-language > ul {
		position: static;
	}
	#global-navi .btn-language > ul li a {
		line-height: 1.0;
		height: auto;
	}
	#global-navi .btn-contact a {
		font-family: 'Montserrat', sans-serif;
		font-size: calc(30 / 750 * 100vw);
		font-weight: 700;
		width: 100%;
		display: -webkit-flex;
		display: flex;
		-webkit-align-items: center;
		align-items: center;
		padding-left: calc(245 / 750 * 100vw);
	}
	#global-navi .btn-contact a::before {
		margin: 0 calc(45 / 750 * 100vw) 0 0;
		width: calc(60 / 750 * 100vw);
		height: calc(50 / 750 * 100vw);
	}

/* investor
--------------------------------------------------------------------------------------------------------*/
	#investor {
		margin-bottom: calc(90 / 750 * 100vw);
	}
	#investor .inner {
		padding-right: calc(60 / 750 * 100vw);
		padding-left: calc(60 / 750 * 100vw);
	}
	#investor a {
		height: calc(182 / 750 * 100vw);
		padding: calc(40 / 750 * 100vw) 0;
	}
	#investor .sec-title {
		font-size: calc(46 / 750 * 100vw);
		margin-bottom: calc(15 / 750 * 100vw);
		padding-right: calc(68 / 750 * 100vw);
		background-size: calc(44 / 750 * 100vw) auto;
	}
	#investor .text {
		font-size: calc(22 / 750 * 100vw);
	}

/* contact
--------------------------------------------------------------------------------------------------------*/
	#contact a {
		height: calc(300 / 750 * 100vw);
		padding: calc(100 / 750 * 100vw) 0;
	}
	#contact .inner {
		padding-right: 0;
		padding-left: 0;
	}
	#contact .sec-title {
		font-size: calc(46 / 750 * 100vw);
		margin-bottom: calc(15 / 750 * 100vw);
		padding-right: calc(75 / 750 * 100vw);
		background-size: calc(44 / 750 * 100vw) auto;
	}
	#contact .text {
		font-size: calc(22 / 750 * 100vw);
	}

/* topicpath
--------------------------------------------------------------------------------------------------------*/
	#topicpath {
		display: none;
	}

/* footer
--------------------------------------------------------------------------------------------------------*/
	#footer .footer-01 {
		padding-top: calc(90 / 750 * 100vw);
		padding-bottom: calc(85 / 750 * 100vw);
	}
	#footer .footer-01 .inner {
		-webkit-flex-direction: column;
		flex-direction: column;
		padding-right: calc(40 / 750 * 100vw);
		padding-left: calc(40 / 750 * 100vw);
	}
	#footer .footer-01 .site-author {
		width: auto;
		margin-right: 0;
	}
	#footer .footer-01 .site-author .logo {
		-webkit-flex-direction: column;
		flex-direction: column;
		-webkit-align-items: center;
		align-items: center;
		margin-bottom: calc(50 / 750 * 100vw);
	}
	#footer .footer-01 .site-author .logo img {
		width: calc(196 / 750 * 100vw);
	}
	#footer .footer-01 .site-author .logo span {
		font-size: calc(24 / 750 * 100vw);
		margin-left: 0;
		margin-top: 0.75em;
	}
	#footer .footer-01 .site-author .description {
		font-size: calc(22 / 750 * 100vw);
		line-height: 1.4545;
		padding-right: calc(85 / 750 * 100vw);
		padding-left: calc(85 / 750 * 100vw);
		text-align: justify;
		text-justify: inter-ideograph;
	}
	#footer .footer-01 .footer-navi {
		padding-top: calc(70 / 750 * 100vw);
		padding-right: calc(85 / 750 * 100vw);
		padding-bottom: calc(105 / 750 * 100vw);
		padding-left: calc(85 / 750 * 100vw);
		margin-right: 0;
		width: 100%;
	}
	#footer .footer-01 .footer-navi .navi-01 {
		height: auto;
		font-size: calc(24 / 750 * 100vw);
		-webkit-justify-content: space-between;
		justify-content: space-between;
		width: 100%;
		writing-mode: horizontal-tb;
	}
	#footer .footer-01 .footer-navi .navi-01 li {
		width: 50%;
		-webkit-flex: 0 0 50%;
		flex: 0 0 50%;
		margin-bottom: calc(50 / 750 * 100vw);
	}
	#footer .footer-01 .footer-navi .navi-01 li:nth-of-type(2n) {
		padding-left: 3.0em;
	}
	#footer .footer-01 .footer-navi .navi-02 {
		padding-top: calc(70 / 750 * 100vw);
		justify-content: space-between;
	}
	#footer .footer-01 .footer-navi .navi-02::before {
		margin: 0;
		width: calc(120 / 750 * 100vw);
	}
	#footer .footer-01 .footer-navi .navi-02 li {
		margin-right: 0;
	}
	#footer .footer-01 .footer-navi .navi-02 li:last-child {
		padding-right: 0.5em;
	}
	#footer .footer-01 .author-info {
		padding-right: calc(80 / 750 * 100vw);
		padding-left: calc(80 / 750 * 100vw);
	}
	#footer .footer-01 .author-info .tel {
		margin-bottom: calc(30 / 750 * 100vw);
		padding-left: calc(64 / 750 * 100vw);
		font-size: calc(52 / 750 * 100vw);
	}
	#footer .footer-01 .author-info .address {
		font-size: calc(22 / 750 * 100vw);
		line-height: 1.3636;
		padding-right: calc(25 / 750 * 100vw);
	}
	#footer .footer-01 .author-info .copyright {
		margin-top: calc(65 / 750 * 100vw);
		font-size: calc(22 / 750 * 100vw);
		position: static;
		text-align: center;
	}
	#footer .footer-02 {
		padding-top: calc(80 / 750 * 100vw);
		padding-bottom: calc(90 / 750 * 100vw);
	}
	#footer .footer-02 .inner {
		padding-right: calc(40 / 750 * 100vw);
		padding-left: calc(40 / 750 * 100vw);
	}
	#footer .footer-02 .footer-content-wrap {
		-webkit-flex-direction: column;
		flex-direction: column;
	}
	#footer .footer-02 .footer-content-01 {
		width: 100%;
		-webkit-flex-direction: column;
		flex-direction: column;
		margin-bottom: calc(65 / 750 * 100vw);
	}
	#footer .footer-02 .footer-content-01 > .title,
	#footer .footer-02 .footer-content-02 > .title {
		font-size: calc(34 / 750 * 100vw);
		width: 100%;
		text-align: center;
		padding-bottom: calc(40 / 750 * 100vw);
		margin-right: 0;
		margin-bottom: calc(50 / 750 * 100vw);
		border-right: none;
		border-bottom: 1px solid #4974a1;
	}
	#footer .footer-02 .footer-content-01 .text-area {
		width: auto;
	}
	#footer .footer-02 .footer-content-01 .text-area .item {
		margin-bottom: calc(50 / 750 * 100vw);
	}
	#footer .footer-02 .footer-content-01 .text-area .item .item-title {
		font-size: calc(28 / 750 * 100vw);
		width: calc(175 / 750 * 100vw);
	}
	#footer .footer-02 .footer-content-01 .text-area .item .item-text {
		font-size: calc(24 / 750 * 100vw);
		font-weight: 400;
		line-height: 1.4166;
		width: calc(495 / 750 * 100vw);
		text-align: justify;
		text-justify: inter-ideograph;
	}
	#footer .footer-02 .footer-content-02 {
		-webkit-flex-direction: column;
		flex-direction: column;
		padding-bottom: calc(80 / 750 * 100vw);
	}
	#footer .footer-02 .footer-content-02 > .title {
		margin-bottom: calc(60 / 750 * 100vw);
	}
	#footer .footer-02 .footer-content-02 .list {
		display: -webkit-flex;
		display: flex;
		-webkit-justify-content: space-between;
		justify-content: space-between;
		width: auto;
	}
	#footer .footer-02 .footer-content-02 .list .item {
		font-size: calc(28 / 750 * 100vw);
		background-position: center top;
		margin-bottom: 0;
		padding-top: calc(115 / 750 * 100vw);
		padding-left: 0;
		line-height: 1.0;
		flex: 1;
		text-align: center;
	}
	#footer .footer-02 .footer-content-03 {
		padding-right: calc(30 / 750 * 100vw);
		padding-left: calc(30 / 750 * 100vw);
	}
	#footer .footer-02 .footer-content-03 .address {
		margin-bottom: calc(85 / 750 * 100vw);
	}
	#footer .footer-02 .footer-content-03 .address .item {
		font-size: calc(24 / 750 * 100vw);
		margin-bottom: calc(8 / 750 * 100vw);
	}
	#footer .footer-02 .footer-content-03 .address .item .item-title {
		width: calc(150 / 750 * 100vw);
	}
	#footer .footer-02 .footer-content-03 .address .item .item-text {
		width: calc(460 / 750 * 100vw);
	}
	#footer .footer-02 .footer-content-03 .button a {
		width: 100%;
		font-size: calc(38 / 750 * 100vw);
		display: -webkit-flex;
		display: flex;
		-webkit-justify-content: center;
		justify-content: center;
		line-height: 1.0;
		border-radius: 2.0em;
		padding: 1.0em 0;
	}
}



/* career
--------------------------------------------------------------------------------------------------------*/
.animated {
	animation-duration: 0.6s;
	-webkit-animation-duration: 0.6s;
}
.about-box {
	text-align: center;
}
.about-box h2 {
	margin-bottom: 48px;
}
.sec-title {
	font-size: 4.6rem;
	font-weight: 600;
	line-height: 1;
}
.sec-title .ja {
	margin-left: 19px;
	font-size: 1.8rem;
	font-weight: 400;
	letter-spacing: 0.05em;
}
.sec-title .ja::before {
	content: '／ ';
}
.flex-box {
	display: -webkit-flex;
	display: flex;
}
article {
	background-color: #fff;
}
#topicpath {
	background-color: #fff;
}


/* fadeInRight2
-----------------------------------------------*/
@-webkit-keyframes fadeInRight2 {
	from { opacity: 0; -webkit-transform: translate3d(15%, 0, 0); transform: translate3d(15%, 0, 0);}
	to { opacity: 1; -webkit-transform: none; transform: none;}
}
@keyframes fadeInRight2 {
	from { opacity: 0; -webkit-transform: translate3d(15%, 0, 0); transform: translate3d(15%, 0, 0);}
	to { opacity: 1; -webkit-transform: none; transform: none;}
}
.fadeInRight2 {
	-webkit-animation-name: fadeInRight2;
	animation-name: fadeInRight2;
}
/* fadeInLeft2
-----------------------------------------------*/
@-webkit-keyframes fadeInLeft2 {
	from { opacity: 0; -webkit-transform: translate3d(-15%, 0, 0); transform: translate3d(-15%, 0, 0);}
	to { opacity: 1; -webkit-transform: none; transform: none;}
}
@keyframes fadeInLeft2 {
	from { opacity: 0; -webkit-transform: translate3d(-15%, 0, 0); transform: translate3d(-15%, 0, 0);}
	to { opacity: 1; -webkit-transform: none; transform: none;}
}
.fadeInLeft2 {
	-webkit-animation-name: fadeInLeft2;
	animation-name: fadeInLeft2;
}

/* mv
------------------------ */
#mv {
	background-color: #fff;
}
#mv .mv-inner {
	position: relative;
	max-width: 1680px;
	height: 640px;
	margin: 0 auto;
	background: url(../images/search/bg_mv.jpg) no-repeat top center;
	background-size: cover;
}
#mv .text-box {
	padding: 185px 15% 0 20.23%;
	color: #fff;
}
#mv .text-box > * {
	text-shadow: 0 0 0.75em rgba(14, 5, 10, 0.3);
}
#mv .text-box .article-title {
	margin-bottom: 17px;
	font-size: 6.4rem;
	font-weight: 800;
	line-height: 1.34375;
}


/* #sec01
--------------------------------------------------------------------------------------------------------*/
#sec01 {
	overflow: hidden;
}
#sec01 .inner {
	padding-right: 0;
	padding-left: 0;
}
#sec01 .inner h2 {
	font-size: 5.2rem;
	font-weight: 800;
	color: #2a2a2a;
	line-height: 1.538;
}
#sec01 .field {
	padding-top: 9.0rem;
	padding-bottom: 12.0rem;
	counter-reset: findjob;
}
#sec01 .field:nth-of-type(1) h3 {
	-webkit-align-items: baseline;
	align-items: baseline;
}
#sec01 .field:nth-of-type(2) {
	background-color: #f7f7f7;
	position: relative;
}
#sec01 .field:nth-of-type(2)::before,
#sec01 .field:nth-of-type(2)::after {
	content: '';
	position: absolute;
	top: 0;
	height: 100%;
	background-color: #f7f7f7;
}
#sec01 .field:nth-of-type(2)::before {
	right: 100%;
	width: 100vw;
}
#sec01 .field:nth-of-type(2)::after {
	left: 100%;
	width: 34.0rem;
}
#sec01 .field-title h3 strong {
	font-size: 4.6rem;
	font-weight: 600;
}
#sec01 .field:nth-of-type(2) .field-title h3 strong {
	line-height: 1.217;
}
#sec01 .field-title h3 span {
	font-size: 1.8rem;
	font-weight: 400;
	display: block;
	/*margin-left: 3.0rem;*/
}
#sec01 .field-title h3 span::before {
	content: '／';
	margin-right: 0.25em;
}
#sec01 .field-title p {
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 1.75;
}
#sec01 .field .field-title p {
	margin-top: 3.0rem;
}
#sec01 .item {
	padding-top: 5.0rem;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	border: none;
}
#sec01 .item .box {
	width: 30.0rem;
	margin-top: 5.0rem;
	margin-right: 5.0rem;
	counter-increment: findjob;
	cursor: pointer;
	-webkit-transition: opacity 0.3s ease;
	transition: opacity 0.3s ease;
}
#sec01 .item .box:hover {
	opacity: 0.6;
}
#sec01 .item .box:nth-of-type(3n) { margin-right: 0;}
#sec01 .item .box:nth-of-type(-n+3) { margin-top: 0;}
#sec01 .item .box dl:nth-of-type(2) { -webkit-animation-delay: 0.05s; animation-delay: 0.05s; }
#sec01 .item .box dl:nth-of-type(3) { -webkit-animation-delay: 0.10s; animation-delay: 0.10s;}
#sec01 .item .box dl:nth-of-type(4) { -webkit-animation-delay: 0.15s; animation-delay: 0.15s;}
#sec01 .item .box dl:nth-of-type(5) { -webkit-animation-delay: 0.20s; animation-delay: 0.20s;}
#sec01 .item .box dl:nth-of-type(6) { -webkit-animation-delay: 0.25s; animation-delay: 0.25s;}
#sec01 .item .box dl:nth-of-type(7) { -webkit-animation-delay: 0.30s; animation-delay: 0.30s;}
#sec01 .item .box dl:nth-of-type(8) { -webkit-animation-delay: 0.35s; animation-delay: 0.35s;}

#sec01 .item a:hover {
	opacity: 1.0;
}
#sec01 .item dl dt {
	color: #fff;
	background-color: #004ea2;
	padding-top: 4.5rem;
	padding-right: 3.0rem;
	padding-left: 3.0rem;
	height: 23.5rem;
	-webkit-flex-direction: column;
	flex-direction: column;
}
#sec01 .field:nth-of-type(2) .item dl dt {
	background-color: #448ad2;
}
#sec01 .item dl dt::before {
	content: counter(findjob, decimal-leading-zero);
	font-family: 'Montserrat', sans-serif;
	font-size: 1.8rem;
	font-weight: 500;
	border-bottom: 1px solid #fff;
	-webkit-align-self: flex-start;
	align-self: flex-start;
	margin-bottom: 1.0rem;
}
#sec01 .item dl dt > * {
	line-height: 1.0;
}
#sec01 .item dl dt strong {
	font-size: 4.2rem;
	font-weight: 700;
	margin-bottom: 0.3rem;
}
#sec01 .field:nth-of-type(2) .item dl dt strong {
	line-height: 0.88;
	margin-bottom: 1.5rem;
}
#sec01 .item dl dt span {
	font-size: 3.6rem;
	font-weight: 300;
	margin-bottom: 1.2rem;
}
#sec01 .item dl dt small {
	font-size: 1.5rem;
}
#sec01 .item dl dt small::before {
	content: '／';
	margin-right: 0.25em;
}
#sec01 .item dl dd {
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
	background-color: #fff;
}
#sec01 .item dl dd p {
	width: 100%;
	font-size: 1.8rem;
	font-weight: 700;
	letter-spacing: 0.015em;
	text-align: center;
}
#sec01 .item dl dd i {
	background-color: #040404;
	width: 6.3rem;
	height: 6.3rem;
	-webkit-flex: 0 0 6.3rem;
	flex: 0 0 6.3rem;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
}

/* #sec02
--------------------------------------------------------------------------------------------------------*/
#sec02 {
	overflow: hidden;
	background-color: #f7f7f7;
	padding-bottom: 12.0rem;
}
#sec02 .inner {
	padding-top: 10.5rem;
	padding-bottom: 10.5rem;
	position: relative;
	background-color: #fff;
}
#sec02 .inner::before,
#sec02 .inner::after {
	content: '';
	position: absolute;
	top: 0;
	height: 100%;
	background-color: #fff;
}
#sec02 .inner::before {
	right: 100%;
	width: 18.0rem;
	opacity: 1.0;
}
#sec02 .inner::after {
	left: 100%;
	width: 100vw;
}
#sec02 .inner h2 {
	-webkit-align-items: baseline;
	align-items: baseline;
	padding-bottom: 6.0rem;
}
#sec02 .inner h2 strong {
	font-size: 4.6rem;
	font-weight: 600;
}
#sec02 .inner h2 span {
	font-size: 1.8rem;
	font-weight: 400;
	margin-left: 3.0rem;
}
#sec02 .inner h2 span::before {
	content: '／';
	margin-right: 0.25em;
}
#sec02 .field {
	width: 1000px;
	margin: 0 auto;
	padding: 0 30px;
	align-items: center;
	-webkit-align-items: center;
	justify-content: space-between;
	-webkit-justify-content: space-between;
	counter-reset: step01;
	position: relative;
	z-index: 4;
}
#sec02 .field::before,
#sec02 .field::after {
	content: '';
	position: absolute;
	z-index: 3;
	top: 125px;
	width: 100.0vw;
	height: 1px;
	background-color: #646567;
}
#sec02 .field::before { left: 50%;}
#sec02 .field::after { right: 50%;}
#sec02 .item,
#sec02 .item dl {
	align-items: center;
	-webkit-align-items: center;
	justify-content: center;
	-webkit-justify-content: center;
	border: 1px solid #646567;
	border-radius: 50%;
}
#sec02 .item {
	position: relative;
	z-index: 5;
	width: 250px;
	height: 250px;
	padding: 10px;
	counter-increment: step01;
}
#sec02 .item::before,
#sec02 .item::after {
	position: absolute;
	content: '';
	top: 50%;
	width: 9px;
	height: 9px;
	background-color: #646567;
	border-radius: 50%;
	transform: translate(0, -50%);
	-webkit-transform: translate(0, -50%);
}
#sec02 .item::before {
	left: -5px;
}
#sec02 .item::after {
	right: -5px;
}
#sec02 .item dl {
	width: 100%;
	height: 100%;
	text-align: center;
	background-color: #fff;
	align-items: flex-start;
	-webkit-align-items: flex-start;
	padding-top: 9.0rem;
	position: relative;
	z-index: 3;
}
#sec02 .item dl::before {
	content: counter(step01, decimal-leading-zero);
	position: absolute;
	font-size: 2.2rem;
	font-family: 'Montserrat', sans-serif;
	font-weight: 600;
	color: #67686a;
	top: 5.0rem;
	left: 0;
	width: 100%;
	height: auto;
	text-align: center;
}
#sec02 .item dt {
	font-size: 2.8rem;
	font-weight: 700;
	color: #004ea2;
	letter-spacing: 0.025em;
	margin-bottom: 0.5rem;
}
#sec02 .item dd {
	font-size: 1.6rem;
	font-weight: 500;
	color: #040404;
	letter-spacing: 0.025em;
}
#sec02 .sub-field {
	padding-top: 3.0rem;
	counter-reset: step02;
}
#sec02 .sub-field dl {
	padding: 2.5rem 0;
	border-bottom: 1px solid #c7c7c7;
	counter-increment: step02;
}
#sec02 .sub-field dt,
#sec02 .sub-field dt > * {
	line-height: 1.0;
}
#sec02 .sub-field dt {
	margin-bottom: 1.5rem;
}
#sec02 .sub-field dt::before {
	content: counter(step02, decimal-leading-zero);
	font-size: 2.6rem;
	font-family: 'Montserrat', sans-serif;
	font-weight: 700;
	color: #004ea2;
	letter-spacing: 0.025em;
}
#sec02 .sub-field dt span {
	font-size: 2.2rem;
	font-weight: 700;
	color: #004ea2;
	letter-spacing: 0.025em;
	margin-left: 1.0em;
}
#sec02 .sub-field dd p {
	font-size: 1.6rem;
	letter-spacing: 0.025em;
	line-height: 1.5;
	color: #1c1c1c;
}


/*
	less than 767px;
---------------------------------------------------------------------------------------------------------------------------------------------*/
@media (max-width: 900px) {
/* common parts
--------------------------------------------------------------------------------------------------------*/
body {
    min-width: 100%;
}
	.inner {
		width: 100%;
	}
	#mv {
		padding-right: calc(40 / 750 * 100vw);
		padding-left: calc(40 / 750 * 100vw);
		margin-bottom: calc(90 / 750 * 100vw);
	}
	#mv .mv-inner {
		height: calc(620 / 750 * 100vw);
		display: -webkit-flex;
		display: flex;
		-webkit-justify-content: center;
		justify-content: center;
		-webkit-align-items: center;
		align-items: center;
	}
	#mv .text-box {
		padding-top: 0;
		padding-left: 0;
	}
	#mv .text-box .article-title {
		font-size: calc(58 / 750 * 100vw);
		margin-bottom: calc(20 / 750 * 100vw);
	}
	#mv .text-box .ja {
		font-size: calc(24 / 750 * 100vw);
	}
}

/*
	less than 767px;
---------------------------------------------------------------------------------------------------------------------------------------------*/
@media (max-width: 767px) {
/* common parts
--------------------------------------------------------------------------------------------------------*/
	.inner {
		width: 100% !important;
	}
	#mv {
		padding-right: calc(40 / 750 * 100vw);
		padding-left: calc(40 / 750 * 100vw);
		margin-bottom: calc(90 / 750 * 100vw);
	}
	#mv .mv-inner {
		height: calc(620 / 750 * 100vw);
		display: -webkit-flex;
		display: flex;
		-webkit-justify-content: center;
		justify-content: center;
		-webkit-align-items: center;
		align-items: center;
	}
	#mv .text-box {
		padding: 0 0 0 8%;
	}
	#mv .text-box .article-title {
		font-size: calc(58 / 750 * 100vw);
		margin-bottom: calc(20 / 750 * 100vw);
	}
	#mv .text-box .ja {
		font-size: calc(24 / 750 * 100vw);
	}
	.sec-title {
		font-size: calc(46 / 750 * 100vw);
		margin-bottom: calc(48 / 750 * 100vw);
	}
	.sec-title .ja {
		font-size: calc(24 / 750 * 100vw);
		display: block;
		margin-top: 0.5em;
		margin-left: 0;
	}
	.about-box h2 {
		margin-bottom: calc(70 / 750 * 100vw);
	}

/* sec01
--------------------------------------------------------------------------------------------------------*/
	#sec01 .inner {
		padding-top: 0;
		padding-right: calc(40 / 750 * 100vw);
		padding-left: calc(40 / 750 * 100vw);
	}
	#sec01 .inner h2 {
		font-size: calc(58 / 750 * 100vw);
	}
	#sec01 .inner h2 br {
		display: none;
	}
	#sec01 .field {
		padding-top: calc(90 / 750 * 100vw);
		padding-bottom: calc(100 / 750 * 100vw);
	}
	#sec01 .field:nth-of-type(1) h3 {
		-webkit-flex-direction: column;
		flex-direction: column;
		-webkit-align-items: flex-start;
		align-items: flex-start;
		margin-bottom: calc(20 / 750 * 100vw);
	}
	#sec01 .field-title h3 strong {
		font-size: calc(46 / 750 * 100vw);
	}
	#sec01 .field-title h3 span {
		font-size: calc(26 / 750 * 100vw);
	}
	#sec01 .field:nth-of-type(2) h3 span {
		margin-top: 0.5em;
	}
	#sec01 .field-title p {
		font-size: calc(24 / 750 * 100vw);
	}
	#sec01 .field-title p br {
		display: none;
	}
	#sec01 .item {
		padding-top: calc(50 / 750 * 100vw);
		-webkit-flex-direction: column;
		flex-direction: column;
	}
	#sec01 .item .box {
		width: 100%;
		margin-top: 0;
		margin-right: 0;
	}
	#sec01 .item .box:not(:last-child) {
		margin-bottom: calc(30 / 750 * 100vw);
	}
	#sec01 .item .box dl dt {
		padding-top: calc(40 / 750 * 100vw);
		padding-right: calc(50 / 750 * 100vw);
		padding-bottom: calc(40 / 750 * 100vw);
		padding-left: calc(50 / 750 * 100vw);
		height: auto;
		display: block;
	}
	#sec01 .item .box dl dt::before {
		font-size: calc(36 / 750 * 100vw);
		margin-bottom: calc(20 / 750 * 100vw);
		display: table;
	}
	#sec01 .item .box dl dt strong,
	#sec01 .item .box dl dt span {
		display: inline-block;
		vertical-align: middle;
		margin-bottom: 0;
	}
	#sec01 .item .box dl dt strong {
		font-size: calc(48 / 750 * 100vw);
	}
	#sec01 .field:nth-of-type(2) .item .box dl dt strong {
		line-height: 1.0;
		margin-bottom: 0;
	}
	#sec01 .field:nth-of-type(2) .item .box dl dt strong br {
		display: none;
	}
	#sec01 .field:nth-of-type(2) .item .box dl dt strong i {
		width: 0.25em;
	}
	#sec01 .item .box dl dt span {
		font-size: calc(46 / 750 * 100vw);
		margin-left: 0.25em;
	}
	#sec01 .item .box dl dt small {
		font-size: calc(28 / 750 * 100vw);
		display: block;
		margin-top: 0.5em;
	}
	#sec01 .item .box dl dd p {
		font-size: calc(34 / 750 * 100vw);
	}
	#sec01 .item .box dl dd i {
		width: calc(100 / 750 * 100vw);
		height: calc(100 / 750 * 100vw);
		-webkit-flex: 0 0 calc(100 / 750 * 100vw);
		flex: 0 0 calc(100 / 750 * 100vw);
	}

/* sec02
--------------------------------------------------------------------------------------------------------*/
	#sec02 {
		padding-bottom: calc(80 / 750 * 100vw);
	}
	#sec02 .inner {
		padding-top: calc(90 / 750 * 100vw);
		padding-right: calc(40 / 750 * 100vw);
		padding-bottom: calc(80 / 750 * 100vw);
		padding-left: calc(40 / 750 * 100vw);
	}
	#sec02 .inner::before,
	#sec02 .inner::after {
		content: none;
	}
	#sec02 .inner h2 {
		font-size: calc(60 / 750 * 100vw);
		-webkit-flex-direction: column;
		flex-direction: column;
		-webkit-align-items: flex-start;
		align-items: flex-start;
		padding-bottom: calc(40 / 750 * 100vw);
	}
	#sec02 .inner h2 strong {
		font-size: calc(46 / 750 * 100vw);
	}
	#sec02 .inner h2 span {
		font-size: calc(26 / 750 * 100vw);
		margin-top: 0.5em;
		margin-left: 0;
	}
	#sec02 .field {
		width: 100%;
		padding-right: 0;
		padding-bottom: 0;
		padding-left: 0;
		-webkit-flex-direction: column;
		flex-direction: column;
		position: relative;
	}
	#sec02 .field::before {
		content: '';
		position: absolute;
		top: 0;
		left: 50%;
		width: 1px;
		height: 100%;
		background-color: #646567;
	}
	#sec02 .field::after {
		content: none;
	}
	#sec02 .item,
	#sec02 .item dl {
		border-radius: calc(10 / 750 * 100vw);
	}
	#sec02 .item {
		width: 100%;
		height: auto;
		padding: calc(10 / 750 * 100vw);
	}
	#sec02 .item:not(:last-child) {
		margin-bottom: calc(50 / 750 * 100vw);
	}
	#sec02 .item::before,
	#sec02 .item::after {
		width: calc(12 / 750 * 100vw);
		height: calc(12 / 750 * 100vw);
		z-index: 1;
	}
	#sec02 .item::before {
		left: calc(50% - calc(6 / 750 * 100vw));
		top: 0;
	}
	#sec02 .item::after {
		right: calc(50% - calc(7 / 750 * 100vw));
		top: 100%;
	}
	#sec02 .item dl {
		padding-top: calc(25 / 750 * 100vw);
		padding-bottom: calc(25 / 750 * 100vw);
	}
	#sec02 .item dl::before {
		position: static;
		font-size: calc(40 / 750 * 100vw);
	}
	#sec02 .item dt {
		font-size: calc(48 / 750 * 100vw);
		margin-bottom: 0;
	}
	#sec02 .item dd {
		font-size: calc(30 / 750 * 100vw);
	}
	#sec02 .sub-field {
		padding-top: calc(50 / 750 * 100vw);
	}
	#sec02 .sub-field dl {
		padding-top: calc(40 / 750 * 100vw);
		padding-bottom: calc(40 / 750 * 100vw);
	}
	#sec02 .sub-field dt {
		margin-bottom: calc(20 / 750 * 100vw);
	}
	#sec02 .sub-field dt::before {
		font-size: calc(42 / 750 * 100vw);
	}
	#sec02 .sub-field dt span {
		font-size: calc(34 / 750 * 100vw);
		margin-left: 0.75em;
	}
	#sec02 .sub-field dd p {
		font-size: calc(26 / 750 * 100vw);
	}


}

/*
---------------------------------------------------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 1068px) and (min-width: 768px) {
	#mv .mv-inner {
    	height: 450px;
	}
	#mv .text-box {
		padding: 90px 0 0 20.23%;
	}
}

.flex-box {
    display: -webkit-flex;
    display: flex;
}
.inner {
    /* width: 1040px; */
    width: 1000px;
    margin: 0 auto;
    padding: 0 20px;
}
