@charset "UTF-8";

/* html5doctor.com Reset v1.6.1 (http://html5doctor.com/html-5-reset-stylesheet/) - http://cssreset.com */
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;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent}
html {
  scroll-padding-top: 280px;
}
body{line-height:1}

article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}
nav ul{list-style:none}
blockquote,q{quotes:none}
blockquote:before,blockquote:after,q:before,q:after{content:none}
a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent}
ins{background-color:#ff9;color:#000;text-decoration:none}
mark{background-color:#ff9;color:#000;font-style:italic;font-weight:bold}
del{text-decoration:line-through}
abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}
table{border-collapse:collapse;border-spacing:0}
ol,ul {list-style:none;}

body{font-family: 'Noto Sans JP', 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif; color:#444; font-weight:400; line-height:1;}
html{font-size: 62.5%;box-sizing: border-box;}
ul{list-style: none; }
a, input{outline:none;}

/**** Start of "Micro cf" ****/

.cf { zoom: 1; }
.cf:before,
.cf:after { content: ""; display: table; }
.cf:after { clear: both; }

/* --------------------------------------------------------
	site setting
-------------------------------------------------------- */
.ff-serif {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
}
.ff-montserrat {
  font-family: "Montserrat", serif;
  font-optical-sizing: auto;
}
.fc-main {
  color:#444;
}
.fc-white {
  color:#fff;
}
.fc-black {
  color:#111;
}
.fc-purple {
  color:#6c3483;
}
.fc-blue {
  color:#0068b6;
}
.fc-red {
  color:#e50012;
}
.fc-orange {
  color:#ffaf00;
}
.fc-bold {
  font-weight:bold;
}
.fs-56 {
  font-size: 5.6rem; /*1680-1281 40-36*/
}
.fs-48 {
  font-size: clamp(3.6rem, 1.447rem + 1vw, 4.0rem); /*1680-1281 40-36*/
}
.fs-40 {
  font-size: clamp(3.6rem, 1.447rem + 1vw, 4.0rem); /*1680-1281 40-36*/
}
.fs-36 {
  font-size: 2.8rem; /*1680-1281 40-36*/
}
.fs-32 {
  font-size: clamp(2.4rem, 0.7152rem + 1vw, 2.6rem); /*1680-1281 32-28*/
}
.fs-28 {
  font-size: clamp(2.0rem, 0.7152rem + 1vw, 2.4rem); /*1680-1281 24-20*/
}
.fs-24 {
  font-size: clamp(2.0rem, 0.7152rem + 1vw, 2.4rem); /*1680-1281 24-20*/
}
.fs-22 {
  font-size: clamp(2.0rem, 1.3584rem + 0.5vw, 2.2rem); /*1680-1281 22-20*/
}
.fs-20 {
  font-size: clamp(1.8rem, 1.1584rem + 0.5vw, 2.0rem); /*1680-1281 20-18*/
}
.fs-18 {
  font-size: 1.8rem;
}
.fs-16 {
  font-size: 1.6rem;
}
.globalnavi.fs-16 {
  font-size: clamp(1.4rem, 1.1856rem + 0.5vw, 1.6rem); /*834-431 16-14*/
}
.fs-15 {
  font-size: 1.5rem;
}
.fs-14 {
  font-size: 1.4rem;
}
.fs-12 {
  font-size: 1.2rem;
}
.fw-900 {
  font-weight:900;
}
.fw-700 {
  font-weight:700;
}
.fw-500 {
  font-weight:500;
}
.fw-400 {
  font-weight:400;
}
.lh-200 {
  line-height:2.0;
}
.lh-180 {
  line-height:1.8;
}
.lh-150 {
  line-height:1.5;
}
.lh-120 {
  line-height:1.2;
}
.lh-100 {
  line-height:1.0;
}
.ta-center {
  text-align: center;
}
.ta-right {
  text-align: right;
}
.mt-200 {
  margin-top:11.9047vw;
}
.mt-160 {
  margin-top:9.5238vw;
}
.mt-150 {
  margin-top:8.9285vw;
}
.mt-120 {
  margin-top:7.1428vw;
}
.mt-100 {
  margin-top:5.9523vw;
}
.mt-90 {
  margin-top:5.3571vw;
}
.mt-80 {
  margin-top:4.7619vw;
}
.mt-70 {
  margin-top:4.1666vw;
}
.mt-60 {
  margin-top:3.5714vw;
}
.mt-50 {
  margin-top:2.9761vw;
}
.mt-40 {
  margin-top:2.3809vw;
}
.mt-30 {
  margin-top:1.7857vw;
}
.mt-20 {
  margin-top:1.1904vw;
}
.mt-15 {
  margin-top:0.8928vw;
}
.mt-10 {
  margin-top:0.5952vw;
}
.mb-60 {
  margin-bottom:3.5714vw;
}
.mb-40 {
  margin-bottom:2.3809vw;
}
.w-1360 {
  margin-right:auto;
  margin-left:auto;
  width:70.8333%;
  min-width:1260px;
}
.w-1200 {
  margin-right:auto;
  margin-left:auto;
  width:61.2444%;
  min-width:1000px;
}
.w-900 {
  margin-right:auto;
  margin-left:auto;
  width:46.875%;
  min-width:900px;
}
.flex-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.flex-container.flex-jc-between {
  justify-content: space-between;
}
.flex-container.flex-ai-center {
  align-items: center;
}
.of-hidden {
  overflow: hidden;
}
.pc{display:block;}
.sp{display:none;}

.indent {
  padding-left:1em;
  text-indent:-1.5em;
}
a:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
}

/* --------------------------------------------------------
	style
-------------------------------------------------------- */

html {
  height: 100%;
}
body {
  position: relative;
  padding-top:120px;
}
a {
  text-decoration: none;
}
.body__inner {
  width:100%;
  overflow: hidden;
}
.loader {
  pointer-events: none;
  position: absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:#fff;
  z-index: 1000;
}
.loaded .loader {
  opacity: 0;
  transition: 0.5s;
}
.loader__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height:100vh;
}
.loader__inner img {
  width: 2.5%;
  height: auto;
}
figure img {
  width:100%;
  height:auto;
}
.note__list {
  list-style-type: none;
}
.note__list.list__centering {
  display: inline-flex;
  flex-direction: column;
}
.note__list > li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  line-height:1.4;
}
.note__list.list__centering li {
  text-align: left;
}
.note__list li:before {
  content:'※';
  margin-right:5px;
}
.note__list li + li {
  margin-top:8px;
}
.disk__list {
  list-style-type: disc;
  margin-left:20px;
}
.disk__list li {
  line-height:1.5;
}
.disk__list li + li {
  margin-top:10px;
}
.decimal__list {
  list-style-type:decimal;
  margin-left:20px;
}
.decimal__list li {
  line-height:1.5;
}
.decimal__list li + li {
  margin-top:10px;
}
/* --------------------------------------------------------
	global navi
-------------------------------------------------------- */
header {
  position: fixed;
  top:0;
  left:0;
  width:100%;
  height:120px;
  background:#fff;
  z-index: 99;
}
header .header__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: space-between;
  align-items: center;
  height:100%;
  box-sizing: border-box;
}
header .main-logo {
  width:22.0588%;
  height:48px;
}
header .main-logo img {
  width:100%;
  height:auto;
}
header .header__inner .globalnavi {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: flex-end;
  width:calc(100% - 24%);
  height:100%;
}
header .header__inner .globalnavi > a, header .header__inner .globalnavi > div {
  display: inline-flex;
  align-items: center;
  height:100%;
  color:#444;
  text-decoration: none;
}
header .header__inner .globalnavi > a.active, header .header__inner .globalnavi > div.active {
  color:#0068b6;
}
header .header__inner .globalnavi a + a, header .header__inner .globalnavi a + div {
  margin-left:2.0833vw;
}
header .header__inner .globalnavi .fs-16 {
  
}
.btn-inquiry {
  position: relative;
  padding:20px 60px 20px 80px;
  color:#e50012;
  border:1px solid #e50012;
  border-radius: 999px;
  box-sizing: border-box;
}
.btn-inquiry:before {
  content:'';
  position:absolute;
  top:50%;
  left:10px;
  width:auto;
  height:70%;
  background:url(../img/common/ico-btn-inquiry.svg);
  background-size: cover;
  aspect-ratio:1/1;
  transform: translate(0,-50%);
}
header .btn__language {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top:50%;
  right:0;
  padding:16px 60px 16px 30px;
  color:#fff;
  text-decoration: none;
  border-radius: 999px 0 0 999px;
  background:#0068b6;
  box-sizing: border-box;
  transform: translate(0,-50%);
}
header .btn__language:after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  width: 9px;
  height: 9px;
  background: #fff;
  border-radius: 999px;
  transform: translate(0, -50%);
}
header .megamenu {
  position: absolute;
  top:120px;
  left:0;
  width:100%;
  background:#fff;
  box-sizing: border-box;
  transform: translate(0,-50px);
  opacity: 0;
  transition: opacity 0.5s, transform 0.5s;
}
header .megamenu.hover {
  transform: translate(0,0);
  opacity: 1;
  transition: opacity 0.5s, transform 0.5s;
}
header .megamenu .megamenu__inner {
  position:relative;
  margin-right:auto;
  margin-left:auto;
  width:1000px;
}
header .megamenu .megamenu__inner > div {
  position: relative;
  display: none;
  padding:40px 0 40px 50px;
  width:100%;
  box-sizing: border-box;
}
header .megamenu .megamenu__inner > div:before {
  content:'';
  display:block;
  position: absolute;
  top:40px;
  left:0;
  width:2px;
  height:calc(100% - 80px);
  background:#e10001;
}
header .megamenu .megamenu__subtitle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
}
header .megamenu .megamenu__subtitle:before {
  content: "\f138";
  pointer-events: none;
  font-family: "Font Awesome 6 Free";
  -webkit-font-smoothing: antialiased;
  margin-right:10px;
  color:#0064aa;
  font-weight: bold;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  line-height: 1;
}
header .megamenu .flex-container {
  justify-content: space-between;
}
header .megamenu .flex-container.list__4column li {
  width:23%;
}
header .megamenu .flex-container.list__3column li {
  width:30%;
}
header .megamenu figcaption {
  color:#444;
}
/* --------------------------------------------------------
	hero
-------------------------------------------------------- */
.hero {
  width:100%;
}
.hero {
  padding:4.6875vw 10vw 15.625vw;
  width:100%;
  background:url(../img/top/bg-hero.jpg) center bottom no-repeat;
  background-size: cover;
  box-sizing: border-box;
}
.hero .inner__top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.hero .inner__top .inner__left {
  width:74%;
}
.hero__inner .hero__logo {
  margin-right:auto;
  margin-left:auto;
  width:72.9729%;
}
.hero .lead__wrapper {
  display: inline-flex;
  flex-direction: column;
}
.hero .lead__wrapper .hero__lead {
  display: inline-block;
}
.hero .lead__wrapper .hero__btn a {
  display: inline-block;
  position: relative;
  padding:20px 60px;
  text-decoration: none;
  border:2px solid #0068b6;
  border-radius: 999px;
  box-sizing: border-box;
}
.hero .lead__wrapper .hero__btn a:after {
  content:'';
  display: block;
  position: absolute;
  top:50%;
  right:30px;
  width:9px;
  height:9px;
  background:#e50012;
  border-radius: 999px;
  transform: translate(0,-50%);
}
.hero .inner__bottom {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.hero .inner__bottom a {
  position:relative;
  padding:50px 20px;
  width:50%;
  color:#fff;
  text-align: center;
  text-decoration: none;
  box-sizing: border-box;
}
.hero .inner__bottom .btn-manufacturer {
  background:#e50012;
}
.hero .inner__bottom .btn-manufacturer:after {
  content:'';
  display:block;
  position: absolute;
  top:0;
  left:50%;
  width:13.3333%;
  aspect-ratio:1/1;
  background:url(../img/common/ico-manufacturer.svg) no-repeat;
  background-size: cover;
  transform: translate(-50%,-50%);
  filter: drop-shadow(3px 3px 4px #000000);
}
.hero .inner__bottom .btn-worker {
  background:#142143;
}
.hero .inner__bottom .btn-worker:after {
  content:'';
  display:block;
  position: absolute;
  top:0;
  left:50%;
  width:13.3333%;
  aspect-ratio:1/1;
  background:url(../img/common/ico-worker.svg) no-repeat;
  background-size: cover;
  transform: translate(-50%,-50%);
  filter: drop-shadow(3px 3px 4px #000000);
}
.hero .inner__top .inner__right {
  width:36%;
}
.hero .inner__top .inner__right img {
  width:100%;
  height:auto;
}
/* --------------------------------------------------------
	main
-------------------------------------------------------- */
.top main {
  position: relative;
  margin-top:-15.625vw;
  box-sizing: border-box;
}
main section {
  position:relative;
  width:100%;
}
.about .inner__top {
  position:relative;
  width:100%;
  z-index: 1;
  overflow: hidden;
}
.about .inner__top .about__background {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: absolute;
  width:100%;
  height:100%;
  z-index: 0;
}
.about .inner__top .about__background:before {
  content:'';
  display:block;
  width:100%;
  height:auto;
  background:url(../img/top/bg-about-top.png) no-repeat;
  background-size: 100% auto;
  aspect-ratio:193/32;
}
.about .inner__top .about__background .bg__middle {
  flex-grow: 1;
  width:100%;
  background:url(../img/top/bg-about-middle.png) repeat-y;
  background-size:100% auto;
  margin-top: -1px;
}
.about .inner__top .about__background:after {
  content:'';
  display:block;
  width:100%;
  height:auto;
  background:url(../img/top/bg-about-bottom.png) no-repeat;
  background-size: 100% auto;
  aspect-ratio:193/32;
}
.about .inner__top .flex-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  padding:8.3333vw 10vw 13.0208vw;
  box-sizing: border-box;
}
.about .inner__top .about__left {
  position: relative;
  padding-top:8.125vw;
  width:50%;
}
.about .inner__top .about__left:before {
  content:'';
  position: absolute;
  top:0;
  left:0;
  width:37.0312vw;
  height:auto;
  aspect-ratio:711/865;
  background:url(../img/top/bg-about02.png) no-repeat;
  background-size: cover;
  transform: translate(-18%,-6%);
}
.about .inner__top .about__right {
  padding-left:3.125vw;
  width:50%;
  box-sizing: border-box;
}
.about .inner__top .about__right figure {
  width:83.8235%;
}
.about .inner__top .about__lead {
  position: relative;
  font-weight: 400;
}
.about .inner__top .about__right .about__lead:after {
  content:'';
  position: absolute;
  top:0;
  left:-3.125vw;
  height:133.735%;
  background:url(../img/top/img-about-border.svg) center bottom no-repeat;
  background-size: auto 100%;
  aspect-ratio:20/319;
  transform: translate(-50%,-500%);
}
.about .inner__top .about__right .about__lead.onScreen:after {
  transform: translate(-50%,0);
  transition: 4.0s;
}
.about .inner__top .about__lead strong {
  color:#ffaf00;
}
.about .inner__top .about__lead .about__en {
  font-size: 2.6rem;
}
.about .inner__top .about__lead .about__en span {
  color:#ffaf00;
  font-size:4.8rem;
}
.about .inner__top .about__lead .about__ja {
  font-size: 1.6rem;
}
.about .inner__bottom {
  position: relative;
  margin-top:-16.6666vw;
  padding:13vw 10vw 8.3333vw;

  
  background:#ececec;
  z-index: 0;
}
.about .inner__bottom .about__catchcopy {
  color:#0064aa;
  font-size:5.0rem;
  font-weight:400;
  text-align: right;
}
.about .inner__bottom .about__catchcopy .inner__text {
  display: inline-block;
  padding-bottom:30px;
  border-bottom:1px solid #e50012;
}
.about .inner__bottom .about__catchcopy .about__en {
  color:#e50012;
  font-size:7.0rem;
}
.about .inner__bottom .about__catchcopy .about__ja {
  margin-left:5.2083vw;
  color:#e50012;
  font-size:4.0rem;
}
.about .inner__bottom .about__btn {
  text-align: right;
}
.about .inner__bottom .about__btn a {
  position: relative;
  display: inline-block;
  padding: 20px 60px;
  text-decoration: none;
  background:#0068b6;
  border-radius: 999px;
  box-sizing: border-box;
}
.about .inner__bottom .about__btn a:after {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    right: 30px;
    width: 9px;
    height: 9px;
    background: #fff;
    border-radius: 999px;
    transform: translate(0, -50%);
}
.section__template01 {
  padding:6.25vw 10vw;
  box-sizing: border-box;
}
.specialist {
  background:#fff;
}
.section__title {
  font-style: italic;
}
.section__title .sub {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
}
.section__title .sub:before {
  content:'';
  margin-right:20px;
  width:50px;
  height:2px;
  background:#e10001;
}
.specialist .section__title .main {
  font-size:6.4rem;
}
.specialist .list__decimal {
  margin-left:20px;
  list-style-type: decimal;
  color:#e50012;
}
.specialist .list__decimal p {
  color:#444;
}
.specialist .flex-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  box-sizing: border-box;
}
.specialist .flex-container figure:nth-of-type(1) {
  width:31.6176%;
}
.specialist .flex-container figure:nth-of-type(2) {
  width:33.8235%;
}
.specialist .flex-container figure:nth-of-type(3) {
  width:34.5588%;
}
.specialist .specialist__btn {
  text-align: right;
}
.specialist .specialist__btn a {
  position: relative;
  display: inline-block;
  padding: 20px 100px 20px 140px;
  text-decoration: none;
  background: #e50012;
  border-radius: 999px;
  box-sizing: border-box;
  transform: translate(0,-50%);
  filter: drop-shadow(3px 3px 4px #000000);
}
.specialist .specialist__btn a:before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 20px;
  width: 80px;
  aspect-ratio: 1 / 1;
  background: url(../img/common/ico-manufacturer.svg) no-repeat;
  background-size: cover;
  transform: translate(0, -50%);
}
.specialist .specialist__btn a:after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  width: 9px;
  height: 9px;
  background: #fff;
  border-radius: 999px;
  transform: translate(0, -50%);
}
.performance {
  background:url(../img/top/bg-performance.jpg) no-repeat;
  background-size: cover;
}
.performance-list li {

}
.performance-list li span {
  color:#e50012;
  display: block;
  font-weight: bold;

}
.performance .performance__btn .btn__inner {
  display: inline-flex;
}
.performance .performance__btn a {
  position: relative;
  display: inline-block;
  padding: 20px 100px 20px 140px;
  text-decoration: none;
  border-radius: 999px;
  box-sizing: border-box;
  transform: translate(0,-50%);
  filter: drop-shadow(3px 3px 4px #000000);
}
.performance .performance__btn a + a {
  margin-left:60px;
}
.performance .performance__btn a:nth-of-type(1) {
  background: #e50012;
}
.performance .performance__btn a:nth-of-type(2) {
  background: #142143;
}
.performance .performance__btn a:before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 20px;
  width: 80px;
  aspect-ratio: 1 / 1;
  transform: translate(0, -50%);
}
.performance .performance__btn a:nth-of-type(1):before {
  background: url(../img/common/ico-manufacturer.svg) no-repeat;
  background-size: cover;
}
.performance .performance__btn a:nth-of-type(2):before {
  background: url(../img/common/ico-worker.svg) no-repeat;
  background-size: cover;
}
.performance .performance__btn a:after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  width: 9px;
  height: 9px;
  background: #fff;
  border-radius: 999px;
  transform: translate(0, -50%);
}
.monitor {
  background:#142143;
}
.monitor__title {
  padding:60px 20px 30px;
  /*font-style: italic;*/
  border-bottom:1px solid #fff;
}
.monitor .swiper {
  position: relative;
  margin-right:auto;
  margin-left:auto;
  width:calc(100% - 270px);
  border-right:1px solid #fff;
  border-left:1px solid #fff;
  box-sizing: border-box;
}
.monitor .swiper:before {
  content:'';
  position:absolute;
  top:0;
  right:50%;
  width:1px;
  height:100%;
  background:#fff;
}
.monitor .swiper:after {
  /*content:'';
  position:absolute;
  top:0;
  left:50%;
  width:1px;
  height:100%;
  background:#fff;*/
}
.monitor .swiper-slide {
  padding:30px 60px;
  box-sizing: border-box;
}
.monitor .swiper-slide figure {
  width:146px;
}
.swiper-button-next, .swiper-rtl .swiper-button-prev {
  right: calc(135px / 2);
  left: auto;
  color:#e3f9ff;
  transform: translateX(50%);
}
.swiper-button-prev, .swiper-rtl .swiper-button-next {
  left: calc(135px / 2);
  right: auto;
  color:#fff;
  transform: translateX(-50%);
}
.monitor-ind {
  text-indent: -1em;
  padding-left:1em;
}
.monitor-enw-ttl {
  border-bottom:1px dotted #cccccc;
  padding-bottom:0.5em;
  /*font-style: italic;*/
}
.information {
  width:100%;
  background:url(../img/top/bg-information.jpg) no-repeat;
  background-size: cover;
}
.information__title {
  padding-bottom:4.1666vw;
  font-style: italic;
  border-bottom:2px solid #e50012;
  box-sizing: border-box;
}
.information .news-list {
  display: inline-block;
  margin-right:auto;
  margin-left:auto;
}
.information .news-list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.information .news-list li + li {
  margin-top:50px;
}
.information .news-list li .date {
  text-align: left;
}
.information .news-list li .text {
  margin-left:50px;
  text-align:left;
}

