@charset "UTF-8";
/*
Theme Name: template
Author: Catwork Co., Ltd.
*/

/* Reset
----------------------------------------------------------- */
:root {
	/* bodyの背景色 */
	--body-bg-color: #fff;

	/* メインのフォントファミリー */
    --main-font: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;

	/* メインのフォントカラー */
	--main-font-color: #333;

	/* h2~h5タグまでのフォントウェイト */
	--h-tag-weight: normal;

	/* ここはブログで使用します */
	--main-color: #023752;
	--main-light-color: #bfe6e6;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header,
menu, nav, output, ruby, section, summary,
time, mark, audio, video{
	zoom:1;	/* hasLayout in IE */
	margin:0;
	padding:0;
	border:0;
	outline:0;
	font:inherit;
	font-size:100%;
	font-weight:normal;
	font-style:normal;
	vertical-align:baseline;
	background:transparent;
	-webkit-text-size-adjust: 100%;
	word-break:break-all;
}
header, menu, nav, footer,
section,article, aside,
details, summary,
figure, figcaption{display:block;}
table{
	border-collapse:collapse;
	border-spacing:0;
}
::placeholder{
	color: #ccc;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
q, blockquote{quotes:none;}
q:before, q:after, blockquote:before, blockquote:after{
	content:"";
	content:none;
}
img{
	font-size:0;
	line-height:0;
	vertical-align:bottom;
	height:auto;
	max-width:100%;
}
input {
	border-radius: 0;
	-webkit-appearance: none;
	line-height: normal;
	color: var(--main-font-color);
}
a{
	margin:0;
	padding:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
	color: var(--main-font-color);
}
a:focus{ outline:none; }
a img{
	border:none;
	vertical-align:middle;
}
textarea{overflow:auto;}
label{cursor:pointer;}
.clearfix:after{
	display:block;
	visibility:hidden;
	content:".";
	clear:both;
	height:0;
	font-size:0;
	line-height:0;
}
* html .clearfix{ zoom:1; }
*:first-child + html .clearfix{ zoom:1; }
* { flex-shrink: 0; }
a{ text-decoration:none; }
strong{ font-weight:normal; }
ul,ol{ list-style-type:none; }
body{
	font-family: var(--main-font);
	font-size:16px;
	line-height:1.5;
	color: var(--main-font-color);
	background: var(--body-bg-color);
}
.wrap{
	width:100%;
	overflow-x:hidden;
}
.inner{
	margin:0 auto;
	width:1200px;
}


/* wordpress ブロックcss
----------------------------------------------------------- */
.wp-block-embed iframe {
    max-width: 100%;
	position: relative !important;
	margin-bottom: 30px;
	pointer-events: none;
}
.wp-block-embed__wrapper {
    position: relative;
}
.wp-block-table{
	padding-bottom: 30px;
	overflow-x: auto;
}
.wp-block-table table {
    border-collapse: collapse;
	width: 100%;
}
.wp-block-table td, .wp-block-table th {
    padding: 0.5em;
    border: 1px solid #777777;
    word-break: normal;
}
.wp-block-table.is-style-stripes td, .wp-block-table.is-style-stripes th {
    border-color: transparent;
}
.wp-block-table.is-style-stripes {
    border-spacing: 0;
    border-collapse: inherit;
    background-color: transparent;
}
.wp-block-table thead{
	background: #aa843f;
	color: #fff;
}
.wp-block-table tfoot{
	background: #aa843f;
	color: #fff;
}
.wp-block-table.is-style-stripes tbody tr:nth-child(odd) {
    background-color: rgba(157, 190, 76, 0.4);
}
.wp-block-table.is-style-stripes tbody tr:nth-child(even) {
    background-color: rgba(255,255,255,1);
}
.wp-block-table figcaption{
	text-align: center;
}
.blogcont ul{
	padding:0 0 30px 30px;
	list-style: disc;
}
.blogcont ol {
	padding: 0 0 30px 30px;
	list-style: decimal;
}
.blogcont ul.pager{
	padding: 0;
	list-style: none;
}
.blogcont a{
	font-weight: bold;
	text-decoration: underline;
}
.blogcont ul.pager a{
	text-decoration:none;
}

/* 引用 */
blockquote.wp-block-quote {
	border-left: 1px solid;
    padding-left: 15px;
}
blockquote.wp-block-quote p {
	padding-bottom: 10px !important;
}

/* 埋め込みコンテンツ */
figure.wp-block-embed {
	margin-top: 30px;
}
blockquote.wp-block-quote cite {
	color: currentColor;
	font-size: 14px;
	color: #aaaaaa;
}

/* ギャラリー　*/
figure.wp-block-gallery {
	display: flex;
}
figure.wp-block-gallery.columns-1 figure.wp-block-image {
	width: 100%;
}
figure.wp-block-gallery.columns-2 figure.wp-block-image {
	width: 48%;
}
figure.wp-block-gallery.columns-3 figure.wp-block-image {
	width: 32%;
}
figure.wp-block-gallery.columns-4 figure.wp-block-image {
	width: 23%;
}
figure.wp-block-gallery.columns-5 figure.wp-block-image {
	width: 18%;
}
figure.wp-block-gallery.columns-6 figure.wp-block-image {
	width: 15%;
}
figure.wp-block-gallery figure.wp-block-image.is-style-rounded img {
	border-radius: 15px;
}

/* 動画 */
.wp-block-video {
	margin-top: 30px;
}
.wp-block-video video {
	max-width: 100%;
}

/* その他 */
.wp-block-embed__wrapper {
	position: relative;
}
.wp-block-embed__wrapper .wp-embedded-content {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
}
.wp-block-embed__wrapper .wp-embedded-content a {
	display: block;
	width: 100%;
	height: 100%;
}
iframe.wp-embedded-content {
	margin-bottom: 0;
}
:root .has-pale-pink-color {
	font-weight: bold;
    color: #f78da7
}
:root .has-vivid-red-color {
	font-weight: bold;
    color: #cf2e2e
}
:root .has-luminous-vivid-orange-color {
	font-weight: bold;
    color: #ff6900
}
:root .has-luminous-vivid-amber-color {
	font-weight: bold;
    color: #fcb900
}
:root .has-light-green-cyan-color {
	font-weight: bold;
    color: #7bdcb5
}
:root .has-vivid-green-cyan-color {
	font-weight: bold;
    color: #00d084
}
:root .has-pale-cyan-blue-color {
	font-weight: bold;
    color: #8ed1fc
}
:root .has-vivid-cyan-blue-color {
	font-weight: bold;
    color: #0693e3
}
:root .has-vivid-purple-color {
	font-weight: bold;
    color: #9b51e0
}
:root .has-white-color {
	font-weight: bold;
    color: #fff
}
:root .has-very-light-gray-color {
	font-weight: bold;
    color: #eee
}
:root .has-cyan-bluish-gray-color {
	font-weight: bold;
    color: #abb8c3
}
:root .has-very-dark-gray-color {
	font-weight: bold;
    color: #313131
}
:root .has-black-color {
	font-weight: bold;
    color: #000
}


/*===============================================
横幅1200px以下
===============================================*/
@media screen and (max-width: 1240px) and (min-width: 431px){
	html,
	body,
	.wrap{
		width:1240px;
	}
}

/*===============================================
横幅431px以上
===============================================*/
@media screen and (min-width: 431px) {
	a:hover{
		opacity:0.8;
		filter:alpha(opacity=80);
		-moz-opacity:0.8;
		transition: all .5s;
	}
	.sp{
		display:none;
	}

	/* スムーススクロール設定 */
	html {
		scroll-behavior: smooth;
	}
	:root {
		--header-height: 135px;
	}


/* header
------------------------------------------------------------------------*/
	
	header{
		width: 100%;
		height: 100px;
		z-index: 10000;
		position: relative;
	}
	header h1{
		position: absolute;
		top: 15px;
		left: 19px;
		font-size: 12px;
	}
	header .logo{
		position: absolute;
		top: 50px;
		left: 20px;
	}
	header .tel a{
		position: absolute;
		top: 29px;
		right: 280px;
		line-height: 1;
	}
	header .sns_box{
		position: absolute;
		top: 25px;
		right: 190px;
		display: flex;
		justify-content: space-between;
		width: 70px;
	}
	header .button{
		position: absolute;
		top: 20px;
		right: 20px;
	}
	header .button a{
		display: block;
		width: 150px;
		height: 35px;
		background: #555;
		color: #fff;
		font-size: 12px;
		line-height: 35px;
		text-align: center;
	}

/* home
------------------------------------------------------------------------*/
	
	/* key ----------------------------------------------*/
	.home .key{
		height: 740px;
		background: url("img/key_bg.png")center center /cover no-repeat;
	}
	.home .key .inner{
		position: relative;
	}
	.home .key .inner .text01{
		position: absolute;
		top: 72px;
		left: 310px;
		writing-mode: vertical-rl;
		text-orientation: upright;
		font-size: 24px;
		line-height: 2.1;
		letter-spacing: 3px;
		white-space: nowrap;
	}
	.home .key .inner .text02{
		position: absolute;
		top: 72px;
		left: 135px;
		writing-mode: vertical-rl;
		text-orientation: upright;
		font-size: 20px;
		line-height: 3.4;
		letter-spacing: 3px;
		white-space: nowrap;
	}
		.home .key .inner .text02::after{
			position: absolute;
			top: 230px;
			left: 35px;
			content: "";
			background: #333;
			width: 1px;
			height: 135px;
		}
	.home .key .inner .text02 > span{
		display: inline-block;
		font-size: 28px;
		margin-top: -20px;
	}
	.home .key .inner .text02 span span{
		display: inline-block;
		background: #f2f2f2;
		padding: 15px;
		margin: 4px 0;
		line-height: 1;
	}
	
	
	/* cont01 ----------------------------------------------*/
	.home .cont01 .box{
		background: #f2f2f2;
		text-align: center;
		padding: 96px 0 78px;
		margin-top: 125px;
	}
	.home .cont01 .box h2{
		font-size: 24px;
		line-height: 2.16;
		position: relative;
	}
		.home .cont01 .box h2::after{
			position: absolute;
			bottom: -55px;
			left: 50%;
			transform: translateX(-50%);
			content: "";
			background: #333;
			width: 1px;
			height: 30px;
		}
	.home .cont01 .box .text01{
		font-size: 18px;
		line-height: 2.55;
		margin-top: 80px;
	}
	.home .cont01 .inner{
		padding: 150px 0 0;
	}
	.home .cont01 .inner .cont{
		padding: 0 0 0 600px;
		box-sizing: border-box;
		position: relative;
	}
		.home .cont01 .inner .cont::before{
			position: absolute;
			top: 0;
			left: -300px;
			content: "";
			background: url("img/home_img01.png")no-repeat;
			width: 1180px;
			height: 540px;
			z-index: -1;
		}
	.home .cont01 .inner .cont:nth-of-type(n+2){
		margin-top: 30px;
	}
	.home .cont01 .inner .cont:nth-of-type(2){
		padding: 0 600px 0 0;
	}
		.home .cont01 .inner .cont:nth-of-type(2)::before{
			left: auto;
			right: -300px;
			background: url("img/home_img02.png")no-repeat;
		}
		.home .cont01 .inner .cont:nth-of-type(3)::before{
			background: url("img/home_img03.png")no-repeat;
		}
	.home .cont01 .inner .cont h3{
		writing-mode: vertical-rl;
		text-orientation: upright;
		width: 100%;
		color: #999;
		font-size: 70px;
		letter-spacing: 24px;
		line-height: 1;
	}
	.home .cont01 .inner .cont:nth-of-type(2) h3{
		width: auto;
	}
	.home .cont01 .inner .cont .text02{
		background: url("img/home_text01.png")right top no-repeat;
		padding-top: 34px;
		font-size: 24px;
		text-align: right;
		line-height: 1;
		margin-top: 55px;
	}
	.home .cont01 .inner .cont:nth-of-type(2) .text02{
		background: url("img/home_text02.png")left top no-repeat;
		text-align: left;
	}
	.home .cont01 .inner .cont:nth-of-type(3) .text02{
		background: url("img/home_text03.png")right top no-repeat;
	}
	.home .cont01 .inner .cont .text03{
		background: rgba(255,255,255,0.8);
		padding: 70px 0 70px 80px;
		line-height: 2.25;
		letter-spacing: -0.6px;
	}
	.home .cont01 .inner .cont:nth-of-type(2) .text03{
		padding: 70px 80px 70px 0;
	}
	.home .cont01 .bg {
		height: 335px;
		animation: bMove 80s linear infinite;
		background: url("img/home_bg01.png");
		margin: 0 0 180px;
	}
	@keyframes bMove {
		0% {background-position: 1940px 0;}
		25% {background-position: 1455px 0;}
		50% {background-position: 970px 0;}
		75% {background-position: 485px 0;}
		100% {background-position: 0 0;}
	}
	
	
	/* cont02 ----------------------------------------------*/
	.home .cont02{
		background: #f2f2f2;
	}
	.home .cont02 .inner{
		padding: 119px 0 130px;
		z-index: 10;
		position: relative;
	}
	.home .cont02 .inner h2{
		background: url("img/home_text04.png")center top no-repeat;
		padding-top: 70px;
		font-size: 16px;
		text-align: center;
		letter-spacing: 3px;
	}
	.home .cont02 .inner .cont{
		width: 1100px;
		background: rgba(255,255,255,0.9);
		padding: 50px;
		box-sizing: border-box;
		margin: 110px auto 0;
		position: relative;
	}
		.home .cont02 .inner .cont::before{
			position: absolute;
			top: -50px;
			left: 50%;
			transform: translateX(-50%);
			content: "";
			background: url("img/home_img04.png")no-repeat;
			width: 1200px;
			height: 320px;
			z-index: -1;
		}
		.home .cont02 .inner .cont:nth-of-type(2)::before{
			background: url("img/home_img05.png")no-repeat;
		}
		.home .cont02 .inner .cont:nth-of-type(3)::before{
			background: url("img/home_img06.png")no-repeat;
		}
	.home .cont02 .inner .cont:nth-of-type(n+2){
		margin-top: 130px;
	}
	.home .cont02 .inner .cont h3{
		font-size: 30px;
		letter-spacing: 4px;
		text-align: center;
	}
		.home .cont02 .inner .cont h3::before{
			content: "Plan";
			padding-right: 20px;
			font-size: 16px;
		}
	.home .cont02 .inner .cont .text01{
		font-size: 18px;
		text-align: center;
		margin-top: 36px;
		position: relative;
	}
	.home .cont02 .inner .cont .text01::after{
		position: absolute;
		bottom: -35px;
		left: 50%;
		transform: translateX(-50%);
		content: "";
		background: url("img/home_line01.png")no-repeat;
		width: 1004px;
		height: 1px;
	}
	.home .cont02 .inner .cont table{
		width: 930px;
		margin: 65px auto 0;
	}
	.home .cont02 .inner .cont table th{
		width: 180px;
		height: 70px;
		font-size: 18px;
		text-align: left;
	}
	.home .cont02 .inner .cont table th span{
		position: relative;
		padding-left: 20px;
	}
		.home .cont02 .inner .cont table th span::before{
			position: absolute;
			top: 50%;
			left: 0;
			transform: translateY(-50%);
			content: "";
			background: #999;
			width: 10px;
			height: 10px;
		}
	.home .cont02 .inner .cont table td{
		font-size: 18px;
	}
	.home .cont02 .inner .cont table td span{
		font-size: 30px;
	}
	.home .cont02 .inner .cont table td ul li{
		padding-left: 26px;
		font-size: 16px;
		line-height: 1.875;
		margin-bottom: 16px;
		position: relative;
	}
		.home .cont02 .inner .cont table td ul li::before{
			position: absolute;
			top: 0;
			left: 0;
			content: "01.";
		}
		.home .cont02 .inner .cont table td ul li:nth-of-type(2)::before{
			content: "02.";
		}
		.home .cont02 .inner .cont table td ul li:nth-of-type(3)::before{
			content: "03.";
		}
	.home .cont02 .inner .cont table td ul li:last-of-type{
		margin-bottom: 0;
	}
	.home .cont02 .inner .text02{
		font-size: 14px;
		line-height: 2;
	}
		.home .cont02 .inner .text02::before{
			content: "※";
		}
	.home .cont02 .inner .text02:nth-of-type(1){
		margin-top: 50px;
	}
	
	
	/* cont03 ----------------------------------------------*/
	.home .cont03 .inner{
		padding: 140px 0 130px;
		z-index: 10;
		position: relative;
	}
	.home .cont03 .inner h2{
		background: url("img/home_text05.png")center top no-repeat;
		padding-top: 70px;
		font-size: 16px;
		text-align: center;
		letter-spacing: 2px;
	}
	.home .cont03 .inner .cont{
		margin: 60px 0 0 420px;
		background: #f2f2f2;
		padding: 74px 0 74px 240px;
		box-sizing: border-box;
		position: relative;
	}
		.home .cont03 .inner .cont::after{
			position: absolute;
			top: 50%;
			left: 780px;
			transform: translateY(-50%);
			content: "";
			background: #f2f2f2;
			width: 1000px;
			height: 100%;
		}
	.home .cont03 .inner .cont:nth-of-type(2){
		margin: 60px 420px 0 0;
		padding: 74px 225px 74px 0;
	}
		.home .cont03 .inner .cont:nth-of-type(2)::after{
			left: auto;
			right: 780px;
		}
	.home .cont03 .inner .cont .kind{
		width: 140px;
		height: 30px;
		background: #fff;
		font-size: 14px;
		text-align: center;
		line-height: 30px;
	}
	.home .cont03 .inner .cont h3{
		font-size: 20px;
		margin-top: 35px;
	}
	.home .cont03 .inner .cont .text01{
		margin-top: 10px;
	}
	.home .cont03 .inner .cont .text02{
		margin-top: 28px;
		line-height: 2;
	}
	.home .cont03 .inner .cont .img{
		position: absolute;
		top: 50%;
		left: -420px;
		transform: translateY(-50%);
		width: 600px;
	}
	.home .cont03 .inner .cont:nth-of-type(2) .img{
		left: auto;
		right: -420px;
	}
	.home .cont03 .inner .cont .img video{
		width: 100%;
	}
	
	
	/* cont04 ----------------------------------------------*/
	.home .cont04{
		height: 800px;
		background: url("img/home_bg02.png")center center/cover no-repeat;
	}
	.home .cont04 .inner{
		padding: 80px 0 72px;
		color: #fff;
		text-align: center;
	}
	.home .cont04 .inner h2{
		line-height: 1.9;
	}
	.home .cont04 .inner h2 span{
		display: block;
		font-size: 38px;
	}
	.home .cont04 .inner .text01{
		line-height: 2.5;
		margin-top: 38px;
	}
	.home .cont04 .inner .text02{
		margin-top: 43px;
	}
	.home .cont04 .inner .sns_btn{
		margin-top: 16px;
	}
	
	
	/* contact_box ----------------------------------------------*/
	.contact_box{
		background: #f2f2f2;
	}
	.contact_box .inner{
		padding: 149px 0 0;
		box-sizing: border-box;
	}
	.contact_box .inner h2{
		background: url("img/home_text06.png")center top no-repeat;
		padding-top: 65px;
		text-align: center;
		letter-spacing: 2px;
	}
	.contact_box .inner table{
		border-collapse: separate;
		border-spacing: 5px 10px;
		margin: 45px auto 0;
		text-align: left;
	}
	.contact_box .inner table th{
		width: 250px;
		height: 60px;
		background: #ccc;
		vertical-align: middle;
		padding: 0 0 0 30px;
		box-sizing: border-box;
		position: relative;
	}
	.contact_box .inner table th span{
		position: absolute;
		top: 50%;
		right: 10px;
		transform: translateY(-50%);
		width: 45px;
		height: 20px;
		background: #fff;
		font-size: 12px;
		line-height: 20px;
		text-align: center;
	}
	.contact_box .inner table td{
		width: 700px;
		height: 60px;
		background: #fff;
		vertical-align: middle;
		box-sizing: border-box;
	}
	.contact_box .inner table td input[type="text"],
	.contact_box .inner table td input[type="tel"],
	.contact_box .inner table td input[type="email"] {
		width: 700px;
		height: 60px;
		padding: 0 0 0 30px;
		font-size: 16px;
		line-height: 60px;
		box-sizing: border-box;
		background: #fff;
		border: none;
	}
	.contact_box .inner table td textarea{
		display: block;
		width: 700px !important;
		height: 270px !important;
		background: #fff;;
		border: none;
		box-sizing: border-box;
		padding: 30px;
	}
	.contact_box .inner .privacy_check{
		text-align: center;
		margin-top: 36px;
	}
	.contact_box .inner .privacy_check input{
		-webkit-appearance: checkbox;
	}
	.contact_box .inner .button input{
		display: block;
		width: 390px;
		height: 50px;
		background: #555;
		border: none;
		color: #fff;
		font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
		font-size: 14px;
		line-height: 50px;
		text-align: center;
		margin: 37px auto 0;
		box-sizing: border-box;
		cursor: pointer;
		border: 1px solid #555;
		transition: all .3s;
	}
	.contact_box .inner .button input:hover {
		color: #555;
		background: #fff;
		transition: all .3s;
	}
	.contact_box .inner h3{
		width: 955px;
		height: 40px;
		background: #ccc;
		box-sizing: border-box;
		margin: 60px auto 0;
		font-size: 15px;
		text-align: center;
		line-height: 40px;
	}
	.contact_box .inner .privacy_box{
		padding: 25px 30px;
		width: 955px;
		height: 180px;
		background: #fff;
		overflow-y: auto;
		margin: 0 auto;
		box-sizing: border-box;
		text-align: left;
	}
	.contact_box .inner .privacy_box h4{
		font-size: 14px;
		line-height: 2;
	}
		.contact_box .inner .privacy_box h4::before{
			content: "【";
		}
		.contact_box .inner .privacy_box h4::after{
			content: "】";
		}
	.contact_box .inner .privacy_box h4:nth-of-type(n+2) {
		margin-top: 20px;
	}
	.contact_box .inner .privacy_box .text01{
		font-size: 14px;
		line-height: 2;
	}


	/*thanks
	--------------------------------------------------------------------------*/
	.thanks {
		background: #f2f2f2;
		height: 100vh;
	}
	.thanks .thanks-cont01{
		padding: 60px 0 30px;
	}
	.thanks .thanks-cont01 h2{
		font-size: 24px;
		font-weight: bold;
		text-align: center;
		color: #333;
		background:transparent;
		margin-bottom: 25px;
		padding: 0;
	}
	.thanks .thanks-cont01 .text{
		line-height: 1.8;
		text-align: center;
		font-size: 14px;
	}
	.thanks .thanks-cont01 .button a{
		display: block;
		width: 280px;
		margin: auto;
		font-size: 18px;
		font-weight: bold;
		letter-spacing: 1px;
		padding: 10px 0;
		text-align: center;
		background: #333;
		color: #fff;
		margin: 30px auto;
		border-radius: 25px;
	}



/* footer
------------------------------------------------------------------------*/
	footer{
		background: #f2f2f2;
	}
	footer .copy{
		width: 955px;
		color: #333;
		font-size: 14px;
		text-align: right;
		line-height: 90px;
		margin: 0 auto;
	}
	
}



/*===============================================
横幅431px以下
===============================================*/
@media screen and (max-width: 431px) {
	html,
	body,
	.wrap{
		width: 430px;
		position: relative;
	}
	.inner{
		box-sizing: border-box;
		padding: 0 15px;
		width: auto;
	}
	img{
		max-width: 100%;
	}
	.pc{
		display: none;
	}
	.sp {
		display: block;
	}

	/* スムーススクロール設定 */
	html {
		scroll-behavior: smooth;
	}
	:root {
		--header-height: 80px;
	}

/* header
------------------------------------------------------------------------*/
	
	header{
		width: 100%;
		background: #fff;
		z-index: 10000;
		position: relative;
	}
		header::before{
			position: fixed;
			top: 0;
			left: 0;
			content: "";
			background: rgba(255,255,255,0.6);
			width: 100%;
			height: 70px;
			z-index: -1;
		}
	header h1{
		position: absolute;
		top: 5px;
		left: 10px;
		color: #333;
		font-size: 10px;
		font-weight: normal;
		letter-spacing: -0.4px;
	}
	header .logo{
		position: fixed;
		top: 22px;
		left: 10px;
	}
	header .tel{
		position: fixed;
		top: 17px;
		right: 132px;
	}
	header .tel a{
		display: block;
		background: url("img/header_tel_sp.png")center center no-repeat;
		width: 22px;
		height: 0;
		padding-top: 22px;
		overflow: hidden;
		box-sizing: border-box;
	}
	header .sns_box{
		position: fixed;
		top: 14px;
		right: 52px;
		display: flex;
		justify-content: space-between;
		width: 65px;
	}
	header .button{
		position: fixed;
		top: 18px;
		right: 15px;
	}
	header .button a{
		display: block;
		width: 22px;
		height: 0;
		background: url("img/header_icon03.png");
		padding-top: 17px;
		overflow: hidden;
	}

/* home
------------------------------------------------------------------------*/
	
	/* key ----------------------------------------------*/
	.home .key{
		height: 760px;
		background: url("img/key_bg_sp.png")center top no-repeat;
		background-size: 100%;
		margin-top: 70px;
	}
	.home .key .inner{
		position: relative;
	}
	.home .key .inner .text01{
		position: absolute;
		top: 390px;
		left: 110px;
		writing-mode: vertical-rl;
		text-orientation: upright;
		font-size: 16px;
		line-height: 1.9;
		letter-spacing: 2px;
		white-space: nowrap;
	}
	.home .key .inner .text02{
		position: absolute;
		top: 390px;
		left: 20px;
		writing-mode: vertical-rl;
		text-orientation: upright;
		font-size: 14px;
		line-height: 2.6;
		letter-spacing: 2px;
		white-space: nowrap;
	}
		.home .key .inner .text02::after{
			position: absolute;
			top: 160px;
			left: 18px;
			content: "";
			background: #333;
			width: 1px;
			height: 90px;
		}
	.home .key .inner .text02 > span{
		display: inline-block;
		font-size: 18px;
		margin-top: -10px;
	}
	.home .key .inner .text02 span span{
		display: inline-block;
		background: #f2f2f2;
		padding: 6px 11px;
		margin: 4px 0;
		line-height: 1;
	}
	
	
	/* cont01 ----------------------------------------------*/
	.home .cont01 .box{
		background: #f2f2f2;
		text-align: center;
		padding: 70px 0;
	}
	.home .cont01 .box h2{
		font-size: 18px;
		line-height: 2.16;
		position: relative;
	}
		.home .cont01 .box h2::after{
			position: absolute;
			bottom: -50px;
			left: 50%;
			transform: translateX(-50%);
			content: "";
			background: #333;
			width: 1px;
			height: 30px;
		}
	.home .cont01 .box .text01{
		font-size: 14px;
		line-height: 2.28;
		margin-top: 70px;
	}
	.home .cont01 .inner{
		padding: 70px 15px 0;
	}
	.home .cont01 .inner .cont{
		padding: 230px 0 0;
		box-sizing: border-box;
		position: relative;
	}
		.home .cont01 .inner .cont::before{
			position: absolute;
			top: 0;
			left: 50%;
			transform: translateX(-50%);
			content: "";
			background: url("img/home_img01.png")no-repeat;
			background-size: 400px;
			width: 400px;
			height: 185px;
			z-index: -1;
		}
		.home .cont01 .inner .cont:nth-of-type(2)::before{
			background: url("img/home_img02.png")no-repeat;
			background-size: 400px;
		}
		.home .cont01 .inner .cont:nth-of-type(3)::before{
			background: url("img/home_img03.png")no-repeat;
			background-size: 400px;
		}
	.home .cont01 .inner .cont:nth-of-type(n+2){
		margin-top: 50px;
	}
	.home .cont01 .inner .cont h3{
		writing-mode: vertical-rl;
		text-orientation: upright;
		width: 50%;
		transform: translateX(20px);
		color: #999;
		font-size: 40px;
		letter-spacing: 18px;
		line-height: 1;
	}
	.home .cont01 .inner .cont .text02{
		background: url("img/home_text01.png")center top no-repeat;
		padding-top: 34px;
		text-align: center;
		line-height: 1;
		margin-top: 40px;
	}
	.home .cont01 .inner .cont:nth-of-type(2) .text02{
		background: url("img/home_text02.png")center top no-repeat;
	}
	.home .cont01 .inner .cont:nth-of-type(3) .text02{
		background: url("img/home_text03.png")center top no-repeat;
	}
	.home .cont01 .inner .cont .text03{
		padding: 30px;
		font-size: 14px;
		line-height: 2.25;
		letter-spacing: -0.6px;
	}
	.home .cont01 .bg {
		height: 335px;
		animation: bMove 80s linear infinite;
		background: url("img/home_bg01.png");
		margin: 50px 0 70px;
	}
	@keyframes bMove {
		0% {background-position: 1940px 0;}
		25% {background-position: 1455px 0;}
		50% {background-position: 970px 0;}
		75% {background-position: 485px 0;}
		100% {background-position: 0 0;}
	}
	
	
	/* cont02 ----------------------------------------------*/
	.home .cont02{
		background: #f2f2f2;
	}
	.home .cont02 .inner{
		padding: 70px 15px;
		z-index: 10;
		position: relative;
	}
	.home .cont02 .inner h2{
		background: url("img/home_text04.png")center top no-repeat;
		padding-top: 70px;
		font-size: 16px;
		text-align: center;
		letter-spacing: 3px;
	}
	.home .cont02 .inner .cont{
		width: 400px;
		background: rgba(255,255,255,0.9);
		padding: 40px 20px 15px;
		box-sizing: border-box;
		margin: 80px auto 0;
		position: relative;
	}
		.home .cont02 .inner .cont::before{
			position: absolute;
			top: -40px;
			left: 50%;
			transform: translateX(-50%);
			content: "";
			background: url("img/home_img04.png")no-repeat;
			background-size: 900px;
			width: 900px;
			height: 250px;
			z-index: -1;
		}
		.home .cont02 .inner .cont:nth-of-type(2)::before{
			background: url("img/home_img05.png")no-repeat;
			background-size: 900px;
		}
		.home .cont02 .inner .cont:nth-of-type(3)::before{
			background: url("img/home_img06.png")no-repeat;
			background-size: 900px;
		}
	.home .cont02 .inner .cont:nth-of-type(n+2){
		margin-top: 100px;
	}
	.home .cont02 .inner .cont h3{
		font-size: 24px;
		letter-spacing: 4px;
		text-align: center;
	}
		.home .cont02 .inner .cont h3::before{
			content: "Plan";
			padding-right: 14px;
			font-size: 12px;
			letter-spacing: 1px;
		}
	.home .cont02 .inner .cont .text01{
		font-size: 14px;
		line-height: 1.9;
		text-align: center;
		margin-top: 22px;
		position: relative;
	}
	.home .cont02 .inner .cont .text01::after{
		position: absolute;
		bottom: -35px;
		left: 50%;
		transform: translateX(-50%);
		content: "";
		background: url("img/home_line01.png")no-repeat;
		width: 320px;
		height: 1px;
	}
	.home .cont02 .inner .cont table{
		width: 320px;
		margin: 65px auto 0;
	}
	.home .cont02 .inner .cont table th{
		display: block;
		width: 100%;
		height: 30px;
		font-size: 14px;
		text-align: left;
	}
	.home .cont02 .inner .cont table th span{
		position: relative;
		padding-left: 20px;
	}
		.home .cont02 .inner .cont table th span::before{
			position: absolute;
			top: 50%;
			left: 0;
			transform: translateY(-50%);
			content: "";
			background: #999;
			width: 10px;
			height: 10px;
		}
	.home .cont02 .inner .cont table td{
		display: block;
		width: 100%;
		font-size: 14px;
		margin-bottom: 25px;
	}
	.home .cont02 .inner .cont table td span{
		font-size: 26px;
	}
	.home .cont02 .inner .cont table td ul li{
		padding-left: 26px;
		font-size: 12px;
		line-height: 1.875;
		margin-bottom: 16px;
		position: relative;
	}
		.home .cont02 .inner .cont table td ul li::before{
			position: absolute;
			top: 0;
			left: 0;
			content: "01.";
		}
		.home .cont02 .inner .cont table td ul li:nth-of-type(2)::before{
			content: "02.";
		}
		.home .cont02 .inner .cont table td ul li:nth-of-type(3)::before{
			content: "03.";
		}
	.home .cont02 .inner .cont table td ul li:last-of-type{
		margin-bottom: 0;
	}
	.home .cont02 .inner .text02{
		font-size: 10px;
		line-height: 2;
	}
		.home .cont02 .inner .text02::before{
			content: "※";
		}
	.home .cont02 .inner .text02:nth-of-type(1){
		margin-top: 20px;
	}
	
	
	/* cont03 ----------------------------------------------*/
	.home .cont03 .inner{
		padding: 70px 15px;
		z-index: 10;
		position: relative;
	}
	.home .cont03 .inner h2{
		background: url("img/home_text05.png")center top no-repeat;
		padding-top: 70px;
		font-size: 16px;
		text-align: center;
		letter-spacing: 2px;
	}
	.home .cont03 .inner .cont{
		margin: 190px 0 0;
		background: #f2f2f2;
		padding: 95px 30px 30px;
		box-sizing: border-box;
		position: relative;
	}
		.home .cont03 .inner .cont::after{
			content: none;
		}
	.home .cont03 .inner .cont:nth-of-type(2){
		margin-top: 210px;
		padding-top: 130px;
	}
	.home .cont03 .inner .cont .kind{
		width: 100px;
		height: 25px;
		background: #fff;
		font-size: 12px;
		text-align: center;
		line-height: 25px;
	}
	.home .cont03 .inner .cont h3{
		font-size: 18px;
		margin-top: 15px;
	}
	.home .cont03 .inner .cont .text01{
		font-size: 14px;
		margin-top: 10px;
	}
	.home .cont03 .inner .cont .text02{
		font-size: 14px;
		margin-top: 22px;
		line-height: 1.9;
	}
	.home .cont03 .inner .cont .img{
		position: absolute;
		top: -150px;
		left: 50%;
		transform: translateX(-50%);
		width: 380px;
	}
	.home .cont03 .inner .cont:nth-of-type(2) .img{
		
	}
	.home .cont03 .inner .cont .img video{
		width: 100%;
	}
	
	
	/* cont04 ----------------------------------------------*/
	.home .cont04{
		height: 800px;
		background: url("img/home_bg02.png")center center/cover no-repeat;
	}
	.home .cont04 .inner{
		padding: 70px 0;
		color: #fff;
		text-align: center;
	}
	.home .cont04 .inner h2{
		font-size: 14px;
		line-height: 1.9;
	}
	.home .cont04 .inner h2 span{
		display: block;
		font-size: 24px;
	}
	.home .cont04 .inner .text01{
		font-size: 14px;
		line-height: 2.1;
		margin-top: 28px;
	}
	.home .cont04 .inner .text02{
		font-size: 14px;
		margin-top: 30px;
	}
	.home .cont04 .inner .sns_btn{
		margin-top: 12px;
	}
	
	
	/* contact_box ----------------------------------------------*/
	.contact_box{
		background: #f2f2f2;
	}
	.contact_box .inner{
		padding: 70px 20px 0;
		box-sizing: border-box;
	}
	.contact_box .inner h2{
		background: url("img/home_text06.png")center top no-repeat;
		padding-top: 65px;
		text-align: center;
		letter-spacing: 2px;
	}
	.contact_box .inner table{
		width: 390px;
		border-collapse: separate;
		border-spacing: 5px 10px;
		margin: 35px auto 0;
		text-align: left;
	}
	.contact_box .inner table th{
		display: block;
		width: 100%;
		height: 50px;
		background: #ccc;
		padding: 0 0 0 10px;
		box-sizing: border-box;
		line-height: 50px;
		position: relative;
	}
	.contact_box .inner table th span{
		position: absolute;
		top: 50%;
		right: 10px;
		transform: translateY(-50%);
		width: 45px;
		height: 20px;
		background: #fff;
		font-size: 12px;
		line-height: 20px;
		text-align: center;
	}
	.contact_box .inner table td{
		display: block;
		width: 100%;
		background: #fff;
		vertical-align: middle;
		box-sizing: border-box;
	}
	.contact_box .inner table td input[type="text"],
	.contact_box .inner table td input[type="tel"],
	.contact_box .inner table td input[type="email"] {
		width: 100%;
		padding: 20px 0 20px 10px;
		font-size: 16px;
		box-sizing: border-box;
		background: #fff;
		border: none;
	}
	.contact_box .inner table td textarea{
		display: block;
		width: 100% !important;
		height: 220px !important;
		background: #fff;;
		border: none;
		box-sizing: border-box;
		padding: 30px;
	}
	.contact_box .inner .privacy_check{
		text-align: center;
		margin-top: 36px;
	}
	.contact_box .inner .privacy_check input{
		-webkit-appearance: checkbox;
	}
	.contact_box .inner .button input{
		display: block;
		width: 320px;
		height: 50px;
		background: #555;
		border: none;
		color: #fff;
		font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
		font-size: 14px;
		line-height: 50px;
		text-align: center;
		margin: 37px auto 0;
		box-sizing: border-box;
		cursor: pointer;
	}
	.contact_box .inner h3{
		width: 390px;
		height: 40px;
		background: #ccc;
		box-sizing: border-box;
		margin: 50px auto 0;
		font-size: 15px;
		text-align: center;
		line-height: 40px;
	}
	.contact_box .inner .privacy_box{
		padding: 20px 25px;
		width: 390px;
		height: 180px;
		background: #fff;
		overflow: scroll;
		margin: 0 auto;
		box-sizing: border-box;
		text-align: left;
	}
	.contact_box .inner .privacy_box h4{
		font-size: 14px;
		line-height: 2;
	}
		.contact_box .inner .privacy_box h4::before{
			content: "【";
		}
		.contact_box .inner .privacy_box h4::after{
			content: "】";
		}
	.contact_box .inner .privacy_box .text01{
		font-size: 14px;
		line-height: 2;
	}


	/*thanks
	--------------------------------------------------------------------------*/
	.thanks {
		height: 100vh;
		background: #f2f2f2;
	}
	.thanks .thanks-cont01{
		margin-top: 105px;
		padding: 80px 0 50px;
	}
	.thanks .thanks-cont01 h2{
		font-size: 30px;
		font-weight: bold;
		text-align: center;
		color: #333;
		background:transparent;
		margin-bottom: 40px;
		padding: 0;
	}
	.thanks .thanks-cont01 .text{
		line-height: 1.8;
		text-align: center;
		font-size: 16px;
	}
	.thanks .thanks-cont01 .button a{
		display: block;
		width: 300px;
		margin: auto;
		font-size: 18px;
		font-weight: bold;
		letter-spacing: 1px;
		padding: 10px 0;
		text-align: center;
		background: #333;
		color: #fff;
		margin: 40px auto 30px;
		border-radius: 25px;
	}


/* footer
------------------------------------------------------------------------*/
	footer{
		background: #f2f2f2;
	}
	footer .copy{
		width: 380px;
		color: #333;
		font-size: 14px;
		text-align: right;
		line-height: 90px;
		margin: 0 auto;
	}

}



/*mail form pro
----------------------------------------------------------*/
div#mfp_hidden {
	overflow: hidden;
	width: 1px;
	height: 1px;
	padding: 0px;
	margin: 0px;
}
div#mfp_hidden input {
	margin: 10px;
}
div.mfp_thanks {
	padding: 30px;
}
div.mfp_thanks p {
	line-height: 1.7em;
}
div.mfp_thanks ul.mfp_caution {
	margin: 0px;
	padding: 0px;
}
div.mfp_thanks ul.mfp_caution li {
	display: block;
	color: #C00;
	margin: 0px;
	padding: 5px 0px;
}
div#mfp_thanks {
	text-align: center;
	font-size: 18px;
	padding: 20px 0px;
}
div#mfp_thanks strong {
	color: #C00;
	font-size: 24px;
}
form#mailformpro {
	padding: 10px 0px;
	box-sizing: border-box;
}
form#mailformpro dl dt {
	float: left;
	width: 160px;
	clear: both;
	font-size: 12px;
	padding: 10px 0px;
	text-align: right;
	border-top: solid 1px #CCC;
	margin: 0px;
}
form#mailformpro dl dd {
	border-top: solid 1px #CCC;
	margin: 0px;
	padding: 10px 5px 20px 170px;
	font-size: 12px;
	line-height: 1.5em;
	text-align: left;
}
form#mailformpro dl dd ul,form#mailformpro dl dd ol {
	margin: 0px;
	padding: 0px;
}
form#mailformpro dl dd ul li,form#mailformpro dl dd ol li {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
.must {
	display: block;
	background-color: #C00;
	border: solid 2px #C00;
	text-shadow: 0px 1px 2px #933;
	padding: 2px 5px;
	font-size: 10px;
	color: #FFF;
	float: left;
	margin: 0px 5px;
	border-radius: 4px;
	box-shadow: 0px 0px 5px #CCC;
	background-image: url(img/mfp_header.png);
	background-size: 100% 100%;
}
.optionally {
	display: block;
	background-color: #06C;
	border: solid 2px #06C;
	text-shadow: 0px 1px 2px #933;
	padding: 2px 5px;
	font-size: 10px;
	color: #FFF;
	float: left;
	margin: 0px 5px;
	border-radius: 4px;
	box-shadow: 0px 0px 5px #CCC;
	background-image: url(img/mfp_header.png);
	background-size: 100% 100%;
}
form#mailformpro label {
	border-radius: 3px;
	margin: 3px;
	display: inline-block;
	white-space: nowrap;
}
table#mfp_confirm_table {
	border-spacing: 0px;
	border-collapse: collapse;
	width: 100%;
	margin: 20px 0;
}
table#mfp_confirm_table tr.mfp_colored {
	background-color: #F6F7F9;
}
table#mfp_confirm_table tr.mfp_achroma {
	background-color: #FFF;
}
table#mfp_confirm_table tr th,table#mfp_confirm_table tr td {
	text-align: left;
	border-top: solid 1px #CCC;
	padding: 9px;
}
table#mfp_confirm_table tr th {
	white-space: nowrap;
	width: 200px;
}
table#mfp_confirm_table tr td {
	line-height: 1.5em;
	word-break: break-all;
}
div#mfp_phase_confirm {
	clear: both;
}
div#mfp_phase_confirm h4 {
	font-size: 36px;
	padding: 10px 0px 0px 0px;
	text-align: center;
}
div#mfp_phase_confirm div#mfp_phase_confirm_inner {
}
div#mfp_overlay {
	position: absolute;
	display: none;
	z-index: 10001;
}
div#mfp_overlay_inner {
	background-color: #FFF;
	padding: 15px;
	margin: 0px auto;
	border-radius: 5px;
	box-shadow: 0px 0px 10px #000;
	width: 640px;
	max-width: 90%;
}
div#mfp_overlay_background {
	background-color: #000;
	position: absolute;
	display: none;
	z-index: 10001;
}
div#mfp_loading_screen {
	z-index: 20000;
	opacity: 0.8;
	display: none;
	background-color: #000;
	position: absolute;
}
div#mfp_loading {
	z-index: 20001;
	position: absolute;
	display: none;
	width: 40px;
	height: 40px;
	background-image: url(img/mfp_loading.gif);
}
.mfp_colored {
	background-color: #F6F7F9;
}
.mfp_achroma {
	background-color: #FFF;
}
div.mfp_err {
	clear: both;
	display: none;
	text-align: center;
	margin: 5px 0px 0px 0px;
	padding: 3px 0px 5px 17px;
	color: #F00;
	font-size: 14px;
	line-height: normal;
	background-image: url(img/mfp_error.gif);
	background-repeat: no-repeat;
	background-position: 427px 7px;
}
.mfp_parent_error {
	border: solid 2px #F00;
}
.problem {
	background-color: #FCC;
}
div#mfp_error {
	background-color: #FEE;
	border: solid 1px #F00;
	padding: 10px;
	display: none;
}
div#mfp_error p {
	padding: 0px;
	margin: 0px;
	font-size: 14px;
	text-align: center;
}
div#mfp_error p strong {
	font-size: 18px;
	color: #F00;
}
div#mfp_warning {
	background-color: #FEE;
	border: solid 1px #F00;
	padding: 10px;
	display: none;
	border-radius: 5px;
}
div#mfp_warning p {
	padding: 0px;
	margin: 0px;
	font-size: 14px;
	text-align: center;
}
div#mfp_warning p strong {
	font-size: 18px;
	color: #F00;
}
div#mfp_price {
	color: #C00;
	font-size: 36px;
	padding: 10px;
	font-weight: bolder;
}
div#mfp_price span {
	color: #666;
	font-size: 12px;
	font-weight: normal;
}
button.mfp_next,button.mfp_prev {
	font-size: 18px;
	margin: 10px;
	padding: 5px 10px;
}
button.mfp_next {
	float: right;
}
button.mfp_prev {
	float: left;
}
ul#mfp_phase_stat {
	padding: 10px;
	text-align: center;
}
ul#mfp_phase_stat li {
	display: inline-block;
	padding: 8px 15px;
	border-radius: 5px;
	margin: 0px 5px;
	list-style: none;
	font-size: 14px;
}
ul#mfp_phase_stat li.mfp_phase_arrow {
	box-shadow: none;
	color: #999;
	padding: 8px 0px;
}
ul#mfp_phase_stat li.mfp_active_phase {
	box-shadow: 0px 1px 6px #000;
	background-image: url(img/mfp_header.png);
	background-size: 100% 100%;
	background-color: #0068B7;
	border: solid 2px #0068B7;
	font-weight: bolder;
	color: #FFF;
	text-shadow: 0px 1px 3px #000;
}
ul#mfp_phase_stat li.mfp_inactive_phase {
	background-image: url(img/mfp_header.png);
	background-size: 100% 100%;
	background-color: #EEE;
	border: solid 2px #EEE;
	color: #999;
	box-shadow: 0px 1px 6px #CCC;
}
div#mfp_shopping_cart {
	border: solid 1px #CCC;
	margin: 0px;
	padding: 0px;
}
div#mfp_shopping_cart p {
	margin: 0px;
	text-align: center;
	padding: 20px 10px;
	font-size: 12px;
	background-color: #FEE;
}
table.mfp_shoppingcart {
	border-spacing: 0px;
	border-collapse: collapse;
	width: 100%;
}
table.mfp_shoppingcart thead tr td {
	background-color: #EEE;
	border-bottom: solid 1px #CCC;
	text-align: center;
	font-size: 12px;
	padding: 5px;
}
table.mfp_shoppingcart tbody tr th,table.mfp_shoppingcart tbody tr td {
	font-size: 12px;
	padding: 5px;
	border-bottom: solid 1px #CCC;
}
table.mfp_shoppingcart tbody tr td select {
	display: block;
	margin: 0px auto;
	text-align: center;
}
table.mfp_shoppingcart tbody tr td select option {
	text-align: center;
}
table.mfp_shoppingcart tbody tr th span {
	display: block;
	font-weight: normal;
	font-size: 10px;
	color: #666;
	padding: 3px 0px;
}
table.mfp_shoppingcart tfoot tr td {
	padding: 5px;
	font-size: 16px;
	font-weight: bolder;
	color: #900;
}
td.msc_price {
	font-size: 12px;
	text-align: right;
}
div.mfp_buttons {
	clear: both;
	padding: 10px 0px;
	text-align: center;
}
div.mfp_buttons button#mfp_button_send {
	padding: 10px 100px;
	background-color: #333;
	border: 1px solid #333;
	color: #FFFFFF;
	cursor: pointer;
}
div.mfp_buttons button#mfp_button_cancel {
	padding: 10px 100px;
	border: 1px solid #333;
	color: #333;
	cursor: pointer;
	background:#fff;
}
.imagebutton {
	margin: 0px;
	padding: 0px;
	border: none;
	outline: none;
	background: none;
}

