@charset "utf-8";

/******************************************************************** loading
*/
#loading {
	width: 100vw;
	height: 100vh;
	transition: all 1s;
	background-color: #fff;

	display: flex;
	justify-content: center;
	align-items: center;

	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
}

.spinner,
.spinner:after {
  border-radius: 50%;
  width: 12em;
  height: 12em;
}
.spinner {
  margin: 60px auto;
  font-size: 10px;
  position: relative;
  text-indent: -9999em;
  border-top: 0.1em solid rgba(188, 188, 188, 0.2);
  border-right: 0.1em solid rgba(188, 188, 188, 0.2);
  border-bottom: 0.1em solid rgba(188, 188, 188, 0.2);
  border-left: 0.1em solid #bcbcbc;
  -webkit-transform: translateZ(0);
  -ms-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-animation: load8 1.1s infinite linear;
  animation: load8 1.1s infinite linear;
}
@-webkit-keyframes load8 {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes load8 {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

/* ローディングアニメーション */
@keyframes sk-scaleout {
  0% {
    transform: scale(0);
  } 100% {
    transform: scale(1.0);
    opacity: 0;
  }
}
.loaded {
  opacity: 0;
  visibility: hidden;
}


/******************************************************************** structure
*/
body{
	color: #444444;
	line-height: 1.8;
    font-family: 'Zen Maru Gothic','M PLUS Rounded 1c', "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN","メイリオ", Meiryo,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	word-break:break-all;
	word-wrap : break-word;
	overflow-wrap : break-word;
	letter-spacing:0.04em;
	background-image: url(../images/bg-dot.svg);
	background-size:15px 15px;
}
@media screen and (min-width: 1024px) {
  body {
    font-size:1.6vw;
  }
}

a {
	color:#002F4F;
	transition:0.3s;
}
a:link,
a:visited,
a:active {
	text-decoration: none;
	color:#FF9999;
}

a:focus{
	overflow:hidden;
}

img{
	max-width:100%;
}

.mincho{
	font-family: "Noto Serif JP", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", Helvetica, Avenir;
}
.non_letter-spacing{
	letter-spacing: 0 !important;
}
.text-narrow {
    transform: scale(0.7, 1);
    width: 125%;
}
.text-wide {
    transform: scale(1.5, 1);
}
.text-narrow-sp {
    transform: scale(0.7, 1);
    width: 125%;
    transform-origin: 15%;
}
.text-wide-sp {
    transform: scale(1.5, 1);
}
ol.ol_base{
	list-style-type: decimal;
	padding-left:1rem;
	margin-bottom:20px;
}
ul.ul_base{
	list-style-type: disc;
	padding-left:1.5rem;
	margin-bottom:20px;
}
a.text_line{
	text-decoration: underline;
}
.indent{
	margin-left:20px;
}
.section p{
	margin-bottom:1.5rem;
}
a.btn-common, a.btn-common-c {
	margin: 0 auto;
	max-width:300px;
	width:90%;
	display:block;
	background:#FF9999;
	border: 1px solid #FF9999;
	color:#fff;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 1.4px;
	padding: 16px 20px 14px;
	position: relative;
	-webkit-transition: all .4s;
	transition: all .4s ;
	text-align:center;
	transition: 0.3s;
	border-radius: 8px;
}

a.btn-common:hover, a.btn-common-c:hover {
	text-decoration:none;
	color: #FF9999;
	background: #fff;
	text-decoration: none;
	border: 1px solid #FF9999;
	cursor: pointer;
}
a.btn-common::after, a.btn-common-c::after{
    content: "";
    width: 5px;
    height: 5px;
    border-top: solid 1px #ffffff;
    border-right: solid 1px #ffffff;
    position: absolute;
    right: 20px;
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(45deg);
    -ms-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg);
    -webkit-transition: -webkit-transform 0.3s;
    transition: 0.3s;
}
a.btn-common:hover::after, a.btn-common-c:hover::after{
	right: 20px;
	border-top: solid 2px #FF9999;
	border-right: solid 2px #FF9999;
}



a.btn-line {
	display: flex;
	align-items: center;
	align-content: center;
	justify-content: center;
	position: relative;
	margin: 0 auto;
	max-width:300px;
	width:90%;
	background:#4bc663;
	border: 1px solid #4bc663;
	color:#fff;
	/*
	font-size: 16px;
	*/
	font-weight: 700;
	letter-spacing: 1.4px;
	padding: 20px 20px 20px;
	line-height:1;
	position: relative;
	transition: all .4s ;
	text-align:center;
	transition: 0.3s;
	border-radius: 8px;
}
a.btn-line::before{
	content: url("../images/ico_line.svg");
	vertical-align: middle;
	padding-right: 10px;
	width: 28px;
	height: 28px;
}
/*
a.btn-line:hover {
	text-decoration:none;
	color: #4bc663;
	background: #fff;
	text-decoration: none;
	border: 1px solid #4bc663;
	cursor: pointer;
}
*/
a.btn-line:hover::after{
	right: 20px;
	border-top: solid 2px #4bc663;
	border-right: solid 2px #4bc663;
}



.flex{
	display:flex;
}




/******************************************************************** txt
*/

h1.ttl{
	text-align:center;
	font-size:6vw;
	font-size:min(6vw, 36px);
	font-weight:normal;
	color:#fff;
	margin-bottom:0;
	line-height:1.3;
}
p.ttl_sub{
	position:relative;
	font-size:18px;
	margin-bottom:10px;
	line-height:1;
	font-weight:bold;
	text-align:center;
	letter-spacing:0;
	color:#FF9999;
}
p.ttl_sub_l{
	font-size:28px;
}
p.ttl_sub2{
	color:#FF9999;
}
h2.ttl_sub{
	position:relative;
	font-size:6vw;
	font-size:min(6vw, 36px);
	margin-bottom:30px;
	line-height:1.5;
	font-weight:bold;
	text-align:center;
	letter-spacing:0;
	color:#484040;
}
.pre_ttl{
	position:relative;
	font-size:17px;
	margin-bottom:30px;
	line-height:1.7;
	text-align:center;
}
.pre_ttl_l{
	font-size:20px;
}
h3.ttl_sub{
	position:relative;
	font-size:20px;
	margin-bottom:30px;
	line-height:1.5;
	text-align:center;
	letter-spacing:0em;
}
.ttl_sub_txt{
	margin-bottom:30px;
}
.sub_txt{
	text-align:center;
	margin-bottom:30px;
	font-size:16px;
}
.sub_txt2{
	text-align:center;
	margin-bottom:15px;
	font-size:16px;
}

.attention{
	color:red;
}
.white{
	color:#fff;
}
.pink {
    color: #FF5381;
    font-weight:bold;
}
.sefumo_color{
	color:#FF9999;
}
.large{
	font-size:1.2em;
}
.large-x{
	font-size:1.5em;
}
.large-xx{
	font-size:1.8em;
}
.marker{
	background:linear-gradient(transparent 60%, #ff6 60%);
}
/******************************************************************** layout
*/
.wrap{
	width:100%;
	max-width:750px;
	margin:0 auto;
	padding:0;
	position:relative;

}
.wrap_s{
	width:90%;
	margin:0 auto;
	padding:0;
}
.wrap_top{
	width:90%;
	margin:0 auto;
	padding:60px 0 60px 0;
}
.wrap_top_s{
	width:90%;
	margin:0 auto;
	padding:50px 0;
}
.wrap_head{
	width:90%;
	margin:0 auto 30px;
	padding:30px 0;
}
.wrap_l{
	border-bottom:1px solid #ccc;
	margin-bottom:30px;
}
.wrap_top:after,.wrap:after,.wrap2:after,.wrap3:after,.wrap4:after,.wrap_l:after,.wrap_x:after {
	clear: both;
	content: "";
	display: block;
}
.b_line{
	border-bottom:1px solid #CCCCCC;
}
.bg01{
	background-color:#ffffff;
}
.bg02{
	background-color:#F2EFED;
}

.sec{
	margin-bottom:50px;
}
.sec_s{
	margin-bottom:30px;
}
.content{
	background: #fff;
	border-radius: 10px;
	padding: 20px 20px;
	text-align: center;
}

.waku {
	margin-bottom: 1.5rem;
	background: #fff;
	border-radius: 10px;
	border: 3px solid #FF9999;
	margin-top: 20px;
	padding: 18px 12px 18px 16px;
}
/******************************************************************** header
*/
header{
	margin: 0;
	width: 100%;
	max-width:750px;
	position: fixed;
	z-index:10;
	background-color:#fff;
	height:56px;
}
.header_wrap{
	margin:0 auto;
	height:56px;
	width:96%;
	display:flex;
	justify-content:space-between;
	align-items:center;
}
.header_wrap h1 img{
	height:50px;
}
.header_r{
	display:flex;
	align-items:center;
	gap:8px;
}
a.header_contact{
	padding:7px 10px;
	background-color:#FF9999;
	color:#fff;
	border-radius:24px;
	line-height:1.3;
}
a.header_contact::before{
	content: "";
	display: inline-block;
	width: 18px;
	height: 18px;
	margin: -1px 4px 0 0;
	background: url("../images/ico_txt.svg") no-repeat;
	background-size: contain;
	vertical-align: middle;
}
.header_tel_btn{
	background-color:#54AFBB;
	color:#fff;
}

.header_tel_btn_sp a{
	display:block;
	padding:7px 10px;
	background-color:#FF9999;
	color:#fff;
	border-radius:24px;
	line-height:1.2;
}
.header_tel_btn_sp a::before{
	content: "";
	display: inline-block;
	width: 18px;
	height: 18px;
	margin: -1px 4px 0 0;
	background: url("../images/ico_tel.svg") no-repeat;
	background-size: contain;
	vertical-align: middle;
}


/******************************************************************** menu
*/

/*開閉ボタン*/
#nav_toggle{
	z-index: 99999;
	top: 14px;
	right: 14px;
	width:36px;
	height:36px;
	background:#FF9999;
	border-radius:24px;
}
#nav_toggle div {
	position: relative;
}
#nav_toggle span{
	display: block;
	height: 1px;
	background:#fff;
	position:absolute;
	width: 60%;
	left: 20%;
	-webkit-transition: 0.5s ease-in-out;
	-moz-transition: 0.5s ease-in-out;
	transition: 0.5s ease-in-out;	
}
#nav_toggle span:nth-child(1){
	top:10px;
}
#nav_toggle span:nth-child(2){
	top:18px;
}
#nav_toggle span:nth-child(3){
	top:26px;
}

