@charset "utf-8";

@media screen and (max-width: 800px) {
    #header:before {
        height: 75vw;
    }

    @keyframes hy {
        0% {
            transform: rotate(0);
        }

        50% {
            transform: rotate(0);
            width: 72%;
            height: 77vw;
        }

        50% {
            transform: rotate(0);
            width: 72%;
            height: 77vw;
        }

        100% {
            width: 75%;
        }
    }


}

/* ==========================================================================
	main
========================================================================== */
#main {
    position: relative;
    margin-top: 120px;
    padding-bottom: 11.4vw;
    z-index: 50;
}

#main .fadein {
    opacity: 0;
    transform: translateX(50px);
    transition: .4s;
}

#main .fadein.move {
    opacity: 100;
    transform: translateX(0px);
}

#main .fadein img {

    display: inline-block;
    width: 355px;
    margin-right: 60px;
    vertical-align: middle;

}

#main .fadein span {
    display: inline-block;
    font-size: 16px;
    font-weight: bold;
    vertical-align: middle;
}


#main .kv {
    opacity: 0;
    transform: translateY(50px);
    transition: .4s;
    width: 100%;
    margin: 8.5714vw 0 7.14vw;
    z-index: 10;
}

#main .kv.move {
    opacity: 100;
    transform: translateY(0px);

}

#main .kv img {
    border: 10px solid #fff;
    box-sizing: border-box;
}

#main h3 {
    position: relative;
    font-size: 38px;
    line-height: 66px;
    font-weight: bold;
    margin-bottom: 32px;
    z-index: 20;
}

#main h3 span {
    font-size: 38px;
    line-height: 66px;
    font-weight: bold;
    color: #065f8e;
}

#main .b_txt {
    position: relative;
    font-size: 15px;
    font-weight: 500;
    color: #065f8e;
    z-index: 20;
}

#main .intro_img01 {
    position: absolute;
    width: 35.74vw;
    right: -7.14vw;
    top: 57.28vw;
    z-index: 15;
    opacity: 0;
    transform: translateX(50px);
    transition: .8s;
}

#main .intro_img01.move {
    opacity: 100;
    transform: translateX(0px);
}

#main .intro_txt {
    position: relative;
    margin-top: 15.35vw;
    z-index: 10;
    right: 0;
    font-size: 15px;
    line-height: 36px;
    font-weight: bold;
    width: 40%;
    margin-left: 60%;


}

#main .intro_img02 {
    position: absolute;
    left: -7.4vw;
    bottom: -11.4vw;
}

#main .intro_img02 .inview {
    position: relative;
    z-index: 5;
    opacity: 0;
    transform: translateX(-50px);
    transition: .8s;

    width: 50vw;
}

#main .intro_img02 .inview.move {
    opacity: 100;
    transform: translateX(0px);

}


#main .intro_img02 .icon {
    position: absolute;
    display: block;
    width: 18vw;
    right: -9vw;
    top: -9vw;
    z-index: 4;
    -webkit-animation: m-scale 9s infinite ease-in-out;
    -ms-animation: m-scale 9s infinite ease-in-out;
    -o-animation: m-scale 9s infinite ease-in-out;
    animation: m-scale 9s infinite ease-in-out;
}


@-moz-keyframes m-scale {
    50% {
        transform: scale(0.8) rotate(90deg);
    }
}

@-webkit-keyframes m-scale {
    50% {
        transform: scale(0.8) rotate(90deg);
    }
}

@-o-keyframes m-scale {
    50% {
        transform: scale(0.8) rotate(90deg);
    }
}

@-ms-keyframes m-scale {
    50% {
        transform: scale(0.8) rotate(90deg);
    }
}

@keyframes m-scale {
    50% {
        transform: scale(0.8) rotate(90deg);
    }
}


#main .icon02 {

    display: block;
    position: absolute;
    width: 57.28vw;
    max-width: 1122px;
    bottom: -36.18vw;
    left: -33.57vw;
    z-index: 1;
    -webkit-animation: main_icon01 15s infinite;
    -ms-animation: main_icon01 15s infinite;
    -o-animation: main_icon01 15s infinite;
    animation: main_icon01 15s infinite;
}


@-moz-keyframes main_icon01 {
    50% {
        transform: translate(50px, 50px);
    }
}

@-webkit-keyframes main_icon01 {
    50% {
        transform: translate(50px, 50px);
    }
}

@-o-keyframes main_icon01 {
    50% {
        transform: translate(50px, 50px);
    }
}

@-ms-keyframes main_icon01 {
    50% {
        transform: translate(50px, 50px);
    }
}

