@charset "utf-8";

/* body
==================================*/
body {
    color: #000;
    font-family: YakuHanJP_Noto, 'Noto Sans JP', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', 'ＭＳ Ｐゴシック', sans-serif;
    font-size: 17px;
    max-height: 100%;
    padding: 0;
    margin: 0;
    font-weight: 500;
    line-height: 1.4;
}

@media screen and (max-width: 767px) {
body {
    font-size: 13px;
    line-height: 22px;
}
}


.container{
    max-width: 950px;
    width: 100%;
    margin: 0 auto;
    overflow: hidden;
    padding: 0 0 50px;
}

.flex{
    display: flex;
    justify-content: space-between;
}
.pc{
    display: block;
}
.sp{
    display: none;
}
img{
    width: 100%;
}

@media only screen and (max-width: 850px){
    .container{
        padding: 0 0 25px;
    }
    .inner{
        /* padding: 0 5vw; */
    }
    .flex{
        flex-wrap: wrap;
    }
    .pc{
        display: none;
    }
    .sp{
        display: block;
    }
}

/* top */
.top .top_alt{
    max-width: 850px;
    padding: 45px 20px;
    margin: 0 auto;
}

.title{
    background-color: #4d144a;
    padding: 25px;
}
.title.red{
    background-color: #aa030e;
}
.title.gr{
    background-color: #002273;
}
.title h2{
    color: #fff;
    font-size: 36px;
    font-weight: 500;
    letter-spacing: 0.03rem;
    padding:0 20px 0 20px;
    border-left: 2px solid #fff;
    line-height: 1.4;
    letter-spacing: -0.02em;
}
.title h2 .font86{
    font-size: 83%;
    color: #ef987b;
}
@media only screen and (max-width: 850px){
    .top .top_alt{
        padding: 15px 20px;
    }
    .title{
        padding: 15px 20px;
    }
    .title h2{
        font-size: 4.8vw;
        line-height: 1.3;
        padding: 0 10px 0 10px;
    }
}
/* sec1 */
.sec1 .flex{
    position: relative;
}
.sec1 .flex .img02{
    width: 100%;
}
.sec1 .flex .txt02{
    width: 40%;
    height: 100%;
    color: #fff;
    position: absolute;
    left: 50%;
    display: flex;
    justify-content: center;
    flex-direction: column;
}
.sec1.sec0 .flex .txt02{
    width: 43%;
    left: 53%;
}

.sec1 .flex .txt02 p{
    font-size: 18px;
    font-weight: 500;
    line-height: 1.5;
    text-align: justify;
   
}
.sec1 .flex .txt02 p span.pink{
   color: #eec0bc;
}
.letter16{
   letter-spacing: 1.6px;
}
.sec1 .flex .txt02 p.note{
    font-size: 9px;
    line-height: 1.2;
    text-align: left;
    justify-content: left ; 
    margin-top: 1em;
}
sup{
     font-size: 50% !important; 
      vertical-align: text-top;
}
/* sec2 */
 .sec2{
    background-color: #fff;
}
.sec2.purple{
    background-color: #e4cbdd;
}
.sec4,
.sec6{
    background-color: #fff;
}
.sec5,
.sec7{
    background-color: #bbcae8;
}

.sec2 .flex,
.sec4 .flex,
.sec5 .flex,
.sec6 .flex,
.sec7 .flex,
.sec8 .flex{
    padding: 45px;
    align-items: flex-start;

}
.img03{
    margin-bottom: 35px;
}
.img03 img{
    height: 198px;
    width: auto;
}
.img03.img04 img{
    height: 240px;
    width: auto;
}
.img03.img02 img{
    height: 206px;
    width: auto;
}
.flex .txt dl dt{
    line-height: 1.4;
    font-size: 23px;
    margin-bottom: 8px;
    font-weight: 700;
    letter-spacing: -0.056em;
    color: #4d144a;
}
.red .flex .txt dl dt{
    color: #aa030e;
}
.flex .txt dl dd{
    line-height: 1.6;
    font-size: 15px;
    font-weight: 500;
    text-align: justify;
    letter-spacing: -0.03em;
}
.flex .txt dl dd.note{
    font-size: 9px;
    line-height: 1.2;
    text-align: left;
    padding-top: 1em;
    margin-left: 1em;
    text-indent: -1em;
}
.flex .txt{
    width: 56%;
}
.blue .flex .txt{
    width: 53%;
}
.flex .img_box{
    width: 39%;
}
.img_box .img{
    margin-bottom: 10px;
}
.img_box .img_alt{
    font-size: 9px;
    background-color: #fff;
    padding: 7px;
    zoom: 100%;
    line-height: 1.6;
}
.sec2 .img_box .img_alt{
    background-color: #eec0bc;
}
.sec2 .img_box .img_alt.pink{
    background-color: #f2e1e5;
}
.sec2 .img_box .img_alt.white{
    background-color: rgba(255, 255, 255, 0.6);
}