/*開閉ボタンopen時*/
#nav_toggle.open span:nth-child(1) {
	top: 14px;
   -webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	transform: rotate(135deg);
}
#nav_toggle.open span:nth-child(2) {
	width: 0;
	left: 50%;
}
#nav_toggle.open span:nth-child(3) {
	top: 14px;
	-webkit-transform: rotate(-135deg);
	-moz-transform: rotate(-135deg);
	transform: rotate(-135deg);
}




nav{
	display: none;
	position: fixed;
	width: 100%;
	height:100vh;
	top:0;
	left: 0;
	z-index:90001;
	background:#FF9999;
}
nav ul{
	display:flex;
	align-items:center;
	align-content:center;
	height:100vh;
	flex-wrap:wrap;
	margin: 0 auto;
	padding-top:20px;
	padding-bottom:20px;
	width: 100%;
	background:#FF9999;
}
nav ul li{
	width:100%;
	margin:4px 1%;
	text-align: center;
	font-size:15px;
	background:#FF9999;
}
nav ul li:last-child{
	border: none;
}
nav ul li a {
	display: block;
	color: #fff !important;
	text-decoration: none;
	padding: 5px;
	transition: 0.5s;
}

header nav ul li a img{
	-webkit-filter: brightness(1) invert(1);
	-ms-filter: brightness(1) invert(1);
	filter: brightness(1) invert(1);
}



