@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;
}

body, html {
    color: #231815;
}

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: 2.535vw 0;
        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: 10px 0;
        }
        .header_logo {
            width: 179.598px;
        }
        .header_pr {
            width: 40px;
        }
    }
    
    
    @media screen and (min-width: 640px) {
        .header_logo {
            width: 210px;
        }
        .header_wrap {
            padding: 9.55px 0;
        }
    }
    
    
    
    .ft_line {
        display: inline-block;
        width: 100%;
        height: 1px;
        background: #cdcdcd;
        border: none;
    }
    
    
    
    .spfv_wrap {
        font-size: 0;
    }
    .spfv_wrap img {
        width: 100%;
    }
    .pcfv_bg {
        display: none;
    }
    .sec1_wrap {
        padding: 0 15px 30px;

    }
    .sec1_txt1 {
        font-size: 16px;
        line-height: 1.48148;
        font-weight: 600;
        margin: 0;
        color: #000;
    }
    
    @media screen and (min-width: 640px) {
        .spfv_wrap {
            display: none;
        }
        .pcfv_bg {
            display: block;
            overflow: hidden;
            position: relative;
            background-size: cover;
            background-position: center;
            background-repeat: no-repeat;
            background-image: url(bg1.png);
            padding: 0 0 15%;
        }
        .pcfv_bg::before {
            content: "";
            position: absolute;
            left: 0;
            bottom: 0;
            width: 100%;
            height: 22%;
            background: #faefbf;
            mix-blend-mode: multiply;
            opacity: .5;
        }
        .pcfv_wrap {
            margin: 0 auto;
            max-width: 1310px;
            padding: 0 0 0 30px;
            box-shadow: 0 0 8px rgba(0,0,0,.5);
            position: relative;
            box-sizing: border-box;
            background: #FFF;
        }
        .pcfv_mv {
            font-size: 0;
            position: relative;
            z-index: 3;
            animation: 3s pcfv_mv_anime;
        }
        @keyframes pcfv_mv_anime {
            0% {
                opacity: 0;
                transform: scale(1.3);
                -webkit-transform: scale(1.3);
            	-ms-transform: scale(1.3);
            }
            100% {
                opacity: 1;
                transform: scale(1);
                -webkit-transform: scale(1);
            	-ms-transform: scale(1);
            }
        }
        .pcfv_bar1 {
            position: absolute;
            left: 0;
            top: 0;
            width: 30px;
            height: 100%;
            background: linear-gradient(180deg, #a90029 0%, #d06c15 100%);
            z-index: 5;
            animation: 3s pcfv_bar1_anime;
        }
        @keyframes pcfv_bar1_anime {
            0% {
                opacity: 0;
                top: -120px;
            }
            60% {
                opacity: 0;
                top: -120px;
            }
            100% {
                opacity: 1;
                top: 0;
            }
        }
        .pcfv_bar2 {
            position: absolute;
            top: 252px;
            right: -87px;
            width: 30px;
            height: 139.718px;
            background: linear-gradient(180deg, #a90029 0%, #d06c15 100%);
            z-index: 5;
            animation: 3s pcfv_bar2_anime;
        }
        @keyframes pcfv_bar2_anime {
            0% {
                opacity: 0;
                top: 372px;
            }
            60% {
                opacity: 0;
                top: 372px;
            }
            100% {
                opacity: 1;
                top: 252px;
            }
        }
        .pcfv_bar3 {
            position: absolute;
            bottom: 22.2%;
            right: 0;
            width: 5%;
            height: 30px;
            background: linear-gradient(90deg, #a90029 0%, #d06c15 100%);
            z-index: 5;
            transform: translateY(100%);
        	-webkit-transform: translateY(100%);
        	-ms-transform: translateY(100%);
        	animation: 3s pcfv_bar3_anime;
        }
        @keyframes pcfv_bar3_anime {
            0% {
                opacity: 0;
                right: -80px;
            }
            60% {
                opacity: 0;
                right: -80px;
            }
            100% {
                opacity: 1;
                right: 0;
            }
        }
        .pcfv_txt1 {
            position: absolute;
            z-index: 5;
            width: 22.752%;
            top: 57%;
            left: 40%;
            font-size: 0;
            animation: 3s pcfv_txt1_anime;
        }
        @keyframes pcfv_txt1_anime {
            0% {
                opacity: 0;
                transform: translateY(60px);
            	-webkit-transform: translateY(60px);
            	-ms-transform: translateY(60px);
            }
            30% {
                opacity: 0;
                transform: translateY(60px);
            	-webkit-transform: translateY(60px);
            	-ms-transform: translateY(60px);
            }
            100% {
                opacity: 1;
                transform: translateY(0px);
            	-webkit-transform: translateY(0px);
            	-ms-transform: translateY(0px);
            }
        }
        .pcfv_txt1 img {
            width: 100%;
        }
        .pcfv_txt2 {
            font-size: 0;
            width: 85.2671%;
            max-width: 1117px;
            position: absolute;
            left: 50%;
            bottom: -29%;
            z-index: 5;
            transform: translateX(-50%);
        	-webkit-transform: translateX(-50%);
        	-ms-transform: translateX(-50%);
        	animation: 3s pcfv_txt2_anime;
        }
        @keyframes pcfv_txt2_anime {
            0% {
                opacity: 0;
                transform: translateX(-50%) translateY(60px);
            	-webkit-transform: translateX(-50%) translateY(60px);
            	-ms-transform: translateX(-50%) translateY(60px);
            }
            30% {
                opacity: 0;
                transform: translateX(-50%) translateY(60px);
            	-webkit-transform: translateX(-50%) translateY(60px);
            	-ms-transform: translateX(-50%) translateY(60px);
            }
            100% {
                opacity: 1;
                transform: translateX(-50%) translateY(0px);
            	-webkit-transform: translateX(-50%) translateY(0px);
            	-ms-transform: translateX(-50%) translateY(0px);
            }
        }
        .sec1_wrap {
            padding: 26px 15px;
        }
        .sec1_txt1 {
            max-width: 920px;
            margin: 0 auto;
            font-size: 18px;
            line-height: 2;
        }
    }
    
    @media screen and (min-width: 1310px) {
        .pcfv_wrap {
            transform: translateX(-15px);
        	-webkit-transform: translateX(-15px);
        	-ms-transform: translateX(-15px);
        }
        .pcfv_bg {
            padding-bottom: 201px;
        }
        .pcfv_bg::before {
            height: 201px;
        }
        .pcfv_bar3 {
            bottom: 201px;
            width: calc((100% - 1310px) / 2 + 80px)
        }
    }
    
    
    .sec2_bg {
        background-image: url(bg2.png);
        background-size: 100%;
        background-repeat: repeat-y;
        overflow: hidden;
    }
    .sec2_wrap {
        padding: 22px 16px 20px;
    }
    .sec2_box {
        background: #FFF;
        position: relative;
        padding: 22px 12px 38px;
        box-shadow: 5px 5px 3.5px rgba(37,20,28,.22);
        margin: 0 0 22px;
    }
    .lv2 {
        position: relative;
        margin: 0 0 30px;
        text-align: center;
        color: #036eb5;
        font-size: 20px;
        font-weight: 600;
        line-height: 1.3428;
        padding: 0 0 12px;
    }
    .lv2::before {
        content: "";
        position: absolute;
        left: 0;
        bottom: 0;
        width: 100%;
        height: 2.5px;
        background: linear-gradient(90deg, #a90029 0%, #f09400 100%);
    }
    .sec2_box_in {
        padding: 0 4px;
    }
    .txtstyle1 {
        font-size: 16px;
        line-height: 1.48148;
        font-weight: 500;
        margin: 0;
    }
    .prof {
        margin: 0 auto 31px;
        width: 66%;
    }
    .prof_img {
        font-size: 0;
    }
    .bar1 {
        position: absolute;
        width: 13.3%;
        right: 4%;
        bottom: 0;
        transform: translateY(50%);
    	-webkit-transform: translateY(50%);
    	-ms-transform: translateY(50%);
    }
    .img3 {
        text-align: center;
        font-size: 0;
        padding: 40px 0 10px;
    }
    .img3 img {
        width: 100%;
    }
    .space{
        margin:0 0.25em;
    }
    
    @media screen and (min-width: 640px) {
        .br-sp {
            display: none;
        }
        .sec2_wrap {
            max-width: 1050px;
            margin: 0 auto;
            padding: 34px 30px 1px;
        }
        .sec2_box {
            box-shadow: 7px 7px 5px rgba(37,20,28,.22);
            padding: 30px 45px 45px;
            margin: 0 0 45px;
        }
        .lv2 {
            color: #231815;
            font-size: 35px;
            margin: 0 auto 50px;
            max-width: 700px;
            padding-bottom: 14px;
        }
        .lv2::before {
            height: 5px;
        }
        .sec2_box_in {
            padding: 0;
        }
        .sec2_flex1 {
            display: flex;
            justify-content: space-between;
            flex-wrap: wrap;
        }
        .sec2_flex1_left {
            width: 314px;
        }
        .prof {
            width: 100%;
            margin: 0;
            padding: 0;
            position: relative;
        }
        .prof::before {
            content: "";
            position: absolute;
            bottom: 0;
            height: 1px;
            width: 100vw;
            background: #9c9c9d;
        }
        .prof1::before {
            right: 0;
        }
        .prof2::before {
            left: 0;
        }
        .sec2_flex1_right {
            width: calc(100% - 314px);
            padding: 0 0 0 5%;
            box-sizing: border-box;
        }
        .txtstyle1 {
            font-size: 18px;
            line-height: 1.7222;
        }
        .sec2_float1_right {
            width: 314px;
            float: right;
            margin: 0 0 30px 5%;
        }
        .img3 {
            padding: 60px 0 30px;
        }
        .img3 img {
            width: 83%;
        }
    
    }
    
    
    .sec3_wrap {
        text-align: center;
        padding: 80px 15px;
    }
    .sec3_txt1 {
        margin: 0;
        font-size: 12px;
    }
    
    
    .sec5_bg {
        background: #edebe9;
    }
    .sec5_wrap {
        padding: 80px 15px;
        text-align: center;
    }
    .sec5_logo {
        font-size: 0;
        margin: 0 0 33px;
    }
    .sec5_logo img {
        width: 425px;
    }
    .sec_txt1 {
        font-weight: 600;
        margin: 0 0 4px;
        font-size: 16px;
    }
    .sec_txt2 {
        margin: 0;
        font-size: 16px;
        line-height: 1.94875;
        color: #000;
    }
    .sec_txt2 a {
        text-decoration: none;
        color: #000;
    }
    
    @media screen and (min-width: 640px) {
        .sec_txt1 {
            font-size: 18px;
            margin: 0;
        }
        .sec_txt2 {
            font-size: 18px;
        }
    }
    
    
    .arrow {
        display: none;
    }
    @media screen and (min-width: 640px) {
        .sec2_box_wrap {
            position: relative;
        }
        .arrow {
            display: inline-block;
            position: absolute;
            width: 63.68%;
        }
        .arrow_right {
            left: -180px;
            transform: translateX(-100%);
        	-webkit-transform: translateX(-100%);
        	-ms-transform: translateX(-100%);
        	opacity: 0;
        }
        .arrow_on.arrow_right {
            animation: 2s inview_arrow_right_anime;
            left: -30px;
            opacity: 1;
        }
        @keyframes inview_arrow_right_anime {
            0% {
                left: -180px;
                opacity: 0;
            }
            100% {
                left: -30px;
                opacity: 1;
            }
        }
        .arrow_left {
            right: -180px;
            transform: translateX(100%);
        	-webkit-transform: translateX(100%);
        	-ms-transform: translateX(100%);
        	opacity: 0;
        }
        .arrow_on.arrow_left {
            animation: 2s inview_arrow_left_anime;
            right: -30px;
            opacity: 1;
        }
        @keyframes inview_arrow_left_anime {
            0% {
                right: -180px;
                opacity: 0;
            }
            100% {
                right: -30px;
                opacity: 1;
            }
        }
        .arrow1 {
            top: 30%;
        }
        .arrow2 {
            top: 20%;
        }
        .arrow3 {
            top: -10%;
        }
        .arrow4 {
            top: 57%;
        }
        
        
    }
    
    .inview_fade {
        opacity: 0;
        transform: translateY(60px);
    	-webkit-transform: translateY(60px);
    	-ms-transform: translateY(60px);
    }
    .inview_fade_on {
        animation: 2s inview_fade_anime;
        opacity: 1;
        transform: translateY(0);
    	-webkit-transform: translateY(0);
    	-ms-transform: translateY(0);
    }
    @keyframes inview_fade_anime {
        0% {
            opacity: 0;
            transform: translateY(60px);
        	-webkit-transform: translateY(60px);
        	-ms-transform: translateY(60px);
        }
        100% {
            opacity: 1;
            transform: translateY(0);
        	-webkit-transform: translateY(0);
        	-ms-transform: translateY(0);
        }
    }
    
    
    
    
    
    
    
    
    
    
    