@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Plus+Jakarta+Sans:ital,wght@0,700;0,800;1,500;1,800&display=swap');

/* --------------------------------------------------
 normalize
--------------------------------------------------- */
button,hr,input{overflow:visible;padding:0;}progress,sub,sup{vertical-align:baseline;}[type=checkbox],[type=radio],legend{box-sizing:border-box;padding:0;}html{line-height:1;-webkit-text-size-adjust:100%}body{margin:0}details,main{display:block}h1{margin:.67em 0;font-size:2em;}hr{box-sizing:content-box;height:0}code,kbd,pre,samp{font-size:1em;font-family:monospace,monospace;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:normal;}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{margin:0;font-size:100%;font-family:inherit;line-height:1;}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{padding:0;border-style:none;}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:ButtonText dotted 1px}fieldset{padding:.35em .75em .625em}legend{display:table;max-width:100%;color:inherit;white-space:normal}textarea{overflow:auto}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px-webkit-appearance:textfield;}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button;}summary{display:list-item}[hidden],template{display:none}table{border-spacing:0;border-collapse:collapse;}td,th{padding:0;font-weight:normal;}ul{margin:0;padding:0;}ul li{margin:0;padding:0;list-style:none;}ol{margin:0;padding:0;}ol li{margin:0;padding:0;list-style:none;}
main,figure,figcaption,time,address,dl,dt,dd{display: block;margin:0;padding:0;}h1,h2,h3,h4,h5{margin:0;font-size:100%;}p{margin:0; padding:0;}address{font-style: normal;}*,*:after,*:before{outline:none;-webkit-tap-highlight-color:rgba(0, 0, 0, 0);scrollbar-color: transparent transparent;scrollbar-width: 0px;-ms-overflow-style: none;}h1,h2,h3,h4{font-weight:normal;}mark{background: none;}html{box-sizing:border-box;}*,*:before,*:after{box-sizing:border-box;}

/* --------------------------------------------------
 common
--------------------------------------------------- */
html{ width: 100%; font-size: 62.5%;}
body{
    min-width: 1000px;
    background: #fff;
    color: #000;
    font-weight: 400;
    font-style: normal;
    font-size: 1.5rem;
    font-family: 'Noto Sans JP', sans-serif;
    line-height: 1;

    -webkit-font-smoothing: antialiased;
}