/******************************************************************** top
*/
.mainimg {
	padding-top:50px;
	padding-bottom:0;
	text-align:center;
}
.mainimg img{
	max-width:100%;
}
.main_bottom{
	width:88%;
	margin:30px auto 0;
}
.main_bottom img{
	width:100%;
}

.main_btn{
	margin:0 0 10px 0;
}
.main_btn li{
	margin-bottom:15px;
	width:100%;
}
.main_btn li a{
	width:100%;
	display:block;
	background:#FF9999;
	border:1px solid #FF9999;
	color:#fff;
	font-size:16px;
    letter-spacing: 0.1em;
    line-height:1.4;
    padding: 20px 30px 20px;
    position: relative;
    text-align:center;
    -webkit-transition: 0.3s;
    transition: 0.3s ;
}
.main_btn li a:hover {
	color:#FF9999;
	background:#fff;
	text-decoration:none;
	-webkit-transition: 0.3s;
    transition: 0.3s ;
}
.main_btn li a::after{
    content: "";
    width: 6px;
    height: 6px;
    border-top: solid 2px #ffffff;
    border-right: solid 2px #ffffff;
    position: absolute;
    right: 16px;
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(45deg);
    -ms-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg);
    -webkit-transition: -webkit-transform 0.3s;
    transition: 0.3s;
}
.main_btn li a:hover::after{
    right: 20px;
    border-top: solid 2px #FF9999;
    border-right: solid 2px #FF9999;
}





