@charset "utf-8";

/* --- SP ---------- */

@media print, screen and (max-width: 740px) {

	body {
		width: 100%;
		margin: 0;
		padding: 0;
		font-size: 90%;
		font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ ProN W3", "ＭＳ Pゴシック", Osaka, sans-serif;
		line-height: 160%;
		overflow-x: hidden;
		position: relative;
	}

	h2{
		letter-spacing:1px;
		font-size:120%;
	}

}


/* --- PC ---------- */

@media print, screen and (min-width: 741px) {
	body {
		width: 100%;
		margin: 0;
		padding: 0;
		font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ ProN W3", "ＭＳ Pゴシック", Osaka, sans-serif;
		line-height: 160%;
		border-top: 12px solid #f9b9b9;
		box-sizing: border-box;
		overflow-x: hidden;
		position: relative;
	}

	h2{
		letter-spacing:1px;
		font-size:140%;
	}

}

/*　フォント　*/
h1,h2,h3,h4,h5,h6{
		font-family: TsukuGoPr5-D, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ＭＳ Pゴシック", Osaka, sans-serif;
}


.en{
	font-family: 'Josefin Sans', sans-serif;
	font-weight:bold;
}

strong{
	font-weight: normal;
}

/*　リンク　*/

a {
	text-decoration: none;
}

a:link {
	color: #182d40;
}

a:visited {
	color: #182d40;
}

a:hover {
	color: #182d40;
	text-decoration: underline;
}

a:active {
	color: #182d40;
	text-decoration: underline;
}

a img {
	border: none;
}

.opac a:hover img {
	filter: alpha(opacity=70);
	-moz-opacity: 0.70;
	opacity: 0.70;
}

a:hover img.opac {
	filter: alpha(opacity=70);
	-moz-opacity: 0.70;
	opacity: 0.70;
}

.clearfix:after {
	content: "";
	clear: both;
	display: block;
}


/*　配置　*/

.img-center {
	text-align: center;
}

.img-right {
	padding: 5px 0 10px 20px;
	float: right;
}

.img-left {
	padding: 5px 20px 10px 0;
	float: left;
}

.clear-right {
	clear: right;
}

.clear-left {
	clear: left;
}

.clear {
	clear: both;
}

.bar{
	letter-spacing: -3px;
	margin-right: 0.3em;
}

.bold {
	font-weight: bold;
}

.big {
	font-size: 120%;
}

.small {
	font-size: 80%;
}

.red {
	color: #ff0000;
}

.orange {
	color: #E67579;
}

.marker_yellow{
	background: linear-gradient(transparent 40%, #ffff66 40%);
}

.marker_pink{
	background: linear-gradient(transparent 40%, #FFDFEF 40%);
}


::-webkit-input-placeholder {
	color: #ccc;
}

:-moz-placeholder {
	color: #ccc;
}

img {
	max-width: 100%;
	width: auto;
	height: auto;
}
.ck_editor img {
	width:auto;
}

div.image90{
	width: 90%;
	margin: 0 auto;
}

div.image80{
	width: 80%;
	margin: 0 auto;
}

div.image60{
	width: 60%;
	margin: 0 auto;
}

div.image50{
	width: 50%;
	margin: 0 auto;
}

div.image40{
	width: 40%;
	margin: 0 auto;
}

div.image30{
	width: 30%;
	margin: 0 auto;
}

div.image20{
	width: 20%;
	margin: 0 auto;
}

span.i_block{
	display: inline-block;
}

/*　ヘッダー　*/
/* --- SP ---------- */

@media print, screen and (max-width: 740px) {

	#header {
		background-color:#fff;
		position: -webkit-sticky; /* Safari */
		position: sticky;
		top: 0;
		z-index: 5000;
	}

	#header_submenu{
		display:none;
	}

	.header_box{
		padding: 10px 0 20px 0;
		position: relative;
	}

	#header .header_box h1{
		position: absolute;
		bottom: 3px;
		font-weight: normal;
		font-size: 7pt;
		margin: 5px 0.5em 0 0.5em;
		padding: 0;
		line-height: 120%;
		color: #333;
	}

	#header .header_box .box03{
		display:none;
	}

	#header .header_box .box04{
		display:none;
	}
	#header .header_box .box01{
		width:35%;
		float:left;
		padding-left: 2%;
	}

	#header .header_box .box02{
		width:50%;
		float:left;
		padding-left:2%;
	}
	#header .header_box .box02 p{
		margin:0;
		font-size:50%;
		line-height:1.6;
	}

	#ham-menu {
		color:#fff;
		background:rgba(230, 117, 120, .9);
		height: 100%;
		padding: 0; /*メニュー内左右上下余白*/
		position: fixed;
		right: -270px; /*メニュー横幅 width と合わせる*/
		top: 0;
		transition: transform 0.3s linear 0s; /*0.3s はアニメーションにかかる時間*/
		width: 270px; /*メニュー横幅*/
		z-index: 1000;
		overflow-y:scroll;
	}


	#ham-menu .sp_sns{
		width:100%;
		display: flex;
		box-sizing: border-box;
		padding: 20px;
	}
	#ham-menu .sp_sns .sp_sns_box{
		width:50px;
	}

	#menu-background {
		background-color: #333; /*黒背景*/
		display: block;
		height: 100%;
		opacity: 0;