.information .information__btn a {
  position: relative;
  display: inline-block;
  padding: 20px 120px;
  color:#444;
  text-decoration: none;
  background:#fff;
  border-radius: 999px;
  box-sizing: border-box;
  filter: drop-shadow(3px 3px 4px #000000);
}
.information .information__btn a:after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  width: 9px;
  height: 9px;
  background: #e50012;
  border-radius: 999px;
  transform: translate(0, -50%);
}
.flex-box{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  }
  .flex-box a {
  width:40%;
  display: flex;
  background-color: #eaf0f9;
  border-radius: 36px;
  padding:1.5em 2em;
  margin:1em auto;
  color:#0068b6;
  }
  .flex-box a:hover {
    background-color: #0068b6;
    color:#eaf0f9;
    }
    .flex-box a:visited {
      text-decoration: none;
      }
  .flex-box a:before {
    content: "\f105";
    pointer-events: none;
    font-family: "Font Awesome 6 Free";
    -webkit-font-smoothing: antialiased;
    display: block;
    width: 15px;
    font-weight: bold;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
  }
/* --------------------------------------------------------
	footer
-------------------------------------------------------- */
footer {
  width:100%;
  overflow: hidden;
}
footer .inner__top {
  width:100%;
  border-top:1px solid #0064aa;
  box-sizing: border-box;
}
footer .inner__top .flex-container .inner__left {
  padding:50px 30px 50px 0;
  width:calc(100% - 970px);
  background:#fff;
  box-sizing: border-box;
}
footer .inner__top .flex-container .inner__left figure {
  width:100%;
}
footer .btn-inquiry {
  position: relative;
  display: block;
  margin-right:auto;
  margin-left:auto;
  padding:20px 10px;
  width:100%;
  color:#e50012;
  text-decoration: none;
  border:1px solid #e50012;
  border-radius: 999px;
  box-sizing: border-box;
  font-weight: bold;
}
footer .btn-inquiry:before {
  content:'';
  position:absolute;
  top:50%;
  left:10px;
  width:auto;
  height:70%;
  background:url(../img/common/ico-btn-inquiry.svg);
  background-size: cover;
  aspect-ratio:1/1;
  transform: translate(0,-50%);
}
footer .inner__top .flex-container .inner__right {
  position: relative;
  padding:50px 0 50px 30px;
  width:970px;
  background:#0068b6;
  box-sizing: border-box;
}
footer .inner__top .flex-container .inner__right:before {
  content:'';
  display: block;
  position: absolute;
  top:0;
  right:1px;
  width:calc(((100vw - 70.8333vw) / 2) + 1px);
  height:100%;
  background:#0068b6;
  transform: translate(100%,0);
}
footer .footer__menulist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: space-between;
}
footer .footer__menulist > li {
  width:32%;
}
footer .footer__menulist .menu__title {
  padding:20px 10px;
  border-radius: 999px;
  background:#e3f9ff;
  box-sizing: border-box;
}
footer .footer__menu {
  margin-left:20px;
}
footer .footer__menu > li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
}
footer .footer__menu li:before {
  content: "\f105";
  pointer-events: none;
  font-family: "Font Awesome 6 Free";
  -webkit-font-smoothing: antialiased;
  display: block;
  width:15px;
  font-weight: bold;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  line-height: 1;
}
footer .footer__menu li a {
  width:calc(100% - 15px);
}
footer .footer__menu li + li {
  margin-top:20px;
}
footer .footer__menu a {
  flex-grow: 1;
  color:#fff;
  text-decoration: none;
}
footer .footer__submenu {
  margin-left:20px;
}
footer .footer__submenu > li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
footer .inner__bottom {
  padding:50px 0 50px;
  width:100%;
  border-top:1px solid #0064aa;
  box-sizing: border-box;
}
footer .inner__bottom  > .flex-container {
  justify-content: space-between;
  align-items: center;
}
footer .inner__bottom .inner__left a {
  color:#444;
}
footer .inner__bottom .inner__left a + a {
  margin-left:40px;
}
footer .inner__bottom .inner__right .flex-container {
  align-items: center;
}
footer .inner__bottom .inner__right figure {
  margin-left:50px;
  width:80px;
  height:80px;
}
footer .sp-copyright {
  display: none;
}
#conBanner p {
  margin:10px auto 0 auto;
  max-width:200px;
  }
  #conBanner p a:link {
    display: block;
  }
  #conBanner p a img {
    width:100%;
  }