/******************************************************************** 吹き出し
*/
.balloon_l,
.balloon_r{
  margin: 30px 0;
  display:flex;
  justify-content: flex-start;
  align-items: flex-start; /*縦位置を上揃え*/
/*   align-items: center; */ /*縦位置を真ん中揃え*/
}
.balloon_r{
  justify-content:flex-end;
}
.faceicon{
  width: 24%;
}
.faceicon img{
  width: 100%; /*任意のサイズ*/
  height: auto;
}
.balloon_r .faceicon{
  margin-left:25px;
}
.balloon_l .faceicon{
  margin-right:25px;
}
.balloon_r .faceicon{
  order:2 !important;
}
.says {
  max-width:550px; /*最大幅*/
  display: flex;
  flex:1;
  flex-wrap: wrap;
  position: relative;
  padding: 17px 13px 15px 18px;
  border-radius: 12px;
  background: #FFE3E3;
  box-sizing:border-box;
  margin:0 !important;
  line-height:1.5;
/*   align-items: center; */
}
.says p{
  margin:8px 0 0 !important; 
}
.says p:first-child{
  margin-top:0 !important;
}
.says:after {
  content: "";
  position: absolute;
  border: 10px solid transparent;
/*   margin-top:-3px;  */
}
.balloon_l .says:after {
  left: -26px;
  border-right: 22px solid #FFE3E3;
}
.balloon_r .says:after {
  right: -26px;
  border-left: 22px solid #FFE3E3;
}




.balloon_l2,
.balloon_r2{
  margin: 30px 0;
  display:flex;
  justify-content: flex-start;
  align-items: flex-start; /*縦位置を上揃え*/
/*   align-items: center; */ /*縦位置を真ん中揃え*/
}
.balloon_r2{
  justify-content:flex-end;
}
.balloon_l2 .faceicon, .balloon_r2 .faceicon{
  width: 35%;
}
.balloon_l2 .faceicon img, .balloon_r2 .faceicon img{
  width: 100%; /*任意のサイズ*/
  height: auto;
}
.balloon_r2 .faceicon{
  margin-left:25px;
}
.balloon_l2 .faceicon{
  margin-right:25px;
}
.balloon_r2 .faceicon{
  order:2 !important;
}
.balloon_l2 .says, .balloon_r2 .says {
  max-width:550px; /*最大幅*/
  display: flex;
  flex:1;
  flex-wrap: wrap;
  position: relative;
  padding: 17px 13px 15px 18px;
  border-radius: 12px;
  background: #FFE3E3;
  box-sizing:border-box;
  margin:0 !important;
  line-height:1.5;
/*   align-items: center; */
}
.balloon_l2 .says p, .balloon_r2 .says p{
	margin:8px 0 0 !important; 
	font-size:4.4vw;
	font-size:min(4.4vw, 22px);
}
.balloon_l2 .says p:first-child, .balloon_r2 .says p:first-child{
  margin-top:0 !important;
}
.balloon_l2 .says:after, .balloon_r2 .says:after {
  content: "";
  position: absolute;
  border: 10px solid transparent;
/*   margin-top:-3px;  */
}
.balloon_l2 .says:after {
  left: -26px;
  border-right: 22px solid #FFE3E3;
}
.balloon_r2 .says:after {
  right: -26px;
  border-left: 22px solid #FFE3E3;
}