.mfp_element_checkbox,
.mfp_element_radio {
	vertical-align: middle;
	margin: 0px 2px;
}
.mfp_element_file {
	font-size: 12px;
	display: inline-block;
	padding: 10px 10px;
	vertical-align: middle;
	border: solid 1px #CCC;
	border-radius: 3px;
	box-shadow: 0px 0px 5px #CCC inset;
	background: #EEE;
}
.mfp_element_reset {
	color: #333;
}
button.mfp_next,button.mfp_prev {
	font-size: 14px;
}
input#mfp_reserve_item,input#mfp_reserve_date {
	display: none;
}
div#mfp_reserve_wrapper {
	position: relative;
	overflow: hidden;
	border: solid 1px #CCC;
}
div#mfp_reserve_inner {
	position: relative;
	padding: 0px 0px 0px 100px;
	overflow: auto;
}
div#mfp_reserve_wrapper table {
	border-spacing: 0px;
	border-collapse: collapse;
}
div#mfp_reserve_wrapper table.mfp_reserve_table_label {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100px;
	background-color: #FEE;
	z-index: 100;
}
div#mfp_reserve_wrapper table.mfp_reserve_table_value {
	padding: 0px 0px 0px 0px;
}
div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_active,
div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_warning {
	cursor: pointer;
}
div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_active:hover,
div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_warning:hover {
	background-color: #E8EEF9;
}
div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_current {
	background-color: #0068B7;
	color: #FFF;
}
td.mfp_reserve_disabled {
	background-color: #CCC;
}
td.mfp_reserve_warning {
	background-color: #FFC;
}
div#mfp_reserve_wrapper table tr td,div#mfp_reserve_wrapper table tr th {
	border: solid 1px #CCC;
	padding: 0px 5px;
	font-size: 12px;
	text-align: center;
	font-family: Osaka,"ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
	font-weight: normal;
	height: 20px;
	text-align: left;
}
td.mfp_reserve_week_0 {
	color: #F00;
	background-color: #FEE;
}
td.mfp_reserve_week_6 {
	color: #00F;
	background-color: #EEF;
}
div.mfp_ok {
	border: solid 1px #111
	;
	display: inline-block;
	padding: 1px 10px;
	margin-top: 5px;
	color: #111
	;
	font-size: 12px;
	display: none;
}
div.prefcodeWrapper {
	position: relative;
}
div.prefcodeResult {
	position: absolute;
	top: 0px;
	left: 0px;
	padding: 5px;
	border: solid 1px #CCC;
	background-color: #FFF;
	box-shadow: 0px 0px 5px #CCC;
	display: none;
}
div.prefcodeResult div {
	cursor: pointer;
}
div.prefcodeResult div:hover {
	background-color: #C9EBFB;
}
div.prefcodeResult div.prefcodeNext {
	background-color: #EEE;
	text-align: center;
}
div.prefLoading {
	padding: 60px 100px;
	background: url(img/mfp_zip_loading.gif) no-repeat center center;
}
.hidefield {
	height: 0px;
	overflow: hidden;
}
.showfield {
	height: auto;
	overflow: visible;
}
div.mfp_attached_thumbnails {
	display: none;
	padding: 5px;
	margin: 5px auto;
	border: solid 1px #CCC;
	border-radius: 3px;
	box-shadow: 0px 0px 5px #CCC inset;
	background: #EEE;
}
div.mfp_attached_thumbnails ul {
	margin: 0px;
	padding: 0px;
}
form#mailformpro dl dd div.mfp_attached_thumbnails ul li {
	display: inline-block;
	vertical-align: top;
	padding: 0px;
	border: solid 4px #FFF;
	margin: 5px;
	box-shadow: 0px 2px 5px #999;
}
form#mailformpro dl dd div.mfp_attached_thumbnails ul li a {
	display: block;
	max-height: 100px;
	overflow: hidden;
}
div.mfp_attached_thumbnails ul li a img {
	display: block;
	max-width: 80px;
}
button.mfp_attached_reset {
	font-size: 14px;
}
div#mfp_OperationCheck {
}
div#mfp_OperationCheck div#mfp_OperationCheck_inner {
	display: none;
}
div#mfp_OperationCheck strong {
	background: #090;
	display: block;
	color: #222;
	text-align: center;
	border-radius: 3px;
}
div#mfp_OperationCheck * {
	padding: 0px;
	margin: 0px;
	font-size: 12px;
}
div#mfp_OperationCheck p {
	padding: 0px 5px;
	margin: 0px;
	font-size: 12px;
}
div#mfp_OperationCheck p a {
	color: #0C0;
	text-decoration: none;
}
div#mfp_OperationCheck p a:hover,
div#mfp_OperationCheck p button:hover {
	text-decoration: underline;
}
div#mfp_OperationCheck p button {
	border: none;
	background: none;
	color: #0C0;
	cursor: pointer;
}
div#mfp_OperationCheck div#mfp_OperationCheck_inner ul {
}
div#mfp_OperationCheck ul li,
div#mfp_OperationCheck ul li label,
div#mfp_OperationCheck ul li label input {
	line-height: 12px;
	font-size: 12px;
	list-style: none;
	vertical-align: middle;
}
div#mfp_OperationCheck ul li {
	padding: 5px 10px;
}
div#mfp_OperationCheck ul li
{
	text-decoration: underline;
}
button#mfp_recorder_record,
button#mfp_recorder_clear,
button#mfp_recorder_restore {
	border-radius: 5px;
	padding: 5px 10px 5px 2em;
	border: solid 1px #CCC;
	background: linear-gradient(to top, #EEE 0%, #CCC 100%);
	text-shadow: 0px 2px 0px #FFF;
	font-size: 16px;
	cursor: pointer;
	outline: none;
	display: inline-block;
	margin: 5px auto;
}
button#mfp_recorder_record {
	background: url(img/mfp_record_disabled.png) no-repeat 5px center #EEE;
	background-size: 24px 24px;
}
button#mfp_recorder_clear {
	background: url(img/mfp_record_remove.png) no-repeat 5px center #EEE;
	background-size: 24px 24px;
}
button#mfp_recorder_restore {
	background: url(img/mfp_record_restore.png) no-repeat 5px center #EEE;
	background-size: 24px 24px;
}
button.enabled#mfp_recorder_record,
button.enabled#mfp_recorder_clear,
button.enabled#mfp_recorder_restore {
	background: url(img/mfp_record_enabled.png) no-repeat 5px center #EEE;
	background-size: 24px 24px;
}
div#mfp_recorder_wrap {
	border: solid 1px #CCC;
	padding: 10px;
	text-align: center;
	margin: 5px auto;
}
td.request_image {
	width: 100px;
}
td.request_image img {
	max-width: 100px;
}
span.mfp_tips {
	background-image: url(img/mfp_header.png);
	background-size: 100% 100%;
	background-color: #FCC;
	display: block;
	border-radius: 5px;
	padding: 10px;
	margin: 2px;
	box-shadow: 0px 2px 10px #999;
}
span.mfp_tips strong {
	color: #800040;
}
span.mfp_tips span {
	display: block;
	padding: 10px;
	color: #008080;
}
span.mfp_tips em {
	font-style: normal;
	color: #090;
	font-weight: bold;
}
@media screen and (max-width: 1240px) {
	div#mfp_overlay_background{
		width:1240px !important;
		height: 100% !important;
	}
	div#mfp_overlay{
		width:1240px !important;
	}
}
@media screen and (max-width: 800px) {
	form#mailformpro dl dt {
		float: none;
		width: auto;
		font-size: 12px;
		padding: 5px;
		text-align: left;
	}
	form#mailformpro dl dd {
		clear: both;
		border-top: none;
		padding: 5px 15px;
		font-size: 12px;
		line-height: 1.5em;
	}
	div.mfp_buttons button {
		font-size: 14px;
	}
	div#mfp_phase_confirm h4 {
		font-size: 18px;
	}
	ul#mfp_phase_stat {
		padding: 0px;
		text-align: left;
	}
	ul#mfp_phase_stat li {
		text-align: center;
		padding: 5px 0px;
		border-radius: 3px;
		margin: 5px;
		list-style: none;
		font-size: 14px;
		width: 28%;
	}
	ul#mfp_phase_stat li.mfp_phase_arrow {
		box-shadow: none;
		display: none;
	}
	ul#mfp_phase_stat li.mfp_active_phase {
	}
	ul#mfp_phase_stat li.mfp_inactive_phase {
	}
	table#mfp_confirm_table tr th {
		white-space: nowrap;
		width: 150px;
	}
	div#mfp_thanks {
		text-align: center;
		font-size: 18px;
		padding: 20px 0px;
	}
	div#mfp_thanks strong {
		color: #C00;
		font-size: 24px;
		display: block;
	}
}

@media screen and (max-width: 431px) {
	div#mfp_overlay_background{
		width:430px !important;
		height: 100% !important;
	}
	div#mfp_overlay{
		width:430px !important;
	}
	div#mfp_overlay_inner{
		width:390px;
		max-width:none;
	}
	div.mfp_buttons button#mfp_button_send {
		padding: 10px 0;
		width:300px;
		margin-bottom: 10px;
	}
	div.mfp_buttons button#mfp_button_cancel {
		padding: 9px 0;
		width:300px;
		margin-right: 3px;
	}
}