/*		position: fixed;*/
		right: 0;
		top: 0;
		transition: all 0.3s linear 0s; /*0.3s はアニメーションにかかる時間*/
		width: 100%;
		z-index: -1;
	}

	#menu-icon {
/*
		background-color: #f9b9b9; アイコン部分背景色
*/
		border-radius: 0 0 0 10px; /*左下角丸*/
		color: #fff; /*アイコン（フォント）色*/
		cursor: pointer;
		display: block;
		font-size: 50px; /*アイコン（フォント）サイズ*/
		height: 50px; /*アイコン縦高さ*/
		line-height: 50px; /*縦位置中央化*/
		position: fixed;
		right: 0;
		text-align: center;
		top: 0;
		width: 50px; /*アイコン横幅*/
		transition: all 0.3s linear 0s; /*0.3s はアニメーションにかかる時間*/
		z-index: 1000;
	}

	#menu-cb {
		display: none; /*チェックボックス本体は消しておく*/
	}

	#menu-cb ~ #menu-icon img:last-child {
		display:none;
	}
	#menu-cb:checked ~ #menu-icon img:first-child {
		display:none;
	}
	#menu-cb:checked ~ #menu-icon img:last-child {
		display:block;
	}

	#menu-cb:checked ~ #ham-menu,
	#menu-cb:checked ~ #menu-icon {
		transform: translate(-270px); /*メニュー本体横幅 width と合わせる*/
	}

	#menu-cb:checked ~ #menu-background {
		opacity: 0.5;
		z-index: 999;
		position:fixed;
	}

	.header_menu ul{
		margin: 0;
		padding: 0;
	}

	.header_menu ul.opac{
		border-bottom: 1px solid #fff;
	}

	.header_menu ul li.main{
		margin: 0;
		padding: 0;
		border-top: 1px solid #fff;
	}

	.header_menu ul li.main:first-child a{
		padding: 0;
	}

	.header_menu ul li.main:first-child a img{
		vertical-align: bottom;
	}

	.header_menu ul li.main a{
		display: block;
		padding: 8px 1em;
		color: #fff;
	}
	.header_menu ul li.main a.online{
		background-color: #c0002d;
	}

	.header_menu ul li.main a:hover{
		background:rgba(150, 150, 150, .9);
		text-decoration: none;
	}

	.header_menu ul li.main ul.sub{
		margin: 0;
		padding: 0;
	}

	.header_menu ul li.main ul.sub li{
		margin: 0;
		padding: 0;
		border-top: 1px dotted #fff;
		list-style: none;
	}

	.header_menu ul li.main ul.sub li:first-child{
		border-top: 1px solid #fff;
	}

	.header_menu ul li.main ul.sub li a{
		text-align: left;
		background:rgba(255, 255, 255, .9);
		color: #de797b;
		line-height: 1.2em;
	}

	.header_menu ul li.main ul.sub li a:hover{
		background:rgba(150, 150, 150, .9);
	}

}

@media print, screen and (max-width: 480px) {

	.header_box{
		padding: 10px 0 0 0;
		position: relative;
		height: 80px;
		box-sizing: border-box;
	}

}


/* --- PC ---------- */

