@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Taviraj:300,400,700,300i,400i,700i");
/*
	Transitive by TEMPLATED
	templated.co @templatedco
	Released for free under the Creative Commons Attribution 3.0 license (templated.co/license)
*/

/* Reset */

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, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	/* font: inherit;	*/
	/* font-family: RC TYPE, Roboto, Avenir, Helvetica, Arial, sans-serif; */
	font-family: 'Zen Maru Gothic', "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	vertical-align: baseline;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}

body {
	line-height: 1;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
	content: '';
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

body {
	-webkit-text-size-adjust: none;
}

/* Box Model */

*, *:before, *:after {
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

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

/* Containers */

.container {
	margin-left: auto;
	margin-right: auto;
}

.container.\31 25\25 {
	width: 100%;
	max-width: 100rem;
	min-width: 80rem;
}

.container.\37 5\25 {
	width: 60rem;
}

.container.\35 0\25 {
	width: 40rem;
}

.container.\32 5\25 {
	width: 20rem;
}

.container {
	width: 80rem;
}

.red {
	color: #FF0000;
	/* font-weight: bold; */
	/* font-size: 1.2em; */
}

#process ul {
	line-height: 1.4rem;
	width: 100%;
	list-style: none;
	padding-left: 0;
	margin: 10px 0;
}

#process ul li {
	padding-bottom: 2rem;
	padding-left: 1em;
	text-indent: -1em;
}

#process ul.info_ls li {
	padding-bottom: 0 !important;
}

.pic {
	margin: 0 0 5px 0;
}

.pic img {
	width: 100%;
	display: block;
	margin: 0 auto;
}

.r_check {
	margin: 0 0 5px 0;
	width: 100%;
	margin: 10px auto;
	border: 1px solid #ccc;
	padding: 10px;
}

.r_check img {
	width: 100%;
	max-width: 200px;
	display: block;
	margin: 0 auto;
}

.fs2 {
	font-size: 2rem;
}

.bld {
	font-weight: bold;
}

.mt0 {
	margin-top: 0 !important;
}

.mb0 {
	margin-bottom: 0 !important;
}

.mb10 {
	margin-bottom: 10px !important;
}

.mt10 {
	margin-top: 10px !important;
}

.pb2rem {
	padding-bottom: 2rem !important;
}

.mtb0 {
	margin: 0 !important;
}

@media screen and (max-width: 1680px) {
	.container.\31 25\25 {
		width: 100%;
		max-width: 100rem;
		min-width: 80rem;
	}
	.container.\37 5\25 {
		width: 60rem;
	}
	.container.\35 0\25 {
		width: 40rem;
	}
	.container.\32 5\25 {
		width: 20rem;
	}
	.container {
		width: 80rem;
	}
}

@media screen and (max-width: 1280px) {
	.container.\31 25\25 {
		width: 100%;
		max-width: 81.25rem;
		min-width: 65rem;
	}
	.container.\37 5\25 {
		width: 48.75rem;
	}
	.container.\35 0\25 {
		width: 32.5rem;
	}
	.container.\32 5\25 {
		width: 16.25rem;
	}
	.container {
		width: 65rem;
	}
}

@media screen and (max-width: 1000px) {
	.container.\31 25\25 {
		width: 100%;
		max-width: 112.5%;
		min-width: 90%;
	}
	.container.\37 5\25 {
		width: 67.5%;
	}
	.container.\35 0\25 {
		width: 45%;
	}
	.container.\32 5\25 {
		width: 22.5%;
	}
	.container {
		width: 90%;
	}
}

@media screen and (max-width: 736px) {
	.container.\31 25\25 {
		width: 100%;
		max-width: 112.5%;
		min-width: 90%;
	}
	.container.\37 5\25 {
		width: 67.5%;
	}
	.container.\35 0\25 {
		width: 45%;
	}
	.container.\32 5\25 {
		width: 22.5%;
	}
	.container {
		width: 90% !important;
	}
}

@media screen and (max-width: 480px) {
	.red {
		font-size: 0.8rem;
	}
	.fs2 {
		font-size: 1.2rem;
	}
	.container.\31 25\25 {
		width: 100%;
		max-width: 112.5%;
		min-width: 90%;
	}
	.container.\37 5\25 {
		width: 67.5%;
	}
	.container.\35 0\25 {
		width: 45%;
	}
	.container.\32 5\25 {
		width: 22.5%;
	}
	.container {
		width: 90% !important;
	}
}

/* Grid */

