@charset "UTF-8";

body {
    width: 100%;
    /*overflow-x: hidden;*/
    font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
    margin: 0;
    text-align: justify;
    line-break: strict;
    overflow-wrap: break-word;
    word-wrap: break-word;
    }
    html, body {
        color: #000;
    }
    
    img {
        max-width: 100%;
        height: auto;
    }


/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
    
    
    .header_bg {
        background: #EFEFEF;
        box-sizing: border-box;
    }
    .header_wrap {
        position: relative;
        text-align: center;
        margin: 0 auto;
        width: 100%;
        max-width: 945px;
        padding: 3.035vw 0 2.335vw;
        box-sizing: border-box;
    }
    .header_logo {
        display: inline-block;
        width: 38.548vw;
    }
    .header_logo img {
        width: 100%;
    }
    .header_pr {
        display: inline-block;
        font-size: 0;
        position: absolute;
    	top: 50%;
    	right: 15px;
    	transform: translateY(-50%);
    	-webkit-transform: translateY(-50%);
    	-ms-transform: translateY(-50%);
    	width: 8.585%;
    }
    .header_pr img {
        width: 100%;
    }
    
    
    @media screen and (min-width: 440px) {
        .header_wrap {
            padding: 14px 0 10px;
        }
        .header_logo {
            width: 150px;
        }
        .header_pr {
            width: 40px;
        }
    }
    
    
    @media screen and (min-width: 640px) {
        .header_logo {
            width: 176px;
        }
        .header_wrap {
            padding: 15.79px 0 11.74px;
        }
    }
    
    
    
    
    
    
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
    .fv_wrap {
        font-size: 0;
        position: relative;
        margin: 0;
    }
    .fv_txt {
        display: none;
    }
    .itr_wrap {
        padding: 22px 22px 38px;
        margin: 0 auto;
        max-width: 920px;
    }
    .itr_txt {
        margin: 0;
        font-size: 13px;
        line-height: 1.64;
        font-weight: 600;
        color: #231815;
    }
    .sec1 {
        padding: 0 22px;
        margin: 0 auto 40px;
        max-width: 920px;
        position: relative;
        z-index: 5;
    }
    .lv2 {
        position: relative;
        margin: 0 0 40px;
        text-align: center;
        font-size: 22px;
    }
    .lv2::before {
        content: "";
        position: absolute;
    	left: 50%;
    	top: 20%;
    	transform: translateX(-50%);
    	-webkit-transform: translateX(-50%);
    	-ms-transform: translateX(-50%);
    	width: 100vw;
    	padding-top: 15%;
    	max-width: 1280px;
    	background-image: url(img3_sp.png);
    	background-position: center;
    	background-repeat: no-repeat;
    	background-size: cover;
    	display: inline-block;
    }    
    .lv2 > span {
        position: relative;
        z-index: 5;
        display: inline-block;
    }
    .flexsec_box1 {
        padding: 0 30px;
        margin: 0 0 40px;
    }
    .prof {
        text-align: center;
    }
    .prof_img {
        font-size: 0;
        margin: 0 0 20px;
    }
    .prof_txt1, .prof_txt2, .prof_txt3 {
        margin: 0;
        font-weight: 600;
    }
    .prof_txt1 {
        margin-bottom: 2px;
        font-size: 16px;
    }
    .prof_txt2 {
        margin-bottom: 2px;
        font-size: 13px;
        line-height: 1.285;
    }
    .prof_txt3 {
        font-size: 24px;
    }
    .prof_txt3 > span {
        font-size: 15px;
    }
    .lv3 {
        font-weight: 600;
        font-size: 16px;
        line-height: 1.7;
        margin: 0 0 22px;
    }
    .txt1 {
        font-size: 16px;
        line-height: 1.7;
        margin: 0 0 22px;
        text-align: left;
    }
    .name {
        display: inline-block;
        font-weight: 600;
    }
    .name1 {
        color: #941D3D;
    }
    .name2 {
        color: #004990;
    }
    .flexsec_box2 {
        margin: 0 0 30px;
    }
    .img1 {
        font-size: 0;
        margin: 0;
        text-align: center;
    }
    .img1 img {
        width: 850px;
    }
    .img2 {
        font-size: 0;
        margin: 0;
        text-align: center;
    }
    .img2 img {
        width: 650px;
    }
    .sec2 {
        padding: 0 22px;
        margin: 100px auto 0;
        max-width: 920px;
        position: relative;
        z-index: 5;
        text-align: center;
    }
    .sec2_txt0 {
        margin: 0 0 90px;
        font-size: 12px;
    }
    .sec2_bnr {
        margin: 0 0 60px;
        font-size: 0;
    }
    .sec2_bnr a {
        display: inline-block;
        width: 100%;
        max-width: 650px;
    }
    .sec2_logo {
        font-size: 0;
        margin: 0 0 30px;
    }
    .sec2_logo img {
        width: 245px;
    }
    .sec2_txt1 {
        font-weight: 600;
        font-size: 16px;
        margin: 0 0 10px;
    }
    .sec2_txt2 {
        font-size: 18px;
        margin: 0 0 20px;
    }
    .sec2_btn {
        font-size: 0;
        margin: 0 0 60px;
    }
    .sec2_btn a {
        display: inline-block;
        width: 100%;
        max-width: 275px;
    }
    .img3 {
        font-size: 0;
        margin: 0;
    }
    .main_wrap {
        border-bottom: 1px solid #cdcdcd;
    }
    .br-pc {
        display: none;
    }
    
    
    @media screen and (min-width: 640px) {
        .main_width {
            margin: 0 auto;
            max-width: 1280px;
            z-index: 5;
            position: relative;
        }
        .main_wrap {
            position: relative;
            overflow: hidden;
        }
        .main_in {
            position: relative;
            z-index: 5;
            overflow: hidden;
            background: #FFF;
            padding: 0 0 10px;
        }
        .mian_bg {
            position: absolute;
            width: 100vw;
            height: 100%;
            top: 0;
            z-index: 1;
            background-image: url(bg.png);
            background-size: 820px;
            background-repeat: repeat;
        }
        .mian_bg.-left {
            left: 0;
            transform: translateX(-100%) scale(-1,1);
        }
        .mian_bg.-right {
            right: 0;
            transform: translateX(100%);
        }
        .fv_txt {
            display: inline-block;
            width: 37%;
            position: absolute;
            left: 0;
            top: 34%;
            font-size: 0;
            z-index: 5;
            animation: 2s fv_txt_anime;
        }
        @keyframes fv_txt_anime {
            0% {
                transform: translateX(-100%);
                opacity: 0;
            }
            25% {
                transform: translateX(-100%);
                opacity: 0;
            }
            100% {
                transform: translateX(0%);
                opacity: 1;
            }
        }
        .itr_wrap {
            padding: 45px 20px;
        }
        .itr_txt {
            font-size: 17px;
        }
        .br-sp {
            display: none;
        }
        .br-pc {
            display: block;
        }
        .lv2 {
            font-size: 30px;
            margin-bottom: 70px;
        }
        .lv2::before {
            top: -70%;
            background-image: url(img3.png);
        }
        .flexsec {
            display: flex;
            justify-content: space-between;
            flex-wrap: wrap;
        }
        .flexsec.-row_reverse {
            flex-direction: row-reverse;
        }
        .flexsec_box1 {
            width: 300px;
        }
        .flexsec_box2 {
            width: calc(100% - 300px - 80px);
        }
        .lv3 {
            font-size: 18px;
        }
        .txt1 {
            font-size: 18px;
        }
        .prof_txt1 {
            font-size: 18px;
        }
        .prof_txt2 {
            font-size: 14px;
        }
        .prof_txt3 {
            font-size: 25px;
        }
        .prof_txt3 > span {
            font-size: 17px;
        }
        .sec1 {
            margin-bottom: 60px;
        }
        .fv_img {
            animation: 2s fv_img_anime;
        }
        @keyframes fv_img_anime {
            0% {
                opacity: 0;
            }
            100% {
                opacity: 1;
            }
        }
        .sec2_logo img {
            width: 304px;
        }
        .sec2_txt1 {
            font-size: 18px;
        }
    }
    
    
    
    .fadeup3 {
        opacity: 0;
        transform: translateY(50px);
    }
    .fadeup3_on {
        animation: 2s fadeup3_anime;
        opacity: 1;
        transform: translateY(0);
    }
    @keyframes fadeup3_anime {
        0% {
            opacity: 0;
            transform: translateY(50px);
        }
        30% {
            opacity: 0;
            transform: translateY(50px);
        }
        100% {
            opacity: 1;
            transform: translateY(0);
        }
    }
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