/* --------------------------------------------------------
  contents
-------------------------------------------------------- */
.contents__hero {
  display: block;
  position: relative;
  width:100%;
  height:auto;
  aspect-ratio:640/167;
}
.breadcrumb {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
}
.breadcrumb li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
}
.breadcrumb li + li:before {
  content: "\f105";
  pointer-events: none;
  font-family: "Font Awesome 6 Free";
  -webkit-font-smoothing: antialiased;
  display: inline;
  margin:0 10px;
  font-weight: bold;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  line-height: 1;
}
.breadcrumb li a {
  color:#0068b6;
}
.contents__article {
  padding-bottom:17.8571vw;
}
.contents__title {
  font-style: italic;
}
.contents__title .sub {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
}
.contents__title .sub:before {
  content:'';
  margin-right:20px;
  width:50px;
  height:2px;
  background:#e10001;
}
.article__title {
  position:relative;
  padding:0 0 35px 0;
  width:100%;
  border-bottom: 2px solid #cce1f0;
  box-sizing: border-box;
}
.article__title:before {
  content:'';
  display: block;
  position: absolute;
  bottom:0;
  left:0;
  width:90px;
  height:2px;
  background:#e50012;
  transform: translate(0,100%);
}
.article__subtitle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  position: relative;
}
.article__subtitle:before {
  content:'';
  display: inline-block;
  margin-right:10px;
  width:50px;
  height:2px;
  background:#e50012;
}
.service .contents__hero {
  background:url(../img/service/bg-title.jpg) no-repeat;
  background-size: cover;
}
.project-leader ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding:10px 0;
  background:#eaf0f9;
  box-sizing: border-box;
}
.project-leader ul li + li {
  margin-top:10px;
}
.project-leader ul li .number {
  width:90px;
  color:#7fb3da;
  font-size: 8.4rem;
  font-weight: 700;
  text-align: center;
}
.project-leader ul li .data {
  padding:0 20px 0 0;
  width:calc(100% - 90px);
  box-sizing: border-box;
}
.decorated-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.decorated-title .title {
  flex-grow: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  position: relative;
}
.decorated-title .title:before {
  content:'';
  display: inline-block;
  margin-right:10px;
  width:50px;
  height:2px;
  background:#e50012;
}
.decorated-title figure {
  width:39.333%;
}
.team03 .decorated-title figure {
  width:46.1111%;
}
.form .contents__hero {
  background:url(../img/form/bg-title.jpg) no-repeat;
  background-size: cover;
}
.form .form__category {
  padding-bottom:20px;
  font-weight: 500;
  border-bottom:1px solid #c4c4c4;
  box-sizing: border-box;
}
.form .contents__article form label {
  display: block;
}
.form .select__wrapper {
  position: relative;
  height:50px;
  z-index: 1;
}
.form .sl-short {
  width:130px;
}
.form .sl-middle {
  width:30%;
}
.form .it-short {
  width:200px;
}
.form .it-long {
  width:80%;
}
.form .ta-long {
  width:80%;
}
.form .select__wrapper::after {
  position: absolute;
  content: '';
  width: 8px;
  height: 8px;
  right: 10px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  border-bottom: 2px solid #c4c4c4;
  border-right: 2px solid #c4c4c4;
  z-index: -1;
}
.form .select__wrapper select {
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  background: none;
  border: none;
  border-radius: 8px;
  width: 100%;
  height: 100%;
  padding: 0 10px;
  border:1px solid #c4c4c4;
  box-sizing: border-box;
}
.form input[type="text"] {
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  background: none;
  border: none;
  height:50px;
  border:1px solid #c4c4c4;
  background:#efefef;
  box-sizing: border-box;
  border-radius: 8px;
}
.form textarea {
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  background: none;
  border: none;
  height:150px;
  border:1px solid #c4c4c4;
  background:#efefef;
  box-sizing: border-box;
  border-radius: 8px;
}
.form input[type="checkbox"] {
  margin-right:5px;
}
.form__item .flex-container > .flex-container + .flex-container {
  margin-left:20px;
}
.form__item input + .suffix, .form__item .select__wrapper + .suffix  {
  margin-left:10px;
}
.form__item .suffix + input {
  margin-left:10px;
}
.form__item .flex-container.type-radio label + label {
  margin-left:60px;
}
.registration-work .checkbox__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.registration-work .checkbox__container li {
  margin-top:20px;
  width:32%;
}