@media print, screen and (min-width: 741px) {

	#header{
		border-bottom:1px solid #ccc;
		position: -webkit-sticky; /* Safari */
		position: sticky;
		top: 0;
		background-color: #fff;
		z-index: 5000;
	}
	#header h1.text01{
		font-size: 70%;
		margin: 8px 0;
		line-height: 130%;
		font-weight: normal;
		font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ ProN W3";
	}
	#header .header_box{
		max-width:1200px;
		width:98%;
		margin:0 auto;
		color:#182d40;
	}
	#header .header_box .box01{
		max-width:200px;
		float:left;
		width:15%;
		padding-right:1%;
	}
	#header .header_box .box01 h1{
		margin:0;
	}
	#header .header_box .box02{
		float:left;
		width:26%;
		font-size:1vw;
	}

	#header .header_box .box02 p{
		margin-top: 10px;
	}

	#header .header_box .box02 p,
	#header_submenu ul li{
		font-family: TsukuGoPr5-D, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ＭＳ Pゴシック", Osaka, sans-serif;
	}
	#header .header_box .box03{
		float:right;
		max-width:240px;
		width:24%;
		padding-right:2%;
	}
	#header .header_box .box04{
		float:right;
		width:30%;
		font-family: TsukuGoPr5-D, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ＭＳ Pゴシック", Osaka, sans-serif;
	}
	#header .header_box .box04 p{
		font-size:70%;
		margin:0;
		text-align:right;
	}
	#header .header_box .box04 .left{
		width:49%;
		float:left;
		background:#e67578;
		text-align:center;
	}
	#header .header_box .box04 .left a,
	#header .header_box .box04 .right a{
		color:#fff;
		display:block;
		font-size:90%;
		-webkit-transition: 0.8s;
		-moz-transition: 0.8s;
		-o-transition: 0.8s;
		-ms-transition: 0.8s;
		transition: 0.8s;
		box-sizing:border-box;
		padding:10px;
	}
	#header .header_box .box04 .right a:nth-of-type(1){
		background-color: #c0002d;
	}
	#header .header_box .box04 .left a:hover,
	#header .header_box .box04 .right a:hover{
		text-decoration:none;
		background:#f9b9b9;
	}
	#header .header_box .box04 .right{
		width:49%;
		float:right;
		background:#e67578;
		text-align:center;
	}

	.header_menu{
		margin-top: 10px;
		padding:10px 0 10px;
		border-top: 1px solid #ccc;
	}

	.header_menu ul{
		max-width:1200px;
		width:100%;
		margin:0 auto;
		list-style-type:none;
		display: flex;
		justify-content: space-between;
		padding:0;
		font-size:95%;
		font-family: TsukuGoPr5-D, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ＭＳ Pゴシック", Osaka, sans-serif;
	}

	.header_menu ul li.main > a{
		position: relative;
		display: inline-block;
		text-decoration: none;
	}
	.header_menu ul li.main{
		position: relative;
	}
	.header_menu ul li.main a::after {
		position: absolute;
		bottom: 2px;
		left: 0;
		content: '';
		width: 100%;
		height: 2px;
		background: #e67578;
		opacity: 0;
		visibility: hidden;
		transition: .3s;
	}

	.header_menu ul li.main a:hover::after {
		bottom: -4px;
		opacity: 1;
		visibility: visible;
	}

	.header_menu ul li.main ul.sub li a{
		color:#fff;
	}

	.header_menu ul li.main ul.sub{
		position: absolute;
		display: block;
		z-index: 100;
/*		border:1px solid red;*/
	}

	.header_menu ul li.main ul.sub li{
		overflow: hidden;
		width: 280px;
		height: 0;
		color: #fff;
		-moz-transition: .2s;
		-webkit-transition: .2s;
		-o-transition: .2s;
		-ms-transition: .2s;
		transition: .2s;
	}
	.header_menu ul li.main:hover ul.sub li a{
		text-align:left;
		padding: 5px 10px;
		color:#fff;
		display:block;
		box-sizing: border-box;
	}
	.header_menu li.main:hover ul.sub li{
		overflow: visible;
		height: 38px;
		border-top: 1px dotted #eee;
		border-bottom: 1px dotted #eee;
		background:rgba(230, 117, 120, .9);
	}

	.header_menu li.main:hover ul.sub li a:after{
		bottom: 0;
		left: 0;
		height: auto;
		background: none;
		opacity: 0;
		visibility: hidden;
		transition: .0s;
	}

	.header_menu li.main:hover ul.sub li:first-child{
		border-top: 0;
	}
	.header_menu li.main:hover ul.sub li:last-child{
		border-bottom: 0;
	}
}