.row {
	border-bottom: solid 1px transparent;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.row>* {
	float: left;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.row:after, .row:before {
	content: '';
	display: block;
	clear: both;
	height: 0;
}

.row.uniform>*> :first-child {
	margin-top: 0;
}

.row.uniform>*> :last-child {
	margin-bottom: 0;
}

.row.\30 \25>* {
	padding: 0 0 0 0rem;
}

.row.\30 \25 {
	margin: 0 0 -1px 0rem;
}

.row.uniform.\30 \25>* {
	padding: 0rem 0 0 0rem;
}

.row.uniform.\30 \25 {
	margin: 0rem 0 -1px 0rem;
}

.row>* {
	padding: 0 0 0 2rem;
}

.row {
	margin: 0 0 -1px -2rem;
}

.row.uniform>* {
	padding: 2rem 0 0 2rem;
}

.row.uniform {
	margin: -2rem 0 -1px -2rem;
}

.row.\32 00\25>* {
	padding: 0 0 0 4rem;
}

.row.\32 00\25 {
	margin: 0 0 -1px -4rem;
}

.row.uniform.\32 00\25>* {
	padding: 4rem 0 0 4rem;
}

.row.uniform.\32 00\25 {
	margin: -4rem 0 -1px -4rem;
}

.row.\31 50\25>* {
	padding: 0 0 0 3rem;
}

.row.\31 50\25 {
	margin: 0 0 -1px -3rem;
}

.row.uniform.\31 50\25>* {
	padding: 3rem 0 0 3rem;
}

.row.uniform.\31 50\25 {
	margin: -3rem 0 -1px -3rem;
}

.row.\35 0\25>* {
	padding: 0 0 0 1rem;
}

.row.\35 0\25 {
	margin: 0 0 -1px -1rem;
}

.row.uniform.\35 0\25>* {
	padding: 1rem 0 0 1rem;
}

.row.uniform.\35 0\25 {
	margin: -1rem 0 -1px -1rem;
}

.row.\32 5\25>* {
	padding: 0 0 0 0.5rem;
}

.row.\32 5\25 {
	margin: 0 0 -1px -0.5rem;
}

.row.uniform.\32 5\25>* {
	padding: 0.5rem 0 0 0.5rem;
}

.row.uniform.\32 5\25 {
	margin: -0.5rem 0 -1px -0.5rem;
}

.\31 2u, .\31 2u\24 {
	width: 100%;
	clear: none;
	margin-left: 0;
}

.\31 1u, .\31 1u\24 {
	width: 91.6666666667%;
	clear: none;
	margin-left: 0;
}

.\31 0u, .\31 0u\24 {
	width: 83.3333333333%;
	clear: none;
	margin-left: 0;
}

.\39 u, .\39 u\24 {
	width: 75%;
	clear: none;
	margin-left: 0;
}

.\38 u, .\38 u\24 {
	width: 66.6666666667%;
	clear: none;
	margin-left: 0;
}

.\37 u, .\37 u\24 {
	width: 58.3333333333%;
	clear: none;
	margin-left: 0;
}

.\36 u, .\36 u\24 {
	width: 50%;
	clear: none;
	margin-left: 0;
}

.\35 u, .\35 u\24 {
	width: 41.6666666667%;
	clear: none;
	margin-left: 0;
}

.\34 u, .\34 u\24 {
	width: 33.3333333333%;
	clear: none;
	margin-left: 0;
}

.\33 u, .\33 u\24 {
	width: 25%;
	clear: none;
	margin-left: 0;
}

.\32 u, .\32 u\24 {
	width: 16.6666666667%;
	clear: none;
	margin-left: 0;
}

.\31 u, .\31 u\24 {
	width: 8.3333333333%;
	clear: none;
	margin-left: 0;
}

.\31 2u\24+*, .\31 1u\24+*, .\31 0u\24+*, .\39 u\24+*, .\38 u\24+*, .\37 u\24+*, .\36 u\24+*, .\35 u\24+*, .\34 u\24+*, .\33 u\24+*, .\32 u\24+*, .\31 u\24+* {
	clear: left;
}

.\-11u {
	margin-left: 91.66667%;
}

.\-10u {
	margin-left: 83.33333%;
}

.\-9u {
	margin-left: 75%;
}

.\-8u {
	margin-left: 66.66667%;
}

.\-7u {
	margin-left: 58.33333%;
}

.\-6u {
	margin-left: 50%;
}

.\-5u {
	margin-left: 41.66667%;
}

.\-4u {
	margin-left: 33.33333%;
}

.\-3u {
	margin-left: 25%;
}

.\-2u {
	margin-left: 16.66667%;
}

.\-1u {
	margin-left: 8.33333%;
}

@media screen and (max-width: 1680px) {
	.row>* {
		padding: 0 0 0 2rem;
	}
	.row {
		margin: 0 0 -1px -2rem;
	}
	.row.uniform>* {
		padding: 2rem 0 0 2rem;
	}
	.row.uniform {
		margin: -2rem 0 -1px -2rem;
	}
	.row.\32 00\25>* {
		padding: 0 0 0 4rem;
	}
	.row.\32 00\25 {
		margin: 0 0 -1px -4rem;
	}
	.row.uniform.\32 00\25>* {
		padding: 4rem 0 0 4rem;
	}
	.row.uniform.\32 00\25 {
		margin: -4rem 0 -1px -4rem;
	}
	.row.\31 50\25>* {
		padding: 0 0 0 3rem;
	}
	.row.\31 50\25 {
		margin: 0 0 -1px -3rem;
	}
	.row.uniform.\31 50\25>* {
		padding: 3rem 0 0 3rem;
	}
	.row.uniform.\31 50\25 {
		margin: -3rem 0 -1px -3rem;
	}
	.row.\35 0\25>* {
		padding: 0 0 0 1rem;
	}
	.row.\35 0\25 {
		margin: 0 0 -1px -1rem;
	}
	.row.uniform.\35 0\25>* {
		padding: 1rem 0 0 1rem;
	}
	.row.uniform.\35 0\25 {
		margin: -1rem 0 -1px -1rem;
	}
	.row.\32 5\25>* {
		padding: 0 0 0 0.5rem;
	}
	.row.\32 5\25 {
		margin: 0 0 -1px -0.5rem;
	}
	.row.uniform.\32 5\25>* {
		padding: 0.5rem 0 0 0.5rem;
	}
	.row.uniform.\32 5\25 {
		margin: -0.5rem 0 -1px -0.5rem;
	}
	.\31 2u\28xlarge\29, .\31 2u\24\28xlarge\29 {
		width: 100%;
		clear: none;
		margin-left: 0;
	}
	.\31 1u\28xlarge\29, .\31 1u\24\28xlarge\29 {
		width: 91.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\31 0u\28xlarge\29, .\31 0u\24\28xlarge\29 {
		width: 83.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\39 u\28xlarge\29, .\39 u\24\28xlarge\29 {
		width: 75%;
		clear: none;
		margin-left: 0;
	}
	.\38 u\28xlarge\29, .\38 u\24\28xlarge\29 {
		width: 66.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\37 u\28xlarge\29, .\37 u\24\28xlarge\29 {
		width: 58.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\36 u\28xlarge\29, .\36 u\24\28xlarge\29 {
		width: 50%;
		clear: none;
		margin-left: 0;
	}
	.\35 u\28xlarge\29, .\35 u\24\28xlarge\29 {
		width: 41.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\34 u\28xlarge\29, .\34 u\24\28xlarge\29 {
		width: 33.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\33 u\28xlarge\29, .\33 u\24\28xlarge\29 {
		width: 25%;
		clear: none;
		margin-left: 0;
	}
	.\32 u\28xlarge\29, .\32 u\24\28xlarge\29 {
		width: 16.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\31 u\28xlarge\29, .\31 u\24\28xlarge\29 {
		width: 8.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\31 2u\24\28xlarge\29+*, .\31 1u\24\28xlarge\29+*, .\31 0u\24\28xlarge\29+*, .\39 u\24\28xlarge\29+*, .\38 u\24\28xlarge\29+*, .\37 u\24\28xlarge\29+*, .\36 u\24\28xlarge\29+*, .\35 u\24\28xlarge\29+*, .\34 u\24\28xlarge\29+*, .\33 u\24\28xlarge\29+*, .\32 u\24\28xlarge\29+*, .\31 u\24\28xlarge\29+* {
		clear: left;
	}
	.\-11u\28xlarge\29 {
		margin-left: 91.66667%;
	}
	.\-10u\28xlarge\29 {
		margin-left: 83.33333%;
	}
	.\-9u\28xlarge\29 {
		margin-left: 75%;
	}
	.\-8u\28xlarge\29 {
		margin-left: 66.66667%;
	}
	.\-7u\28xlarge\29 {
		margin-left: 58.33333%;
	}
	.\-6u\28xlarge\29 {
		margin-left: 50%;
	}
	.\-5u\28xlarge\29 {
		margin-left: 41.66667%;
	}
	.\-4u\28xlarge\29 {
		margin-left: 33.33333%;
	}
	.\-3u\28xlarge\29 {
		margin-left: 25%;
	}
	.\-2u\28xlarge\29 {
		margin-left: 16.66667%;
	}
	.\-1u\28xlarge\29 {
		margin-left: 8.33333%;
	}
}

@media screen and (max-width: 1280px) {
	.row>* {
		padding: 0 0 0 1.5rem;
	}
	.row {
		margin: 0 0 -1px -1.5rem;
	}
	.row.uniform>* {
		padding: 1.5rem 0 0 1.5rem;
	}
	.row.uniform {
		margin: -1.5rem 0 -1px -1.5rem;
	}
	.row.\32 00\25>* {
		padding: 0 0 0 3rem;
	}
	.row.\32 00\25 {
		margin: 0 0 -1px -3rem;
	}
	.row.uniform.\32 00\25>* {
		padding: 3rem 0 0 3rem;
	}
	.row.uniform.\32 00\25 {
		margin: -3rem 0 -1px -3rem;
	}
	.row.\31 50\25>* {
		padding: 0 0 0 2.25rem;
	}
	.row.\31 50\25 {
		margin: 0 0 -1px -2.25rem;
	}
	.row.uniform.\31 50\25>* {
		padding: 2.25rem 0 0 2.25rem;
	}
	.row.uniform.\31 50\25 {
		margin: -2.25rem 0 -1px -2.25rem;
	}
	.row.\35 0\25>* {
		padding: 0 0 0 0.75rem;
	}
	.row.\35 0\25 {
		margin: 0 0 -1px -0.75rem;
	}
	.row.uniform.\35 0\25>* {
		padding: 0.75rem 0 0 0.75rem;
	}
	.row.uniform.\35 0\25 {
		margin: -0.75rem 0 -1px -0.75rem;
	}
	.row.\32 5\25>* {
		padding: 0 0 0 0.375rem;
	}
	.row.\32 5\25 {
		margin: 0 0 -1px -0.375rem;
	}
	.row.uniform.\32 5\25>* {
		padding: 0.375rem 0 0 0.375rem;
	}
	.row.uniform.\32 5\25 {
		margin: -0.375rem 0 -1px -0.375rem;
	}
	.\31 2u\28large\29, .\31 2u\24\28large\29 {
		width: 100%;
		clear: none;
		margin-left: 0;
	}
	.\31 1u\28large\29, .\31 1u\24\28large\29 {
		width: 91.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\31 0u\28large\29, .\31 0u\24\28large\29 {
		width: 83.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\39 u\28large\29, .\39 u\24\28large\29 {
		width: 75%;
		clear: none;
		margin-left: 0;
	}
	.\38 u\28large\29, .\38 u\24\28large\29 {
		width: 66.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\37 u\28large\29, .\37 u\24\28large\29 {
		width: 58.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\36 u\28large\29, .\36 u\24\28large\29 {
		width: 50%;
		clear: none;
		margin-left: 0;
	}
	.\35 u\28large\29, .\35 u\24\28large\29 {
		width: 41.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\34 u\28large\29, .\34 u\24\28large\29 {
		width: 33.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\33 u\28large\29, .\33 u\24\28large\29 {
		width: 25%;
		clear: none;
		margin-left: 0;
	}
	.\32 u\28large\29, .\32 u\24\28large\29 {
		width: 16.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\31 u\28large\29, .\31 u\24\28large\29 {
		width: 8.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\31 2u\24\28large\29+*, .\31 1u\24\28large\29+*, .\31 0u\24\28large\29+*, .\39 u\24\28large\29+*, .\38 u\24\28large\29+*, .\37 u\24\28large\29+*, .\36 u\24\28large\29+*, .\35 u\24\28large\29+*, .\34 u\24\28large\29+*, .\33 u\24\28large\29+*, .\32 u\24\28large\29+*, .\31 u\24\28large\29+* {
		clear: left;
	}
	.\-11u\28large\29 {
		margin-left: 91.66667%;
	}
	.\-10u\28large\29 {
		margin-left: 83.33333%;
	}
	.\-9u\28large\29 {
		margin-left: 75%;
	}
	.\-8u\28large\29 {
		margin-left: 66.66667%;
	}
	.\-7u\28large\29 {
		margin-left: 58.33333%;
	}
	.\-6u\28large\29 {
		margin-left: 50%;
	}
	.\-5u\28large\29 {
		margin-left: 41.66667%;
	}
	.\-4u\28large\29 {
		margin-left: 33.33333%;
	}
	.\-3u\28large\29 {
		margin-left: 25%;
	}
	.\-2u\28large\29 {
		margin-left: 16.66667%;
	}
	.\-1u\28large\29 {
		margin-left: 8.33333%;
	}
}

@media screen and (max-width: 1000px) {
	.row>* {
		padding: 0 0 0 1.5rem;
	}
	.row {
		margin: 0 0 -1px -1.5rem;
	}
	.row.uniform>* {
		padding: 1.5rem 0 0 1.5rem;
	}
	.row.uniform {
		margin: -1.5rem 0 -1px -1.5rem;
	}
	.row.\32 00\25>* {
		padding: 0 0 0 3rem;
	}
	.row.\32 00\25 {
		margin: 0 0 -1px -3rem;
	}
	.row.uniform.\32 00\25>* {
		padding: 3rem 0 0 3rem;
	}
	.row.uniform.\32 00\25 {
		margin: -3rem 0 -1px -3rem;
	}
	.row.\31 50\25>* {
		padding: 0 0 0 2.25rem;
	}
	.row.\31 50\25 {
		margin: 0 0 -1px -2.25rem;
	}
	.row.uniform.\31 50\25>* {
		padding: 2.25rem 0 0 2.25rem;
	}
	.row.uniform.\31 50\25 {
		margin: -2.25rem 0 -1px -2.25rem;
	}
	.row.\35 0\25>* {
		padding: 0 0 0 0.75rem;
	}
	.row.\35 0\25 {
		margin: 0 0 -1px -0.75rem;
	}
	.row.uniform.\35 0\25>* {
		padding: 0.75rem 0 0 0.75rem;
	}
	.row.uniform.\35 0\25 {
		margin: -0.75rem 0 -1px -0.75rem;
	}
	.row.\32 5\25>* {
		padding: 0 0 0 0.375rem;
	}
	.row.\32 5\25 {
		margin: 0 0 -1px -0.375rem;
	}
	.row.uniform.\32 5\25>* {
		padding: 0.375rem 0 0 0.375rem;
	}
	.row.uniform.\32 5\25 {
		margin: -0.375rem 0 -1px -0.375rem;
	}
	.\31 2u\28medium\29, .\31 2u\24\28medium\29 {
		width: 100%;
		clear: none;
		margin-left: 0;
	}
	.\31 1u\28medium\29, .\31 1u\24\28medium\29 {
		width: 91.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\31 0u\28medium\29, .\31 0u\24\28medium\29 {
		width: 83.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\39 u\28medium\29, .\39 u\24\28medium\29 {
		width: 75%;
		clear: none;
		margin-left: 0;
	}
	.\38 u\28medium\29, .\38 u\24\28medium\29 {
		width: 66.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\37 u\28medium\29, .\37 u\24\28medium\29 {
		width: 58.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\36 u\28medium\29, .\36 u\24\28medium\29 {
		width: 50%;
		clear: none;
		margin-left: 0;
	}
	.\35 u\28medium\29, .\35 u\24\28medium\29 {
		width: 41.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\34 u\28medium\29, .\34 u\24\28medium\29 {
		width: 33.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\33 u\28medium\29, .\33 u\24\28medium\29 {
		width: 25%;
		clear: none;
		margin-left: 0;
	}
	.\32 u\28medium\29, .\32 u\24\28medium\29 {
		width: 16.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\31 u\28medium\29, .\31 u\24\28medium\29 {
		width: 8.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\31 2u\24\28medium\29+*, .\31 1u\24\28medium\29+*, .\31 0u\24\28medium\29+*, .\39 u\24\28medium\29+*, .\38 u\24\28medium\29+*, .\37 u\24\28medium\29+*, .\36 u\24\28medium\29+*, .\35 u\24\28medium\29+*, .\34 u\24\28medium\29+*, .\33 u\24\28medium\29+*, .\32 u\24\28medium\29+*, .\31 u\24\28medium\29+* {
		clear: left;
	}
	.\-11u\28medium\29 {
		margin-left: 91.66667%;
	}
	.\-10u\28medium\29 {
		margin-left: 83.33333%;
	}
	.\-9u\28medium\29 {
		margin-left: 75%;
	}
	.\-8u\28medium\29 {
		margin-left: 66.66667%;
	}
	.\-7u\28medium\29 {
		margin-left: 58.33333%;
	}
	.\-6u\28medium\29 {
		margin-left: 50%;
	}
	.\-5u\28medium\29 {
		margin-left: 41.66667%;
	}
	.\-4u\28medium\29 {
		margin-left: 33.33333%;
	}
	.\-3u\28medium\29 {
		margin-left: 25%;
	}
	.\-2u\28medium\29 {
		margin-left: 16.66667%;
	}
	.\-1u\28medium\29 {
		margin-left: 8.33333%;
	}
}

@media screen and (max-width: 736px) {
	.row>* {
		padding: 0 0 0 1.25rem;
	}
	.row {
		margin: 0 0 -1px -1.25rem;
	}
	.row.uniform>* {
		padding: 1.25rem 0 0 1.25rem;
	}
	.row.uniform {
		margin: -1.25rem 0 -1px -1.25rem;
	}
	.row.\32 00\25>* {
		padding: 0 0 0 2.5rem;
	}
	.row.\32 00\25 {
		margin: 0 0 -1px -2.5rem;
	}
	.row.uniform.\32 00\25>* {
		padding: 2.5rem 0 0 2.5rem;
	}
	.row.uniform.\32 00\25 {
		margin: -2.5rem 0 -1px -2.5rem;
	}
	.row.\31 50\25>* {
		padding: 0 0 0 1.875rem;
	}
	.row.\31 50\25 {
		margin: 0 0 -1px -1.875rem;
	}
	.row.uniform.\31 50\25>* {
		padding: 1.875rem 0 0 1.875rem;
	}
	.row.uniform.\31 50\25 {
		margin: -1.875rem 0 -1px -1.875rem;
	}
	.row.\35 0\25>* {
		padding: 0 0 0 0.625rem;
	}
	.row.\35 0\25 {
		margin: 0 0 -1px -0.625rem;
	}
	.row.uniform.\35 0\25>* {
		padding: 0.625rem 0 0 0.625rem;
	}
	.row.uniform.\35 0\25 {
		margin: -0.625rem 0 -1px -0.625rem;
	}
	.row.\32 5\25>* {
		padding: 0 0 0 0.3125rem;
	}
	.row.\32 5\25 {
		margin: 0 0 -1px -0.3125rem;
	}
	.row.uniform.\32 5\25>* {
		padding: 0.3125rem 0 0 0.3125rem;
	}
	.row.uniform.\32 5\25 {
		margin: -0.3125rem 0 -1px -0.3125rem;
	}
	.\31 2u\28small\29, .\31 2u\24\28small\29 {
		width: 100%;
		clear: none;
		margin-left: 0;
	}
	.\31 1u\28small\29, .\31 1u\24\28small\29 {
		width: 91.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\31 0u\28small\29, .\31 0u\24\28small\29 {
		width: 83.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\39 u\28small\29, .\39 u\24\28small\29 {
		width: 75%;
		clear: none;
		margin-left: 0;
	}
	.\38 u\28small\29, .\38 u\24\28small\29 {
		width: 66.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\37 u\28small\29, .\37 u\24\28small\29 {
		width: 58.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\36 u\28small\29, .\36 u\24\28small\29 {
		width: 50%;
		clear: none;
		margin-left: 0;
	}
	.\35 u\28small\29, .\35 u\24\28small\29 {
		width: 41.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\34 u\28small\29, .\34 u\24\28small\29 {
		width: 33.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\33 u\28small\29, .\33 u\24\28small\29 {
		width: 25%;
		clear: none;
		margin-left: 0;
	}
	.\32 u\28small\29, .\32 u\24\28small\29 {
		width: 16.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\31 u\28small\29, .\31 u\24\28small\29 {
		width: 8.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\31 2u\24\28small\29+*, .\31 1u\24\28small\29+*, .\31 0u\24\28small\29+*, .\39 u\24\28small\29+*, .\38 u\24\28small\29+*, .\37 u\24\28small\29+*, .\36 u\24\28small\29+*, .\35 u\24\28small\29+*, .\34 u\24\28small\29+*, .\33 u\24\28small\29+*, .\32 u\24\28small\29+*, .\31 u\24\28small\29+* {
		clear: left;
	}
	.\-11u\28small\29 {
		margin-left: 91.66667%;
	}
	.\-10u\28small\29 {
		margin-left: 83.33333%;
	}
	.\-9u\28small\29 {
		margin-left: 75%;
	}
	.\-8u\28small\29 {
		margin-left: 66.66667%;
	}
	.\-7u\28small\29 {
		margin-left: 58.33333%;
	}
	.\-6u\28small\29 {
		margin-left: 50%;
	}
	.\-5u\28small\29 {
		margin-left: 41.66667%;
	}
	.\-4u\28small\29 {
		margin-left: 33.33333%;
	}
	.\-3u\28small\29 {
		margin-left: 25%;
	}
	.\-2u\28small\29 {
		margin-left: 16.66667%;
	}
	.\-1u\28small\29 {
		margin-left: 8.33333%;
	}
}

@media screen and (max-width: 480px) {
	.row>* {
		padding: 0 0 0 1.25rem;
	}
	.row {
		margin: 0 0 -1px -1.25rem;
	}
	.row.uniform>* {
		padding: 1.25rem 0 0 1.25rem;
	}
	.row.uniform {
		margin: -1.25rem 0 -1px -1.25rem;
	}
	.row.\32 00\25>* {
		padding: 0 0 0 2.5rem;
	}
	.row.\32 00\25 {
		margin: 0 0 -1px -2.5rem;
	}
	.row.uniform.\32 00\25>* {
		padding: 2.5rem 0 0 2.5rem;
	}
	.row.uniform.\32 00\25 {
		margin: -2.5rem 0 -1px -2.5rem;
	}
	.row.\31 50\25>* {
		padding: 0 0 0 1.875rem;
	}
	.row.\31 50\25 {
		margin: 0 0 -1px -1.875rem;
	}
	.row.uniform.\31 50\25>* {
		padding: 1.875rem 0 0 1.875rem;
	}
	.row.uniform.\31 50\25 {
		margin: -1.875rem 0 -1px -1.875rem;
	}
	.row.\35 0\25>* {
		padding: 0 0 0 0.625rem;
	}
	.row.\35 0\25 {
		margin: 0 0 -1px -0.625rem;
	}
	.row.uniform.\35 0\25>* {
		padding: 0.625rem 0 0 0.625rem;
	}
	.row.uniform.\35 0\25 {
		margin: -0.625rem 0 -1px -0.625rem;
	}
	.row.\32 5\25>* {
		padding: 0 0 0 0.3125rem;
	}
	.row.\32 5\25 {
		margin: 0 0 -1px -0.3125rem;
	}
	.row.uniform.\32 5\25>* {
		padding: 0.3125rem 0 0 0.3125rem;
	}
	.row.uniform.\32 5\25 {
		margin: -0.3125rem 0 -1px -0.3125rem;
	}
	.\31 2u\28xsmall\29, .\31 2u\24\28xsmall\29 {
		width: 100%;
		clear: none;
		margin-left: 0;
	}
	.\31 1u\28xsmall\29, .\31 1u\24\28xsmall\29 {
		width: 91.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\31 0u\28xsmall\29, .\31 0u\24\28xsmall\29 {
		width: 83.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\39 u\28xsmall\29, .\39 u\24\28xsmall\29 {
		width: 75%;
		clear: none;
		margin-left: 0;
	}
	.\38 u\28xsmall\29, .\38 u\24\28xsmall\29 {
		width: 66.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\37 u\28xsmall\29, .\37 u\24\28xsmall\29 {
		width: 58.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\36 u\28xsmall\29, .\36 u\24\28xsmall\29 {
		width: 50%;
		clear: none;
		margin-left: 0;
	}
	.\35 u\28xsmall\29, .\35 u\24\28xsmall\29 {
		width: 41.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\34 u\28xsmall\29, .\34 u\24\28xsmall\29 {
		width: 33.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\33 u\28xsmall\29, .\33 u\24\28xsmall\29 {
		width: 25%;
		clear: none;
		margin-left: 0;
	}
	.\32 u\28xsmall\29, .\32 u\24\28xsmall\29 {
		width: 16.6666666667%;
		clear: none;
		margin-left: 0;
	}
	.\31 u\28xsmall\29, .\31 u\24\28xsmall\29 {
		width: 8.3333333333%;
		clear: none;
		margin-left: 0;
	}
	.\31 2u\24\28xsmall\29+*, .\31 1u\24\28xsmall\29+*, .\31 0u\24\28xsmall\29+*, .\39 u\24\28xsmall\29+*, .\38 u\24\28xsmall\29+*, .\37 u\24\28xsmall\29+*, .\36 u\24\28xsmall\29+*, .\35 u\24\28xsmall\29+*, .\34 u\24\28xsmall\29+*, .\33 u\24\28xsmall\29+*, .\32 u\24\28xsmall\29+*, .\31 u\24\28xsmall\29+* {
		clear: left;
	}
	.\-11u\28xsmall\29 {
		margin-left: 91.66667%;
	}
	.\-10u\28xsmall\29 {
		margin-left: 83.33333%;
	}
	.\-9u\28xsmall\29 {
		margin-left: 75%;
	}
	.\-8u\28xsmall\29 {
		margin-left: 66.66667%;
	}
	.\-7u\28xsmall\29 {
		margin-left: 58.33333%;
	}
	.\-6u\28xsmall\29 {
		margin-left: 50%;
	}
	.\-5u\28xsmall\29 {
		margin-left: 41.66667%;
	}
	.\-4u\28xsmall\29 {
		margin-left: 33.33333%;
	}
	.\-3u\28xsmall\29 {
		margin-left: 25%;
	}
	.\-2u\28xsmall\29 {
		margin-left: 16.66667%;
	}
	.\-1u\28xsmall\29 {
		margin-left: 8.33333%;
	}
}

/* Basic */

@-ms-viewport {
	width: device-width;
}

body {
	-ms-overflow-style: scrollbar;
}

@media screen and (max-width: 480px) {
	html, body {
		min-width: 320px;
	}
}

body {
	background: #fff;
}

body.is-loading *, body.is-loading *:before, body.is-loading *:after {
	-moz-animation: none !important;
	-webkit-animation: none !important;
	-ms-animation: none !important;
	animation: none !important;
	-moz-transition: none !important;
	-webkit-transition: none !important;
	-ms-transition: none !important;
	transition: none !important;
}

/* Type */

html {
	font-size: 13pt;
}

@media screen and (max-width: 1680px) {
	html {
		font-size: 11pt;
	}
}

@media screen and (max-width: 1280px) {
	html {
		font-size: 11pt;
	}
}

@media screen and (max-width: 1000px) {
	html {
		font-size: 12pt;
	}
}

@media screen and (max-width: 736px) {
	html {
		font-size: 12pt;
	}
}

@media screen and (max-width: 480px) {
	html {
		font-size: 12pt;
	}
}

body {
	/*		background-color: #f2f2f2;	*/
	color: #444;
	/* font-size: 14px; */
	font-size: 15px;
	/* line-height: 24px; */
	line-height: 1.7;
}

body, input, select, textarea {
	/*	font-family: "Taviraj", serif;	*/
	font-weight: 300;
	/*
	font-size: 1rem;
	line-height: 1.65;
	*/
}

a {
	text-decoration: underline;
}

a:hover {
	text-decoration: none;
}

strong, b {
	font-weight: 400;
}

em, i {
	font-style: italic;
}

p {
	margin: 0 0 2rem 0;
}

h1, h2, h3, h4, h5, h6 {
	font-weight: 400;
	line-height: 1.5;
	margin: 0;
}

h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
	color: inherit;
	text-decoration: none;
}

h2 {
	font-size: 1.5rem;
	font-weight: 700;
	text-transform: uppercase;
}

@media screen and (max-width: 736px) {
	h2 {
		font-size: 1.25rem;
	}
}

h3 {
	font-size: 1.35rem;
}

h4 {
	font-size: 1.1rem;
}

h4 {
	/*	font-size: 0.9rem;	*/
	text-align: center;
	font-size: 2rem;
	margin: 2rem auto;
}

@media screen and (max-width: 736px) {
	h4 {
		font-size: 1rem;
	}
}

h6 {
	font-size: 0.7rem;
}

sub {
	font-size: 0.8rem;
	position: relative;
	top: 0.5rem;
}

sup {
	font-size: 0.8rem;
	position: relative;
	top: -0.5rem;
}

blockquote {
	border-left: solid 4px;
	font-style: italic;
	margin: 0 0 2rem 0;
	padding: 0.5rem 0 0.5rem 2rem;
}

code {
	border-radius: 4px;
	border: solid 1px;
	font-family: "Courier New", monospace;
	font-size: 0.9rem;
	margin: 0 0.25rem;
	padding: 0.25rem 0.65rem;
}

pre {
	-webkit-overflow-scrolling: touch;
	font-family: "Courier New", monospace;
	font-size: 0.9rem;
	margin: 0 0 2rem 0;
}

pre code {
	display: block;
	line-height: 1.75;
	padding: 1rem 1.5rem;
	overflow-x: auto;
}

hr {
	border: 0;
	border-bottom: solid 1px;
	margin: 2rem 0;
}

hr.major {
	margin: 3rem 0;
}

.align-left {
	text-align: left;
}

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

.align-right {
	text-align: right;
}

input, select, textarea {
	/*		color: #555;	*/
	color: #000000;
}

a {
	color: #E60012;
}

strong, b {
	color: #555;
}

h1, h2, h3, h4, h5, h6 {
	color: #555;
}

blockquote {
	border-left-color: rgba(144, 144, 144, 0.25);
}

code {
	background: rgba(144, 144, 144, 0.075);
	border-color: rgba(144, 144, 144, 0.25);
}

hr {
	border-bottom-color: rgba(144, 144, 144, 0.25);
}

.triangle {
	width: 100%;
	padding: 0;
	margin: 5px 0;
	text-align: center;
}

.show {
	display: block;
}

.hide {
	display: none;
}

.showSP {
	display: none;
}

.showPC {
	display: block;
}

@media screen and (max-width: 736px) {
	.showSP {
		display: block;
	}
	.showPC {
		display: none;
	}
}

/* Box */

.box {
	margin-bottom: 2rem;
	background: #FFF;
}

.box .content {
	padding: 1.5rem;
}

.box .content h3 {
	font-weight: bold;
	position: relative;
	padding: 0 2rem 1rem;
	border-bottom: 6px solid #f2363a;
	margin: 0 0 1rem 0;
	font-size: 2rem;
	color: #000;
}

/*
.box .content h3:before {
	position: absolute;
	bottom: -6px;
	left: 0;
	width: 20%;
	height: 6px;
	content: '';
	background: #ffdedf;
}
*/

.box .content p.innerText {
	color: #2f2725;
	/* font-weight: bold;	*/
	width: 100%;
	margin: 0 auto 10px;
}

.box .content .movie {
	margin: 10px auto 0;
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
}

.box .content .movie iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.box .content ul.innerList {
	color: #2f2725;
	width: 100%;
	margin: 0 auto;
}

.box .content ul.innerList.nomark {
	list-style: none;
	text-indent: -1em;
}

.box> :last-child, .box> :last-child> :last-child, .box> :last-child> :last-child> :last-child {
	margin-bottom: 0;
}

.box.alt {
	border: 0;
	border-radius: 0;
	padding: 0;
}

@media screen and (max-width: 736px) {
	.box .content {
		padding: 1rem;
	}
	.box .content p.innerText {
		/*	font-size: 16px;
		line-height: 30px;	*/
		width: 100%;
	}
	.box .content h3 {
		font-size: 18px;
		padding: 0 0 0.5rem;
	}
}

.box {
	border-color: rgba(144, 144, 144, 0.25);
}

/* Button */

input[type="submit"], input[type="reset"], input[type="button"], button, .button {
	-moz-appearance: none;
	-webkit-appearance: none;
	-ms-appearance: none;
	appearance: none;
	-moz-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
	-webkit-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
	-ms-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
	transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
	border-radius: 4px;
	border: 0;
	cursor: pointer;
	display: inline-block;
	font-weight: 400;
	height: 2.85rem;
	line-height: 2.95rem;
	padding: 0 1.5rem;
	text-align: center;
	text-decoration: none;
	white-space: nowrap;
	text-transform: uppercase;
}

input[type="submit"].icon, input[type="reset"].icon, input[type="button"].icon, button.icon, .button.icon {
	padding-left: 1.35rem;
}

input[type="submit"].icon:before, input[type="reset"].icon:before, input[type="button"].icon:before, button.icon:before, .button.icon:before {
	margin-right: 0.5rem;
}

input[type="submit"].fit, input[type="reset"].fit, input[type="button"].fit, button.fit, .button.fit {
	display: block;
	margin: 0 0 1rem 0;
	width: 100%;
}

input[type="submit"].small, input[type="reset"].small, input[type="button"].small, button.small, .button.small {
	font-size: 0.8rem;
}

input[type="submit"].big, input[type="reset"].big, input[type="button"].big, button.big, .button.big {
	font-size: 1.35rem;
}

input[type="submit"].disabled, input[type="submit"]:disabled, input[type="reset"].disabled, input[type="reset"]:disabled, input[type="button"].disabled, input[type="button"]:disabled, button.disabled, button:disabled, .button.disabled, .button:disabled {
	-moz-pointer-events: none;
	-webkit-pointer-events: none;
	-ms-pointer-events: none;
	pointer-events: none;
	opacity: 0.25;
}

.attachment label {
	/* ボタン部分の見た目（任意） */
	display: inline-block;
	position: relative;
	background: #666;
	color: #fff;
	font-size: 16px;
	padding: 10px 18px;
	border-radius: 4px;
	transition: all 0.3s;
}

.attachment label:hover {
	background: #888;
	transition: all 0.4s;
}

.attachment label input[type="file"] {
	/* 今回のポイント */
	position: absolute;
	left: 0;
	top: 0;
	opacity: 0;
	width: 100%;
	height: 100%;
}

.attachment .filename {
	font-weight: 16px;
	margin: 0 0 0 10px;
}

@media screen and (max-width: 480px) {
	input[type="submit"], input[type="reset"], input[type="button"], button, .button {
		padding: 0;
	}
}

input[type="submit"], input[type="reset"], input[type="button"], button, .button {
	background-color: #f2f2f2;
	color: #000 !important;
}

input[type="submit"]:hover, input[type="reset"]:hover, input[type="button"]:hover, button:hover, .button:hover {
	background-color: white;
}

input[type="submit"]:active, input[type="reset"]:active, input[type="button"]:active, button:active, .button:active {
	background-color: #e5e5e5;
}

input[type="submit"].alt, input[type="reset"].alt, input[type="button"].alt, button.alt, .button.alt {
	background-color: transparent;
	box-shadow: inset 0 0 0 2px rgba(144, 144, 144, 0.25);
	color: #555 !important;
}

input[type="submit"].alt:hover, input[type="reset"].alt:hover, input[type="button"].alt:hover, button.alt:hover, .button.alt:hover {
	background-color: rgba(144, 144, 144, 0.075);
}

input[type="submit"].alt:active, input[type="reset"].alt:active, input[type="button"].alt:active, button.alt:active, .button.alt:active {
	background-color: rgba(144, 144, 144, 0.2);
}

input[type="submit"].alt.icon:before, input[type="reset"].alt.icon:before, input[type="button"].alt.icon:before, button.alt.icon:before, .button.alt.icon:before {
	color: #bbb;
}

input[type="submit"].special, input[type="reset"].special, input[type="button"].special, button.special, .button.special {
	background-color: #E60012;
	color: #ffffff !important;
}

input[type="submit"].special:hover, input[type="reset"].special:hover, input[type="button"].special:hover, button.special:hover, .button.special:hover {
	background-color: #E22038;
}

input[type="submit"].special:active, input[type="reset"].special:active, input[type="button"].special:active, button.special:active, .button.special:active {
	background-color: #439aea;
}

/* Form */

form {
	margin: 0 0 2rem 0;
}

form .field {
	margin-bottom: 2rem;
}

form .field.btm0 {
	margin-bottom: 0;
}

form .field.half {
	display: inline-block;
	width: 48%;
}

form .field.half.first {
	margin-right: 2.5%;
}

@media screen and (max-width: 1000px) {
	form .field.half {
		display: block;
		width: 100%;
	}
	form .field.half.first {
		margin-right: 0;
	}
}

label {
	display: block;
	font-weight: bold;
	margin: 0 0 3px 0;
}

label em {
	color: #ff0000;
	font-size: 10px;
	font-style: normal;
}

label .error, p.error {
	color: #ff0000;
	padding-left: 10px;
	margin-bottom: 0.5rem;
}

input[type="text"], input[type="password"], input[type="email"], input[type="url"], select, textarea {
	-moz-appearance: none;
	-webkit-appearance: none;
	-ms-appearance: none;
	appearance: none;
	border-radius: 4px;
	border: none;
	border: solid 1px;
	color: inherit;
	display: block;
	outline: 0;
	padding: 0 1rem;
	text-decoration: none;
	width: 100%;
	font-size: 16px;
}

input[type="tel"] {
	-moz-appearance: none;
	-webkit-appearance: none;
	-ms-appearance: none;
	appearance: none;
	border-radius: 4px;
	border: none;
	border: solid 1px;
	color: inherit;
	display: block;
	outline: 0;
	padding: 0 1rem;
	text-decoration: none;
	width: 50%;
}

input.account {
	width: 95%;
	float: right;
}

@media screen and (max-width: 736px) {
	input[type="tel"], input[type="url"].account {
		width: 90%;
	}
}

input[type="text"]:invalid, input[type="password"]:invalid, input[type="email"]:invalid, input[type="url"]:invalid, input[type="tel"]:invalid, select:invalid, textarea:invalid {
	box-shadow: none;
}

input[type="text"].error, input[type="password"].error, input[type="email"].error, input[type="url"].error, input[type="tel"].error, select.error, textarea.error {
	border-color: rgba(220, 20, 60, 1);
}

.input-etc-wrapper input[type="text"] {
	width: 60%;
	display: inline;
	margin: 10px 0;
}

.select-wrapper {
	text-decoration: none;
	display: block;
	position: relative;
}

.select-wrapper:before {
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	font-family: FontAwesome;
	font-style: normal;
	font-weight: normal;
	text-transform: none !important;
}

.select-wrapper:before {
	/* content: '\f078'; */
	display: block;
	height: 2.75rem;
	line-height: 2.75rem;
	pointer-events: none;
	position: absolute;
	right: 0;
	text-align: center;
	top: 0;
	width: 2.75rem;

	/* 背景設定 */
	content: '';
	background-image: url(../images/chevron-down-solid.svg);
	background-size: 40%;
	background-position: center;
	background-repeat: no-repeat;
}

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

input[type="text"], input[type="password"], input[type="url"], input[type="email"], input[type="tel"], select {
	height: 2.75rem;
}

textarea {
	padding: 0.75rem 1rem;
}

input[type="checkbox"], input[type="radio"] {
	-moz-appearance: none;
	-webkit-appearance: none;
	-ms-appearance: none;
	appearance: none;
	display: block;
	float: left;
	margin-right: -2rem;
	opacity: 0;
	width: 1rem;
	z-index: -1;
}

input[type="checkbox"]+label, input[type="radio"]+label {
	text-decoration: none;
	cursor: pointer;
	display: inline-block;
	font-size: 1rem;
	font-weight: 300;
	padding-left: 2.4rem;
	padding-right: 0.75rem;
	line-height: 1.6;
	position: relative;
}

input[type="checkbox"]+label:before, input[type="radio"]+label:before {
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	font-family: FontAwesome;
	font-style: normal;
	font-weight: normal;
	text-transform: none !important;
}

input[type="checkbox"]+label:before, input[type="radio"]+label:before {
	border-radius: 4px;
	border: solid 1px;
	content: '';
	display: inline-block;
	height: 1.65rem;
	line-height: 1.58125rem;
	position: absolute;
	text-align: center;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	width: 1.65rem;
}

input[type="checkbox"]:checked+label:before, input[type="radio"]:checked+label:before {
	/* content: '\f00c'; */


	/* 背景設定 */
	content: '';
	background-image: url(../images/check-solid.svg);
	background-size: 70%;
	background-position: center;
	background-repeat: no-repeat;
}



input[type="checkbox"]+label:before {
	border-radius: 4px;
}

input[type="radio"]+label:before {
	border-radius: 100%;
}

::-webkit-input-placeholder {
	opacity: 1.0;
}

:-moz-placeholder {
	opacity: 1.0;
}

::-moz-placeholder {
	opacity: 1.0;
}

:-ms-input-placeholder {
	opacity: 1.0;
}

.formerize-placeholder {
	opacity: 1.0;
}

label {
	color: #555;
}

input[type="text"], input[type="password"], input[type="email"], input[type="url"], input[type="tel"], select, textarea {
	background: rgba(144, 144, 144, 0.075);
	border-color: rgba(144, 144, 144, 0.25);
	font-size: 16px;
}

input[type="text"]:focus, input[type="password"]:focus, input[type="email"]:focus, input[type="url"]:focus, input[type="tel"]:focus, select:focus, textarea:focus {
	border-color: #E60012;
	box-shadow: 0 0 0 1px #E60012;
}

.select-wrapper:before {
	color: rgba(144, 144, 144, 0.25);
}

input[type="checkbox"]+label, input[type="radio"]+label {
	color: #444;
}

input[type="checkbox"]+label:before, input[type="radio"]+label:before {
	background: rgba(144, 144, 144, 0.075);
	border-color: rgba(144, 144, 144, 0.25);
}

input[type="checkbox"]+label.error:before, input[type="radio"]+label.error:before {
	border-color: rgba(220, 20, 60, 1);
}

input[type="checkbox"]:checked+label:before, input[type="radio"]:checked+label:before {
	background-color: #E60012;
	border-color: #E60012;
	color: #ffffff;
}

input[type="checkbox"]:focus+label:before, input[type="radio"]:focus+label:before {
	border-color: #E60012;
	box-shadow: 0 0 0 1px #E60012;
}

::-webkit-input-placeholder {
	color: #bbb !important;
}

:-moz-placeholder {
	color: #bbb !important;
}

::-moz-placeholder {
	color: #bbb !important;
}

:-ms-input-placeholder {
	color: #bbb !important;
}

.formerize-placeholder {
	color: #bbb !important;
}

/* Icon */

.icon {
	text-decoration: none;
	border-bottom: none;
	position: relative;
}

.icon:before {
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	font-family: FontAwesome;
	font-style: normal;
	font-weight: normal;
	text-transform: none !important;
}

.icon>.label {
	display: none;
}

/* Image */

.image {
	border: 0;
	display: inline-block;
	position: relative;
}

.image img {
	display: block;
}

.image.left, .image.right {
	max-width: 40%;
}

.image.left img, .image.right img {
	width: 100%;
}

.image.left {
	float: left;
	margin: 0 1.5rem 1rem 0;
	top: 0.25rem;
}

.image.right {
	float: right;
	margin: 0 0 1rem 1.5rem;
	top: 0.25rem;
}

.image.fit {
	display: block;
	margin: 0 auto;
	width: 300px;
}

.image.fit img {
	width: 100%;
}

.image.main {
	display: block;
	margin: 0 0 3rem 0;
	width: 100%;
}

.image.main img {
	width: 100%;
}

/* List */

ol {
	list-style: decimal;
	margin: 0 0 2rem 0;
	padding-left: 1.25rem;
}

ol li {
	padding-left: 0.25rem;
}

ul {
	list-style: disc;
	margin: 0 0 2rem 0;
	padding-left: 1rem;
}

ul li {
	padding-left: 0.5rem;
}

ul.alt {
	list-style: none;
	padding-left: 0;
}

ul.alt li {
	/* border-top: solid 1px; */
	padding: 0.5rem 0;
}

ul.alt li:first-child {
	border-top: 0;
	padding-top: 0;
}

ul.icons {
	cursor: default;
	list-style: none;
	padding-left: 0;
}

ul.icons li {
	display: inline-block;
	padding: 0 1rem 0 0;
}

ul.icons li:last-child {
	padding-right: 0;
}

ul.icons li .icon:before {
	font-size: 2rem;
}

ul.actions {
	cursor: default;
	list-style: none;
	padding-left: 0;
}

ul.actions li {
	display: inline-block;
	padding: 0 1rem 0 0;
	vertical-align: middle;
	width: 100%;
}

ul.actions.two li {
	width: 48%;
}

ul.actions.two li:first-child {
	width: 68%;
	float: right;
}

ul.actions.two li:last-child {
	width: 30%;
	float: left;
}

ul.actions li:last-child {
	padding-right: 0;
}

ul.actions.small li {
	padding: 0 0.5rem 0 0;
}

ul.actions.vertical li {
	display: block;
	padding: 1rem 0 0 0;
}

ul.actions.vertical li:first-child {
	padding-top: 0;
}

ul.actions.vertical li>* {
	margin-bottom: 0;
}

ul.actions.vertical.small li {
	padding: 0.5rem 0 0 0;
}

ul.actions.vertical.small li:first-child {
	padding-top: 0;
}

ul.actions.fit {
	display: table;
	margin-left: -1rem;
	padding: 0;
	table-layout: fixed;
	width: calc(100% + 1rem);
}

ul.actions.fit li {
	display: table-cell;
	padding: 0 0 0 1rem;
}

ul.actions.fit li>* {
	margin-bottom: 0;
}

ul.actions.fit.small {
	margin-left: -0.5rem;
	width: calc(100% + 0.5rem);
}

ul.actions.fit.small li {
	padding: 0 0 0 0.5rem;
}

@media screen and (max-width: 480px) {
	ul.actions {
		margin: 0 0 2rem 0;
	}
	ul.actions li {
		padding: 1rem 0 0 0;
		display: block;
		text-align: center;
		width: 100%;
	}
	ul.actions.two li {
		width: 100%;
		float: none;
	}
	ul.actions.two li:first-child, ul.actions li:first-child {
		width: 100%;
		padding-top: 0;
	}
	ul.actions.two li:last-child {
		width: 30%;
	}
	ul.actions li>* {
		width: 100%;
		margin: 0 !important;
	}
	ul.actions li>*.icon:before {
		margin-left: -2rem;
	}
	ul.actions.small li {
		padding: 0.5rem 0 0 0;
	}
	ul.actions.small li:first-child {
		padding-top: 0;
	}
	ul.actions.two li:last-child input[type="submit"].special {
		font-size: 1rem;
	}
}

dl {
	margin: 0 0 2rem 0;
}

dl dt {
	display: block;
	font-weight: 400;
	margin: 0 0 1rem 0;
}

dl dd {
	margin-left: 2rem;
}

ul.alt li {
	border-top-color: rgba(144, 144, 144, 0.25);
}

/* Section/Article */

section.special, article.special {
	text-align: center;
}

h2#logo {
	width: 100%;
	background: #ffffff;
}

h2#logo p {
	width: 100%;
	margin: 0 auto;
}

h2#logo p img {
	width: 90%;
	max-width: 900px;
	margin: 0 auto;
	padding: 0;
	display: block;
}

header {
	margin: 0 auto;
	/* max-width: 1200px; */
	max-width: 750px;
}

#header img {
	width: 100%;
	display: block;
	margin: 0 auto;
}

header.title {
	background: #f2f2f2;
	text-align: center;
	margin: 0 auto;
	padding: 1rem 0;
	max-width: 100%;
}

@media screen and (max-width: 736px) {
	header {
		margin: 0 auto 2rem;
		max-width: 750px;
	}
}

/* Table */

.table-wrapper {
	-webkit-overflow-scrolling: touch;
	overflow-x: auto;
}

table {
	margin: 0 0 2rem 0;
	width: 100%;
}

table tbody tr {
	border: solid 1px;
	border-left: 0;
	border-right: 0;
}

table td {
	padding: 0.75rem 0.75rem;
}

table th {
	font-size: 0.9rem;
	font-weight: 400;
	padding: 0 0.75rem 0.75rem 0.75rem;
	text-align: left;
}

table thead {
	border-bottom: solid 2px;
}

table tfoot {
	border-top: solid 2px;
}

table.alt {
	border-collapse: separate;
}

table.alt tbody tr td {
	border: solid 1px;
	border-left-width: 0;
	border-top-width: 0;
}

table.alt tbody tr td:first-child {
	border-left-width: 1px;
}

table.alt tbody tr:first-child td {
	border-top-width: 1px;
}

table.alt thead {
	border-bottom: 0;
}

table.alt tfoot {
	border-top: 0;
}

table tbody tr {
	border-color: rgba(144, 144, 144, 0.25);
}

table tbody tr:nth-child(2n+1) {
	background-color: rgba(144, 144, 144, 0.075);
}

table th {
	color: #555;
}

table thead {
	border-bottom-color: rgba(144, 144, 144, 0.25);
}

table tfoot {
	border-top-color: rgba(144, 144, 144, 0.25);
}

table.alt tbody tr td {
	border-color: rgba(144, 144, 144, 0.25);
}

/* Wrapper */

.wrapper {
	padding: 0;
	position: relative;
	margin: 0;
	min-height: 93vh;
	position: relative;
	/*←相対位置*/
}

.wrapper .txt_close {
	text-align: center;
	font-size: 1.2rem;
	color: #ff0000;
	font-weight: bold;
}

.wrapper.pd10 {
	padding: 0 0 10px 0;
}

.wrapper>.inner {
	margin: 0 auto;
	width: 100%;
	padding-bottom: 2rem;
	/* max-width: 950px; */
	max-width: 750px;
}

body#top .wrapper>.inner {
	/* padding-bottom: 30%; */
	/* padding-bottom: 10%; */
	padding-bottom: 5%;
}

body#form .wrapper>.inner {
	max-width: 750px;
}

/* 
		@media screen and (max-width: 1280px) {
			.wrapper > .inner {
				width: 75rem;
			}
		}
		*/

@media screen and (max-width: 1000px) {
	.wrapper>.inner {
		width: 100%;
	}
	.wrapper.style3 {
		background-attachment: scroll;
	}
	.wrapper.style4 h3 {
		padding: 0 0;
	}
}

@media screen and (max-width: 736px) {
	.wrapper {
		padding: 0 0 1rem 0;
	}
	/* body#top .wrapper>.inner {
		padding-bottom: 50%;
	} */
}

/* Header */

body.subpage {
	padding-top: 3.125em;
}

@-moz-keyframes reveal-header {
	0% {
		top: -4em;
		opacity: 0;
	}
	100% {
		top: 0;
		opacity: 1;
	}
}

@-webkit-keyframes reveal-header {
	0% {
		top: -4em;
		opacity: 0;
	}
	100% {
		top: 0;
		opacity: 1;
	}
}

@-ms-keyframes reveal-header {
	0% {
		top: -4em;
		opacity: 0;
	}
	100% {
		top: 0;
		opacity: 1;
	}
}

@keyframes reveal-header {
	0% {
		top: -4em;
		opacity: 0;
	}
	100% {
		top: 0;
		opacity: 1;
	}
}

/*
	#header {
		background: rgba(0, 0, 0, 0.75);
		color: #a6a6a6;
		cursor: default;
		height: 3.25em;
		left: 0;
		line-height: 3.25em;
		position: fixed;
		text-align: right;
		top: 0;
		width: 100%;
		z-index: 10001;
	}

		#header .toggle span {
			display: none;
		}

		#header > .logo {
			display: inline-block;
			height: inherit;
			left: 1.25rem;
			line-height: inherit;
			margin: 0;
			padding: 0;
			position: absolute;
			top: 0;
		}

		#header > .logo a {
			font-size: 1.25rem;
			color: #FFF;
			text-decoration: none;
		}

		#header > .logo span {
			font-weight: 300;
			font-size: .75rem;
			color: rgba(255, 255, 255, 0.5);
		}

		#header > a {
			-moz-transition: color 0.2s ease-in-out;
			-webkit-transition: color 0.2s ease-in-out;
			-ms-transition: color 0.2s ease-in-out;
			transition: color 0.2s ease-in-out;
			display: inline-block;
			padding: 0 0.75em;
			color: inherit;
			text-decoration: none;
			color: #FFF;
		}

		#header > a[href="#menu"] {
			text-decoration: none;
			-webkit-tap-highlight-color: transparent;
		}

		#header > a[href="#menu"]:before {
			content: "";
			-moz-osx-font-smoothing: grayscale;
			-webkit-font-smoothing: antialiased;
			font-family: FontAwesome;
			font-style: normal;
			font-weight: normal;
			text-transform: none !important;
		}

		#header > a[href="#menu"]:before {
			margin: 0 0.5em 0 0;
		}

		#header > a + a[href="#menu"]:last-child {
			border-left: solid 1px rgba(0, 0, 0, 0.15);
			padding-left: 1.25em;
			margin-left: 0.5em;
		}

		#header > a:last-child {
			padding-right: 1.25em;
		}

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

			#header > a {
				padding: 0 0.5em;
			}

			#header > a + a[href="#menu"]:last-child {
				padding-left: 1em;
				margin-left: 0.25em;
			}

			#header > a:last-child {
				padding-right: 1em;
			}
		}

		#header.reveal {
			-moz-animation: reveal-header 0.5s ease;
			-webkit-animation: reveal-header 0.5s ease;
			-ms-animation: reveal-header 0.5s ease;
			animation: reveal-header 0.5s ease;
		}

		#header.alt {
			-moz-animation: none;
			-webkit-animation: none;
			-ms-animation: none;
			animation: none;
			background-color: transparent;
			box-shadow: none;
			overflow: hidden;
			position: absolute;
			top: 1.5em;
		}

		#header.alt h1 {
			left: 2.5em;
		}

		#header.alt nav {
			right: 2.5em;
		}

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

		body.subpage {
			padding-top: 44px;
		}

		#header {
			height: 44px;
			line-height: 44px;
		}

			#header > h1 {
				left: 1em;
			}

				#header > h1 a {
					font-size: 1em;
				}

	}

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

		#header {
			min-width: 320px;
		}

	}
*/

/* Menu */

#menu {
	-moz-transform: translateX(20em);
	-webkit-transform: translateX(20em);
	-ms-transform: translateX(20em);
	transform: translateX(20em);
	-moz-transition: -moz-transform 0.5s ease, box-shadow 0.5s ease, visibility 0.5s;
	-webkit-transition: -webkit-transform 0.5s ease, box-shadow 0.5s ease, visibility 0.5s;
	-ms-transition: -ms-transform 0.5s ease, box-shadow 0.5s ease, visibility 0.5s;
	transition: transform 0.5s ease, box-shadow 0.5s ease, visibility 0.5s;
	-webkit-overflow-scrolling: touch;
	background: #000;
	box-shadow: none;
	color: #000;
	height: 100%;
	max-width: 80%;
	overflow-y: auto;
	padding: 3em 2em;
	position: fixed;
	right: 0;
	top: 0;
	visibility: hidden;
	width: 20em;
	z-index: 10002;
}

#menu>ul {
	margin: 0 0 1rem 0;
}

#menu>ul.links {
	list-style: none;
	padding: 0;
}

#menu>ul.links>li {
	padding: 0;
}

#menu>ul.links>li>a:not(.button) {
	border: 0;
	border-top: solid 1px rgba(255, 255, 255, 0.25);
	color: #fff;
	display: block;
	line-height: 3.5em;
	text-decoration: none;
}

#menu>ul.links>li>a:not(.button):hover {
	color: #E60012;
}

#menu>ul.links>li>.button {
	display: block;
	margin: 0.5em 0 0 0;
}

#menu>ul.links>li:first-child>a:not(.button) {
	border-top: 0 !important;
}

#menu .close {
	text-decoration: none;
	-moz-transition: color 0.2s ease-in-out;
	-webkit-transition: color 0.2s ease-in-out;
	-ms-transition: color 0.2s ease-in-out;
	transition: color 0.2s ease-in-out;
	-webkit-tap-highlight-color: transparent;
	border: 0;
	color: #fff;
	cursor: pointer;
	display: block;
	height: 3.25em;
	line-height: 3.25em;
	padding-right: 1.25em;
	position: absolute;
	right: 0;
	text-align: right;
	top: 0;
	vertical-align: middle;
	width: 7em;
}

#menu .close:before {
	content: "";
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	font-family: FontAwesome;
	font-style: normal;
	font-weight: normal;
	text-transform: none !important;
}

#menu .close:before {
	font-size: 1.25em;
}

#menu .close:hover {
	color: #f2f2f2;
}

@media screen and (max-width: 736px) {
	#menu .close {
		height: 4em;
		line-height: 4em;
	}
}

#menu.visible {
	-moz-transform: translateX(0);
	-webkit-transform: translateX(0);
	-ms-transform: translateX(0);
	transform: translateX(0);
	box-shadow: 0 0 1.5em 0 rgba(0, 0, 0, 0.2);
	visibility: visible;
}

@media screen and (max-width: 736px) {
	#menu {
		padding: 2.5em 1.75em;
	}
}

/* Banner */

#banner {
	display: -ms-flexbox;
	-ms-flex-pack: center;
	-ms-flex-align: center;
	-moz-align-items: center;
	-webkit-align-items: center;
	-ms-align-items: center;
	align-items: center;
	display: -moz-flex;
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-moz-justify-content: center;
	-webkit-justify-content: center;
	-ms-justify-content: center;
	justify-content: center;
	/*	background-image: url("../../images/banner.jpg");	*/
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	border-top: 0;
	min-height: 100vh;
	height: 100vh !important;
	width: 100%;
	position: relative;
	text-align: center;
	overflow: hidden;
}

#banner .inner {
	-moz-transform: scale(1.0);
	-webkit-transform: scale(1.0);
	-ms-transform: scale(1.0);
	transform: scale(1.0);
	-moz-transition: opacity 1s ease, -moz-transform 1s ease;
	-webkit-transition: opacity 1s ease, -webkit-transform 1s ease;
	-ms-transition: opacity 1s ease, -ms-transform 1s ease;
	transition: opacity 1s ease, transform 1s ease;
	opacity: 1;
	position: relative;
	z-index: 2;
}

#banner h1 {
	font-size: 4rem;
	margin-bottom: 1rem;
	color: #FFF;
}

#banner p {
	color: rgba(255, 255, 255, 0.65);
	font-size: 1.5rem;
	margin-bottom: 3rem;
}

#banner a {
	color: #FFF;
	text-decoration: none;
}

#banner video {
	-moz-transform: translateX(50%) translateY(50%);
	-webkit-transform: translateX(50%) translateY(50%);
	-ms-transform: translateX(50%) translateY(50%);
	transform: translateX(50%) translateY(50%);
	position: absolute;
	bottom: 50%;
	right: 50%;
	width: auto;
	height: auto;
	min-width: 100%;
	min-height: 100%;
	overflow: hidden;
}

#banner:before {
	-moz-transition: opacity 3s ease;
	-webkit-transition: opacity 3s ease;
	-ms-transition: opacity 3s ease;
	transition: opacity 3s ease;
	-moz-transition-delay: 1.25s;
	-webkit-transition-delay: 1.25s;
	-ms-transition-delay: 1.25s;
	transition-delay: 1.25s;
	content: '';
	display: block;
	background-color: rgba(0, 0, 0, 0.75);
	height: 100%;
	left: 0;
	opacity: 0.45;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: 1;
}

@media screen and (max-width: 1280px) {
	#banner video {
		display: none;
	}
}

@media screen and (max-width: 736px) {
	#banner {
		min-height: 0;
		height: auto !important;
		padding: 6rem 2rem 4rem 2rem;
	}
	#banner .inner {
		width: 100%;
	}
	#banner h1 {
		font-size: 1.75em;
		margin-bottom: 0.5em;
		padding-bottom: 0;
	}
	#banner p {
		font-size: 1.25em;
	}
	#banner br {
		display: none;
	}
	#banner .button {
		width: 100%;
	}
}

@media screen and (max-width: 480px) {
	#banner p {
		font-size: 1em;
	}
}

body.is-loading #banner .inner {
	-moz-transform: scale(0.99);
	-webkit-transform: scale(0.99);
	-ms-transform: scale(0.99);
	transform: scale(0.99);
	opacity: 0;
}

body.is-loading #banner:before {
	opacity: 1;
}

/* Main */

#main {
	padding: 4rem 0 2rem 0;
}

