@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: #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;
    }
    
    
    
    
    .mwrap {
        overflow: hidden;
    }
    .fv_bg {
        background: #C2AB9D;
        position: relative;
        z-index: 5;
    }
    .fv_wrap {
        position: relative;
        margin: 0 auto;
        max-width: 1110px;
    }
    .fv_mv {
        font-size: 0;
        margin: 0;
        text-align: center;
        box-shadow: 0 0 5px rgba(0,0,0,.3);
        position: relative;
        z-index: 5;
    }
    .sec1_bg {
        background: #9A735B;
        position: relative;
        z-index: 3;
    }
    .sec1_wrap {
        text-align: center;
        padding: 0 10px 16px;
    }
    .sec1_logo {
        font-size: 0;
        margin: 0 0 17px;
    }
    .sec1_logo img {
        width: 196px;
    }
    .sec1_h {
        color: #FFF;
        font-family: 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho Pro", serif;
        font-weight: 600;
        margin: 0;
        font-size: 19.5px;
        line-height: 1.4818;
    }
    .sec1_h > span {
        font-size: 17.3px;
    }
    .fv_d {
        display: none;
    }
    
    
    @media screen and (min-width: 640px) {
        .sec1_wrap {
            padding: 0 20px 20px;
        }
        .sec1_logo {
            margin: 0;
        }
        .sec1_logo img {
            width: 287px;
        }
        .sec1_h {
            font-size: 57px;
            line-height: 1.2;
        }
        .sec1_h > span {
            font-size: 39px;
        }
    }
    @media screen and (min-width: 1100px) {
        .fv_d {
            display: inline-block;
            position: absolute;
            width: 964px;
            top: -64px;
        }

        .fv_d1 {
            z-index: 2;
            left: -890px;
        }
        .fv_d2 {
            z-index: 2;
            right: -890px;
        }

    }    
    
    
    .main_wrap {
        margin: 0 auto;
        max-width: 920px;
        padding: 40px 15px 0;
        box-sizing: border-box;
        position: relative;
    }
    .txt1 {
        font-size: 16px;
        font-weight: 600;
        line-height: 1.65111;
        margin: 0 0 40px;
        letter-spacing: .025em;
    }
    .prof_photo {
        text-align: center;
        font-size: 0;
        position: relative;
        z-index: 5;
    }
    .prof_photo img {
        width: 75%;
    }
    .prof {
        position: relative;
        padding: 0 0 0;
        margin: 0 0 30px;
    }
    .prof_bar {
        display: inline-block;
        position: absolute;
        z-index: 2;
        width: calc(100% + 15px);
        height: 132px;
        bottom: 10%;
        right: 15%;
        /*background: #E0D5CD;*/
        background-size: cover;
        background-repeat: no-repeat;
    }
    .prof1 .prof_bar {
        background-image: url(ob1.png);
        background-position: right top;
    }
    .txt2 {
        font-size: 16px;
        line-height: 1.722222;
        font-weight: 500;
        margin: 0;
    }
    .name {
        font-weight: 600;
    }
    .name1 {
        color: #EC6D74;
    }
    .name2 {
        color: #4694D1;
    }
    .float1 {
        margin: 0 0 40px;
    }
    .prof2 .prof_bar {
        left: 15%;
        right: auto;
        background-image: url(ob2.png);
        background-position: left top;
    }
    .float2 {
        margin: 0 0 40px;
    }
    
    
    @media screen and (min-width: 640px) {
        .txt1 {
            font-size: 18px;
        }
        .float1 {
            clear: both;
        }
        .prof1 {
            float: left;
        }
        .prof {
            width: 372px;
            margin: 0 46px 20px 0;
            padding: 0 0 0;
        }
        .prof img {
            width: 100%;
        }
        .prof_bar {
            width: 100vw;
            height: 200px;
            background-size: contain;
            bottom: 52px;
            right: 0;
        }
        .prof_bar::before {
            content: "";
            position: absolute;
            top: 0;
            right: 100px;
            width: 100%;
            height: 100%;
            background: #E0D5CD;
        }
        .prof2 .prof_bar::before {
            left: 100px;
        }
        .prof2 .prof_bar {
            left: 0;
        }
        .prof2 {
            float: right;
            margin-right: 0;
            margin-left: 46px;
            margin-bottom: 20px;
        }
        .ms_d {
            position: absolute;
            z-index: 5;
            width: 1080px;
            height: 100%;
            background-size: contain;
            background-position: left top;
            background-repeat: repeat-y;
            top: -120px;
        }
        .ms_d1 {
            background-image: url(d2_left.png);
            left: -1080px;
            height: calc(100% + 120px);
        }
        .ms_d2 {
            background-image: url(d2_right.png);
            right: -1080px;
            top: 30px;
            height: calc(100% - 30px);
        }
    }
    
    
    .bnrsec1 {
        position: relative;
        margin: 0 0 40px;
    }
    .bnrsec1::before {
        content: "";
        position: absolute;
        z-index: 1;
        width: 200vw;
        height: 100%;
        left: 50%;
        top: 0;
    	transform: translateX(-50%);
    	-webkit-transform: translateX(-50%);
    	-ms-transform: translateX(-50%);
    	background: #C2AB9D;
    }
    .bnrsec1_wrap {
        position: relative;
        z-index: 5;
        padding: 40px 0 30px;
        text-align: center;
    }
    .bnrsec1_img {
        font-size: 0;
        margin: 0 0 24px;
    }
    .bnrsec1_img img {
        width: 542.7px;
        box-shadow: 0 0 10px rgba(0,0,0,.3);
    }
    .bnrsec1_txt p {
        margin: 0;
        font-size: 14px;
        line-height: 1.4286;
        font-weight: 500;
    }
    
    
    .sec2_wrap .txt2 {
        margin-bottom: 60px;
    }
    .sec2_img {
        font-size: 0;
        text-align: center;
        margin: 0 0 48px;
    }
    .sec2_img img {
        width: 583px;
    }
    .sec2_txt1 {
        text-align: center;
        margin: 0 0 30px;
        font-size: 13px;
        font-weight: 500;
    }
    
    @media screen and (min-width: 640px) {
        .br-sp {
            display: none;
        }
    }
    
    
    .bft_bg {
        background: #E0D5CD;
        position: relative;
    }
    .bft_bg::before {
        content: "";
        position: absolute;
        top: 0;
        width: 200vw;
        left: 50%;
    	transform: translateX(-50%);
    	-webkit-transform: translateX(-50%);
    	-ms-transform: translateX(-50%);
    	height: 100%;
    	background: #E0D5CD;
    }
    .bft_wrap {
        position: relative;
        z-index: 5;
        text-align: center;
        padding: 42px 15px;
    }
    .bft_logo {
        font-size: 0;
        margin: 0 0 12px;
    }
    .bft_logo img {
        width: 242px;
    }
    .bft_txt1 {
        font-weight: 600;
        margin: 0 0 8px;
        font-size: 17px;
    }
    .bft_txt2 {
        font-size: 13px;
        font-weight: 500;
        margin: 0;
    }
    .bft_txt2 a {
        color: #231815;
        text-decoration: none;
    }
    .bft_txt2_1 {
        margin-bottom: 12px;
    }
    
    
    .switch_wrap {
        margin: 0 auto 14px;
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        position: relative;
        z-index: 5;
        max-width: 135px;
        text-align: center;
        box-sizing: border-box;
    }
    .switch {
        margin: 0;
        width: 50%;
        box-sizing: border-box;
    }
    .switch a {
        display: inline-block;
        background: #FFF;
        color: #AA0012;
        text-decoration: none;
        font-weight: 600;
        width: 100%;
        font-size: 14px;
        padding: 5px 0 3px;
        box-sizing: border-box;
        transition: .2s;
    }
    .switch a:hover {
        background: #E4A8A8;
        color: #FFF;
    }
    .switch.active a {
        background: #AA0012;
        color: #FFF;
    }
    .switch1 a {
        border-radius: 0 0 0 10px;
    }
    .switch2 a {
        border-radius: 0 0 10px 0;
    }

    @media screen and (min-width: 640px) {
        .switch_wrap {
            position: absolute;
            top: 0;
            left: calc(50% + 143.5px + 10vw + 5%);
            transform: translateX(-50%);
        	-webkit-transform: translateX(-50%);
        	-ms-transform: translateX(-50%);
        	width: 20vw;
        	max-width: 244px;
        }
        .switch a {
            font-size: 18px;
            padding: 9px 0 8px;
        }
        .switch1 a {
            border-radius: 0 0 0 18px;
        }
        .switch2 a {
            border-radius: 0 0 18px 0;
        }
    }
    @media screen and (min-width: 1110px) {
        .switch_wrap {
        	width: 244px;
            left: calc(50% + 330px);
                }
        }

    
    .postbnr {
        text-align: center;
        margin: 60px 0 100px;
    }
    .postbnr a {
        display: inline-block;
        transition: .2s;
    }
    .postbnr a:hover {
        opacity: .5;
    }
    .postbnr img {
        width: 451px;
    }
    @media screen and (min-width: 640px) {
        .postbnr {
            margin: 90px 0 100px;
        }
    }
    
    
    





