/*　メイン　*/
/* --- SP ---------- */
@media print, screen and (max-width: 740px) {

	.pc_contents {
		display: none;
	}

	.btn_black{
		max-width:400px;
		width:80%;
		margin:30px auto;
		text-align:center;
	}

	.btn_black a{
		font-family: TsukuGoPr5-D, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ＭＳ Pゴシック", Osaka, sans-serif;
		font-weight:bold;
		font-size:90%;
		letter-spacing:1px;
		display: block;
		cursor: pointer;
		margin: 0 auto;
		padding: 10px;
		color: #fff;
		text-align: center;
		text-decoration: none;
		background-color: #000;
		box-shadow: 6px 6px 0 #ccc, 6px 8px 0 rgba(0,0,0,0.2);
		-webkit-transition: color 0.3s, background-color 0.3s, box-shadow 0.3s, -webkit-transform 0.3s;
		transition: color 0.3s, background-color 0.3s, box-shadow 0.3s, transform 0.3s;
	}

	.btn_black a:hover{
		background-color: #333;
		box-shadow: 6px 3px 0 #ccc, 6px 6px 0px rgba(0,0,0,0.2);
		-webkit-transform: translateY(3px);
		transform: translateY(3px);
	}

	.btn_black a:active{
		color: #ddd;
		background-color: #555;
		box-shadow: 0 0 0 #ccc, 0 0 0px rgba(0,0,0,0.2);
		-webkit-transform: translateY(6px);
		transform: translateY(6px);
		transition-duration: 0.1s;
	}

	.btn_pink{
		width:100%;
		margin:30px auto;
		text-align:center;
	}

	.btn_pink a{
		font-family: TsukuGoPr5-D, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ＭＳ Pゴシック", Osaka, sans-serif;
		font-weight:bold;
		letter-spacing:2px;
		display: block;
		cursor: pointer;
		margin: 0 auto;
		padding: 20px;
		color: #fff;
		text-align: center;
		text-decoration: none;
		background-color: #e67578;
		box-shadow: 6px 6px 0 #ffd5d6, 6px 8px 0 rgba(230,117,120,0.2);
		-webkit-transition: color 0.3s, background-color 0.3s, box-shadow 0.3s, -webkit-transform 0.3s;
		transition: color 0.3s, background-color 0.3s, box-shadow 0.3s, transform 0.3s;
	}

	.btn_pink a:hover{
		background-color: #f09294;
		box-shadow: 6px 3px 0 #ffd5d6, 6px 6px 0px rgba(230,117,120,0.2);
		-webkit-transform: translateY(3px);
		transform: translateY(3px);
	}

	.btn_pink a:active{
		color: #fff;
		background-color: #ffb2b4;
		box-shadow: 0 0 0 #ffd5d6, 0 0 0px rgba(230,117,120,0.2);
		-webkit-transform: translateY(6px);
		transform: translateY(6px);
		transition-duration: 0.1s;
	}

	#main{
		width: 100%;
		margin: 0;
		padding: 0;
	}

	#main h2{
		font-size: 130%;
		line-height: 160%;
		text-align: center;
		margin: 0;
	}

	p.lead{
		font-size: 110%;
		line-height: 160%;
		margin-left: 1em;
		margin-right: 1em;
	}

	.title_pic{
		width: 100%;
		margin: 0 auto;
		line-height: 0;
		position: relative;
	}

	.title_pic_bottom{
		width: 100%;
		height: 70px;
	}

	.title_pic_bottom.about_title01{
		background: url(../img_sp/about/about_title01.png) center top no-repeat;
	}

	.title_pic_bottom.about_title02{
		background: url(../img_sp/about/about_title02.png) center top no-repeat;
	}

	div.style02 .title_pic_bottom.no_title{
		background: url(../img_sp/shop/common_circle.png) center top no-repeat;
	}

	.style01{
		width: 100%;
		padding: 0 0 15px 0;
		background: #fff;
	}

	.style02{
		width: 100%;
		padding: 0 0 15px 0;
		background: url(../img/common/bk01.png);
	}

	.style03{
		width: 100%;
		padding: 0 0 15px 0;
		background: #ffe8e8;
	}

	.style04{
		width: 100%;
		padding: 0 0 15px 0;
		background: #FFECED;
	}

	.main_body{
		width: 96%;
		margin: 0 auto;
		padding-top: 15px;
	}


	select.box{
		width: 100%;
		-webkit-appearance: none;
		-moz-appearance: none;
		appearance: none;
		margin: 0;
		height: 30px;
		background: transparent;
		position: relative;
		z-index: 1;
		padding: 0 0 0 10px;
		border: 1px solid #ccc;
	}

	select::-ms-expand {
		display: none;
	}

	.selectbox{
		width: 100%;
		margin: 0 auto;
		position: relative;
		background: #fff;
	}

	.selectbox::before{
		content:'';
		position: absolute;
		z-index: 0;
		top: 0;
		right: 0;
		background: #f2f2f2;
		height: 30px;
		width: 30px;
		border: 1px solid #ccc;
		box-sizing: border-box;
	}

	.selectbox::after{
		content:'';
		position: absolute;
		z-index: 0;
		top: 12px;
		bottom: 0;
		right: 9px;
		margin: 0 auto;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 6px 6px 0 6px;
		border-color: #333 transparent transparent transparent;
	}


	/* 影付きのパターン */
	.contents_bk{
		position: absolute;
		width: 100%;
		height: 100%;
		top: 5px;
		right: -5px;
		background: url(../img/common/bk03.png);
	}

}