/******************************************************************** 選ばれる理由
*/
#point{
	background-color:#FF9999;
}
#point .ttl_sub{
	color:#fff;
}
#point .ttl_sub2{
	color:#f3ff00;
}
.point_ul{
	display:flex;
	flex-wrap:wrap;
	gap:10px 3%;
}
.point_ul li{
	width:31.333%;
	background-color:#FFF;
	padding:8px 0;
	border-radius:10px;
	text-align:center;
	line-height:1.5;
	color:#FF5381;
}
.point_ul li p{
	margin:0;
	color:#444444;
	font-weight:bold;
	font-size:3.8vw;
	font-size:min(3.8vw, 24px);
	line-height:1.5;
}





/******************************************************************** チャットレディって？
*/
#about{

}
.section_02_01{

}
.section_02_01_l{
	margin-bottom:30px;
	text-align:center;
}
.section_02_01_l img{
	width:60%;
}
.section_02_01_r{
	text-align:center;
}
.section_02_01_r span{
	font-weight:bold;
	font-size:1.6em;
}
.section_02_01_r_waku{
	margin-top:20px;
	padding:15px 10px;
	background-color:#ffe3e3;
	font-size:0.78em;
	letter-spacing:0;
	text-align:left;
}
.about_ttl_sub{
	display:block;
	margin:0 auto 20px;
	padding:14px 10px;
	text-align:center;
	font-size:4.8vw;
	font-size:min(4.8vw, 24px);
	font-weight:bold;
	color:#fff;
	background-color:#FF9999;
	border-radius:24px;
	line-height:1;
}


ul.about_ex{

}
ul.about_ex li{
	position:relative;
	margin-bottom:30px;
	background-color:#FFE3E3;
	padding:4vw;
	border-radius:10px;
	text-align:left;
	line-height:1.5;
}
ul.about_ex li h4{
	text-align:center;
	margin-bottom:10px;
	color:#FF5381;
}
ul.about_ex li p{
	margin-bottom:8px;
}

ul.about_ex li p img{
	border-radius:8px;
}

/******************************************************************** ブログ
*/
dl.blog_dl{
	background: #fff;
	border-radius: 10px;
	border: 3px solid #FF9999;
	margin-top: 20px;
	padding: 18px 12px 18px 16px;
}
dl.blog_dl p.title{
	margin-bottom:0.8em;
}
dl.blog_dl dd{
	border-bottom-color: #ccc;
	border-bottom-style: dotted;
	border-bottom-width: 3px;
	margin-bottom:8px;
}
dl.blog_dl dd:last-child{
	border-bottom:none;
	margin-bottom:0;
}
.newMark{
	color:#fff;
	background-color:#f54281;
	margin-left:5px;
	padding:0 6px;
	font-size:0.9em;
	line-height:1;
	border-radius:4px;
}

.blog_detail_box{
	background: #fff;
	border-radius: 10px;
	border: 3px solid #FF9999;
	margin-top: 20px;
	padding: 24px 12px 2px 16px;
}
.blog_ttl{
	position: relative;
	font-size: 5vw;
	font-size: min(5vw, 30px);
	margin-bottom: 20px;
	line-height: 1.5;
	font-weight: bold;
	text-align: center;
	letter-spacing: 0;
	color: #484040;
}
/******************************************************************** ルームアイテム
*/
.ul_roomitem{
	display:flex;
	flex-wrap:wrap;
	gap:4%;
	margin-left:1.5em;
}
.ul_roomitem li{
	width:48%;
	
}




