
/*=================================================
 * CSS for PC
 * ================================================= */

/***************************************
ROOT
****************************************/

:root {
  --font-color: #333;
  --font-color-white: #fff;
  --sub-color: #ff8f00;
  --cast-color: #ffde00;
  --bg-color: #f9f9f9;
  --border-color: #ddd;
  --accent-color: #e63946;
  --font-base: Meiryo,'Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;
}


/***************************************
CAST STYLE
****************************************/

/** course **/
.c1{	color: #fff;}
.c2{	color: #e5d2ff;}
.c3{	color: #ffbfd3;}
.c4{	color: #ffe76d;}
.c0{	color: #ccc;}






/***************************************
TITLE
****************************************/

.s_title{
	position: relative;
	text-align: center;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.s_title em{
	position: relative;
	display: block;
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	font-size: 38px;
	line-height: 40px;
	margin: 0 0 10px 0;
	color: #000;
}

.s_title span{
	position: relative;
	display: inline-block;
	vertical-align: top;
	font-family: "FontA";
	font-size: 14px;
	line-height: 16px;
	letter-spacing: 1px;
	color: var(--sub-color);
}
.s_title span:before,
.s_title span:after{
	content: '';
	width: 20px;
	border-bottom: 1px solid currentColor;
	position: absolute;
	top: 8px;
}
.s_title span:before{	left: -30px;}
.s_title span:after{	right: -30px;}


.ss_title{
	padding: 19px 0 19px 0;
	text-align: center;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.ss_title span{
	font-family: "FontA";
	font-size: 28px;
	line-height: 34px;
}

.ss_title em{
	position: relative;
	font-size: 16px;
	line-height: 16px;
	color: #ff99cc;
}

.ss_title em:before,
.ss_title em:after{
	content: '';
	display: inline-block;
	width: 40px;
	border-bottom: 1px solid #ffd0eb;
	position: absolute;
	top: 10px;
}
.ss_title em:before{	left: -50px;}
.ss_title em:after{ right: -50px; }


/***************************************
MAIN CONTENTS
****************************************/

.main_bg{
	padding: 20px;
-webkit-background-size: 3px 3px;
-moz-background-size: 3px 3px;
background-size: 3px 3px;
background-color: rgba(255, 255, 255, 0.7);
background-image: -webkit-gradient(linear, 0 0, 100% 100%,
            color-stop(.25, #ffffff), color-stop(.25, transparent),
            color-stop(.5, transparent), color-stop(.5, #ffffff),
            color-stop(.75, #ffffff), color-stop(.75, transparent),
            to(transparent));
background-image: -webkit-linear-gradient(-45deg, #ffffff 25%, transparent 25%,
          transparent 50%, #ffffff 50%, #ffffff 75%,
          transparent 75%, transparent);
background-image: -moz-linear-gradient(-45deg, #ffffff 25%, transparent 25%,
          transparent 50%, #ffffff 50%, #ffffff 75%,
          transparent 75%, transparent);
background-image: -ms-linear-gradient(-45deg, #ffffff 25%, transparent 25%,
          transparent 50%, #ffffff 50%, #ffffff 75%,
          transparent 75%, transparent);
background-image: -o-linear-gradient(-45deg, #ffffff 25%, transparent 25%,
          transparent 50%, #ffffff 50%, #ffffff 75%,
          transparent 75%, transparent);
background-image: linear-gradient(-45deg, #ffffff 25%, transparent 25%,
          transparent 50%, #ffffff 50%, #ffffff 75%,
          transparent 75%, transparent);
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.main{
	background: #fff;
	box-shadow: 0 0 5px 1px rgba(67, 67, 67, 0.05);
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}




/***************************************
COMMON STYLE
****************************************/

/***** font color *****/
a, a:hover, .tx_a, .tx_a:hover{	color: #0089d8;}
body, .tx0, .tx0:hover{	color: #000;}

.sat{	color	: #0066ff;}
.sun{	color	: #cc0000;}
.tel, .tel a{	color: #b38600 !important;}
.mail, .mail a{	color: #ff0099;}

.anchor{
	display: block;
	padding-top: 120px;
	margin-top: -120px;
}


/***** icon *****/

.icon{
	font-family: "FontA";
	letter-spacing: 0.5px;
}
.i1{	color: #aaffa3;}
.i2{	color: #ff7f7f;}
.i3{	color: #d39fff;}

@keyframes now{
	0% {opacity:0;}
	20% {opacity:0;}
	80% {opacity:1;}
	100% {opacity:1;}
}



/***** buttun *****/
.bt_main,
input.bt_main{
	display: inline-flex;
	align-items: center;
	align-content: center;
	justify-content: center;
	width: calc(100% - 20px);
	max-width: 260px;
	height: 60px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	font-size: 16px;
	line-height: 26px;
	text-align: center;
	color: #fff;
	background: #000;
	border: none;
	border-radius: 5px;
	-webkit-transition	: 0.2s ease-in-out;
	-moz-transition	: 0.2s ease-in-out;
	-o-transition	: 0.2s ease-in-out;
	transition		: 0.2s ease-in-out;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.form input.bt_main{
	-webkit-appearance: none;
}
.bt_main:hover,
input.bt_main:hover{
	color: #fff !important;
	opacity: 0.7;
	filter: alpha(opacity=70);
}


/***** slider *****/
.slick-prev, .slick-next , ul#slideIcon li,
#newface .bx-wrapper .bx-controls-direction a{	color: #ffffff;}
.slick-prev, .slick-next , ul#slideIcon li,
#newface .bx-wrapper .bx-controls-direction a{	background-color: rgba(255, 155, 212, 0.9);}
.bx-wrapper .bx-pager.bx-default-pager a{	background-color: #ccc;}
.bx-wrapper .bx-pager.bx-default-pager a.active{	background-color: #ff3399;}



/***************************************
ROLLOVER
****************************************/

.fade{
	display: inline-block;
	padding: 0;
}

.fade,
.up a{
	-webkit-transition	: 0.2s ease-in-out;
	-moz-transition	: 0.2s ease-in-out;
	-o-transition	: 0.2s ease-in-out;
	transition		: 0.2s ease-in-out;
}

.fade:hover,
.fade:hover{
	opacity: 0.8;
	filter: alpha(opacity=80);
}


/***************************************
GOOGLE FONT
****************************************/

@font-face {
	font-family: FontA;
	src: url('../font/LibreCaslonDisplay-Regular.ttf') format("truetype");
}


/***** font *****/


.page_title:after,
.page_title em,
#copyright,
.font1{
	font-family: FontA;
}

.hd_info,
.page_title span,
.s_title,
#finfo,
.ss_title em,
.min{	font-family: "Sawarabi Mincho";}


.pc_none{	display: none;}


/*=================================================
 * CSS for SP
 * ================================================= */

@media screen and (max-width: 650px) {

	.anchor{
		display: block;
		padding-top: 70px;
		margin-top: -70px;
	}


	.pc_none{	display: inline;}
	.sp_none{	display: none;}


	/***************************************
	TITLE
	****************************************/
	.s_title{
		padding-bottom: 15px;
	}
	.s_title em{
		font-weight: 600;
		font-size: 28px;
		line-height: 30px;
		margin: 0 0 8px 0;
	}
	.s_title span{
		font-size: 10px;
	}
	.s_title:after{
		content: '';
		width: 60px;
		left: calc(50% - 30px);
	}
	.ss_title{
		padding: 10px 0 5px 0;
	}
	.ss_title span{
		font-size: 20px;
		line-height: 22px;
	}
	.ss_title em{
		font-size: 10px;
		line-height: 12px;
	}
	.ss_title em:before,
	.ss_title em:after{
		width: 30px;
		position: absolute;
		top: 6px;
	}
	.ss_title em:before{	left: -40px;}
	.ss_title em:after{ right: -40px; }

	/***************************************
	MAIN CONTENTS
	****************************************/
	.main_bg{
		padding: 10px;
	}
	.main{
	}

	/***************************************
	COMMON STYLE (SP ONLY)
	****************************************/
}