/* --- PC ---------- */
@media print, screen and (min-width: 741px) {

	.sp_contents {
		display: none;
	}

	.btn_black{
		max-width:340px;
		width:80%;
		margin:70px auto;
		text-align:center;
	}

	.btn_black a{
		font-family: TsukuGoPr5-D, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ＭＳ Pゴシック", Osaka, sans-serif;
		font-weight:bold;
		letter-spacing:2px;
		display: block;
		cursor: pointer;
		margin: 0 auto;
		padding: 20px;
		color: #fff;
		text-align: center;
		text-decoration: none;
		background-color: #000;
		box-shadow: 6px 6px 0 #ccc, 6px 8px 0 rgba(0,0,0,0.2);
		-webkit-transition: color 0.3s, background-color 0.3s, box-shadow 0.3s, -webkit-transform 0.3s;
		transition: color 0.3s, background-color 0.3s, box-shadow 0.3s, transform 0.3s;
	}

	.btn_black a:hover{
		background-color: #333;
		box-shadow: 6px 3px 0 #ccc, 6px 6px 0px rgba(0,0,0,0.2);
		-webkit-transform: translateY(3px);
		transform: translateY(3px);
	}

	.btn_black a:active{
		color: #ddd;
		background-color: #555;
		box-shadow: 0 0 0 #ccc, 0 0 0px rgba(0,0,0,0.2);
		-webkit-transform: translateY(6px);
		transform: translateY(6px);
		transition-duration: 0.1s;
	}

	.btn_pink{
		width:100%;
		margin:70px auto;
		text-align:center;
	}

	.btn_pink a{
		font-family: TsukuGoPr5-D, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ＭＳ Pゴシック", Osaka, sans-serif;
		font-weight:bold;
		letter-spacing:2px;
		display: block;
		cursor: pointer;
		margin: 0 auto;
		padding: 20px;
		color: #fff;
		text-align: center;
		text-decoration: none;
		background-color: #e67578;
		box-shadow: 6px 6px 0 #ffd5d6, 6px 8px 0 rgba(230,117,120,0.2);
		-webkit-transition: color 0.3s, background-color 0.3s, box-shadow 0.3s, -webkit-transform 0.3s;
		transition: color 0.3s, background-color 0.3s, box-shadow 0.3s, transform 0.3s;
	}

	.btn_pink a:hover{
		background-color: #f09294;
		box-shadow: 6px 3px 0 #ffd5d6, 6px 6px 0px rgba(230,117,120,0.2);
		-webkit-transform: translateY(3px);
		transform: translateY(3px);
	}

	.btn_pink a:active{
		color: #fff;
		background-color: #ffb2b4;
		box-shadow: 0 0 0 #ffd5d6, 0 0 0px rgba(230,117,120,0.2);
		-webkit-transform: translateY(6px);
		transform: translateY(6px);
		transition-duration: 0.1s;
	}


	#main{
		width: 100%;
		margin: 0;
		padding: 0;
	}

	#main h2{
		font-size: 160%;
		line-height: 160%;
		text-align: center;
		margin: 0;
	}

	p.lead{
		font-size: 110%;
		line-height: 160%;
		text-align: center;
	}

	.title_pic{
		max-width: 2000px;
		width: 100%;
		margin: 0 auto;
		line-height: 0;
		position: relative;
	}

	.title_pic_bk{
		background: #ffecec;
	}

	.title_pic_bottom{
		max-width: 2200px;
		margin: 0 auto;
		width: 100%;
		height: 90px;
		position: relative;
		top: -90px;
		margin-bottom: -90px;
	}

	#main .title_pic h2{
		line-height: 0;
	}

	.title_pic_bottom.about_title01{
		background: url(../img/about/about_title01.png) center top no-repeat;
	}

	.title_pic_bottom.about_title02{
		background: url(../img/about/about_title02.png) center top no-repeat;
	}

	div.style02 .title_pic_bottom.no_title{
		position: absolute;
		left: 0;
		right: 0;
		bottom: 0;
		background: url(../img/shop/common_circle.png) center top no-repeat;
		top: auto;
		margin-bottom: 0;
	}

	.style01{
		width: 100%;
		padding: 0 0 50px 0;
		background: #fff;
	}

	.style02{
		width: 100%;
		padding: 0 0 50px 0;
		background: url(../img/common/bk01.png);
	}

	.style03{
		width: 100%;
		padding: 0 0 50px 0;
		background: #ffe8e8;
	}

	.style04{
		width: 100%;
		padding: 0 0 50px 0;
		background: #FFECED;
	}

	.white_space{
		width: 100%;
		height: 120px;
		background: #fff;
	}

	.main_body{
		max-width: 1200px;
		width: 90%;
		margin: 0 auto;
		padding-top: 50px;
	}


	select.box{
		width: 100%;
		-webkit-appearance:none;
		-moz-appearance:none;
		appearance:none;
		margin: 0;
		height: 30px;
		background: transparent;
		position: relative;
		z-index: 1;
		padding:0 0 0 10px;
		border:1px solid #ccc;
	}

	select::-ms-expand {
		display: none;
	}

	.selectbox{
		width: 100%;
		margin: 0 auto;
		position: relative;
		background: #fff;
	}

	.selectbox::before{
		content:'';
		position:absolute;
		z-index: 0;
		top: 0;
		right: 0;
		background: #f2f2f2;
		height: 30px;
		width: 30px;
		border: 1px solid #ccc;
		box-sizing: border-box;
	}

	.selectbox::after{
		content:'';
		position: absolute;
		z-index: 0;
		top: 12px;
		bottom: 0;
		right: 9px;
		margin: 0 auto;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 6px 6px 0 6px;
		border-color: #333 transparent transparent transparent;
	}


	/* 影付きのパターン */
	.contents_bk{
		position: absolute;
		width: 100%;
		height: 100%;
		top: 10px;
		right: -10px;
		background: url(../img/common/bk03.png);
	}

}