img{ width: 100%; vertical-align: bottom;}
i{ display: block;}
a{ color: #000; text-decoration: none;}
a:hover{ color: #000; text-decoration: none;}
.sp{ display: none;}
#wrap{ position: relative;}

@media screen and (max-width: 768px){
    body{ min-width: 0; font-size: 3.555vw;}
    .pc{ display: none;}
    .sp{ display: block;}
}

/* --------------------------------------------------
 main
--------------------------------------------------- */
.btn a{ display: flex; width: 90px; height: 90px; background: #003894; color: #fff; font-weight: 700; font-size: 2rem; font-family: 'Plus Jakarta Sans', sans-serif; align-items: center; justify-content: center;}

@media screen and (max-width: 768px){
    .btn a{ width: 16vw; height: 16vw; font-size: 3.555vw;}
}

/* sec1
--------------------------------------------------- */
.sec1{ padding: 60px 0 210px; background: url("../images/bg_main.jpg") no-repeat bottom center / contain;}
.sec1 .logo{ text-align: center;}
.sec1 .logo img{ width: 1000px;}
.sec1 .lead{ margin: 65px 0 0; text-align: center; font-weight: 500; font-size: 2rem; line-height: 1.75;}
.sec1 figure{ margin: 75px auto 0; width: 1000px;}

@media screen and (max-width: 768px){
    .sec1{ padding: 8.888vw 0 6.222vw; background: none;}
    .sec1 .logo img{ width: 88.888vw;}
    .sec1 .lead{ margin: 4vw 0 0; color: #003894; text-align: center; font-size: 4vw; line-height: 1.66;}
    .sec1 figure{ margin: 6.222vw 0 0; width: 100%;}
}

.sec2{ padding:  0 0 60px;}
.sec2 h2{ margin: -150px auto 0; padding: 55px 125px 0; width: 1000px; border-radius: 50px; background: #fff;}

@media screen and (max-width: 768px){
    .sec2{ padding: 0 9.777vw 8.4444vw;}
    .sec2 h2{ margin: 0 auto; padding: 0; width: 64vw; border-radius: 0; background: none;}
}

.type1{ display: flex; margin: 60px auto 0; width: 450px; height: 50px; border-radius: 50px; background: #003894; color: #fff; letter-spacing: normal; font-weight: 700; font-size: 2.5rem; line-height: 1; align-items: center; justify-content: center;}
.type1s{ border: 1px solid; background: #fff; color: #003894;}
.type2 + .type1{ margin: 30px auto 0;}

@media screen and (max-width: 768px){
    .type1{ margin: 8vw 0 0; width: 100%; height: 8.888vw; border-radius: 8.888vw; font-size: 3.555vw;}
    .type2 + .type1{ margin: 30px auto 0;}
}

.list-prof{ display: flex; padding: 60px 0 0; justify-content: center;}
.list-prof > li{ padding: 0 40px; width: 422px;}
.list-prof figure{ text-align: center;}
.list-prof figure img{ margin: 0 auto; width: 300px;}
.list-prof figcaption{ margin: 20px 0 0; letter-spacing: -.032em; font-weight: 700; font-size: 2rem;}
.list-prof figcaption span{ display: block; margin: 10px 0 0; font-size: 2.5rem;}
.list-prof p{ margin: 30px 0 0; text-align: justify; line-height: 2;}

@media screen and (max-width: 768px){
    .list-prof{ flex-direction: column; padding: 5.333vw 0 0;}
    .list-prof > li{ padding: 5.333vw 0 0; width: 100%;}
    .list-prof figure img{ width: 40vw;}
    .list-prof figcaption{ margin: 5.333vw 0 0; text-align: left; white-space: nowrap; font-size: 4vw;}
    .list-prof figcaption span{ display: inline; margin: 0 0 0 .5em; font-size: 4.888vw;}
    .list-prof p{ margin: 2.666vw 0 0; line-height: 1.75;}
}

.sec3{ padding: 60px 0; background: #d7f0f0;}
.box{ position: relative; margin: 0 auto; padding: 0 50px 70px; width: 1000px; border: 1px solid #003894; border-radius: 50px;}
.box time{ position: absolute; top: 45px; left: 50px; z-index: 10; border-bottom: 1px solid; font-weight: 800; font-style: italic; font-size: 2rem; font-family: 'Plus Jakarta Sans', sans-serif;}

@media screen and (max-width: 768px){
    .sec3{ padding: 2.666vw 9.777vw 8.888vw;}
    .box{ padding: 0; width: 100%; border: none; border-radius: 0;}
    .box time{ position: relative; top: auto; left: auto; display: inline; font-size: 3.555vw;}
}

.img1{ overflow: hidden; margin: 0 -50px; border-radius: 50px 50px 0 0;}

@media screen and (max-width: 768px){
    .img1{ margin: 2.666vw 0 0; border-radius: 0;}
}

.talk{ margin: 15px auto 0; width: 600px;}
.talk p{ padding: 30px 0 0; text-align: justify; line-height: 2;}
.talk p span{ color: #003894; font-weight: 700;}

@media screen and (max-width: 768px){
    .talk{ margin: 0; width: 100%;}
    .talk p{ padding: 8.888vw 0 0; line-height: 1.75;}
}

.item{ position: relative; display: flex; margin: 60px 0 0; padding: 0 0 0 35px; justify-content: space-between; align-items: center;}
.item:before{ position: absolute; top: 0; left: 0; width: 5px; height: 100%; background: #000; content: "";}
.item:after{ position: absolute; top: 0; left: 10px; width: 5px; height: 100%; background: #003894; content: "";}
.item .detail{ padding: 10px 0; line-height: 2;}

@media screen and (max-width: 768px){
    .item{ margin: 8.888vw 0 0; padding: 0 0 0 4.444vw;}
    .item:before{ left: 0; width: 3px;}
    .item:after{ left: 6px; width: 3px;}
    .item .detail{ padding: 0; line-height: 1.75;}
}

.dl-share{ display: flex; margin: 60px auto 0; padding: 0 40px; width: 900px; height: 50px; border-radius: 40px; background: #fff; color: #003894; justify-content: space-between; align-items: center;}
.dl-share dt{ font-weight: 500; font-style: italic; font-family: 'Plus Jakarta Sans', sans-serif;}
.dl-share ul{ display: flex;}
.dl-share ul > li{ padding: 0 0 0 40px; font-size: 3rem;}
.dl-share ul a{ display: block; color: #003894;}

@media screen and (max-width: 768px){
    .dl-share{ margin: 5.333vw 0 0; padding: 0 15px; width: 100%; height: 8.888vw; border-radius: 8.888vw;}
    .dl-share ul > li{ padding: 0 0 0 6.222vw; font-size: 2rem;}
}

.type2{ display: flex; flex-direction: column; margin: 60px 0 0; font-weight: 500; font-size: 2.5rem; line-height: 1.6; align-items: center;}
.type2 i{ margin: 0 0 30px; width: 65px;}
.type2 span{ display: block; font-size: 3.25rem;}
.type2 em{ color: #003894; font-weight: 700; font-style: normal;}

@media screen and (max-width: 768px){
    .type2{ margin: 8vw 0 0; font-size: 4.444vw;}
    .type2 i{ margin: 0 0 2.666vw; width: 11.555vw;}
    .type2 span{ font-size: 5.777vw;}
}

.list-spec > li{ display: flex; padding: 40px 0 0; justify-content: space-between; align-items: center;}
.list-spec figure{ width: 510px;}
.list-spec .detail{ width: 350px;}
.list-spec .detail h4{ color: #003894; font-weight: 700; font-size: 2.5rem; line-height: 1.6;}
.list-spec .detail p{ margin: 30px 0 0; line-height: 2;}
.list-spec > li:nth-child(even){ flex-direction: row-reverse;}
.list-spec > li:nth-child(even) .detail h4{ text-align: right;}

@media screen and (max-width: 768px){
    .list-spec > li{flex-direction: column; padding: 8.888vw 0 0; }
    .list-spec figure{ width: 100%;}
    .list-spec .detail{ padding: 5.333vw 0 0; width: 100%;}
    .list-spec .detail h4{ font-size: 4.444vw;}
    .list-spec .detail p{ margin: 4.444vw 0 0; line-height: 1.75;}
    .list-spec > li:nth-child(even){ flex-direction: column;}
    .list-spec > li:nth-child(even) .detail h4{ text-align: left;}
}

.list-item > li{ display: flex; padding: 60px 0 0; justify-content: space-between;}
.list-item figure{ position: relative; width: 510px;}
.list-item figure:after{ display: block; padding-top: 170.588%; content: "";}
.list-item figure img{ position: absolute; top: 0; left: 0; width: 100%;}
.list-item .detail{ position: relative; padding: 70px 0 0; width: 350px;}
.list-item .ttl{ position: relative; display: flex; justify-content: center;}
.list-item .ttl h4{ width: 120px;}
.list-item .exp{ position: absolute; bottom: 0; left: 0; width: 100%;}
.list-item .exp p{ margin: 40px 0 0; text-align: justify; line-height: 2;}

.list-item > li:nth-child(even){ flex-direction: row-reverse;}
.list-item > li:nth-child(even) .btn{ display: flex; justify-content: flex-end;}

@media screen and (max-width: 768px){
    .list-item{ margin: 0 -9.777vw;}
    .list-item > li{ position: relative; flex-direction: column; padding: 8.888vw 0 0;}
    .list-item > li:first-child{ padding: 4.444vw 0 0;}
    .list-item figure{ width: 100%;}
    .list-item .detail{ position: static; padding: 0 9.777vw; width: 100%;}
    .list-item .ttl{ position: absolute; top: 14.221vw; left: 9.777vw;}
    .list-item .ttl h4{ width: 16.888vw;}
    .list-item .exp{ position: relative; bottom: auto; left: auto; display: flex; flex-direction: row-reverse; padding: 5.333vw 0 0; justify-content: space-between;}
    .list-item .exp p{ margin: 0; width: 60.444vw; line-height: 1.75;}
    .list-item > li:nth-child(even){ flex-direction: column;}
    .list-item > li:nth-child(even) .ttl{ top: 18.665vw; right: 9.777vw; left: auto;}
    .list-item > li:nth-child(even) .btn{ display: block;}
}

.list-result > li{ display: flex; padding: 30px 0 0; align-items: center;}
.list-result i{ width: 100px;}
.list-result p{ position: relative; margin: 0 0 0 40px; padding: 0 0 0 50px; color: #003894; font-weight: 700; font-size: 2.5rem; line-height: 1.6;}
.list-result p span{ display: block;}
.list-result p:before{ position: absolute; top: 50%; left: 0; width: 25px; height: 110px; background: url("../images/arrow.png") no-repeat center / contain; content: ""; transform: translate(0,-50%);}
.list-result > li:nth-child(even){ flex-direction: row-reverse;}
.list-result > li:nth-child(even) p{ margin: 0 40px 0 0; padding: 0 50px 0 0; text-align: right;}
.list-result > li:nth-child(even) p:before{ right: 0; left: auto; transform: translate(0,-50%) rotate(180deg);}

@media screen and (max-width: 768px){
    .list-result > li{ padding: 5.333vw 0 0;}
    .list-result i{ width: 13.422vw;}
    .list-result p{ margin: 0 0 0 2.666vw; padding: 0 0 0 8.888vw; font-size: 3.555vw; line-height: 1.5;}
    .list-result p:before{ width: 5.777vw; height: 21.866vw; background: url("../images/arrow_sp.png") no-repeat center / contain;}
    .list-result > li:nth-child(even) p{ margin: 0 2.666vw 0 0; padding: 0 8.888vw 0 0;}
}

/* sec3
--------------------------------------------------- */

/* 傾斜15度リピート */
.act1-1 { transform: translate(0) rotate(0); animation: act1-1 2s running steps(1) infinite;}
@keyframes act1-1 {
    0% { transform: translate(0) rotate(0);}
    50% { transform: translate(0) rotate(15deg);}
    100% { transform: translate(0) rotate(0);}
}

/* 傾斜15度リピート */
.act1-2 { transform: translate(0) rotate(0); animation: act1-2 2s running steps(1) infinite;}
@keyframes act1-2 {
    0% { transform: translate(0) rotate(0);}
    50% { transform: translate(0) rotate(-15deg);}
    100% { transform: translate(0) rotate(0);}
}

/* フェードイン1 */
.act2-1 { opacity: 0;}
.fadein2-1{ animation: popup .6s .5s cubic-bezier(0.22, 1, 0.36, 1) 1 forwards;}
@keyframes popup {
  0% { opacity: 0; transform: translateY(40px) scale(0.8);}
  100% { transform: translateY(0) scale(1.0);}
  80%, 100% { opacity: 1;}
}

/* フェードイン2 */
.act2-3 { opacity: 0; transform: translateY(-150px);}
.fadein2-3{ animation: poyoyon .5s cubic-bezier(0.12, 0, 0.39, 0) 1 forwards;}
@keyframes poyoyon {
    0% { opacity: 0; transform: translateY(-150px);}
    50% { transform: translateY(0);}
    65% { transform: translateY(-30px);}
    100% { transform: translateY(0);}
    20%,100% { opacity: 1;}
}

/* フェードイン3 */
.act3 { opacity: 0;}
.fadein3{ animation: zoomIn2 .8s cubic-bezier(0.25, 1, 0.5, 1) 1 forwards;}
/*.act3s{ opacity: 0; animation: zoomIn2 1.2s cubic-bezier(0.25, 1, 0.5, 1) 1 forwards;}*/
.act4 { opacity: 0;}
.fadein4{ animation: zoomIn2 .8s .8s cubic-bezier(0.25, 1, 0.5, 1) 1 forwards;}
@keyframes zoomIn2 {
  0% { opacity: 0; transform: scale(0.8);}
  100% { opacity: 1; transform: scale(1);}
}

.act3s {
  animation: poyoyon3 3s infinite;
  opacity: 1;
}
@keyframes poyoyon3 {
  0%, 40% {
    transform: skew(0deg, 0deg);
  }
  5% {
    transform: skew(5deg, 5deg);
  }
  10% {
    transform: skew(-4deg, -4deg);
  }
  15% {
    transform: skew(3deg, 3deg);
  }
  20% {
    transform: skew(-2deg, -2deg);
  }
  25% {
    transform: skew(1deg, 1deg);
  }
  30% {
    transform: skew(-0.6deg, -0.6deg);
  }
  35% {
    transform: skew(0.3deg, 0.3deg);
  }
}


/* フェードイン */
.act5 { opacity: 0;}
.fadein5{ animation: act5 .6s cubic-bezier(0.25, 1, 0.5, 1) 1 forwards;}
@keyframes act5 {
  0% { opacity: 0; transform: translateX(30px);}
  100% { opacity: 1; transform: translateX(0);}
}
.act6 { opacity: 0;}
.fadein6{ animation: act6 .6s cubic-bezier(0.25, 1, 0.5, 1) 1 forwards;}
@keyframes act6 {
  0% { opacity: 0; transform: translateX(-30px);}
  100% { opacity: 1; transform: translateX(0);}
}

/* --------------------------------------------------
 aside
--------------------------------------------------- */
aside{ overflow: hidden; margin: 0 calc(50% - 50vw); padding: 5.2083vw 0 7.2916vw; width: 100vw; background: #003894;}
aside h2{ display: flex; justify-content: center;}
aside h2 span{ display: flex; width: 23.4375vw; height: 2.6041vw; border-radius: 2.6041vw; background: #fff; color: #003894; font-weight: 800; font-size: 1.0416vw; font-family: 'Plus Jakarta Sans', sans-serif; align-items: center; justify-content: center;}
aside ul{ display: flex; margin: 2.0833vw 0 0; padding: 0 13.802vw; flex-wrap: wrap; justify-content: center;}
aside ul > li{ padding: 3.125vw 1.302vw 0; width: 20%;}
aside ul a{ display: block; color: #fff;}
aside ul a:hover{ color: #fff;}
aside ul time{ display: inline-block; margin: 1.0416vw 0 0; border-bottom: 1px solid; font-weight: 800; font-style: italic; font-size: 1.0416vw; font-family: 'Plus Jakarta Sans', sans-serif;}
aside ul p{ position: relative; margin: 1.5625vw 0 0; font-weight: 700; font-size: .7812vw; line-height: 2;}
aside ul p span{ position: absolute; top: -1.2vw; left: 0; color: #eb0000; font-weight: 800; font-family: 'Plus Jakarta Sans', sans-serif;}
aside .more{ display: flex; padding: 5.2083vw 0 0; justify-content: center;}
aside .more span{ display: flex; width: 23.4375vw; height: 2.6041vw; border: 1px solid; border-radius: 2.6041vw; color: #fff; font-weight: 800; font-size: 1.0416vw; font-family: 'Plus Jakarta Sans', sans-serif; cursor: pointer; align-items: center; justify-content: center;}
aside .more.open{ display: none;}
aside .drop{ display: none;}
aside .drop ul{ margin: 0; justify-content: flex-start;}

@media screen and (max-width: 768px){
    aside{ margin: 0; padding: 9.777vw 9.777vw 0; width: 100%;}
    aside h2 span{ width: 100%; height: 8.8888vw; border-radius: 8.8888vw; font-size: 3.5555vw;}
    aside ul{ flex-direction: column; margin: 3.5555vw 0 0; padding: 0;}
    aside ul > li{ padding: 5.3333vw 0 0; width: 100%;}
    aside ul a{ display: flex; justify-content: space-between;}
    aside ul a figure{ width: 50%;}
    aside ul a .detail{ padding: 1.4222vw 0 0 3.1111vw; width: 50%;}
    aside ul time{ margin: 0; font-size: 3.5555vw;}
    aside ul p{ margin: 5.3333vw -9.777vw 0 0; font-size: 2.6666vw; line-height: 1.75;}
    aside ul p span{ top: -3.8vw;}
    aside .more{ padding: 5.3333vw 0 0;}
    aside .more span{ width: 100%; height: 8.8888vw; border-radius: 8.8888vw; font-size: 3.5555vw;}
}

aside .info{ position: relative; margin: 4.1666vw calc(50% - 50vw); width: 100vw;}
aside .info .lead1{ margin: 0 auto; width: 52.0833vw;}
aside .info .lead2{ margin: 2.8645vw auto 0; width: 52.0833vw;}
aside .info .lead3{ position: absolute; top: -8.5416vw; right: 3.125vw; width: 18.2291vw;}
aside .info .img{ position: absolute; width: 7.9166vw;}
aside .info .img9{ top: 12.3437vw; left: 4.2708vw;}
aside .info .img10{ top: -3.2291vw; left: 13.125vw;}
aside .info .img11{ top: 6.0937vw; left: 22.8125vw;}
aside .info .img12{ bottom: 3.0208vw; left: 12.0833vw;}
aside .info .img13{ top: 7.2916vw; right: 19.0104vw;}
aside .info .img14{ right: 4.2187vw; bottom: 7.0833vw;}
aside .info .img15{ right: 14.2187vw; bottom: -1.4583vw;}

@media screen and (max-width: 768px){
    aside .info{ margin: 30px calc(50% - 50vw); padding: 0 4.8885vw; width: 100vw;}
    aside .info .lead1{ width: 100%;}
    aside .info .lead2{ margin: 4.4444vw 0 0; width: 100%;}
    aside .info .lead3{ top: 17.4222vw; right: 8.7107vw; width: 22.2222vw;}
    aside .info .img{ width: 9.244vw;}
    aside .info .img9{ top: 8.7111vw; left: 4.4441vw;}
    aside .info .img10{ top: 19.7333vw; left: 12.444vw;}
    aside .info .img11{ top: auto; bottom: 10.0444vw; left: 17.7773vw;}
    aside .info .img12{ top: auto; bottom: 0.8888vw; left: 6.6662vw;}
    aside .info .img13{ top: 18.1333vw; right: auto; left: 26.844vw;}
    aside .info .img14{ top: auto; right: 6.6662vw; bottom: 1.3333vw;}
    aside .info .img15{ right: 17.5107vw; bottom: 10.0444vw;}
}

/* --------------------------------------------------
 footer
--------------------------------------------------- */
footer{ margin: 0 calc(50% - 50vw); padding: 7.2916vw 0 5.2083vw; width: 100vw; background: #003894; text-align: center;}
footer small{ display: inline-block; width: 11.9791vw;}

@media screen and (max-width: 768px){
    footer{ margin: 0; padding: 20px 0 30px; width: 100%;}
    footer small{ width: 40.622vw;}
}