@keyframes main_icon01 {
    50% {
        transform: translate(50px, 50px);
    }
}


@media screen and (max-width: 800px) {
    #main {
        margin-top: 55px;
        padding-bottom: 0;
    }

    #main .fadein img {
        width: 223px;
        margin-right: 20px;

    }

    #main .fadein span {
        font-size: 12px;
    }


    #main .kv {
        width: calc(100% + 5vw);
        margin: 17.5vw 0 10vw;
        z-index: 10;
    }

    #main .kv img {
        border: 5px solid #fff;
        border-right: none;
    }

    #main h3 {
        font-size: 25px;
        line-height: 45px;
        margin-bottom: 15px;
        z-index: 20;
        padding: 0 10px;
        box-sizing: border-box;
    }

    #main h3 span {
        font-size: 25px;
        line-height: 45px;
        box-sizing: border-box;
    }

    #main .b_txt {
        font-size: 10px;
        padding: 0 10px;
        box-sizing: border-box;
    }

    #main .intro_img01 {
        width: 53vw;
        right: 0;
        top: 110vw;
        opacity: .5;
        transform: translateX(0px);
    }

    #main .intro_img01.move {
        opacity: .5;
        transform: translateX(0px);
    }

    #main .intro_txt {
        margin-top: 13vw;
        font-size: 14px;
        line-height: 33px;
        width: 100%;
        margin-left: 0;
        z-index: 20;
        padding: 0 10px;
        box-sizing: border-box;


    }

    #main .intro_img02 {
        position: relative;
        left: -5vw;
        bottom: 0;
        margin-top: 18vw;
    }

    #main .intro_img02 .inview {
        position: relative;
        z-index: 5;
        opacity: 0;
        transform: translateX(-50px);
        transition: .8s;

        width: 87.5vw;
    }

    #main .intro_img02 .icon {
        width: 32vw;
        right: -16vw;
        top: -16vw;
    }

    #main .icon02 {
        width: 100vw;
        bottom: -65vw;
        left: -55vw;
    }


    @-moz-keyframes main_icon01 {
        50% {
            transform: translate(25px, 25px);
        }
    }

    @-webkit-keyframes main_icon01 {
        50% {
            transform: translate(25px, 25px);
        }
    }

    @-o-keyframes main_icon01 {
        50% {
            transform: translate(25px, 25px);
        }
    }

    @-ms-keyframes main_icon01 {
        50% {
            transform: translate(25px, 25px);
        }
    }

    5 @keyframes main_icon01 {
        50% {
            transform: translate(25px, 25px);
        }
    }
}



@media screen and (max-width: 500px) {
    #main .intro_img01 {
        top: 125vw;
    }

    #main .fadein span.about_title_ja {
        display: block;
        margin: 20px 0 0;
    }
}

/* ==========================================================================
	main02
========================================================================== */
.main02 {
    position: relative;
    z-index: 55;
    padding-bottom: 9.2vw;
}

.main02:before {
    content: "";
    display: block;
    position: absolute;
    width: 71.4vw;
    height: 27.85vw;
    top: 8.21vw;
    right: 0;
    border-radius: 60px 0 0 0px;
    background: #f2ef5b;
    z-index: 1;
    -webkit-animation: right-left 10s infinite;
    -ms-animation: right-left 10s infinite;
    -o-animation: right-left 10s infinite;
    animation: right-left 10s infinite;
}


@-moz-keyframes right-left {
    50% {
        transform: translate(50px, 0);
    }
}

@-webkit-keyframes right-left {
    50% {
        transform: translate(50px, 0);
    }
}

@-o-keyframes right-left1 {
    50% {
        transform: translate(50px, 0);
    }
}

@-ms-keyframes right-left {
    50% {
        transform: translate(50px, 0);
    }
}

@keyframes right-left {
    50% {
        transform: translate(50px, 0);
    }
}


.main02 .intro_img03 {
    position: relative;
    width: 33.3%;
    margin: 0 0 15.7vw 66.6%;
    z-index: 10;
    transform: translateY(50px);
    transition: .8s;
    opacity: 0;
}

.main02 .intro_img04 {
    position: absolute;
    left: -7.14vw;
    top: 16.4vw;
    z-index: 15;
    width: 39.28vw;
    transform: translateY(50px);
    transition: .8s;
    opacity: 0;

}


.main02 .intro_img03.move,
.main02 .intro_img04.move {
    opacity: 100;
    transform: translateY(0px);
}


.main02 h2 {
    padding-left: 45.41%;
    box-sizing: border-box;
    font-size: 30px;
    line-height: 58px;
    font-weight: bold;
}