/* flex-boxのパターン */
/* --- SP ---------- */

@media print, screen and (max-width: 740px) {

	div.flex_contents{
	}

	div.flex_contents a{
		text-decoration: none;
	}

	div.flex_contents a h4{
	}

	div.flex_contents a p{
		color: #000;
	}

	div.flex_contents .flex_box.pt01{
		width: 98%;
		padding: 5px 10px 5px 5px;
		box-sizing: border-box;
		text-align: center;
		margin: 10px auto 0 auto;
		display: flex;
		-webkit-align-items: center;
		align-items: center;
	}

	div.flex_contents .flex_box.pt02{
		width: 98%;
		padding: 5px 10px 5px 5px;
		box-sizing: border-box;
		text-align: center;
		margin: 10px auto 0 auto;
		display: flex;
		-webkit-align-items: center;
		align-items: center;
	}

	div.flex_contents .flex_box.pt03{
		width: 98%;
		padding: 5px 10px 5px 5px;
		box-sizing: border-box;
		text-align: center;
		margin: 10px auto 0 auto;
		display: flex;
		-webkit-align-items: center;
		align-items: center;
	}

	div.flex_contents .flex_box.pt04{
		width: 98%;
		padding: 5px 10px 5px 5px;
		box-sizing: border-box;
		text-align: center;
		margin: 10px auto 0 auto;
		display: flex;
		-webkit-align-items: center;
		align-items: center;
	}

	div.flex_img{
		width: 36%;
		-webkit-flex-shrink: 0;
		flex-shrink: 0;
		text-align: center;
		margin-right: 5px;
		box-sizing: border-box;
	}

	div.flex_contents .flex_box.pt01 .flex_img img{
		max-width: 320px;
	}

	div.flex_contents .flex_box.pt02 .flex_img img{
		max-width: 320px;
	}

	div.flex_contents .flex_box.pt03 .flex_img img{
		max-width: 200px;
	}

	div.flex_text{
		width: 64%;
	}

	div.flex_box h4{
		font-size: 100%;
		text-align: left;
		margin: 10px 0;
		line-height: 150%;
	}

	div.flex_box h4 span.big{
		font-size: 130%;
	}

	div.flex_text p{
		font-size: 100%;
		text-align: left;
		margin: 10px 0 0 0;
		line-height: 150%;
		color: #000;
	}

}


/* --- PC ---------- */

