@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Plus+Jakarta+Sans:ital,wght@0,200..800;1,200..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: 1200px;
    background: #002f51;
    color: #fff;
    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: #fff; text-decoration: none;}
a:hover{ color: #fff; text-decoration: none;}
.sp{ display: none;}
#wrap{ position: relative;}

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

.fadein1{ opacity: 0; animation: fadein1 1s cubic-bezier(.23,1,.32,1) .75s forwards;}
@keyframes fadein1 {
    0% { opacity: 0;}
    100% { opacity: 1;}
}

.fadein2{ opacity: 0; animation: fadein2 1s cubic-bezier(.23,1,.32,1) .25s forwards;}
@keyframes fadein2 {
    0% { opacity: 0; transform: translateY(13%);}
    100% { opacity: 1; transform: translateY(0);}
}

@keyframes slidein {
    0% { width: 0; opacity: 0;}
    100% { width: 100%; opacity: 1;}
}

/* --------------------------------------------------
 main
--------------------------------------------------- */
.lp header{ position: relative; height: 56.25vw; background: url("../images/main.jpg") no-repeat top center / contain;}
.lp h1{ position: absolute; top: 50%; left: 50%; width: 39.0625vw; opacity: 0; transform: translate(-50%,-50%); animation: fadein1 1s cubic-bezier(.23,1,.32,1) 1s forwards;}

@media screen and (max-width: 768px){
    .lp header{ height: 125.2203467vw; background: url("../images/main_sp.jpg") no-repeat top center / contain;}
    .lp h1{ top: 4.444444444vw; width: 64.18875556vw; transform: translate(-50%,0);}
}

.content{ text-align: center;}

@media screen and (max-width: 768px){
}

.catch{ position: relative; margin: -50px auto 0; padding: 20px 0 0; width: 600px; border-radius: 25px 25px 0 0; background: #002f51; font-size: 5rem; line-height: 1.4;}

@media screen and (max-width: 768px){
    .catch{ margin: -4.444444444vw auto 0; padding: 1.777777778vw 0 0; width: 80vw; border-radius: 2.222222222vw 2.222222222vw 0 0; font-size: 6.222222222vw; line-height: 1.285714286;}
}

.lead-wrap{ position: relative; margin: 75px 0 0; padding: 20px 0;}
.lead-wrap:before,
.lead-wrap:after{ position: absolute; left: 0; width: 0; height: 1px; background: #fff; content: "";}
.lead-wrap:before{ top: 0;}
.lead-wrap:after{ bottom: 0;}

.lead{ position: relative; display: block; padding: 75px 0;}
.lead:before,
.lead:after{ position: absolute; left: 0; width: 0; height: 1px; background: #fff; content: "";}
.lead:before{ top: 0;}
.lead:after{ bottom: 0;}
.lead span{ font-weight: 900; font-size: 3.5rem; opacity: 0;}

.lead-wrap.is-animate:before,
.lead-wrap.is-animate:after,
.lead-wrap.is-animate .lead:before,
.lead-wrap.is-animate .lead:after{ animation: slidein 1s cubic-bezier(.23,1,.32,1) forwards;}
.lead-wrap.is-animate .lead span{ animation: fadein1 1s cubic-bezier(.23,1,.32,1) 1s forwards;}

@media screen and (max-width: 768px){
    .lead-wrap{ margin: 3.555555556vw 0 0; padding: 1.777777778vw 0;}
    .lead{ padding: 6.222222222vw 0;}
    .lead span{ font-size: 4vw; opacity: 1;}
    
    .lead-wrap:before,
    .lead-wrap:after{ width: 100%;}
    
    .lead:before,
    .lead:after{ width: 100%;}
    
    .lead-wrap.is-animate:before,
    .lead-wrap.is-animate:after,
    .lead-wrap.is-animate .lead:before,
    .lead-wrap.is-animate .lead:after{ width: 100%; animation: none;}
    .lead-wrap.is-animate .lead span{ animation: none;}
}

.update{ margin: 80px 0 0; text-decoration: underline; font-weight: 600; font-size: 2rem; font-family: "Plus Jakarta Sans", sans-serif;}

@media screen and (max-width: 768px){
    .update{ margin: 2.666666667vw 0 0; font-size: 3.555555556vw;}
}

.dl-share{ display: flex; margin: 50px auto 0; padding: 0 38px; width: 400px; height: 50px; border-radius: 25px; background: #fff; color: #002f51; justify-content: space-between; align-items: center;}
.dl-share dt{ font-weight: 600; font-family: "Plus Jakarta Sans", sans-serif;}
.dl-share dd ul{ display: flex; align-items: center;}
.dl-share dd ul > li{ margin: 0 0 0 40px;}
.dl-share dd ul a{ display: block; width: 30px;}

@media screen and (max-width: 768px){
    .dl-share{ margin: 8vw auto 0; padding: 0 4.444444444vw; width: 80vw; height: 8.888888889vw; border-radius: 4.444444444vw;}
    .dl-share dd ul > li{ margin: 0 0 0 7.111111111vw;}
    .dl-share dd ul a{ width: 5.333333333vw;}
}

section{ position: relative; margin: 100px auto 0; width: 1200px;}

@media screen and (max-width: 768px){
    section{ margin: 8.888888889vw 0 0; width: 100%;}
}

.sec1:before{ position: absolute; top: 0; left: 50%; width: 100vw; height: 1px; background: #fff; content: ""; transform: translate(-50%,0);}
.sec1 h2{ display: flex; margin: 0 auto; width: 250px; height: 104px; border-radius: 0 0 25px 25px; background: #eb0000; color: #fff; font-weight: 700; font-size: 4rem; justify-content: center; align-items: center;}
.sec1 h2 span{ font-weight: 700; font-size: 6.4rem; font-family: "Plus Jakarta Sans", sans-serif;}

@media screen and (max-width: 768px){
    .sec1 h2{ width: 27.55555556vw; height: 11.55555556vw; border-radius: 0 0 2.222222222vw 2.222222222vw; font-size: 4.444444444vw;}
    .sec1 h2 span{ font-size: 7.111111111vw;}
}

.list-thumb{ display: flex; margin: 35px 0 0; justify-content: center;}
.list-thumb > li{ width: 343px; opacity: 0;}
.list-thumb figure{ position: relative; margin: 0 auto; width: 250px;}
.list-thumb figcaption{ position: absolute; bottom: -37px; left: 50%; display: flex; width: 75px; height: 75px; border-radius: 100%; background: #eb0000; color: #fff; font-weight: 900; font-size: 5rem; font-family: "Plus Jakarta Sans", sans-serif; transform: translate(-50%,0); justify-content: center; align-items: center;}
.list-thumb p{ margin: 50px 0 0; font-size: 4rem; line-height: 1.4;}

@media screen and (max-width: 768px){
    .list-thumb{ position: relative; flex-direction: column; margin: 6.222222222vw 0 0; padding: 0 9.955555556vw; text-align: left;}
    .list-thumb:after{ position: absolute; top: -16vw; left: 13.33333333vw; z-index: -1; width: 1px; height: calc(100% + 16vw + 5.333333333vw); background: #fff; content: "";}
    .list-thumb > li{ position: relative; display: flex; flex-direction: row-reverse; width: 100%; justify-content: space-between;}
    .list-thumb > li + li{ margin: 3.555555556vw 0 0;}
    .list-thumb figure{ position: static; margin: 0; width: 17.77777778vw;}
    .list-thumb figcaption{ top: 0; bottom: auto; left: 0; width: 6.666666667vw; height: 6.666666667vw; border: 1px solid #fff; font-size: 4.444444444vw; transform: none;}
    .list-thumb p{ margin: 0; padding: 0 0 0 8.888888889vw; font-size: 6.222222222vw; line-height: 1.285714286;}
}

.sec1 h3 + figure{ opacity: 0;}

.box{ margin: 100px 0 0; padding: 60px 0 100px; border-radius: 25px 25px 0 0; background: #fff; text-align: left;}
.box h3{ display: flex; font-size: 5rem; justify-content: center; align-items: center;}
.box h3 i{ display: flex; width: 75px; height: 75px; border-radius: 100%; background: #eb0000; color: #fff; font-weight: 900; font-style: normal; font-family: "Plus Jakarta Sans", sans-serif; justify-content: center; align-items: center;}
.box h3 span{ position: relative; margin: 0 0 0 35px; width: 747px; color: #002f51; font-weight: 700;}
.box h3 span:after{ position: absolute; bottom: -20px; left: 0; width: 0; height: 10px; border-radius: 5px; background: #eb0000; content: "";}
.box h3 span.is-animate:after{ animation: slidein .5s cubic-bezier(.23,1,.32,1) .25s forwards;}
.box figure{ margin: 60px 0 0;}
.box p{ margin: 30px auto 0; width: 900px; color: #000; text-align: justify; line-height: 2;}
.box p + h3{ margin: 100px 0 0;}

@media screen and (max-width: 768px){
    .box{ margin: 7.111111111vw 0 0; padding: 7.555555556vw 9.777777778vw 10.22222222vw; border-radius: 0;}
    .box h3{ font-size: 4.444444444vw; justify-content: flex-start;}
    .box h3 i{ width: 6.666666667vw; height: 6.666666667vw;}
    .box h3 span{ margin: 0 0 0 0.888888889vw; width: 71.11111111vw;}
    .box h3 span:after{ bottom: -1.777777778vw; height: 1.066666667vw; border-radius: 0.533333333vw;}
    .box figure{ margin: 5.333333333vw calc(50% - 50vw) 0;}
    .box p{ margin: 5.333333333vw 0 0; width: 100%; line-height: 1.75;}
    .box p + h3{ margin: 7.111111111vw 0 0;}
}

.item{ margin: 100px 0 0;}
.item dl{ margin: 60px 0 0; font-size: 3.2rem;}
.item dt{ font-weight: 700; line-height: 1.5;}
.item dd{ margin: 20px 0 0; font-family: "Plus Jakarta Sans", sans-serif;}
.item .btn{ margin: 40px 0 0;}
.item .btn a{ display: flex; margin: 0 auto; width: 450px; height: 50px; border: 2px solid #eb0000; border-radius: 25px; color: #eb0000; font-weight: 800; font-size: 2rem; font-family: "Plus Jakarta Sans", sans-serif; justify-content: center; align-items: center;}
.item .btn a:hover{ background: #eb0000; color: #fff;}

@media screen and (max-width: 768px){
    .item{ margin: 0; padding: 0 9.777777778vw;}
    .item dl{ margin: 5.333333333vw 0 0; font-size: 3.555555556vw;}
    .item dd{ margin: 3.555555556vw 0 0;}
    .item .btn{ margin: 5.777777778vw 0 0;}
    .item .btn a{ width: 100%; height: 8.888888889vw; border-radius: 4.444444444vw; font-size: 3.555555556vw;}
}

.sec2{ padding: 90px 0; border-radius: 0 0 25px 25px; background: #fff0e1; text-align: left;}
.sec2 h2{ color: #002f51; text-align: center; font-size: 5.6rem; line-height: 1.535714286;}
.sec2 h2 span{ display: inline-block; margin: 0 8px 0 0; width: 168px; height: 80px; border-radius: 25px; background: #eb0000; color: #fff; text-align: center; font-weight: 700; font-size: 4.56rem; line-height: 75px;}
.sec2 h2 + p{ margin: 40px auto 0; width: 650px; color: #002f51; text-align: justify; font-weight: 700; font-size: 2rem; line-height: 1.75;}

@media screen and (max-width: 768px){
    .sec2{ padding: 8vw 0 8.888888889vw; border-radius: 0;}
    .sec2 h2{ letter-spacing: -.04em; font-size: 6.222222222vw; line-height: 1.285714286;}
    .sec2 h2 span{ margin: 0 1.066666667vw 0 0; width: 18.66666667vw; height: 8.888888889vw; border-radius: 4.444444444vw; font-size: 5.066666667vw; line-height: 8.888888889vw; letter-spacing: .02em;}
    .sec2 h2 + p{ margin: 5.333333333vw auto 0; width: 80vw; font-size: 3.555555556vw;}
}

.list-prof-wrap{ margin: 100px 0 0; padding: 0 0 50px; background: #002f51;}
.list-prof{ display: flex; justify-content: center;}
.list-prof > li{ position: relative; display: flex; flex-direction: column; padding: 65px 20px 0; width: 340px; opacity: 0; align-items: center;}
.list-prof figure{ width: 150px;}
.list-prof i{ position: absolute; top: -25px; left: 50%; display: flex; width: 105px; height: 50px; border-radius: 25px; background: #eb0000; color: #fff; font-weight: 700; font-style: normal; font-size: 2rem; transform: translate(-50%,0); align-items: center; justify-content: center;}
.list-prof i span{ margin: 0 .1em 0 0; font-weight: 800; font-size: 3rem; font-family: "Plus Jakarta Sans", sans-serif;}
.list-prof .detail{ margin: 30px 0 0;}
.list-prof dl{ width: 300px; text-align: center; white-space: nowrap; font-weight: 700; font-size: 2rem;}
.list-prof dt{ padding: 0 0 10px; border-bottom: 2.5px solid #eb0000;}
.list-prof dd{ margin: 2px 0 0; padding: 20px 0 0; border-top: 2.5px solid #eb0000;}
.list-prof p{ margin: 30px 0 0; width: 260px; text-align: justify; line-height: 2;}

@media screen and (max-width: 768px){
    .list-prof-wrap{ margin: 8.888888889vw 0 0; padding: 8vw 9.777777778vw;}
    .list-prof{ flex-direction: column;}
    .list-prof > li{ flex-direction: row; padding: 0; width: 100%; flex-wrap: wrap;}
    .list-prof > li + li{ margin: 6.222222222vw 0 0;}
    .list-prof figure{ width: 22.22222222vw;}
    .list-prof .detail{ margin: 0; padding: 0 0 0 2.222222222vw; width: calc(100% - 22.22222222vw);}
    .list-prof i{ position: relative; top: auto; left: auto; width: 18.66666667vw; height: 8.888888889vw; border-radius: 4.444444444vw; font-size: 3.555555556vw; transform: none;}
    .list-prof i span{ font-size: 5.333333333vw;}
    .list-prof dl{ margin: 2.222222222vw 0 0; width: 100%; text-align: left; font-size: 3.555555556vw;}
    .list-prof dt{ padding: 0 0 0.888888889vw; border-bottom: 0.444444444vw solid #eb0000;}
    .list-prof dd{ margin: 0.444444444vw 0 0; padding: 1.777777778vw 0 0; border-top: 0.444444444vw solid #eb0000;}
    .list-prof p{ margin: 2.666666667vw 0 0; width: 100%; text-align: left; line-height: 1.75;}
}

.look{ position: relative;}
.list-ftf + .look{ margin: 80px 0 0;}
.look > img{ opacity: 0;}
.look i{ position: absolute; top: 20px; right: 100px; width: 160px;}
.look i.is-animate { animation: fuwafuwa 1.5s ease-in-out infinite alternate;}
 
@keyframes fuwafuwa {
0% { transform: translate(0, 0) rotate(-10deg);}
50% { transform: translate(0, -8px) rotate(0deg);}
100% { transform: translate(0, 0) rotate(10deg);}
}

@media screen and (max-width: 768px){
    .list-ftf + .look{ margin: 8.888888889vw 0 0;}
    .look i{ top: 3.555555556vw; right: 6.222222222vw; width: 15.37777778vw;}
}

.sec2 .btn{ margin: 60px 0 0;}
.sec2 .btn a{ display: flex; margin: 0 auto; width: 450px; height: 50px; border: 1px solid #eb0000; border-radius: 25px; color: #eb0000; font-weight: 800; font-size: 2rem; font-family: "Plus Jakarta Sans", sans-serif; align-items: center; justify-content: center;}
.sec2 .btn a:hover{ background: #eb0000; color: #fff;}

@media screen and (max-width: 768px){
    .sec2 .btn{ margin: 5.333333333vw 0 0;}
    .sec2 .btn a{ width: 80vw; height: 8.888888889vw; border-radius: 4.444444444vw; font-size: 3.555555556vw;}
}

.list-ftf{ margin: 0 auto; padding: 20px 0 0; width: 900px;}
.list-ftf > li{ display: flex; margin: 40px 0 0; opacity: 0; justify-content: flex-end; align-items: flex-start;}
.list-ftf figure{ text-align: center;}
.list-ftf figure img{ width: 100px;}
.list-ftf figcaption{ margin: 10px 0 0; color: #002f51; font-weight: 700; font-size: 2rem;}
.list-ftf .detail{ position: relative; margin: 20px 0 0 60px; padding: 30px 40px; width: 598px; border-radius: 21px; background: #fff; color: #000; line-height: 2;}
.list-ftf .detail:after{ position: absolute; top: 40px; left: -40px; width: 46px; height: 42px; background: url("../images/arrow.png") no-repeat center / contain; content: "";}
.list-ftf > li:nth-child(even){ flex-direction: row-reverse;}
.list-ftf > li:nth-child(even) .detail{ margin: 20px 60px 0 0;}
.list-ftf > li:nth-child(even) .detail:after{ right: -40px; left: auto; transform: scale(-1, 1);}

@media screen and (max-width: 768px){
    .list-ftf{ margin: 0 auto; padding: 2.666666667vw 0 0; width: 87.11111111vw;}
    .list-ftf > li{ margin: 3.555555556vw 0 0; justify-content: space-between;}
    .list-ftf figure img{ width: 13.33333333vw;}
    .list-ftf figcaption{ margin: 2.222222222vw 0 0; font-size: 3.555555556vw;}
    .list-ftf .detail{ margin: 3.555555556vw 0 0; padding: 2.666666667vw 3.555555556vw; width: 67.55555556vw; border-radius: 4.444444444vw; line-height: 1.75;}
    .list-ftf .detail:after{ top: 5.333333333vw; left: -5.866666667vw; width: 8.177777778vw; height: 7.466666667vw;}
    .list-ftf > li:nth-child(even) .detail{ margin: 3.555555556vw 0 0;}
    .list-ftf > li:nth-child(even) .detail:after{ right: -5.866666667vw;}
}


/* --------------------------------------------------
 aside
--------------------------------------------------- */
aside{ overflow: hidden; margin: 0 calc(50% - 50vw); padding: 100px 0 150px; width: 100vw;}
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: #002f51; 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: 8.888888889vw 9.777777778vw 0; width: 100%;}
    aside h2 span{ width: 100%; height: 8.888888889vw; border-radius: 4.444444444vw; 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: 0 0 5.2083vw; width: 100vw; 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;}
}