@charset "UTF-8";

html {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 62.5%;
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: 1;
    color: #000;
}

*,
*:before,
*:after {
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
}

img,
video {
    width: 100%;
    vertical-align: bottom;
    height: auto;
    display: inline-block;
}


a {
    display: inline-block;
    text-decoration: none;
    cursor: pointer;
    color: #083BAF;
}
a:hover {
    opacity: 0.75;
    transition: 0.3s;
}
button:hover {
    opacity: 0.75;
    transition: 0.3s;
}

li {
    list-style: none;
}

input {
    border: 1px;
    font-size: 1.6rem;
    height: 2em;
    padding: 0 1em;
    background: #efefef;
}
textarea{
    font-size: 1.6rem;
    padding: 1em;
}
button {
    border: 1px;
    font-size: 1.6rem;
    height: 2em;
    padding: 0 1em;
    background: #efefef;
}
span{
    display: inline-block;
}

.progress {
    background: #fff;
    color: #000;
    height: 100%;
    position: fixed;
    top: 0;
    z-index: 9999;
    width: 100%;
}

.progress__img {
    width: 15%;
    fill: #fff;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.header__button{
    display: flex;
    align-items: center;
    justify-content: flex-start;
}
.header {
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    padding: 11px 0% 10px 5%;
    height: 90px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 100;
    background-color: #fff;
    box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.19);
}
.header-height {
    height: 90px;
}

.header__logo {
    height: 69px;
    width: auto;
}

.headerBtnText{
    margin-left: 15px;
    line-height: 1.43;
    font-weight: 500;
    font-size:  1.4rem;
    letter-spacing: -0.06em;
}


.headerBtnText__under{
    display: block;

}

.headerBtnText__under {
    display: block;
}




.headerBtnText__underLeft{
    margin-top: -2px;
    font-family: din-2014, sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size:  2.1rem;
    letter-spacing: 0.06em;
    line-height: 1.29;
}

.headerBtnText__underRight{
    margin-left: -2px;
}

.header__list {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.header__item{
    overflow: hidden;
}

.header__item + .header__item{
    margin-left:50px;
}

.header__link{
    font-family: din-2014,sans-serif;
    font-style: normal;
    font-weight: 700;
    font-size:  1.6rem;
    letter-spacing: 0.05em;
    line-height: 1.25;
    padding-bottom: 2px;
    position: relative;
    height: 20px;
    z-index: 1;
    border-bottom:  1.5px solid #F8E24E;
    padding-bottom: 1px
}
.header__link::after{
    content: "";
    width: 100%;
    height: 1.5px;
    background-color: #F8E24E;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
}

.header__link--cta{
    background-color: #083BAF;
    color: #fff;
    width: 250px;
    height: 90px;
    background: #083baf;
    font-weight: bold;
    font-size:  2.1rem;
    letter-spacing: 0.05em;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    border: none;
}
.header__link--cta::before {
    height: 0;
    display: block;
    position: absolute;
    content: "";
    border-top: solid 40px #fff;
    border-right: solid 40px transparent;
    top: -6px;
    left: -6px;
    z-index: 2;
}

/*以下ハンバーガーメニューcss*/
.sp-hum {
    display: none;
}
.sp-header-nav {
    display: none;
}
/* __________footer_____________ */


.footer__wrap{
    text-align: center;
}

.footer__button{
    margin: auto;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    text-align: left;
    margin-bottom: 60px;
}

.footer__list{
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 60px;
}

.footer__item{
    display: inline-block;
    border-right: #083BAF solid 1px;
}

.footer__link{
    padding: 0 25.5px;
    font-weight: bold;
    font-size:  1.6rem;
    letter-spacing: 0.05em;
    text-align: center;
    color: #083baf;
}

.footer__item:last-child{
    border-right: none;
}


.footer__copy{
    border-top: #000 solid 0.5px;
    font-family: din-2014, sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size:  1.4rem;
    text-align: center;
    color: #a0a0a0;
    padding: 14px 0;
}




/* ______component______ */
@keyframes fadeInUp {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0, 20%, 0);
        transform: translate3d(0, 20%, 0);
    }
    100% {
        opacity: 1;
        -webkit-transform: none;
        transform: none;
    }
}