@media print,screen and (min-width: 741px) {

	div.flex_contents{
		display: flex;
		flex-wrap: wrap;
		-webkit-justify-content: space-between;
		justify-content: space-between;
	}

	div.flex_contents a{
		text-decoration: none;
	}

	div.flex_contents a h4{
	}

	div.flex_contents a p{
		color: #000;
	}

	div.flex_contents .flex_box.pt01{
		width: 100%;
		padding: 10px 20px;
		box-sizing: border-box;
		text-align: center;
		margin-top: 15px;
	}

	div.flex_contents .flex_box.pt02{
		width: 49%;
		padding: 10px 20px;
		box-sizing: border-box;
		text-align: center;
		margin-top: 15px;
	}

	div.flex_contents .flex_box.pt03{
		width: 32%;
		padding: 10px 20px;
		box-sizing: border-box;
		text-align: center;
		margin-top: 15px;
	}

	div.flex_contents .flex_box.pt04{
		width: 24%;
		padding: 10px 20px;
		box-sizing: border-box;
		text-align: center;
		margin-top: 15px;
	}

	div.flex_img{
		width: 100%;
		text-align: center;
		margin: 0 auto;
	}

	div.flex_contents .flex_box.pt02 .flex_img img{
		max-width: 320px;
	}

	div.flex_contents .flex_box.pt01 .flex_img img{
		max-width: 320px;
	}

	div.flex_contents .flex_box.pt03 .flex_img img{
		max-width: 200px;
	}

	div.flex_box h4{
		font-size: 150%;
		margin: 10px 0 0 0;
		line-height: 150%;
	}

	div.flex_box h4 span.big{
		font-size: 150%;
	}

	div.flex_box p{
		font-size: 100%;
		margin: 10px 0 0 0;
		line-height: 150%;
		text-align: left;
		color: #000;
	}

}



/*　フッター　*/
/* --- SP ---------- */
@media print, screen and (max-width: 740px) {

	#footer{
		width:100%;
		background:#f5f5f5;
		padding: 15px 0 70px 0;
	}
	.footer_body{
		max-width:1200px;
		width:98%;
		margin:0 auto;
	}
	.footer_body .left{
		width:100%;
		border: 0;
		box-sizing:border-box;
		padding:0 8%;
		text-align:center;
		font-size:90%;
	}
	.footer_body .left p{
		margin:5px 0;
	}
	.footer_btn{
		width:100%;
		margin-top:10px;
		border:1px solid #000000;
	}
	.footer_btn a{
		display:block;
		padding:10px 5px;
		box-sizing:border-box;
		-webkit-transition: all .3s;
		transition: all .3s;
	}
	.footer_btn a:hover{
		text-decoration:none;
		background:#000;
		color:#fff;
	}
	.footer_body .right{
		display:none;
	}
	.footer_wrap{
		display: flex;
		justify-content: center;
		margin:25px 0;
	}
	.footer_wrap h3{
		text-align:center;
		margin-top:0;
		margin-bottom:5px;
		font-size:90%;
	}
	.footer_wrap ul{
		list-style-type:none;
		padding:0;
		margin:0;
	}
	.footer_box{
		margin:0 1.5%;
	}
	.footer_box li{
		font-size:75%;
	}

	#footer_sub{
		width: 100%;
		margin: 20px 0 0 0;
		padding: 10px 0 10px;
		text-align: center;
		background: #fff;
	}

	#footer_sub p{
		margin:0;
	}
	.footer_logo{
		max-width:190px;
		width:80%;
		margin:0 auto;
	}
	.footer_tel{
		max-width:400px;
		width:80%;
		margin:0 auto;
	}
	.pagetop{
		width:140px;
		margin:0 auto;
	}
	.footer_logo h2{
		margin:0;
	}

	div#side_btn{
		display: none;
	}

	div#sp_bottom_btn{
		display: -webkit-flex; /* Safari */
		display: flex;
		-webkit-flex-wrap: nowrap; /* Safari */
		flex-wrap: nowrap;
		-webkit-justify-content: space-between; /* Safari */
		justify-content: space-between;
		position: fixed;
		bottom: 0;
		z-index: 100;
	}

	div#sp_bottom_btn div.box{
		width: 32.5%;
		line-height: 0;
		box-sizing: border-box;
		border-right: 1px solid #fff;
	}

	div#sp_bottom_btn div.box:nth-child(4){
		border-right: none;
	}

	.link-bnr a{
		background: #e67578;
		color: #fff;
		box-sizing: border-box;
		padding: 10px 0;
		max-width: 220px;
		width: 90%;
		margin: 10px auto;
		display: block;
		-webkit-transition: all 0.7s ease;
		-moz-transition: all 0.7s ease;
		-o-transition: all 0.7s ease;
		transition: all  0.7s ease;
	}

	.link-bnr a:hover{
		text-decoration: none;
		background: #f59d9f;
	}
}