@media screen and (max-width: 736px) {
	#main {
		padding: 3rem 0 1rem 0;
	}
}

/* Footer */

#footer {
	padding: 2rem 0;
	color: #fff;
	background-color: #444;
	width: 100%;
	margin: 0;
	/* width: 100%; */
	/* padding: 1rem; */
	/* background: #f2f2f2; */
	/* position: absolute; */
	/*←絶対位置*/
	/* bottom: 0; */
	/*下に固定*/
}

#footer .inBox {
	width: 98%;
	max-width: 1200px;
	margin: 0 auto;
}

#footer .inBox h5 {
	font-size: 14px;
	padding: 0;
	margin: 0;
	font-weight: bold;
}

#footer .inBox dl {
	list-style: none;
	padding: 0;
	margin: 0;
}

#footer .inBox dl dt {
	font-weight: 600;
	font-size: 16px;
}

#footer .inBox dl dd {
	margin-left: 0;
	font-size: 12px;
}

#footer .copyright {
	color: #bbb;
	font-size: 12px;
	padding: 10px 0;
	text-align: center;
}

#footer .advertising {
	color: #bbb;
	font-size: 8px;
	margin: 0;
	padding: 5px 0;
	text-align: right;
	width: 95%;
	max-width: 870px;
}

@media screen and (max-width: 736px) {
	#footer .inBox {
		font-size: 12px;
	}
}