.width7{
    display: inline-block;
    width: 7.7em;
}
.img_box .btn{
    margin-top: 20px;
}
.btn a{
    color: #fff;
    background: rgb(39,55,64);
    background: url(../img/btn_img.png) no-repeat;
    background-size: contain;
    box-sizing: border-box;
    display: block;
    width: 100%;
    max-width: 200px;
    padding: 9px 22px 9px 0;
    font-size: 16px;
    font-weight: 700;
    text-decoration: none;
    border-style: solid;
    text-align: center;
    margin: 0 auto;
}

.return{
    margin: 30px auto 50px;
    padding-bottom: 15px;
    text-align: right;
    border-bottom: #e1251b solid 1px;
    width: 89.5%;
}
.return.ore{
    border-bottom: #e1140a solid 1px;
}
.return a{
    font-size: 14px;
    font-weight: 500;
}

@media only screen and (min-width: 850px) and (max-width: 930px){
    .sec2 .img_box .img img.pl_5{
    padding-left: 5vw;
    }
}
@media only screen and (max-width: 850px){
  .sec1 .flex .img02{
        width: 100%;
     
    }
    .sec1 .flex .txt02{
        width:65%; 
        position: absolute;
        top: 17px;
        left: 22px;
        justify-content: flex-start;
    }
    .sec1 .flex .txt02 p{
        font-size: 2.25vw;
        line-height: 1.6;
    }
    .sec2 .flex, .sec4 .flex, .sec5 .flex,
     .sec6 .flex, .sec7 .flex,.sec8 .flex{
        padding:7vw 6vw;
    }
    .img03{
        margin-bottom: 25px;
    }
    .img03 img,.img03.img02 img, .img03.img04 img{
        height: auto;
        margin: 0 auto;
    }
    
    .blue .flex .txt, .flex .txt{
        width: 100%;
    }
    .flex .img_box{
        width: 100%;
    }
    .flex .txt dl dt{
        font-size: 4.2vw;
    }
    .flex .txt dl dd{
        font-size: 1em;
    }
    .img_box .img{
        width: 75%;
        margin: 4% auto;
    }
    .img_box .img_alt{
        zoom: 100%;
        padding: 2% 3%;
        font-size: 2.3vw;
    }
    .return{
        margin: 15px auto 25px;
        width: 90vw;
    }
    .return a{
        font-size: 0.8em;
    }
    .sec2.purple .return.ore{
        border-bottom: none;
        margin: 0 auto;
    }
    .sec1.sec0 .flex .txt02 {
        width: 73%;
        top: 6vw;
        left: 6%;
    }
    .img_box .btn{
        margin-top: 7vw;
    }
}
/* sec3 */
.sec3 .flex{
    align-items: center;
    background-image: url(../img/img02.jpg);
    background-size: cover;
    min-height: 360px;
}
.sec3 .flex .img02{
    width: 46%;
}
.sec3 .flex .txt02{
    padding:25px 29px;
    width: 35%;
    color: #fff;
    position: relative;
}
.sec3 .flex .txt02 p{
    font-size: 18px;
    font-weight: 500;
    line-height: 1.6;
   text-align: justify;
}
.sec3 .flex .txt02 p span.lightblue{
color:#bbcae8;
}
.icon_isv{
    position: absolute;
    width: 100%;
    max-width: 120px;
    left: -140px;
    top:calc(50% - 60px);
}
.sec4 .img_box .img_alt,
.sec6 .img_box .img_alt,
.sec8 .img_box .img_alt
{
    background-color: rgba(0, 34, 115, 0.15);
}
.sec5 .img_box .img_alt,.sec7 .img_box .img_alt{
    background-color: rgba(255, 255, 255, 0.6);
}