/******************************************************************** 体験談
*/
.voice_list h3{
	text-align:center;
	color:#FF5381;
	font-size:4.4vw;
	font-size:min(4.4vw, 22px);
}


.balloon_l3,
.balloon_r3{
  margin: 30px 0;
  display:flex;
  justify-content: flex-start;
  align-items: flex-start; /*縦位置を上揃え*/
}
.balloon_r3{
  justify-content:flex-end;
}
.balloon_l3 .faceicon, .balloon_r3 .faceicon{
  width: 25%;
}

.balloon_l3 .faceicon img, .balloon_r3 .faceicon img{
  width: 100%; /*任意のサイズ*/
  height: auto;
  border-radius:8px;
}
.balloon_r3 .faceicon{
  margin-left:18px;
}
.balloon_l3 .faceicon{
  margin-right:18px;
}
.balloon_r3 .faceicon{
  order:2 !important;
}
.balloon_l3 .says, .balloon_r3 .says {
  max-width:550px; /*最大幅*/
  display: flex;
  flex:1;
  flex-wrap: wrap;
  position: relative;
  padding: 13px 8px 13px 12px;
  border-radius: 12px;
  background: #fff;
  border: solid 5px #FFE3E3;
  box-sizing:border-box;
  margin:0 !important;
  line-height:1.5;
/*   align-items: center; */
}
.balloon_l3 .says p, .balloon_r3 .says p{
	margin:8px 0 0 !important; 
	font-size:4vw;
	font-size:min(4vw, 20px);
}
.balloon_l3 .says p:first-child, .balloon_r3 .says p:first-child{
  margin-top:0 !important;
}
.balloon_l3 .says:after, .balloon_r3 .says:after {
  content: "";
  position: absolute;
  border: 10px solid transparent;
/*   margin-top:-3px;  */
}
.balloon_l3 .says:before {
	content: "";
	position: absolute;
	top: 50px;
	left: -24px;
	margin-top: -12px;
	border: 12px solid transparent;
	border-right: 12px solid #FFF;
	z-index: 2;
}
.balloon_l3 .says:after {
	content: "";
	position: absolute;
	top: 50px;
	left: -40px;
	margin-top: -20px;
	border: 20px solid transparent;
	border-right: 20px solid #FFE3E3;
	z-index: 1;
}
.balloon_r3 .says:before {
  content: "";
  position: absolute;
  top: 50px;
  right: -24px;
  margin-top: -12px;
  border: 12px solid transparent;
  border-left: 12px solid #FFF;
  z-index: 2;
}

.balloon_r3 .says:after {
  content: "";
  position: absolute;
  top: 50px;
  right: -40px;
  margin-top: -20px;
  border: 20px solid transparent;
  border-left: 20px solid #FFE3E3;
  z-index: 1;
}
/******************************************************************** 求人応募の流れ
*/
#flow{
	background-color:#FF9999;
}
#flow .ttl_sub{
	color:#fff;
}
#flow .ttl_sub2{
	color:#f3ff00;
}
.flow_ul{

}
.flow_ul li{
	position:relative;
	margin-bottom:30px;
	background-color:#FFF;
	padding:5vw;
	border-radius:10px;
	text-align:center;
	line-height:1.5;
	color:#FF5381;
}
.flow_ul li::after {
	content:"";
	position:absolute;
	bottom:-20px;
	left:50%;
	transform:translateX(-50%);
	background: #ffffff;
	height: calc(50px / 2);
	width: 50px;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
}
.flow_ul li:last-child::after {
	background: none;
}
.flow_ul li .flow_num{
	font-size:1.2em;
	margin-bottom:8px;
}
.flow_ul li p{
	margin:0;
	text-align:left;
	color:#444444;
	font-weight:bold;
	/*
	font-size:3.8vw;
	font-size:min(3.8vw, 24px);
	*/
	line-height:1.5;
}