.registration-work .checkbox__container::after {
  display: block;
  content:"";
  width: 32%;
}
.survey .survey-list li + li {
  margin-top:3.5714vw;
}
.survey .checkbox__container li + li {
  margin-top:20px;
}
.survey .question-webmedia {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: space-between;
}
.survey .question-webmedia li {
  width:32%;
}
.button__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
}
.button__container button {
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  background: none;
  border: none;
  padding:20px 5.9523vw;
  border-radius:999px;
  box-sizing: border-box;
}
.button__container button.btn-accept {
  background:#e50012;
}
.button__container button.btn-decline {
  background:#c4c4c4;
}
.button__container button + button {
  margin-left:5.3571vw;
}
/* --------------------------------------------------------
  ハンバーガーナビ
-------------------------------------------------------- */
#nav-tgl {
  display: none;
}
.nav__bg {
  display: none;
}
.scroll-prevent {
  position: fixed;
  z-index: -1;
  width: 100%;
  height: 100%;
}
.nav-tgl-btn {
  display:none;
  cursor: pointer;
  position: fixed;
  top: 0;
  right: 0;
  margin: 0;
}
.drawer-open {
  z-index: 999;
  width:45px;
  height:50px;
  transition: background .6s, transform .6s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.drawer-open::before,
.drawer-open::after {
  content: "";
}
.drawer-open span,
.drawer-open::before,
.drawer-open::after {
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  right: 20px;
  width: 25px;
  border-bottom: 4px solid #0064aa;
  transition: transform .6s cubic-bezier(0.215, 0.61, 0.355, 1);
  z-index: 1;
}
.drawer-open::before {
  transform: translateY(-10px);
}
.drawer-open::after {
  transform: translateY(10px);
}
.drawer-close {
  z-index: 998;
  width: 100%;
  height: 100%;
  pointer-events: none;
  transition: background .6s;
}
#nav-tgl:checked+.drawer-open {
  transform: translateX(0);
}
#nav-tgl:checked+.drawer-open span {
  transform: scaleX(0);
}
#nav-tgl:checked+.drawer-open::before {
  border-color: #fff;
  transform: rotate(45deg);
}
#nav-tgl:checked+.drawer-open::after {
  border-color: #fff;
  transform: rotate(-45deg);
}
#nav-tgl:checked~.drawer-close {
  pointer-events: auto;
  background: rgba(0, 0, 0, .5);
}
.content-wrapper {
  transition: transform .6s cubic-bezier(0.215, 0.61, 0.355, 1);
}
#nav-tgl:checked~.content-wrapper {
  transform: translateX(-250px);
}
.drawer-menu {
  z-index: 998;
  position: fixed;
  top: 0;
  right: 0;
  padding:60px 25px;
  width:80%;
  height:100%;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  overflow-scrolling: touch;
  background:#0068b6;
  transform: translateX(100%);
  transition: transform .6s cubic-bezier(0.215, 0.61, 0.355, 1);
  box-sizing: border-box;
}
#nav-tgl:checked~.drawer-menu {
  transform: none;
}
.drawer-menu > ul {
  padding-bottom:80px;
  box-sizing: border-box;
}
.drawer-menu .drawer-dropdown {
  width: 100%;
  border-bottom: 1px solid #eee;
  box-sizing: border-box;
}