.main02 p {
    padding-left: 45.41%;
    box-sizing: border-box;
    font-size: 15px;
    line-height: 36px;
    font-weight: bold;
}

.main02 p.intro_txt {
    margin: 65px 0 40px;
}

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

    .main02 {
        padding-bottom: 18vw;
        padding-top: 53.13vw;
    }

    .main02:before {
        display: none;
    }

    .main02 .intro_img03 {
        position: absolute;
        width: 50vw;
        margin: 0;
        right: 0;
        top: -71.13vw;
    }

    .main02 .intro_img04 {
        position: relative;
        left: -5vw;
        top: auto;
        width: 59.6vw;
    }

    .main02 h2 {
        position: absolute;
        top: 0;
        left: 68vw;
        writing-mode: vertical-rl;
        font-feature-settings: normal;
        font-size: 24px;
        font-weight: 700;
        line-height: 1.8;
        padding: 0;
    }

    .main02 h3 {
        width: 69px;
        position: absolute;
        top: 0;
        left: calc(59.6vw + 8.75vw);

    }

    .main02 p {
        padding: 0 10px;
        font-size: 14px;
        line-height: 33px;
    }

    .main02 p.intro_txt {
        width: 51.8vw;
        margin: 14.25vw 0 35px;
    }
}

/* ==========================================================================
	promise
========================================================================== */
.promise {
    position: relative;
    z-index: 60;
    padding: 10vw 5vw 8.57vw;
    box-sizing: border-box;
    background: #f1f0e9;
}

.promise .tit span {
    color: #242424;
}

.promise .tit span.blue {
    color: #065f8e;
}

.promise .tit_txt {
    display: flex;
    justify-content: center;
    position: absolute;
    width: 200px;
    top: -120px;
    left: 14.28vw;
}

.promise .tit_txt h2 {
    z-index: 50;
    opacity: 0;
    transform: translateX(-50px);
    transition: .8s;
    margin-left: 20px;
}

.promise .tit_txt h2.move {
    opacity: 1;
    transform: translateX(0);
}

.promise .tit_txt span.en {

    font-size: 15px;
    font-weight: 500;
    animation-delay: 4s;
    opacity: 0;
    transform: translateX(-50px);
    transition: 1s;

}

.promise .tit_txt span.en.move {
    opacity: 1;
    transform: translateX(0);

}

.promise .promise_box {
    position: relative;
    width: 69.16%;
    z-index: 15;
    transition: .8s;
    opacity: 0;
    transform: translateY(50px);
}

.promise .promise_box.move {
    opacity: 1;
    transform: translateY(0);
}

.promise_box .w_box {
    position: relative;
    width: 100%;
    background: #fff;
    border-radius: 60px;
    padding: calc(6.4vw + 10px) 5.3vw 6vw;
    box-sizing: border-box;
    z-index: 10;
}

.promise .promise_box .en {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 280px;
    height: 60px;
    border: 2px solid #065f8e;
    color: #065f8e;
    font-size: 18px;
    font-weight: 500;
    left: 6.4vw;
    top: -30px;
    z-index: 15;
    border-radius: 60px;
    font-style: italic;
}

.promise .promise_box h3 {
    font-size: 20px;
    line-height: 1.5;
    font-weight: bold;
    margin-bottom: 16px;
}

.promise .promise_box p {
    font-size: 15px;
    line-height: 36px;
    font-weight: bold;
}

.promise .promise_box.box01,
.promise .promise_box.box03 {
    margin-left: 30%;
}

.promise .promise_box.box02 {
    margin: 6vw 0 6vw 8.3vw;
}

.promise_img01 {
    position: absolute;
    width: 20vw;
    right: -5.8vw;
    top: calc(100% - 2.857vw);
    z-index: 20;
}

.promise_img02 {
    position: absolute;
    width: 38.57vw;
    left: -5vw;
    bottom: -4.285vw;
    z-index: 1;
}

.promise_box_btn {
    margin: 30px 0 0;
}

.promise_box_btn a {
    font-size: 15px;
    font-weight: bold;
    color: #242424;
    width: 100%;
    height: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #Fff;
    border: 3px solid #000;
    border-radius: 5px;
    padding: 2px 0 0;
    box-sizing: border-box;
    position: relative;
    transition: .3s;
}

.promise_box_btn a::after {
    content: '';
    display: block;
    width: 21px;
    height: 11px;
    position: absolute;
    right: 30px;
    top: 0;
    bottom: 0;
    margin: auto;
    background: url(../image/common/link_icon.png);
    background-size: contain;
    background-repeat: no-repeat;
    transition: .3s;
}