/* Flexgrid */

#flexgrid {
	width: 100%;
	margin: 0 0 2.5rem 0;
	display: -moz-flex;
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-moz-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-moz-align-items: stretch;
	-webkit-align-items: stretch;
	-ms-align-items: stretch;
	align-items: stretch;
}

#flexgrid>* {
	-moz-flex-shrink: 1;
	-webkit-flex-shrink: 1;
	-ms-flex-shrink: 1;
	flex-shrink: 1;
	-moz-flex-grow: 0;
	-webkit-flex-grow: 0;
	-ms-flex-grow: 0;
	flex-grow: 0;
}

#flexgrid>* {
	width: 33.33333%;
}

#flexgrid>* {
	padding: 3rem;
	width: calc(33.33333% + 2rem);
}

#flexgrid> :nth-child(-n+3) {
	padding-top: 0;
}

#flexgrid> :nth-last-child(-n+3) {
	padding-bottom: 0;
}

#flexgrid> :nth-child(3n+1) {
	padding-left: 0;
}

#flexgrid> :nth-child(3n) {
	padding-right: 0;
}

#flexgrid> :nth-child(3n+1), #flexgrid> :nth-child(3n) {
	width: calc(33.33333% + -1rem);
}

#flexgrid>div {
	border-style: solid;
	border-color: rgba(255, 255, 255, 0.25);
	border-left-width: 1px;
	border-top-width: 1px;
	text-align: center;
}

