@charset "utf-8";

/* reset */
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,code,form,fieldset,legend,input,textarea,p,blockquote,th,td{margin:0;padding:0;}
table{border-collapse:collapse; width:100%;}
fieldset,img{border:0; vertical-align:top;}
address,caption,cite,code,dfn,em,th,var{font-style:normal;font-weight:normal;}
li{list-style:none;}
caption,th{text-align:left;}
h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:400;}
q:before,q:after{content:'';}
abbr,acronym{border:0;font-variant:normal;}
sup{vertical-align:text-top;}
sub{vertical-align:text-bottom;}
input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit;}
input,textarea,select{*font-size:100%;}
legend{color:#000;}
del,ins{text-decoration:none;}
section{display:block;}
figure,figcaption{margin:0; padding:0;}
main {display:block;padding:0;margin:0;
}
.cf:after{content:".";display:block;height:0;clear:both;visibility:hidden;font-size: 0.1em;}
.cf	{display:inline-block;zoom:1;}
ul.col {
	letter-spacing:-0.5em;
}
ul.col li {
	display:inline-block;
	vertical-align:top;
	letter-spacing:0.01em;
}
/* \*/
* html .cf	{height:1%;}
.cf	{display:block;}
/* */
a:link,a:visited {
    backface-visibility:hidden;
-webkit-backface-visibility: hidden;  
	
	text-decoration:none;
	color:var(--c-bsc);
    transition:ease-in-out .2s;
-moz-transition:ease-in-out .2s;
-webkit-transition:ease-in-out .2s;
-o-transition:ease-in-out .2s;
}
a:hover {
    outline:none;
}
a:focus, *:focus { outline:none; }
img {
	max-width: 100%;
    height: auto;
}

.dbl-spinner {
    position: fixed;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: transparent;
    border: 4px solid transparent;
    border-top: 4px solid #f3f6fa;
    border-left: 4px solid #f3f6fa;
    -webkit-animation: 2s spin linear infinite;
    animation: 2s spin linear infinite;
    z-index: 9;
    left: 50%;
    margin-left: -24px;
    top: 50%;
    margin-top: -24px;
}
                                      
.dbl-spinner:nth-child(2) {
    border: 4px solid transparent;
    border-right: 4px solid #0077cb;
    border-bottom: 4px solid #0077cb;
    -webkit-animation: 1s spin linear infinite;
    animation: 1s spin linear infinite;
}

@-webkit-keyframes spin {
    from {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    to {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}
          
@keyframes spin {
    from {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    to {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

html {
    height: 100%;
}
:root {
    --f-jp: "Noto Sans JP", serif;
    --f-en: "Montserrat", sans-serif;
    --f-min: "Noto Serif JP", serif;
    --f-en2: "Cinzel", serif;
    --c-bsc:#000;
    --c-blue:#0b318f;
    
    
}
.com-btn {
    border: #cfdde3 1px solid;
    padding: 18px;
    display: block;
    text-align: center;
    max-width: 340px;
    margin: auto;
    position: relative;
    font-weight: 500;
    border-radius: 40px;
    letter-spacing: 0.09em;
    font-size: 17px;
}
br.sp-only {
    display: none;
}
.fade {
    transition: opacity 1.5s cubic-bezier(0.215, 0.61, 0.355, 1), transform .8s cubic-bezier(0.215, 0.61, 0.355, 1),filter 1s cubic-bezier(0.215, 0.61, 0.355, 1);

    transform: translateY(40px);
    opacity: 0;
    -ms-filter: blur(4px);
  filter: blur(4px);
}
.fade.anime {
    transform: translateY(0px);
    opacity: 1;
    ms-filter: blur(0px);
  filter: blur(0px);
}
.fade-left {
    transition: opacity 1.5s cubic-bezier(0.215, 0.61, 0.355, 1), transform .8s cubic-bezier(0.215, 0.61, 0.355, 1),filter 1s cubic-bezier(0.215, 0.61, 0.355, 1);

    transform: translateX(-40px);
    opacity: 0;
    -ms-filter: blur(4px);
  filter: blur(4px);
}
.fade-left.anime {

    transform: translateX(0px);
    opacity: 1;
    -ms-filter: blur(0px);
  filter: blur(0px);
}
.fade-right {
    transition: opacity 1.5s cubic-bezier(0.215, 0.61, 0.355, 1), transform .8s cubic-bezier(0.215, 0.61, 0.355, 1),filter 1s cubic-bezier(0.215, 0.61, 0.355, 1);
    transform: translateX(40px);
    opacity: 0;
    -ms-filter: blur(4px);
    filter: blur(4px);
}
.fade-right.anime {
    transform: translateX(0px);
    opacity: 1;
    -ms-filter: blur(0px);
    filter: blur(0px);
}
#overlay {
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background-color: rgba(58,62,51,0.74);
    z-index: 6;
    display: none;
}
body {
    font-family:var(--f-jp);
    font-size: 16px;
    line-height: 2;
    letter-spacing: normal;
    color: var(--c-bsc);
    word-wrap: break-word;
    font-weight: 500;
    position: relative;
    text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%; /* Safari */
}
.header__site-id {
    position: absolute;
    z-index: 1;
    left: 50px;
    right: 0;
    top: 50px;
}
.header__site-id img {
    width: 250px;
}
.main-visual {
    display: flex;
    align-items: center;
    margin-bottom: 250px;
    height: 100vh;
    overflow: hidden;
}
.main-visual__logo {
    width: 45%;
    padding-right: 5%;
    padding-left: 5%;
    flex-shrink: 0;
    text-align: center;
    
    
}


.main-visual__logo img {
    width: 500px;
}
.main-visual__logo #lottie {
    max-width: 650px;
    margin-left: auto;
    margin-right: auto;
    transition: transform 1.7s cubic-bezier(0.65, 0, 0.35, 1);
    transform: translateX(50%);
}
.anime .main-visual__logo #lottie{
    transform: translateX(0%);
}
.main-visual__txt {
    font-family: var(--f-min);
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0.06em;
    line-height: 2.3;
}
.main-visual__txt h2 {
    font-weight: 700;
    line-height: 1.3;
    font-size: 56px;
    letter-spacing: 0.06em;
    margin-bottom: 50px;
}

.main-visual__txt h2,
.main-visual__txt p{
    transition: opacity 1.9s cubic-bezier(0.215, 0.61, 0.355, 1), transform 1.5s cubic-bezier(0.215, 0.61, 0.355, 1),filter 1s cubic-bezier(0.215, 0.61, 0.355, 1);

    transform: translateY(40px);
    opacity: 0;
    -ms-filter: blur(4px);
  filter: blur(4px);
}
.main-visual__txt h2.anime,
.main-visual__txt p.anime{
    transform: translateY(0px);
    opacity: 1;
    ms-filter: blur(0px);
  filter: blur(0px);
}


.second-ttl {
    line-height: 1.3;
    font-weight: 700;
    margin-bottom: 130px;
}
.second-ttl span {
    font-family: var(--f-en);
    font-weight: 600;
    font-size: 88px;
    display: block;
}
.bg-blue {
    position: absolute;
    z-index: -1;
}
.history {
    padding-left: 7%;
    padding-right: 7%;
    position: relative;
    padding-top: 50px;
    margin-bottom: 250px;
    padding-bottom: 150px;
}
.history__txt {
    text-align: right;
    margin-bottom: 80px;
    margin-top: -70px;
}
.history__icon {
    position: absolute;
    z-index: 1;
    opacity: 0.4;
}
.history__icon--pos01 {
    left: 0;
    top: -100px;
}
.history__icon--pos02 {
    right: 50%;
    margin-right: 50px;
    bottom: 0;
}
.history:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -150px;
    background-image: url("../../images/bg_history.png");
    background-repeat: no-repeat;
    background-position: center bottom;
    background-size: 100% 100%;
    z-index: -1;
    height: 500px;
}
.history:after {
    content: "";
    position: absolute;
    left: 0;
    top: -50px;
    bottom: 0;
    right: 50%;
    background-color: var(--c-blue);
    z-index: -1;
    background-image:url("../../images/noise.png");
    animation: noise_anime 1s steps(10) infinite;
}
@keyframes noise_anime {
	from { background-position: 0 0; }
	to { background-position: 123px 456px; }
}
.history__num {
    position: absolute;
    z-index: 1;
    font-family: var(--f-en2);
    font-size: 140px;
    line-height: 1;
    top: 120px;
    color: #fff;
    text-align: left;
    right: 55%;
    width: 350px;
}
.history .second-ttl {
    text-align: right;
}
.history__movie img {
    width: 100%;
    opacity: 0.75;
    transition: ease-in-out .3s;
}
.history__movie a:hover img {
    opacity: 0.8;
}
.history__movie a {
    display: block;
    position: relative;
    background-color: #000;
}
.history__movie a:after {
    width: 80px;
    height: 80px;
    border: 2px #fff solid;
    border-radius: 50%;
    content: "";
    position: absolute;
    z-index: 2;
    left: 50%;
    top: 50%;
    margin-top: -40px;
    margin-left: -40px;
    background-image: url("../../images/arrow.svg");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 18px;
    transition: ease-in-out .3s;
}
.history__movie a:hover:after {
    transform: scale(1.1);
}
.bg-blue svg {
    width: 100%;
    height: 100%;
    position: relative;
}
.bg-blue svg mask {
    width: 100%;
    height: 100%;
}
.message {
    padding-left: 7%;
    padding-right: 7%;
    margin-bottom: 300px;
}
.message h2 {
    text-align: center;
}
.message__flex {
    display: flex;
}
.message__img {
    width: 35%;
    flex-shrink: 0;
    padding-right: 10%;
}
.message__txt h3 {
    font-family: var(--f-min);
    font-weight: 700;
    font-size: 35px;
    margin-bottom: 60px;
}
.message__name {
    text-align: right;
    margin-top: 60px;
}
.employees {
    padding-right: 7%;
    position: relative;
    padding-top: 150px;
    padding-bottom: 150px;
    display: flex;
    align-items: center;
}
.employees__icon {
    position: absolute;
    z-index: 1;
    opacity: 0.4;
}
.employees__icon--pos01 {
    right: 0;;
    bottom: 50px;
}
.employees__icon--pos02 {
    left: 25%;
    top: -50px;
    bottom: 0;
}
.employees:after {
    content: "";
    background-color: var(--c-blue);
    position: absolute;
    z-index:-1;
    right: 0;
    top: 0;
    bottom: 0;
    left: 15%;
    background-image:url("../../images/noise.png");
    animation: noise_anime 1s steps(10) infinite;
}
.employees__img {
    flex-shrink: 0;
    width: 52%;
    margin-right: 7%;
    position: relative;
    z-index: 2;
}
.employees__txt {
    color: #fff;
    position: relative;
    z-index: 2;
}
.employees__icon-square {
    position: absolute;
    z-index: 1;
    left: 25%;
    width: 20px;
    height: 350px;
    background-color: rgba(238,238,238,0.39);
    bottom: -100px;
    opacity: 0.4;
}
.employees__txt h2 {
    font-family: var(--f-min);
    font-weight: 600;
    font-size: 35px;
    margin-bottom: 20px;
}
.infographics {
    padding-left: 7%;
    padding-bottom: 250px;
    padding-right: 7%;
    overflow: hidden;
    background-image: url("../../images/bg_info.png");
    background-repeat: no-repeat;
    background-position: right top;
    padding-top: 250px;
}
.infographics__slide {
position: relative;
}
.infographics__item {
    background-color: var(--c-blue);
    color: #fff;
    text-align: center;
    padding: 60px;
    box-sizing: border-box;
    background-image:url("../../images/noise.png");
    animation: noise_anime 1s steps(10) infinite;
}
.infographics__item h3 {
    font-weight: 700;
    font-family: var(--f-min);
  font-weight: 600;
    font-size: 30px;
    display: inline-block;
    border-bottom: #fff 1px solid;
    margin-bottom: 30px;
}
.infographics__item h3 sup {
    font-size: 50%;
}
.infographics__item p {
    text-align: left;
}
.infographics__item p span {
    display: block;
    font-size: 75%;
    margin-top: 10px;
}
.infographics__num {
    font-weight: 700;
    font-size: 30px;
    margin-bottom: 15px;
}
.infographics__eng {
    font-family: var(--f-en2);
    writing-mode: vertical-rl;
-ms-writing-mode: tb-rl;
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0.1em;
    position: absolute;
    z-index: 1;
    left: 25px;
    top: 25px;
    line-height: 1;
}
.infographics__num span {
    font-family: var(--f-en2);
    font-size:110px;
    line-height: 1;
    margin-left: 5px;
    margin-right: 5px;
}
.infographics .swiper-button-next, .infographics .swiper-button-prev {
    width: 80px;
    height: 80px;
    margin-top: -40px;
    background-color: #fff;
    border-radius: 50%;
    background-image: url("../../images/arrow_prev.svg");
    background-size: 20px;
    background-repeat: no-repeat;
    background-position: center center;
    box-shadow: 0px 0px 16px 1px rgba(0, 0, 0, 0.11);
}
.infographics .swiper-button-next:after,
.infographics .swiper-button-prev:after{
    display: none;
}
.infographics .swiper-button-next svg,
.infographics .swiper-button-prev svg{
    display: none;
}
.infographics .swiper-button-prev {
    transform: scale(-1, 1);
    left: -40px;
}
.infographics .swiper-button-next {
    right: -40px;
}
.swiper-button-next.swiper-button-disabled, .swiper-button-prev.swiper-button-disabled {
  opacity: 0 !important;
}
.footer {
    background-color: var(--c-blue);
    color: #fff;
    text-align: center;
    padding-left: 7%;
    padding-right: 7%;
    padding-top: 80px;
    padding-bottom: 80px;
    background-image:url("../../images/noise.png");
    animation: noise_anime 1s steps(10) infinite;
}
.footer__logo img {
    width: 200px;
    margin-bottom: 50px;
}
.footer__site-id img {
    width: 220px;
}
.footer__copy {
    font-size: 14px;
    margin-top: 40px;
}
br.sp-only {
        display: none;
    }
@media screen and (max-width: 1080px) {
html {
    font-size: calc(100vw / 37.5);
  }
body {
  font-size: 1.4rem;
  line-height: 1.9;
}
    br.sp-only {
        display: inherit;
    }
.main-visual {
  display: block;
  align-items: center;
    padding-left: 8%;
    padding-right: 8%;
    margin-bottom: 8rem;
    height: auto;
}
.main-visual__logo img {
  width: 23rem;
    
}
.main-visual__logo #lottie {
  max-width: 650px;
  transform: translateX(0%);
}
.header__site-id {
  position: static;
    text-align: center;
    padding-top: 3rem;
    margin-bottom: 4rem;
}

.header__site-id img {
  width: 18rem;
}
.main-visual__logo {
  width: 100%;
  padding-right: 0%;
    padding-left: 0;
    margin-bottom: 3rem;
}
.main-visual__txt h2 {
  font-size: 2.3rem;
  margin-bottom: 3rem;
}
.main-visual__txt {
  font-size: 1.4rem;
}
.second-ttl span {
  font-size: 4.5rem;
    line-height: 1.1;
    margin-bottom: 1rem;
}
.second-ttl {
  margin-bottom: 6rem;
}
.history {
    padding-bottom: 0;
    padding-top: 0;
    margin-bottom: 11rem;
}
.history__txt {
  text-align: center;
  margin-bottom: 10rem;
  margin-top: -8rem;
}
.history__num {
    position:static;
    font-size: 6rem;
    width: auto;
    margin-bottom: 1rem;
}
.history::after {
    right: 7rem;
    top: 17rem;
    bottom: 8rem;
}
.history .second-ttl {
    margin-bottom: 11rem;
    text-align: center;
  }
.history__movie a::after {
  width: 6rem;
  height: 6rem;
  margin-top: -3rem;
  margin-left: -3rem;
  background-size: 2rem;
}
.history::before {
  bottom: -8rem;
  height: 20rem;
}
.history__icon {
  left: 7rem;
  top: 16rem;
  width: 21rem;
}
.history__icon--pos02 {
  display: none;
}
.message {
    padding-left: 8%;
    padding-right: 8%;
    margin-bottom: 13rem;
}
.message__flex {
  display: block;
}
.message__img {
    width: 100%;
    flex-shrink: 0;
    padding-right: 0%;
    text-align: center;
    margin-bottom: 4rem;
}
.message__img img {
    width: 22rem;
}
.message__txt h3 {
  font-size: 2rem;
  margin-bottom: 3rem;
}
.message__name {
    text-align: right;
    margin-top: 4rem;
    margin-left: auto;
    width: 20rem;
}
.employees {
  padding-right: 0;
  display: block;
    padding-top: 0;
    padding-bottom: 11rem;
    overflow: hidden;
}
.employees__img {
  width: auto;
    margin-left: 8%;
    margin-right: 8%;
    margin-bottom: 2rem;
}
.employees::after {
  right: 0%;
  left: 0%;
    top: 12rem;
}
.employees__txt {
    padding-left: 8%;
    padding-right: 8%;
}
.employees__txt h2 {
  font-size: 2.3rem;
  margin-bottom: 1rem;
}
.employees__icon--pos01 {
  right: 2rem;
  bottom: 0;
  width: 22rem;
  top: inherit;
}
.employees__icon--pos02 {
  left: -1%;
  top: 17rem;
  bottom: inherit;
  width: 20rem;
    display: none;
}
.infographics {
  padding-left: 8%;
  padding-bottom: 10rem;
  padding-right: 8%;
  padding-top: 10rem;
    background-size: 35rem;
}
.infographics__item {
  padding: 2rem;
}
.infographics__item h3 {
  font-size: 2rem;
}
.infographics__num {
  font-size: 2.2rem;
  margin-bottom: 1rem;
}
.infographics__num span {
  font-size: 7rem;
}
.infographics .swiper-button-next,
.infographics .swiper-button-prev {
  width: 5rem;
  height: 5rem;
  margin-top: -2.5rem;
  background-size: 1.5rem;
}
.infographics .swiper-button-next {
  right: -1rem;
}
.infographics .swiper-button-prev {
  left: -1rem;
}
.infographics__eng {
  font-size: 1.1rem;
  left: 1.5rem;
  top: 1.5rem;
}
.footer {
  padding-top: 6rem;
  padding-bottom: 6rem;
}
.footer__logo img {
  width: 13rem;
  margin-bottom: 4rem;
}
.footer__site-id img {
  width: 17rem;
}
.footer__copy {
  font-size: 1.2rem;
  margin-top: 2rem;
}
}











