@charset "utf-8";
*, *:before, *:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
html {
    font-size: 62.5%;
}
body{
    font-family: -apple-system, BlinkMacSystemFont, GeneralFonts, Hiragino Kaku Gothic ProN, Yu Gothic Medium, YuGothic-Medium, 游ゴシック Medium, YuGothic, 游ゴシック, Meiryo, Helvetica Neue, Segoe UI, sans-serif;
    color: #34333C;
}
.center{text-align:center;}
.left{text-align:left;}
.right{text-align:right;}
.bold{font-weight:700;}
a{
	text-decoration: underline;
	color:#3366CF;/* リンク色 */
    word-break: break-all;
    text-indent: 0;}
a:hover{
	text-decoration: none;}

.maker {
    background: linear-gradient(transparent 75%, #ffefcc 25%);
}
.bg_gradient{
	background: linear-gradient(90deg, #c5f1f8 0%, #ffeaec 100%);
}
.bg_pink{
	background: #ffe7f5;
}
/*************************************************
PC
**************************************************/
.only_pc{display: block!important;}
.only_sp{display: none!important;}
.pd_t_b_50{padding: 50px 0;}
.pd_t_b_40{padding: 40px 0;}
.pd_t_b_30{padding: 30px 0;}
.pd_t_b_20{padding: 20px 0;}
.pd_t_b_10{padding: 10px 0;}
.mt_60{margin-top: 60px;}
.mt_50{margin-top: 50px;}
.mt_40{margin-top: 40px;}
.mt_30{margin-top: 30px;}
.mt_20{margin-top: 20px;}
.mt_15{margin-top: 15px;}
.mt_10{margin-top: 10px;}
.pb_60{padding-bottom: 60px;}
.pb_20{padding-bottom: 20px;}
.w1100{width:1100px;margin:0 auto;}
.w1000{width:1000px;margin:0 auto;}
.w950{width:950px;margin:0 auto;}
.w900{width:900px;margin:0 auto;}
.w750{width:750px;margin:0 auto;}
.note,
.notice{
    font-size: 1.4rem;
}
.notice{
    padding-left: 1.5em;
    position: relative;
}
.notice:before{
    content: "※";
    display: inline-block;
    position: absolute;
    top: 0;
    left: 0;
}
.indent{
 padding-left: 1em;
text-indent: -1em;
}

/*contents-------------*/
p{
	font-size: 1.6rem;
}
#FV_area{
	text-align: center;
	 background: url("../img/fv_bg_01.jpg");
    background-position: top, center;
    background-repeat: repeat-x;
	position: relative;
}
#FV_area h1{
	width: 1100px;
	margin: 0 auto;
}
.btn_area{
	position: relative;
	margin-top: 20px;
	text-align: center;
}
#FV_area .btn_area{
	position: absolute;
	bottom: 40px;
	right: calc(50% - 260px);
	z-index: 1;
}
.btn_area a{
	display: block;
	text-align: center;
    width: 520px;
	margin: 0 auto;
    background: linear-gradient( #efb536 0%, #efb536 48%, #efa736 52%, #efa736 100%);
    color: #ffffff;
	border: 5px solid #ffffff;
	font-weight: bold;
    font-size: 2.8rem;
    padding: 23px 0 21px;
    border-radius: 999px;
    text-decoration: none;
    box-shadow: 0px 0px 10px #a67176;
}
.btn_area:hover{
	opacity: 0.7;
}
.btn_area p{
	position: absolute;
    top: -30px;
    right: calc(50% - 150px);
    background: #ffffff;
    border: 5px solid #c48b31;
    font-weight: bold;
    width: 300px;
    font-size: 2.0rem;
    padding: 8px 0px 6px;
    border-radius: 999px;
	z-index: 2;
}

/*content_01-------------*/
#content_01{
	padding: 50px 0 120px;
}
.Q_list{
	display: flex;
	justify-content: space-between;
	position: relative;
}
.Q_list:after{
    display: inline-block;
    content: "";
    position: absolute;
    border-left: dotted 11px #ffd1df;
    bottom: -70px;
    right: calc(50% - 5px);
    height: 60px;
}
.Q_list li{
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 48%;
	border: 5px #ffd1df solid;
	padding: 20px;
}
.Q_list li .img_box{
	width: 30%;
}
.Q_list li .text_box{
	width: 67%;
}
.Q_list li p{
	font-weight: bold;
	font-size: 1.6rem;
}
.Q_list li p.title{
	font-size: 2.6rem;
	margin-bottom: 20px;
	line-height: 1.7;
}
.Q_list li p.title span{
	color: #c41485;
	background: linear-gradient(transparent 75%, #ffe9b9 25%);
}

/*content_02-------------*/
#content_02{
	padding: 70px 0 50px;
	text-align: center;
	position: relative;
}
#content_02 h2 {
    position: absolute;
    top: -35px;
    right: calc(50% - 300px);
    width: 600px;
    margin: 0 auto 30px;
    padding: 15px 0 13px;
    background: #b60081;
	border-radius: 5px;
    color: #ffffff;
    font-size: 3.0rem;
}
#content_02 h2:before {
    content: "";
    display: inline-block;
    position: absolute;
    width: 0;
    height: 0;
    border-left: 15px solid transparent;
    border-right: 15px solid transparent;
    border-top: 20px solid #b60081;
    border-radius: 5px;
    bottom: -10px;
    right: calc(50% - 15px);
}
#content_02 h2 span{
	color: #ffefcd;
}
#content_02 .text_box{
	width: 650px;
    margin: 30px 0 50px;
    color: #ffffff;
    border-radius: 999px;
    background: #ffffff;
    padding: 6px;
    border: solid 4px #b60081;
    font-size: 2.6rem;
    line-height: 1.7;
    position: relative;
}
.line_box{
	border: dotted 4px #b60081;
	padding: 25px 0;
	border-radius: 999px;
}
#content_02 .text_box p{
	font-size: 3.0rem;
  font-weight: bold;
  background: linear-gradient(-24deg, #ff5d5d 0%, #ff4192 50%, #b60081 100%);
  -webkit-background-clip: text;
  color: transparent;
}
#content_02 .text_box img{
	position: absolute;
	bottom: -20px;
	right: -330px;
	width: 400px;
}
#content_02 .text{
	font-size: 2.4rem;
	line-height: 1.8;
	font-weight: bold;
}
#content_02 .text span{
	background: linear-gradient(transparent 60%, #ffffff 40%);
	padding: 0 3px;
	color: #b60081;
}
#content_02 .img_box{
	width: 600px;
    margin: 30px auto 0;
}
/*btn_area-------------*/
.btn_list{
	display: flex;
	justify-content: center;
	gap:30px 40px;
	flex-wrap: wrap;
}
.btn_list li{
	width: 520px;
}
.btn_list img:hover{
	opacity: 0.7;
}