#flexgrid>div> :last-child {
	margin-bottom: 0;
}

#flexgrid>div:nth-child(3n - 2) {
	border-left-width: 0;
}

#flexgrid>div:nth-child(-n+3) {
	border-top-width: 0;
}

#flexgrid>div .icon {
	display: -moz-flex;
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-moz-align-items: center;
	-webkit-align-items: center;
	-ms-align-items: center;
	align-items: center;
	-moz-justify-content: center;
	-webkit-justify-content: center;
	-ms-justify-content: center;
	justify-content: center;
	font-size: 3.5rem;
	background: #fff;
	color: #E60012;
	width: 8rem;
	height: 8rem;
	border-radius: 100%;
	margin: 0 auto 2rem auto;
}

@media screen and (max-width: 1000px) {
	#flexgrid>* {
		width: 100%;
	}
	#flexgrid>* {
		padding: 2rem;
		width: calc(33.33333% + 1.33333rem);
	}
	#flexgrid> :nth-child(-n+3) {
		padding-top: 2rem;
	}
	#flexgrid> :nth-last-child(-n+3) {
		padding-bottom: 2rem;
	}
	#flexgrid> :nth-child(3n+1) {
		padding-left: 2rem;
	}
	#flexgrid> :nth-child(3n) {
		padding-right: 2rem;
	}
	#flexgrid> :nth-child(3n+1), #flexgrid> :nth-child(3n) {
		padding: 2rem;
		width: calc(100% + 4rem);
	}
	#flexgrid>* {
		padding: 2rem;
		width: calc(50% + 2rem);
	}
	#flexgrid> :nth-child(-n+2) {
		padding-top: 2rem;
	}
	#flexgrid> :nth-last-child(-n+2) {
		padding-bottom: 2rem;
	}
	#flexgrid> :nth-child(2n+1) {
		padding-left: 2rem;
	}
	#flexgrid> :nth-child(2n) {
		padding-right: 2rem;
	}
	#flexgrid> :nth-child(2n+1), #flexgrid> :nth-child(2n) {
		padding: 2rem;
		width: calc(100% + 4rem);
	}
	#flexgrid>* {
		padding: 2rem;
		width: calc(100% + 4rem);
	}
	#flexgrid> :nth-child(-n+1) {
		padding-top: 0;
	}
	#flexgrid> :nth-last-child(-n+1) {
		padding-bottom: 0;
	}
	#flexgrid> :nth-child(1n+1) {
		padding-left: 0;
	}
	#flexgrid> :nth-child(1n) {
		padding-right: 0;
	}
	#flexgrid> :nth-child(1n+1), #flexgrid> :nth-child(1n) {
		width: calc(100% + 2rem);
	}
	#flexgrid>div:nth-child(2n - 1) {
		border-left-width: 1px;
	}
	#flexgrid>div:nth-child(-n+2) {
		border-top-width: 1px;
	}
	#flexgrid>div:nth-child(-n+3) {
		border-top-width: 1px;
	}
	#flexgrid>div:nth-child(n) {
		border-left-width: 0;
	}
	#flexgrid>div:nth-child(-n+1) {
		border-top-width: 0;
	}
	#flexgrid>div .icon {
		font-size: 2rem;
		width: 6rem;
		height: 6rem;
	}
}