.drawer-menu .btn__toggle {
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  padding:15px 0;
  width: 100%;
  color:#fff;
  font-size:1.6rem;
  line-height:160%;
  box-sizing: border-box;
}
.drawer-menu .btn__toggle:hover {
  text-decoration: none;
}
.drawer-menu .btn__toggle:after {
  pointer-events: none;
  font-family: "Font Awesome 5 Free";
  content: "\f107";
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  margin-left: 20px;
  font-weight: bold;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  line-height: 1;
}
.drawer-menu .btn__toggle.open:after {
  content: "\f106";
}
.drawer-dropdown-menu {
  margin-left:20px;
  padding-bottom:30px;
}
.drawer-dropdown-menu a {
  color:#fff;
}
.drawer-dropdown-menu > li + li {
  margin-top:25px;
}
.drawer-dropdown-menu > li > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.drawer-dropdown-menu > li > a:before {
  content:'';
  display: inline-block;
  margin-right:5px;
  width:14px;
  height:14px;
  border-radius:999px;
  background:#fff;
}
.drawer-submenu {
  margin-left:20px;
}
.drawer-submenu > li + li {
  margin-top:20px;
}
.drawer-submenu > li > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
}
.drawer-submenu > li > a:before {
  content:'';
  display: inline-block;
  margin-right:5px;
  width:9px;
  height:2px;
  background:#fff;
}
.drawer-banner {
  padding-top:25px;
}
.drawer-banner .btn-inquiry {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  margin-right:auto;
  margin-left:auto;
  padding: 0;
  width:220px;
  height:54px;
  color: #e50012;
  font-size: 1.5rem;
  border-radius: 999px;
  background:#fff;
  box-sizing: border-box;
}
.drawer-banner .btn-inquiry:before {
  width: 38px;
  height: 38px;
}
.drawer-banner .btn-language {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  margin-top:15px;
  margin-right:auto;
  margin-left:auto;
  padding: 0;
  width:220px;
  height:54px;
  color: #0068b6;

  font-size: 1.5rem;
  border-radius: 999px;
  background:#fff;
  box-sizing: border-box;
}
.drawer-banner .btn-language:after {
  content:'';
  display:block;
  position: absolute;
  top:50%;
  right:35px;
  width:5px;
  height:5px;
  border-radius: 999px;
  background: #0068b6;
  transform: translate(0,-50%);
}
/* --------------------------------------------------------
  ページTOP
-------------------------------------------------------- */
#page-top {
  position: fixed;
  bottom: 100px;
  right: 60px;
  z-index:99;
}
#page-top a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  cursor:pointer;
  width:80px;
  height:80px;
  color:#fff;
  font-size:1.4rem;
  line-height:110%;
  font-weight: bold;
  background:rgba(244,6,4,0.8);
  border-radius: 999px;
  text-align: center;
  text-decoration: none;
  transition: 0.5s;
}
#page-top a:before {
  pointer-events: none;
  font-family: "Font Awesome 5 Free";
  content: "\f077";
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  margin-top:-8px;
  margin-bottom: 2px;
  font-weight: bold;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
}
#page-top a:hover {
  text-decoration: none;
}
@media screen and (max-width: 540px) {
  #page-top {
    bottom: 20px;
    right: 20px;
  }
  #page-top a {
    width:60px;
    height:60px;
    font-size:1.2rem;
  }
}
/* --------------------------------------------------------
	responsive
-------------------------------------------------------- */
@media screen and (min-width: 1921px) {
}
@media screen and (max-width: 1680px) {
  header .header__inner {
    padding:0 180px 0 20px;
    width:100%;
    min-width: auto;
  }
  header .header__inner .globalnavi a + a, header .header__inner .globalnavi a + div {
    margin-left: 20px;
  }
  header .btn-inquiry {
    padding: 20px 20px 20px 0;
    width:180px;
    text-align: right;
  }
}
@media screen and (max-width: 1440px) {
  .mt-20 {
    margin-top:20px;
  }
  .mt-15 {
    margin-top:15px;
  }
  .mt-10 {
    margin-top:10px;
  }
  .w-1360 {
    width:calc(100% - 40px);
    min-width: auto;
  }
}
@media screen and (max-width: 1360px) {
  .monitor .swiper-slide {
    padding: 30px 30px;
  }
  footer .btn-inquiry {
    width: 100%;
  }
}
@media screen and (max-width: 1280px) {
  .w-1200 {
    width:calc(100% - 40px);
    min-width:auto;
  }
}
@media screen and (max-width: 1279px) {
  footer .inner__top .flex-container .inner__left {
    width: 260px;
  }
  footer .inner__top .flex-container .inner__right {
    width: calc(100% - 260px);
  }
  .w-900 {
    width: 80%;
    min-width: auto;
  }
}
@media screen and (max-width: 1120px) {
}
@media screen and (max-width: 960px) {
  .nav-tgl-btn {
    display: block;
  }
  .globalNavi {
    display: none;
  }
  .fs-48 {
    font-size: 2.8rem;
  }
  .fs-40 {
    font-size: clamp(2.8rem, 1.944rem + 1.99vw, 3.6rem); /*834-431 36-28*/
  }
  .fs-36 {
    font-size:1.8rem;
  }
  .fs-32 {
    /*font-size: clamp(2.4rem, 1.9568rem + 0.99vw, 2.8rem);*/ /*834-431 28-24*/
    font-size:2.0rem;
  }
  .fs-28 {
    /*font-size: clamp(2.0rem, 1.5728rem + 0.99vw, 2.4rem);*/ /*834-431 24-20*/
   font-size:1.8rem;
  }
  .fs-24 {
    /*font-size: clamp(1.8rem, 1.5856rem + 0.5vw, 2.0rem);*/ /*834-431 20-18*/
    font-size:1.8rem;
  }
  .fs-22 {
    font-size: clamp(1.8rem, 1.5856rem + 0.5vw, 2.0rem); /*834-431 20-18*/
  }
  .fs-20 {
    font-size:1.8rem;
  }
  .fs-18 {
    font-size:1.8rem;
  }
  .fs-16 {
    font-size:1.6rem;
  }
  .fs-14 {
    font-size:1.4rem;
  }
  .mt-200 {
    margin-top:100px;
  }
  .mt-160 {
    margin-top:80px;
  }
  .mt-150 {
    margin-top:75px;
  }
  .mt-120 {
    margin-top:60px;
  }
  .mt-100 {
    margin-top:60px;
  }
  .mt-90 {
    margin-top:40px;
  }
  .mt-80 {
    margin-top:40px;
  }
  .mt-60, .survey-list li + li {
    margin-top:40px;
  }
  .mt-40 {
    margin-top:40px;
  }
  .mt-30 {
    margin-top:30px;
  }
  .mb-40 {
    margin-bottom:30px;
  }
  .lh-200 {
    line-height:1.8;
  }
.pc{display:none;}
.sp{display:block;}
  body {
    padding-top:60px;
  }
  .loader__inner img {
    width: 60px;
    height: auto;
  }
  header {
    height: 60px;
  }
  header .header__inner {
    padding: 0 0 0 20px;
  }
  header .header__inner .globalnavi {
    margin-right:65px;
  }
  header .header__inner .globalnavi > a, header .megamenu, header .btn__language {
    display: none;
  }
  header .main-logo {
    width: 220px;
    height: auto;
    margin-top:10px;
  }
  header .header__inner .globalnavi a + a, header .header__inner .globalnavi a + div {
    margin-left: 0;
  }
  header .header__inner .globalnavi .btn-inquiry {
    padding: 0;
    width:auto;
    border: none;
  }
  header .header__inner .globalnavi .btn-inquiry span {
    display:none;
  }
  header .header__inner .globalnavi .btn-inquiry:before {
    content: '';
    display: block;
    position: relative;
    top: auto;
    left: auto;
    width: 35px;
    height: 35px;
    background: url(../img/common/ico-btn-inquiry.svg);
    background-size: cover;
    aspect-ratio: 1 / 1;
    transform: translate(0, 0);
  }
  .hero {
    padding: 4.6875vw 0vw 15.625vw;
}
  .hero__inner {
    width:100%;
  }
  .hero .inner__top {
    flex-wrap: wrap;
    width: calc(100% - 40px);
    margin-right:auto;
    margin-left:auto;
  }
  .hero .inner__top .inner__left, .hero .inner__top .inner__right {
    width: 100%;
  }
  .hero .inner__top .inner__left {
    order: 1;
    margin-top:30px;
  }
  .hero .lead__wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    align-items: center;
  } 
  .hero .inner__top .inner__right {
    order: 0;
    text-align: center;
  }
  .hero .inner__top .inner__right img {
    margin-top:2em;
    width:55%;
    max-width:340px;
    min-width:200px;
  }
  .hero .inner__bottom .btn-manufacturer:after, .hero .inner__bottom .btn-worker:after {
    width: 50px;
  }
  .hero__inner .hero__logo {
    width:272px;
  }
  .hero .lead__wrapper .hero__btn {
    width:100%;
  }
  .hero .lead__wrapper .hero__btn a {
    display: block;
    margin-right:auto;
    margin-left:auto;
    padding: 20px;
    width:60%;
    text-align: center;
  }
  .hero .inner__bottom {
    margin-top:75px;
  }
  .section__template01 {
    padding: 60px 0;
  }
  .flex-box a {
    width:100%;
    }
    
  .about .inner__top {
    position: relative;
    width: 100%;
    height: auto;
    background: url(../img/top/bg-about01.png) no-repeat;
    background-size: 100% 100%;
    aspect-ratio: auto;
    z-index: 1;
    overflow: hidden;
  }
  .about .inner__top:after {
    left: 0%;
  }
  .about .inner__top .flex-container {
    flex-wrap: wrap;
  }
  .about .inner__top .about__left {
    width: 100%;
    text-align: center;
  }
  .about .inner__top .about__left:before {
    left: 50%;
    width: 400px;
    transform: translate(-50%, -6%);
  }
  .about .inner__top .about__right {
    margin-top:230px;
    width: 100%;
    text-align: center;
  }
  .about .inner__top .about__right figure {
    margin-right:auto;
    margin-left:auto;
    width: 256px;
  }
  .about .inner__top .about__lead {
    display:inline-block;
    text-align: left;
  }
  .about .inner__top .about__lead .about__en {
    font-size: 1.45rem;
  }
  .about .inner__top .about__lead .about__ja {
    font-size: 1.4rem;
  }
  .about .inner__top .about__right .about__lead:after {
    height: 110%;
  }
  .about .inner__bottom .about__catchcopy {
    font-size: 1.9rem;
    text-align: center;
  }
  .about .inner__bottom .about__catchcopy .about__en {
    font-size: 2.7rem;
  }
  .about .inner__bottom .about__catchcopy .about__ja {
    font-size: 2.0rem;
  }
  .about .inner__bottom .about__btn {
    text-align: center;
  }
  .about .inner__bottom .about__btn a {
    display: block;
    margin-right:auto;
    margin-left:auto;
    padding: 20px;
    width:60%;
  }
  .specialist .section__title .main {
    font-size: 3.2rem;
  }
  .specialist .specialist__btn {
    margin-top:70px;
    text-align: center;
  }
  .specialist .flex-container {
    flex-direction: column;
  }
  .specialist .flex-container figure:nth-of-type(1), .specialist .flex-container figure:nth-of-type(2), .specialist .flex-container figure:nth-of-type(3) {
    width: 100%;
  }
  .specialist .flex-container figure + figure {
    margin-top:70px;
  }
  .specialist .specialist__btn a {
    display: block;
    margin-right:auto;
    margin-left:auto;
    padding: 20px;
    width:60%;
    transform: translate(0, 0);
  }
  .specialist .specialist__btn a:before {
    width: 60px;
  }


  .performance .performance__btn {
    margin-top:60px;
  }
  .performance .performance__btn .btn__inner {
    display:block;
  }
  .performance .performance__btn a {
    display: block;
    margin-right:auto;
    margin-left:auto;
    padding: 20px;
    width:60%;
    transform: translate(0, 0);
  }
  .performance .performance__btn a + a {
    margin-top:40px;
    margin-left: auto;
  }
  .performance .performance__btn a:before {
    width: 60px;
  }
  .monitor__title {
    margin-right:auto;
    margin-left:auto;
    padding: 40px 20px;
    width: calc(100% - 27%);
    border-right:1px solid #3383bb;
    border-left:1px solid #3383bb;
    border-bottom: none;
    box-sizing: border-box;
  }
  .monitor .swiper {
    width: calc(100% - 27%);
    border-right:1px solid #3383bb;
    border-left:1px solid #3383bb;
  }
  .monitor .swiper:before {
    content:none;
  }
  .monitor .swiper:after {
    content:none;
  }
  .monitor .swiper-slide {
    padding: 0 20px 40px;
  }
  .swiper-button-next, .swiper-rtl .swiper-button-prev {
    right: calc(13.5% / 2);
  }
  .swiper-button-prev, .swiper-rtl .swiper-button-next {
    left: calc(13.5% / 2);
  }
  .swiper-button-next:after, .swiper-button-prev:after {
    font-size: 3.2rem;
  }
  .monitor .swiper-slide figure {
    width: 73px;
  }
  .monitor .swiper-slide figure + p {
    margin-top:10px;
  }
  .information__title {
    font-size: 2.6rem;
  }
  .information .news-list {
    width:calc(100% - 40px);
  }
  .information .news-list li {
    flex-direction: column;
  }
  .information .news-list li .text {
    margin-left: 0;
  }
  .information .information__btn {
    margin-left:auto;
    margin-right:auto;
    width:calc(100% - 40px);
  }
  .information .information__btn a {
    display: block;
    margin-right:auto;
    margin-left:auto;
    padding: 20px;
    width:60%;
  }
  footer .inner__top .flex-container {
    flex-direction: column;
    width:100%;
  }
  footer .inner__top .flex-container .inner__left {
    padding: 40px 10px;
    width:100%;
  }
  footer .inner__top .flex-container .inner__left figure {
    margin-right: auto;
    margin-left: auto;
    width:304px;
  }
  footer .btn-inquiry {
    width: 60%;
  }
  footer .inner__top .flex-container .inner__right {
    padding: 40px 20px;
    width:100%;
  }
  footer .inner__top .flex-container .inner__right:before {
    content: none;
  }
  footer .footer__menulist .menu__title {
    font-size:1.8rem;
  }
  footer .footer__menu {
    font-size:1.4rem;
  }
  footer .footer__menulist {
    flex-direction: column;
    justify-content:flex-start;
  }
  footer .footer__menulist > li {
    width: 100%;
  }
  footer .footer__menulist > li + li {
    margin-top: 40px;
  }
  footer .inner__bottom {
    padding: 20px 0;
  }
  footer .inner__bottom .inner__left .flex-container {
    flex-wrap: wrap;
    margin-top:-15px;
    margin-left:-20px;
  }
  footer .inner__bottom .inner__left a, footer .inner__bottom .inner__left a + a {
    margin-top:15px;
    margin-left: 20px;
  }
  footer .inner__bottom .inner__right .flex-container p {
    display:none;
  }
  footer .sp-copyright {
    display: block;
    margin-right:auto;
    margin-left:auto;
    width:calc(100% - 40px);
    font-size: 1.0rem;
  }
  .contents__hero {
    aspect-ratio:25/23;
  }
  .service .contents__hero {
    padding:40px 0;
    background:url(../img/service/bg-title-sp.jpg) no-repeat;
    background-size: cover;
  }
  .contents__title .main {
    margin-top:15px;
  }
  .w-900 {
    width: calc(100% - 40px);
  }
  .project-leader ul li .number {
    width: 60px;
    font-size: 4.2rem;
  }
  .project-leader ul li .data {
    width: calc(100% - 60px);
  }