/*fotter-------------*/

/*************************************************
SP
**************************************************/
@media screen and (max-width: 780px) {	
.only_sp{display: block!important;}
.only_pc{display: none!important;}
.pd_t_b_50{padding: 30px 0;}
.pd_t_b_40{padding: 25px 0;}
.pd_t_b_30{padding: 20px 0;}
.pd_t_b_20{padding: 10px 0;}
.pd_t_b_10{padding: 5px 0;}
.mt_60{margin-top: 40px;}
.mt_50{margin-top: 30px;}
.mt_40{margin-top: 25px;}
.mt_30{margin-top: 20px;}
.mt_20{margin-top: 10px;}
.mt_15{margin-top: 8px;}
.mt_10{margin-top: 5px;}
.pb_60{padding-bottom: 35px;}
.pb_20{padding-bottom: 15px;}
.w1100,.w1000,.w950,.w900,.w750{
	width:auto;
	margin:0 15px;
}
.note,
.notice{
    font-size: 1.2rem;
}
.notice{
    padding-left: 1.5em;
}

/*contents-------------*/
p{
	font-size: 1.4rem;
}
#content{
	padding-bottom: 30px;
}
#FV_area{
	text-align: center;
	 background: url("../img/fv_bg_01.jpg");
    background-position: top, center;
    background-repeat: repeat-x;
	position: relative;
}
#FV_area h1{
	width: 100%;
	margin: 0;
}
#FV_area .btn_area{
	bottom: 7vw;
	right: 0;
	width: 100%;
}
.btn_area a{
    width: 92%;
	margin: 0 auto;
	border: 3px solid #ffffff;
    font-size: 5.6vw;
    padding: 2.5vw 0 2.3vw;
}
.btn_area p{
    top: -6.5vw;
    right: 15%;
    border: 3px solid #c48b31;
    width: 70%;
    font-size: 4vw;
    padding: 1.1vw 0px 1vw;
}

/*content_01-------------*/
	#content_01{
		padding: 30px 0 85px;
	}
.Q_list{
	display: block;
}
.Q_list:after{
    border-left: dotted 8px #ffd1df;
    bottom: -65px;
    right: calc(50% - 4px);
    height: 60px;
}
.Q_list li{
	width: 100%;
	border: 5px #ffd1df solid;
	padding: 15px;
	align-items: flex-end;
}
.Q_list li:nth-of-type(2n){
	flex-direction: row-reverse;
	text-align: right;
}
.Q_list li+li{
	margin-top: 30px;
}
.Q_list li .img_box{
	width: 30%;
}
.Q_list li .text_box{
	width: 70%;
}
.Q_list li p{
	font-size: 4vw;
}
.Q_list li p.title{
	font-size: 5.3vw;
}

/*content_02-------------*/
#content_02{
	padding: 30px 0;
}
#content_02 h2 {
        top: -35px;
        position: relative;
        right: auto;
        width: 100%;
        margin: -25px 0 0;
        padding: 15px 0 13px;
        font-size: 2.2rem;
}
#content_02 .text_box{
	width: 100%;
	margin: 0 0 43vw;
	padding: 5px;
	border: solid 3px #b60081;
	font-size: 4.8vw;
}
.line_box{
	border: dotted 3px #b60081;
	padding: 15px 0;
}
#content_02 .text_box p{
	font-size: 4.8vw;
	text-align: center;
}	
    #content_02 .text_box img {
        position: absolute;
        bottom: -37.5vw;
        right: calc(50% - 30vw);
        width: 61vw;
}
#content_02 .text{
	font-size: 1.6rem;
	text-align: left;
}
#content_02 .img_box{
	width: auto;
    margin: 20px 0 0;
}
/*btn_area-------------*/

.btn_list .btn_area a{
	width: 100%;
}
}/*SP体裁ここまで--------------------------------------------- */


/* right_arrow 右向きアロー
------------------------------------------------------------ */
    a.right_arrow {
    position: relative;
    padding-right: 16px;
    text-decoration: none;
	}
    .right_arrow:after {
        position: absolute;
    display: inline-block;
    content: "";
    line-height: 1;
    right: 30px;
    top: 1.2em;
    width: 0.7em;
    height: 0.7em;
    border: 4px solid currentColor;
    border-top: 0;
    border-right: 0;
    box-sizing: border-box;
    transform: rotate(-135deg);
}
@media screen and (max-width: 740px) {
    a.right_arrow {
    padding-right: 17px;
	}
	.right_arrow:after {
    right: 25px;
    top:0.9em;
    width: 0.6em;
    height: 0.6em;
	border: 3px solid currentColor;
	border-top: 0;
    border-right: 0;
}
}