.grid-style {
	width: 100%;
	margin: 0 0 2.5rem 0;
	display: -moz-flex;
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	-moz-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-moz-align-items: stretch;
	-webkit-align-items: stretch;
	-ms-align-items: stretch;
	align-items: stretch;
}

.grid-style>* {
	-moz-flex-shrink: 1;
	-webkit-flex-shrink: 1;
	-ms-flex-shrink: 1;
	flex-shrink: 1;
	-moz-flex-grow: 0;
	-webkit-flex-grow: 0;
	-ms-flex-grow: 0;
	flex-grow: 0;
}

.grid-style>* {
	width: 50%;
}

.grid-style>* {
	padding: 3rem;
	width: calc(50% + 3rem);
	display: flex;
}

.grid-style> :nth-child(-n+2) {
	padding-top: 0;
}

.grid-style> :nth-last-child(-n+2) {
	padding-bottom: 0;
}

.grid-style> :nth-child(2n+1) {
	padding-left: 0;
}

.grid-style> :nth-child(2n) {
	padding-right: 0;
}

.grid-style> :nth-child(2n+1), .grid-style> :nth-child(2n) {
	width: calc(50% + 0rem);
}

.grid-style .box {
	margin: 0;
}

@media screen and (max-width: 1000px) {
	.grid-style>* {
		width: 100%;
	}
	.grid-style>* {
		padding: 2rem;
		width: calc(50% + 2rem);
	}
	.grid-style> :nth-child(-n+2) {
		padding-top: 2rem;
	}
	.grid-style> :nth-last-child(-n+2) {
		padding-bottom: 2rem;
	}
	.grid-style> :nth-child(2n+1) {
		padding-left: 2rem;
	}
	.grid-style> :nth-child(2n) {
		padding-right: 2rem;
	}
	.grid-style> :nth-child(2n+1), .grid-style> :nth-child(2n) {
		padding: 2rem;
		width: calc(100% + 4rem);
	}
	.grid-style>* {
		padding: 2rem;
		width: calc(100% + 4rem);
	}
	.grid-style> :nth-child(-n+1) {
		padding-top: 0;
	}
	.grid-style> :nth-last-child(-n+1) {
		padding-bottom: 0;
	}
	.grid-style> :nth-child(1n+1) {
		padding-left: 0;
	}
	.grid-style> :nth-child(1n) {
		padding-right: 0;
	}
	.grid-style> :nth-child(1n+1), .grid-style> :nth-child(1n) {
		width: calc(100% + 2rem);
	}
}