.block-under1280,
.block-under1000,
.block-under1024,
.block-under900,
.block-under768,
.block-under481,
.block-under376{
    display: none;
}


/* ______component______ */

@media screen and (max-width: 1100px) {
    .header {
        padding: 11px 0% 10px 2%;
    }

    .header__item + .header__item {
        margin-left: 30px;
    }
}

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


    .header {
        padding: 15px 5%;
    }
    .header-height {
        height: 70px;
    }

    .header__logo{
        height: 40px;
    }

    .headerBtnText {
        margin-left: 8px;
        font-size: 0.7rem;
    }

    .headerBtnText__underLeft{
        font-size:  1.2rem;
    }
    /* _________________________ */

    .header__nav{
        display: none;
    }
    
    .sp-header-nav,
    .sp-hum {
        display: block;
    }

    .header-hum {
        display: block;
        cursor: pointer;
        position: fixed;
        z-index: 300;
        top: 28px;
        right: 24px;
    }
    
    .header-hum.open{
        right: 40px;
    }

    .header-hum__wrap {
        position: relative;
        display: block;
        width: 30px;
        height: 17px;

        z-index: 300;
    }

    .header-hum__wrap.open {
        height: 23px;
    }

    .sp-header-nav {
        position: fixed;
        width: 100%;
        left: 0;
        top: 0;
        height: 0vh;
        overflow: hidden;
        transition: 0.3s;
        transition-property: height, padding;
        overflow: scroll;
        z-index: 200;
        padding: 0 5%;
        background-color: #083BAF;
    }

    .sp-header-nav.open {
        height: 55vh;
        padding: 120px 0;
    }

    .header__navCenter{
        position: relative;
    }

    .sp-header-nav__list {
        display: inline-block;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }

    .sp-header-nav__link{
        font-size:  1.4rem;
        letter-spacing: 0.05em;
        text-align: center;
        color: #fff;
        font-family: din-2014, sans-serif;
        font-weight: 700;
        font-style: normal;
        padding: 17px 0;
        width: 100%;
        display: block;
        min-width: 150px;
    }

    .header-hum__line {
        display: block;
        margin: auto;
        width: 100%;
        height: 2px;
        background-color: #083BAF;
        transition: 0.3s;
        position: absolute;
    }

    .header-hum__line--top {
        top: 0;
        left: 0;
        transform: translateY(0%);

    }

    .header-hum__line--top.open {
        top: 0;
        left: 0;
        transform: translateY(0%) rotate(-45deg);
        transform-origin: right;
        background-color: #fff;
    }
    
    .header-hum__line--center {
        top: 50%;
        left: 0;
        transform: translateY(-50%);
    }
    
    .header-hum__line--under {
        bottom: 0;
        left: 0;
        transform: translateY(0%);
    }
    
    .header-hum__line--center.open {
        opacity: 0;
        
    }
    
    .header-hum__line--under.open {
        bottom: 0;
        left: 0;
        transform: translateY(0%) rotate(45deg);
        transform-origin: right;
        background-color: #fff;
    }

}







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

    .header{
        height: 70px;
    }

    .block-under768{
        display: block;
    }

    .progress__img {
        width: 50%;
    }

    /* _________________ */
    .footer__button{
        margin-bottom: 40px;
    }

    .footer__list{
        flex-flow: column wrap;
    }

    .footer__item{
        border: none;
        margin-bottom: 20px;
    }

    .footer__item:last-child{
        margin-bottom: 0;
    }

    .footer__copy{
        padding: 16px 0;
    }
    
}

@media screen and (max-width:481px) {
    .block-under481{
        display: block;
    }

    .progress__img {
        width: 60%;
    }


}