.decorated-title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
  }
.decorated-title figure {
    margin-top:30px;
    margin-right:auto;
    margin-left:auto;
    width: 47.2%;
  }
.team03 .decorated-title figure {
    width: 55.3333%;
  }
  .form .contents__hero {
    padding:40px 0;
    background:url(../img/form/bg-title-sp.jpg) no-repeat;
    background-size: cover;
    aspect-ratio:75/71;
  }
  .form .form__category {
    font-size:2.1rem;
  }
  .form .it-long, .form .ta-long {
    width: 100%;
  }
  .form__item.mt-50 {
    margin-top:60px;
  }
  .form__item.birth > .flex-container {
    flex-direction: column;
  }
  .form__item.birth > .flex-container > .flex-container + .flex-container {
    margin-top:20px;
    margin-left: 0;
  }
  .registration-work .checkbox__container li {
    margin-top: 30px;
    width: 48%;
  }
  .form .button__container {
    flex-direction: column;
    align-items: center;
  }
  .button__container button {
    width:70%;
    font-size:2.1rem;
  }
  .button__container button + button {
    margin-top:35px;
    margin-left: 0;
  }
}
@media screen and (max-width: 768px) {
}
@media screen and (max-width: 640px) {
  .hero .lead__wrapper .hero__btn a, .about .inner__bottom .about__btn a, .specialist .specialist__btn a, .performance .performance__btn a, .information .information__btn a {
    width: 80%;
  }
  footer .btn-inquiry {
    width: 78%;
  }
  
}
@media screen and (max-width: 540px) {
}
@media screen and (max-width: 430px) {
  .hero .lead__wrapper .hero__btn a, .about .inner__bottom .about__btn a, .specialist .specialist__btn a, .performance .performance__btn a, .information .information__btn a {
    width: 100%;
  }
  footer .btn-inquiry {
    width: 96%;
  }
}
@media screen and (max-width: 375px) {

}
/* --------------------------------------------------------
	animation
-------------------------------------------------------- */
.obj__animation--fadeup {
  opacity:0;
  transform: translate(0,200px);
}
.loaded .obj__animation--fadeup.onScreen {
  opacity:1;
  transform: translate(0,0);
  transition: 1.0s;
}
.loaded .obj__animation--fadeup.firstview.onScreen {
  transition-delay: 1.0s;
}
.loaded .obj__animation--fadeup.onScreen + .obj__animation--fadeup.onScreen {
  transition-delay: 0.25s;
}
.loaded .obj__animation--fadeup.onScreen + .obj__animation--fadeup.onScreen  + .obj__animation--fadeup.onScreen {
  transition-delay: 0.5s;
}
.loaded .obj__animation--fadeup.onScreen + .obj__animation--fadeup.onScreen  + .obj__animation--fadeup.onScreen + .obj__animation--fadeup.onScreen {
  transition-delay: 0.75s;
}
.loaded .obj__animation--fadeup.onScreen + .obj__animation--fadeup.onScreen  + .obj__animation--fadeup.onScreen + .obj__animation--fadeup.onScreen + .obj__animation--fadeup.onScreen {
  transition-delay: 1.0s;
}
.loaded .section__title .obj__animation--fadeup.onScreen + .obj__animation--fadeup.onScreen {
  transition-delay: 0s;
}
/*.loaded .obj__animation--fadeup.firstview.onScreen + .obj__animation--fadeup.firstview.onScreen {
  transition-delay: 1.0s;
}*/
.loaded .hero__lead.obj__animation--fadeup.firstview.onScreen {
  transition-delay: 1.25s;
}
.loaded .hero__btn.obj__animation--fadeup.firstview.onScreen {
  transition-delay: 1.5s;
}
.loaded .hero .inner__right .obj__animation--fadeup.firstview.onScreen {
  transition-delay: 1.75s;
}
.loaded .btn-manufacturer.obj__animation--fadeup.firstview.onScreen {
  transition-delay: 1.0s;
}
.loaded .btn-worker.obj__animation--fadeup.firstview.onScreen {
  transition-delay: 2.25s;
}
.contents__article section > * {
  opacity:0;
  transform: translate(0,200px);
}
.contents__article section > *.onScreen {
  opacity:1;
  transform: translate(0,0);
  transition: 1.0s;
}

@keyframes opacity {
  0% {
    opacity: 0.1;
  }
  50% {
    opacity: 1.0;
  }
  100% {
    opacity: 0.1;
  }
}
@keyframes scaleUp {
  0% {
    transform: translate(-50%, 0) scale(1.0);
  }
  50% {
    transform: translate(-50%, 0) scale(1.2);
  }
  100% {
    transform: translate(-50%, 0) scale(1.0);
  }
}
@keyframes fadeInFromTop {
  0% {
    opacity: 0;
    transform: translateY(-100%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.animated {
  animation-duration: 0.5s;
  animation-fill-mode: both;
  animation-timing-function: ease-in-out;
}
.fadeInFromTop {
  animation-name: fadeInFromTop;
}