/******************************************************************** 10.よくあるご質問
*/


.faq-list .item {
  background: #fff;
  border-radius: 10px;
  border: 3px solid #FF9999;
  margin-top:20px;
  padding: 18px 12px 18px 16px;
}
.faq-list dt {
  font-weight: 500;
  padding-left: 30px;
  position: relative;
  padding-right: 32px;
  cursor: pointer;
}
.faq-list dt::before {
  content: 'Q';
  display: block;
  position: absolute;
  width: 50px;
  height: 36px;
  top: 0;
  left: 0;
  font-size:20px;
  line-height:1.4;
}
@media (min-width: 1024px) {
	.faq-list dt::before {
	  content: 'Q';
	  display: block;
	  position: absolute;
	  width: 50px;
	  height: 36px;
	  top: 0;
	  left: 0;
	  font-size:26px;
	  line-height:1.4;
	}
}

.faq-list dt::after {
	content: '';
	display: block;
	position: absolute;
	width: 30px;
	height: 36px;
	top: -5px;
	right: 0;
	background: url(../images/icon_faq_plus.svg) no-repeat center/contain;
	-webkit-transition: -webkit-transform .3s;
	transition: -webkit-transform .3s;
	transition: transform .3s;
	transition: transform .3s, -webkit-transform .3s;
}




.faq-list dt.is-open::after {
	background: url(../images/icon_faq_close.svg) no-repeat center/contain;
	-webkit-transform: rotate(90deg);
	-ms-transform: rotate(90deg);
	transform: rotate(90deg);
}
.faq-list dd {
	margin-top: 20px;
	font-size: 15px;
	font-weight:normal;
	padding-left: 30px;
	padding-right: 30px;
	position: relative;
	display: none;
}
.faq-list dd::before {
	content: 'A';
	display: block;
	position: absolute;
	font-weight: 500;
	font-size:20px;
	color:#FF9999;
	width: 50px;
	height: 36px;
	top: 0;
	left: 0;
	line-height:1.4;
}



/******************************************************************** 11.お問い合わせ
*/
.section_11{
	background-color:#F8F5F1;
}





/******************************************************************** product yoko scroll table
*/
.flex-scrolling {
    overflow-x: auto;
    margin-bottom:10px;
}
.flex-scrolling::-webkit-scrollbar {
    width: 20px;
    border-radius: 20px;
    background: #f1f1f1;
}
.flex-scrolling::-webkit-scrollbar-thumb {
    border-radius: 20px;
    background: #8494a1;
}
.table_guide {
	display: inline-block;
	color: #fff;
	background-color:#002F4F;
	font-size: 13px;
	margin-bottom: 5px;
	padding: 1px 5px;
}
.flex-scrolling table {
    width: 880px;
    margin-bottom: 2px !important;
}

 /* 横スクロール時に固定する対応 */
.flex-scrolling {
  overflow-x: scroll;
  width: 100%;
  height:auto;
}







/******************************************************************** care
*/

table.base_table{
	width:100%;
    border: 1px #cccccc solid;
    border-collapse: collapse;
    border-spacing: 0;
    margin:0 auto;
}

table.base_table th{
	width:26%;
    padding: 8px 4px 8px 8px;
    border: #cccccc solid;
    border-width: 0 0 1px 1px;
    background: #FF9999;
    color:#fff;
    font-weight: normal;
    line-height: 120%;
    text-align: center;
}
table.base_table td{
    padding: 8px 4px 8px 8px;
    border: 1px #cccccc solid;
    border-width: 0 0 1px 1px;
    background: #ffffff;
    text-align: left;

}


table.base_table_sp{
	width:100%;
    border: 1px #cccccc solid;
    border-bottom: none;
    border-collapse: collapse;
    border-spacing: 0;
    margin:0 0 0 0;
}
table.base_table_sp th{
    display: block;
    width: 100%;
    position: relative;
    padding: 5px;
    border: #cccccc solid;
    border-width: 0 0 1px 0;
    background: #FF9999;
    color:#fff;
    font-weight: normal;
    line-height: 120%;
    text-align: center;
}
table.base_table_sp td{
    display: block;
    width: 100%;
    position: relative;
    padding: 5px;
    border: 1px #cccccc solid;
    border-width: 0 0 1px 0;
    background: #ffffff;
    text-align:left;
}