/* --- PC ---------- */
@media print, screen and (min-width: 741px) {

	#footer{
		width:100%;
		background:#f5f5f5;
		padding:50px 0 0 0;
	}
	.footer_body{
		max-width:1200px;
		width:98%;
		margin:0 auto;
	}
	.footer_body .left{
		width:38%;
		border-right:1px solid #c9c9c9;
		box-sizing:border-box;
		padding:0 5%;
		float:left;
		text-align:center;
		font-size:90%;
	}
	.footer_body .left p{
		margin:5px 0;
	}
	.footer_btn{
		width:100%;
		margin-top:5px;
		border:1px solid #000000;
	}
	.footer_btn a{
		display:block;
		padding:8px 5px;
		box-sizing:border-box;
		-webkit-transition: all .3s;
		transition: all .3s;
	}
	.footer_btn a:hover{
		text-decoration:none;
		background:#000;
		color:#fff;
	}
	.footer_body .right{
		width:62%;
		float:left;
		padding-left: 2%;
		box-sizing:border-box;
	}
	.footer_wrap{
		display: flex;
		margin:25px 0;
	}
	.footer_wrap h3{
		margin-top:0;
		margin-bottom:5px;
		font-size:90%;
	}
	.footer_wrap ul{
		list-style-type:none;
		padding:0;
		margin:0;
	}
	.footer_box{
		margin:0 1.0%;
	}
	.footer_box li{
		font-size:75%;
	}

	#footer_sub{
		width: 100%;
		margin: 50px 0 0 0;
		padding:70px 0 30px;
		text-align:center;
		background: #fff;
	}

	#footer_sub p{
		margin:0;
	}
	.footer_logo{
		max-width:290px;
		width:100%;
		margin:0 auto;
	}
	.pagetop{
		width:140px;
		margin:0 auto;
	}
	.footer_logo h2{
		margin:0 auto;
		max-width: 240px;
	}

	.footer_tel{
		margin:0 auto;
		max-width: 240px;
	}

	div#side_btn{
		width: 40px;
		position: fixed;
		top: 280px;
		right: 0;
		z-index: 9998;
		line-height: 0;
	}

	div#side_btn a{
		display: block;
		margin: 0 0 1px 0;
		padding: 0;
		border: 0;
		line-height: 0;
	}

	.link-bnr a{
		background: #e67578;
		color: #fff;
		box-sizing: border-box;
		padding: 10px 0;
		max-width: 220px;
		width: 90%;
		margin: 20px auto;
		display: block;
		-webkit-transition: all 0.7s ease;
		-moz-transition: all 0.7s ease;
		-o-transition: all 0.7s ease;
		transition: all  0.7s ease;
	}

	.link-bnr a:hover{
		text-decoration: none;
		background: #f59d9f;
	}
}


.Thanks__btn {
	margin-top: 40px; }
@media screen and (max-width: 768px) {
	.Thanks__btn {
		margin-top: 20px; } }
.Thanks__btn__link {
	width: 400px;
	height: 62px;
	margin: 0 auto;
	background-color: #242424;
	color: white!important;
	font-weight: bold;
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 31px;
	font-size: 18px;
	transition: all 0.3s 0s ease;
	cursor: pointer; }
.Thanks__btn__link:hover {
	opacity: 0.7;
	color: white; }
@media screen and (max-width: 768px) {
	.Thanks__btn__link {
		max-width: 400px;
		width: 100%; } }
.Thanks__btn__link__arrow {
	width: 7px;
	margin-left: 16px; }

.NotFoundBox {
	position: relative;
padding: 80px 0;}
@media screen and (max-width: 768px) {
	.NotFoundBox {
		padding: 40px 0; } }
.NotFoundBox__title {
	text-align: center;
	font-size: 36px;
	font-weight: bold;
	margin-bottom: 60px; }
@media screen and (max-width: 768px) {
	.NotFoundBox__title {
		margin-bottom: 27px;
		font-size: 24px;
		text-align: left; } }
.NotFoundBox__text {
	font-size: 16px;
	font-weight: 500;
	line-height: 1.6;
	width: 652px;
	margin: 0 auto; }
@media screen and (max-width: 768px) {
	.NotFoundBox__text {
		font-size: 1.6em;
		width: 100%;
		margin-bottom: 40px; } }