/* sec11 */
.sec9 .inner{
    padding:0 45px 45px;
}
.sec9 .inner a{
    display: block;
    transition: .3s;
}
.border01{
    font-size: 19px;
    font-weight: 500;
    text-align: center;
    border: 2px solid #e1251b;
    color: #e1251b;
    padding: 5px;
}
.border01:hover{
    color: #fff;
    background-color: #e1251b;
}
.border02{
    font-size: 19px;
    font-weight: 500;
    text-align: center;
    padding: 5px;
    border: 2px solid #80140a;
}
.border02:hover{
    color: #fff;
    background-color: #80140a;
}
.border01, .border02{
    margin-bottom: 5px;
}
.sec9_note{
    font-size: 14px;
    line-height: 1;
    text-align: right;
    margin-bottom: 45px;
}
.arrow{
    font-size: 19px;
    font-weight: 500;
    text-align: center;
    padding: 3px;
    background-color: #aa030e;
    color: #fff;
    max-width: 305px;
    margin: 0 auto;
    position: relative;
    margin-bottom: 45px;
}

.arrow::before{
    content: '';
    position: absolute;
    top: 110%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    width: 0px;
    height: 0px;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-top: 21px solid #aa030e;
    z-index: -1;
}
.sec9 .flex{
    margin-top: 85px;
    justify-content: center;
}
.sec9 .flex .btn{
    width: 32%;
    position: relative;
    margin: 0 12px;
}
.sec9 .flex .btn a{
    max-width: 300px;
    padding: 15px 0;
    font-size: 18px;
    background-image: url(../img/btn_img-02.png);
}
.indent-left{
    text-indent: -1.5em;
}
.sec9 .flex .btn::before{
    content: '';
    background-image: url(../img/up01.svg);
    background-repeat: no-repeat;
    background-size: contain;
    width: 182px;
    height: 40px;
    position: absolute;
    top: -60%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}
.sec9 .flex .btn:nth-child(2):before{
    background-image: url(../img/up02.svg);
    background-repeat: no-repeat;
    background-size: contain;
}


.bottom_small{
    font-size: 14px;
    margin-top: -25px;
    zoom: 97%;
}
.pc.inline-block{
    display: inline-block;
}

@media only screen and (max-width: 850px){
    .sec3 .flex{
        background-image: url(../img/img02_sp.jpg);
        background-repeat: no-repeat;
        min-height: auto;
    }
    .sec3 .flex .img02,
    .sec3 .flex .txt02{
        width: 100%;
    }
    .sec3 .flex .img02 {
        width: 100%;
        overflow: hidden;
        background-position: center;
    }
    .sec3 .flex .txt02 {
        width: 65%;
        padding-left: 35%;
        margin-top: -30%;
    }
    .icon_isv{
        max-width:25%;
        left: unset;
        right: 5%;
        top:calc(-100% - 12%);
    }
    .sec3 .flex .txt02::after{
        content: '';
        clear: both;
    }
    .sec3 .flex .txt02 p {
        font-size: 2.25vw;
        line-height: 1.6;
        float: right;
    }
    .sec9 .inner {
        padding: 0 5vw 5vw;
    }
    .border01,
    .border02,
    .arrow{
        font-size: 1.15em;
    }
    .arrow{
        max-width: 245px;
    }
    .sec9 .flex {
        margin-top: 60px;
    }
    .sec9 .flex .btn{
        width: 45%;
        margin: 0 5px;
    }
    .sec9 .flex .btn a{
        font-size: 0.8em;
        padding: 3.5vw 0;
        line-height: 1.3;
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        background-image: url(../img/btn_img-02-sp.png);
        background-size: 100%;
    }
    .sec9 .flex .btn::before{
        width: 145px;
        height: 24px;
        top: -52%;
    }
    .sec9 .flex .btn:nth-child(2):before{
        background-repeat: no-repeat;
        background-size: contain;
    }

    .bottom_small{
        zoom: 100%;
        line-height: 1.5;
        padding: 0 5vw;
        font-weight: 400;
        font-size: 10px;
    }

    .end{
        text-align: right;
        padding-right: 1.5em;
    }
    .pc.inline-block{
        display: none;
    }
    .sec9_note{
        font-size: 2.13vw;
        margin-bottom: 2.53vw;
    }
}
