@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: #AAC2C1;
        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: #729A97;
        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;
    }
    .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;
        }
        .fv_d {
            display: inline-block;
            position: absolute;
            width: 544px;
        }
        .fv_d1 {
            z-index: 2;
            bottom: -100px;
            left: -500px;
        }
        .fv_d2 {
            z-index: 2;
            top: 10px;
            right: -500px;
        }
    }
    
    
    
    
    .main_wrap {
        margin: 0 auto;
        max-width: 920px;
        padding: 40px 15px 40px;
        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 30px;
        margin: 0 0 30px;
    }
    .prof_bar {
        display: inline-block;
        position: absolute;
        z-index: 2;
        width: calc(100% + 15px);
        height: 132px;
        bottom: 0;
        right: 0;
        background: #D3E1DF;
        border-radius: 0 999px 999px 0;
    }
    .prof_bar::before {
        content: "";
        display: inline-block;
        width: 99px;
        height: 10px;
        background-image: url(dots.png);
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        position: absolute;
        top: 50%;
        left: 20px;
    	transform: translateY(-50%);
    	-webkit-transform: translateY(-50%);
    	-ms-transform: translateY(-50%);
    }
    .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: 0;
        right: auto;
        border-radius: 999px 0 0 999px;
    }
    .prof2 .prof_bar::before {
        left: auto;
        right: 20px;
    }
    .float2 {
        margin: 0 0 40px;
    }
    
    
    @media screen and (min-width: 640px) {
        .txt1 {
            font-size: 18px;
        }
        .prof1 {
            float: left;
        }
        .prof {
            width: 363px;
            margin: 0 45px 30px 0;
            padding: 0 0 40px;
        }
        .prof img {
            width: 100%;
        }
        .prof_bar {
            width: 100vw;
            height: 162.5px;
        }
        .prof_bar::before {
            right: 360px;
            left: auto;
        }
        .float1 {
            margin-bottom: 20px;
        }
        .prof2 {
            float: right;
            margin-right: 0;
            margin-left: 45px;
            margin-bottom: 20px;
        }
        .float2_txt {
            padding: 16px 0 0;
        }
        .prof2 .prof_bar::before {
            right: auto;
            left: 360px;
        }
        .ms_d {
            position: absolute;
            z-index: -1;
            width: 681.5px;
            height: 100%;
            background-size: contain;
            background-position: left top;
            background-repeat: repeat-y;
            top: -40px;
        }
        .ms_d1 {
            background-image: url(d2_left.png);
            left: -630px;
            height: calc(100% + 40px);
        }
        .ms_d2 {
            background-image: url(d2_right.png);
            right: -630px;
            top: -80px;
            height: calc(100% + 80px);
        }
    }
    
    
    .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: #AAC2C1;
    }
    .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);
        border-radius: 30px;
    }
    .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: #D3E1DF;
    }
    .bft_wrap {
        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;
    }
    .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 60px;
        }
    }
    
    
    





