.promise_box_btn a:hover {
    color: #065f8e;
}

.promise_box_btn a:hover::after {
    right: 25px;
}


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


    .promise {
        padding: 14vw 0 15vw;
    }

    .promise .tit_txt {
        display: block;
        position: relative;
        width: 100%;
        top: auto;
        left: auto;
        text-align: center;
    }

    .promise .tit_txt h2 {
        font-size: 27px;
        line-height: 42px;
        margin-left: 0;
        margin-bottom: 13px;
    }


    .promise .tit_txt .v_txt {

        writing-mode: horizontal-tb;
        font-feature-settings: normal;
        display: inline-block;
        -webkit-writing-mode: horizontal-tb;
    }

    .promise .tit_txt .en.v_txt {
        display: none;
    }

    .promise .tit_txt h2 span {
        font-size: 27px;
        line-height: 42px;
    }

    .promise .tit_txt span.en {
        font-size: 11px;
        text-align: center;
        margin-bottom: 13.75vw;
    }

    .promise .promise_box {
        width: 100%;
        padding-top: 240px;
    }

    .promise .promise_box:before {
        content: "";
        display: block;
        width: 100%;
        height: 300px;
        position: absolute;
        left: 0;
        top: 0;
        z-index: 1;
        background: url(../image/about/promise_img01_sp.jpg) center center;
        background-size: cover;
    }

    .promise .promise_box.box02:before {
        background-image: url(../image/about/promise_img02_sp.jpg);
    }

    .promise .promise_box.box03:before {
        background-image: url(../image/about/promise_img03_sp.jpg);
    }

    .promise_box .w_box {
        width: calc(100% - 10vw - 20px);
        border-radius: 30px;
        padding: 50px 9.9vw 45px;
        z-index: 5;
        margin: 0 auto;
    }

    .promise .promise_box .en {
        width: 170px;
        height: 40px;
        border: 1px solid #065f8e;
        color: #065f8e;
        font-size: 11px;
        left: 0;
        right: 0;
        margin: auto;
        top: -20px;
        z-index: 15;
        border-radius: 40px;
    }

    .promise .promise_box h3 {
        font-size: 17px;
        line-height: 28px;
        margin-bottom: 18px;
    }

    .promise .promise_box p {
        font-size: 13px;
        line-height: 26px;
    }

    .promise .promise_box.box01,
    .promise .promise_box.box03 {
        margin-left: 0;
    }

    .promise .promise_box.box02 {
        margin: 12.5vw 0;
    }


    .promise_box_btn a {
        font-size: 15px;
        height: 50px;
        border-width: 2px;
        border-radius: 2px;
    }

    .promise_box_btn a::after {
        width: 16px;
        height: 8px;
        right: 20px;
    }

    .promise_box_btn a:hover::after {
        right: 15px;
    }

}

/* ==========================================================================
	company 
========================================================================== */
.company {
    position: relative;
    z-index: 5;
    padding: 14.2vw 0 9.285vw;
}

.company .contents_inr {
    -js-display: flex;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.company h2 {
    display: inline-block;
    font-size: 44px;
    font-weight: bold;
}

.company h2 .en {
    display: block;
    font-size: 15px;
    font-weight: 500;
    margin-top: 37px;
}

.company ul {
    width: 70%;
}

.company li {
    -js-display: flex;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 34px 20px;
    box-sizing: border-box;
    border-top: 1px solid #065f8e;
}

.company li:last-child {
    border-bottom: 1px solid #065f8e;
}

.company h3 {
    font-size: 16px;
    font-weight: bold;
    color: #065f8e;
    line-height: 25px;
    width: 22%;
    box-sizing: border-box;
}

.company p {
    font-size: 15px;
    font-weight: bold;
    line-height: 25px;
    width: 78%;
}

@media screen and (max-width: 800px) {
    .company {
        position: relative;
        z-index: 5;
        padding: 14vw 10px 11vw;
    }

    .company .contents_inr {
        display: block;
    }

    .company h2 {
        display: block;
        font-size: 27px;
    }

    .company h2 .en {
        font-size: 11px;
        margin-top: 18px;
    }

    .company ul {
        width: 100%;
        margin-top: 42px;
    }

    .company li {
        padding: 18px 10px;
        border-top: 1px solid #065f8e;
    }

    .company li:last-child {
        border-bottom: none;
    }

    .company h3 {
        font-size: 14px;
        line-height: 24px;
        width: 25%;
    }

    .company p {
        font-size: 14px;
        line-height: 24px;
        width: 75%;
        padding-left: 10px;
        box-sizing: border-box;
    }


}