/* 利用規約同ボタン	*/

.policy {
	margin: 20px auto;
	text-align: center;
}

.submit_btnarea {
	width: 100%;
	margin: 0 auto;
}

.submit_btnarea button[type="submit"] {
	font-size: 2rem;
	padding: 1rem 0;
	height: auto;
}

.submit_btnarea button[type="submit"][disabled] {
	color: #ccc;
	border-color: #ccc;
	cursor: default;
	opacity: 30%;
}

.submit_btnarea button[type="submit"]:hover {
	opacity: 1;
}

.form_btn {
	cursor: pointer;
	transition: all .5s ease-out;
	position: relative;
}

.form_btn:hover {
	border: 1px solid #005183;
	background: #fff;
	color: #005183;
}

.sel_date {
	width: 30%;
	float: left;
	margin-right: 1px;
	max-width: 100px;
}

.fl {
	float: left;
}

.mt5 {
	margin-top: 5px;
}

.mr5 {
	margin-right: 5px;
}

.ml40 {
	margin-left: 40px;
}

.ml40pc {
	margin-left: 40px;
}

.manki {
	margin: 0 0 0 40px;
}

@media screen and (max-width: 500px) {
	.ml40pc {
		margin-left: 0;
	}
}

h5.midashi {
	font-size: 1.8em;
	margin-top: 1.8em;
	text-align: center;
	position: relative;
	display: inline-block;
	padding: 0 45px;
}