.privacy_box{
	margin-bottom:10px;
	padding:20px;
	border:1px solid #ccc;
	font-size:13px !important;
	height:120px;
	overflow-y:scroll;
	line-height:1.3;
}
.privacy_box p{
	font-size:13px !important;
	margin-bottom:0.5em;
}
.privacy_box dl dt{
	margin-top:0.5em;
	font-size:13px !important;
}
.privacy_box dl dd{
	font-size:13px !important;
}



/******************************************************************** footer
*/
footer{
	margin:0 0 42px 0;
	width:100%;
	font-size:12px;
	color:#fff;
	background-color:#FF9999;
	text-align:center;
}
.foot_info{
	font-size:12px;
	padding-top:20px;
	text-align:center;
}_
footer a{
	color:#fff;
}
footer .foot_copy{
	font-size:10px;
	padding:10px 0 20px 0;
	text-align:center;
}



/******************************************************************** footer fix
*/


.l_footer {
	position: fixed;
	width: 100%;
	bottom: 0;
	left:0;
	z-index:10;
	margin: 0 auto;
	height:52px;
	background-color:#fff;
}
.l_footer_wrap{
	width: 100%;
	margin:0 auto;
	max-width:750px;
	text-align:center;
	padding:0;
}
.l_footer_btn{

}
.l_footer_btn ul{
	display:flex;
	align-items:center;

}
.l_footer_btn ul li{
	text-align:center;
	height:52px;
}
.l_footer_btn ul li a {
	display: flex;
	align-items:center;
	align-content:center;
	justify-content:center;
	position: relative;
	height:100%;
	color:#fff;
	font-size:16px;
}


.l_footer_btn ul li.foot_fix_menu_01 a::before {
  content: url("../images/ico_line.svg");
  vertical-align: middle;
  padding-right: 10px;
  width:28px;
  height:28px;
}
.l_footer_btn ul li.foot_fix_menu_02 a::before {
  content: url("../images/ico_mail.svg");
  vertical-align: middle;
  padding-right: 10px;
  width:28px;
  height:28px;
}
/*
.l_footer_btn ul li a::before {
  content: "";
  width: 4px;
  height: 4px;
  border-top: solid 2px #ffffff;
  border-right: solid 2px #ffffff;
  position: absolute;
  right: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(45deg);
  -ms-transform: translateY(-50%) rotate(45deg);
  transform: translateY(-50%) rotate(45deg);
  -webkit-transition: -webkit-transform 0.3s;
  transition: 0.3s;
}
*/
.foot_fix_menu_01{
	width:50%;
}
.foot_fix_menu_02{
	width:50%;
}
.foot_fix_menu_01 a{
	background-color: #4bc663;
}
.foot_fix_menu_02 a{
	background-color: #fb9c0f;
}
.l_footer_btn .l_foot_tel{
	background-color:#54AFBB;
	color:#fff;
	height:s62px;
	line-height:1.4;
}

.l_footer_btn .l_foot_tel .l_foot_tel_btn{

}
.l_footer_btn .l_foot_tel .l_foot_tel_btn a{
	position:relative;
	display:block;
	color:#fff;
	font-size:28px;
	letter-spacing:0.08em;
}

.l_footer_btn .l_foot_tel .l_foot_tel_btn a::before{
	content: "";
	display: inline-block;
	width: 18px;
	height: 18px;
	margin: -1px 6px 0 0;
	background: url("../images/ico_tel.svg") no-repeat;
	background-size: contain;
	vertical-align: middle;
}
.l_footer_btn .l_foot_tel p.l_foot_tel_btn_txt{
	font-size:11px;
	padding-bottom:10px;
}



/******************************************************************** thanks
*/
.thanks{
	margin:30px auto;
}
.thanks p{
	margin:15px auto;
}