h5.midashi:before, h5.midashi:after {
	content: '';
	position: absolute;
	top: 50%;
	display: inline-block;
	width: 44px;
	height: 2px;
	background-color: black;
	-webkit-transform: rotate(-60deg);
	transform: rotate(-60deg);
}

h5.midashi:before {
	left: 0;
}

h5.midashi:after {
	right: 0;
}

.limit {
	text-align: center;
	font-weight: bold;
	/* font-size: 1.6rem; */
	/* font-size: 1.3rem; */
	font-size: 1.2rem;
}

.limit .txt_s {
	font-size: 14px;
}

.seat {
	margin: 1rem auto;
	max-width: 300px;
}

@media screen and (max-width: 736px) {
	h5.midashi {
		font-size: 1.2em;
		margin-top: 1.2em;
	}
}

#loading {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background-color: #000;
	z-index: 9000;
	color: #ffffff;
}

#animation {
	margin: 0;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 9999;
}

.box-scroll {
	padding: 20px;
	overflow-y: scroll;
	height: 300px;
	border: 1px solid #e3e3e3;
	/* font-size: 14px; */
	margin-bottom: 2rem;
}

/* ====================================
	CSSの強制上書き
==================================== */

/* ---------------------------------
  タイトル
--------------------------------- */

header.title, .box .content h3.title {
	padding: 0.5em;
	color: #010101;
	/* background: #eaf3ff; */
	/* border-bottom: solid 5px #6cb4e4; */

	background: #fff1c1;
	border-bottom: solid 5px #f6ba63;

	text-align: center;
	font-weight: bold;
	margin: 0 0 20px;
	font-size: 1.35rem;
}

@media screen and (max-width: 750px) {
	header.title, .box .content h3.title {
		font-size: 16px;
		/* border-bottom: solid 3px #6cb4e4; */
		border-bottom: solid 3px #f6ba63;
		padding: 1rem 5px;
	}
}

/* ---------------------------------
  フォーム関連
--------------------------------- */

/* 希望コース */

.course_ttl {
	font-size: 125%;
}

/* メッセージ */

.form_message {
	margin: 0 auto 10px;
	padding: 10px 15px;
	font-size: 13px;
	border-radius: 5px;
}

/* ---------------------------------
  モーダル
--------------------------------- */

.modal__close, .modal__open {
	margin: 15px auto 0;
	max-width: 260px;
	width: 100%;
	border: none;
	border-radius: 3px;
	background: #000;
	color: #fff;
	text-align: center;
	font-weight: bold;
	font-size: 16px;
	line-height: 50px;
	cursor: pointer;
}

.modal__container {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 999999;
	display: none;
	overflow: auto;
	width: 100%;
	height: 100%;
}

.modal__overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.8);
}

.modal__body {
	display: table;
	width: 100%;
	height: 100%;
}

.modal__main {
	display: table-cell;
	padding: 25px;
	vertical-align: middle;
	text-align: center;
}

.modal__content {
	position: relative;
	display: inline-block;
	box-sizing: border-box;
	padding: 25px;
	max-width: 600px;
	width: 95%;
	background: #fff;
	color: #000;
	/* font-size: 1.6rem; */
}

@media screen and (max-width:414px) {
	.modal__main {
		padding: 10px;
	}
	.modal__content {
		padding: 10px;
		/* font-size: 1.4rem; */
	}
}

/* ---------------------------------
  バーコード読み取り
--------------------------------- */

#interactive.viewport>canvas, #interactive.viewport>video {
	max-width: 100%;
	width: 100%;
}

canvas.drawingBuffer {
	position: absolute;
	top: 0;
	left: 0;
}

/* ---------------------------------
  ポイントカードの説明
--------------------------------- */

.cardSample {
	display: flex;
	align-items: center;
	margin: 25px 0;
	padding: 2%;
	border: solid 1px #000;
}

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

.cardSample__thumbnail {
	padding-right: 2%;
	width: 22%;
}

.cardSample__text {
	width: 78%;
	font-size: 13px !important;
}

.cardSample__text ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.cardSample__text li {
	margin-left: 1em;
	text-indent: -1em;
}

@media screen and (max-width:750px) {
	.cardSample {
		margin: 2.5% 0;
	}
}

@media screen and (max-width:520px) {
	.cardSample {
		flex-direction: column;
		margin: 5% 0;
		padding: 5%;
	}
	.cardSample__thumbnail {
		padding: 0 0 2% 0;
		width: 60%;
	}
	.cardSample__text {
		width: 100%;
	}
}

/* ---------------------------------
  公開メッセージ
--------------------------------- */

.alert_message {
	background: red;
	color: #fff;
	padding: 2%;
	font-size: 22px;
	font-weight: bold;
}

@media screen and (max-width:750px) {
	.alert_message {
		font-size: 20px;
	}
}

@media screen and (max-width:550px) {
	.alert_message {
		font-size: 18px;
	}
}

@media screen and (max-width:450px) {
	.alert_message {
		font-size: 16px;
	}
}

/* ---------------------------------
  応募方法
--------------------------------- */

.entryText strong {
	font-size: 110%;
	/* color: red; */
	margin: 0 2px;
	font-weight: bold;
	color: #000;
}

/* ---------------------------------
  お買い上げ店名
--------------------------------- */

.store-wrapper {
	display: flex;
	align-items: center;
	margin-top: 10px;
}

.store-wrapper span {
	margin: 10px;
}

.field-store .select-wrapper {
	max-width: 400px;
}

#storename {
	max-width: 350px;
}

/* ####################################################
	追加CSS（2024/04/10）
#################################################### */

#thanks .wrapper p,
#thanks .wrapper ul,
#thanks .wrapper li,
#top .wrapper p,
#top .wrapper ul,
#top .wrapper li,
#top .wrapper dl,
#top .wrapper dt,
#top .wrapper dd {
	margin: 0;
	padding: 0;
	text-indent: 0;
	list-style: none;
}



/* pタグ設定 */

#thanks .wrapper p.innerText,
#top .wrapper p.innerText {
	margin-bottom: 1rem;
}

/* ulタグ設定 */

#thanks .wrapper ul.innerList,
#top .wrapper ul.innerList {
	margin-bottom: 1rem;
}

#thanks .wrapper ul.indent li,
#top .wrapper ul.indent li {
	margin-left: 1em;
	text-indent: -1em;
}

/* dlタグ設定 */

#top .wrapper dl,
#top .wrapper dl.innerList {
	margin-bottom: 1rem;
}

#top .wrapper dl.indent dd {
	margin-left: 1em;
	text-indent: -1em;
}

/* キャンペーンタイトル */

#top .campaign_name {
	font-size: 1.5rem;
	margin: 2rem auto;
}

#top .campaign_name .sp-show {
	display: none;
}

@media screen and (max-width: 750px) {
	#top .campaign_name {
		font-size: 1.3rem;
		font-size: 3.5vw;
	}
}

@media screen and (max-width: 550px) {
	#top .campaign_name {
		font-size: 1.1rem;
		font-size: 4.5vw;
	}
	#top .campaign_name .sp-show {
		display: block;
	}
}

/* イベント情報 */

#top dl.event_info {
	border: solid 1px #6cb4e4;
	margin-bottom: 1rem;
}

#top dl.event_info dt {
	background: #6cb4e4;
	text-align: center;
	padding: 4px 8px;
	color: #ffffff;
}

#top dl.event_info dd {
	padding: 1rem 1rem 0;
}


/* 商品 */

#top .wrapper dl.course dd + dt {
	margin-top: 1rem !important;
}


/* コース選択 */

.field_note {
	list-style: none;
	padding: 0;
	font-size: 13px;
	text-indent: -1em;
	margin-left: 1em;
} 

.course_select,
.course_select dt,
.course_select dd {
	margin: 0;
	padding: 0;
}


.course_select dt {
	background: #6cb4e4;
	padding: 5px 15px;
	margin: 5px 0;
	color: #fff;
	font-weight: bold;
	font-size: 14px;
}

.course_select dd {
	padding: 6px 10px;
	border-top: dotted 1px #cacaca;
	/* margin-top: 10px; */
}

.course_select dt + dd {
	border: none;
}

input[type="radio"]:disabled+label:before {
	background: rgba(144, 144, 144, 0.75);
	border-color: rgba(144, 144, 144, 0.5);
}

input[type="radio"]:disabled+label {
	opacity: 0.4;
	text-decoration: line-through;
}


.line-through {
	opacity: 0.4;
	text-decoration: line-through;
}

.member_note {
	font-size: 12px;
}



.course_list {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
}

.course_list li {
	width: 33%;
}

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


@media screen and (max-width: 750px) {
	.course_list li {
		width: 50%;
	}
}

@media screen and (max-width: 550px) {
	/* .course_list li {
		width: 70%;
	} */
}


/* ####################################################
	共通CSS
#################################################### */

.mb15 {
	margin-bottom: 15px;
}

.mb10 {
	margin-bottom: 10px;
}