a, abbr, acronym, address, applet, article, aside, audio, b, big, blockquote, body, canvas, caption, center, cite, code, dd, del, details, dfn, div, dl, dt, em, embed, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, output, p, pre, q, ruby, s, samp, section, small, span, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, tt, u, ul, var, video {
	font: inherit;
	font-size: 100%;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
	border: 0;
}
html {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
table {
	border-spacing: 0;
	border-collapse: collapse;
}
caption, td, th {
	font-weight: 400;
	text-align: left;
	vertical-align: middle;
}
blockquote, q {
	quotes: none;
}
blockquote:after, blockquote:before, q:after, q:before {
	content: '';
	content: none;
}
a img {
	border: none;
}
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
	display: block;
}
* {
	margin: 0;
	padding: 0;
}
html {
	font-size: 62.5%;
	height: 100%;
	-webkit-text-size-adjust: 100%;
}
body {
	font-family: 'Hiragino maru Gothic ProN W4', 'Hiragino Kaku Gothic Pro', 'Hiragino Sans', arial, Meiryo, 'MS PGothic', sans-serif;
	font-size: 10px;
	font-size: 1rem;
	line-height: 1.5;
	text-align: justify;
	text-justify: inter-ideograph;
	word-break: break-all;
	color: #42210b;
	background: #F5F5DC;
}
img {
	width: 100%;
	height: auto;
	-webkit-transition: .3s all;
	transition: .3s all;
	vertical-align: bottom;
}
a {
	text-decoration: none;
}
.larger {
	font-size: 160%;
	font-weight: 700;
	color: #008a9c;
}
.notice {
	color: #008a9c;
}
.container {
	font-size: 160%;
	position: relative;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: 100vh;
	margin: 0 auto;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
}
footer, header {
	-webkit-flex-shrink: 0;
	-ms-flex-negative: 0;
	flex-shrink: 0;
}
main {
	min-height: 1px;
	-webkit-box-flex: 1;
	-webkit-flex: 1 0 auto;
	-ms-flex: 1 0 auto;
	flex: 1 0 auto;
}
iframe {
  	border:none;
  	width:100%;
}
label {
	display: inline-block;
	margin-right: 20px;
}
input[type=number], input[type=text] {
	font-size: 100%;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%;
	padding: 6px;
	color: #42210b;
	border: 2px solid #008a9c;
	border-radius: 4px;
	-webkit-appearance: none;
}
input[type=number]:focus, input[type=text]:focus {
	border: 2px solid #23B5D3;
	outline: 0;
	background-color: rgba(218, 179, 0, .1);
}
input[type=number]::-webkit-inner-spin-button, input[type=number]::-webkit-outer-spin-button {
	margin: 0;
	-webkit-appearance: none;
}
input[type=number] {
	-moz-appearance: textfield;
}
input[name=zip1] {
	width: 50px;
}
input[name=age], input[name=card_num1], input[name=card_num2], input[name=card_num3], input[name=tel0], input[name=tel1], input[name=tel2], input[name=zip2] {
	width: 60px;
}
input[type=checkbox], input[type=radio] {
	margin-right: 5px;
}
input[name=store] {
	display: inline-block;
	width: 70%;
	margin-top: 10px;
}
.select-wrap {
	position: relative;
	display: inline-block;
	width: 100%;
	max-width: 400px;
}
.select-wrap:before {
	position: absolute;
	z-index: 1;
	top: 50%;
	right: 10px;
	width: 6px;
	height: 6px;
	margin-top: -6px;
	content: '';
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	pointer-events: none;
	border: 0;
	border-right: solid 2px #23B5D3;
	border-bottom: solid 2px #23B5D3;
}
select {
	font-size: inherit;
	width: 100%;
	height: 32px;
	padding: 2px 12px;
	vertical-align: middle;
	text-indent: .01px;
	text-overflow: '';
	color: inherit;
	border: 2px solid #008a9c;
	border-radius: 4px;
	outline: 0;
	background: none #fff;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
select option {
	background-color: #fff;
}
select::-ms-expand {
	display: none;
}
select:-moz-focusring {
	color: transparent;
}
.radioWrap li {
	display: inline-block;
	margin-bottom: 16px;
}
.radio-input {
	display: none;
}
.radio-input+label {
	position: relative;
	display: inline-block;
	padding-left: 24px;
}
.radio-input+label::before, .radio-input:checked+label::after {
	position: absolute;
	display: block;
	content: '';
	border-radius: 50%;
}
.radio-input+label::before {
	top: 2px;
	left: 0;
	width: 16px;
	height: 16px;
	border: 2px solid #008a9c;
}
.radio-input:checked+label {
	color: #008a9c;
}
.radio-input:checked+label::after {
	top: 6px;
	left: 4px;
	width: 12px;
	height: 12px;
	background: #008a9c;
}
.disabled {
	opacity: .5;
}
.btn {
	font-size: 140%;
	font-weight: 700;
	position: relative;
	z-index: 99;
	display: block;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%;
	max-width: 400px;
	margin: 0 auto;
	padding: 10px;
	-webkit-transition: .3s all;
	transition: .3s all;
	text-align: center;
	color: #fff;
	border: 3px solid #fff;
	border-radius: 40px;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0, #E4444A), to(#9D1F24));
	background: -webkit-linear-gradient(#E4444A 0, #9D1F24 100%);
	background: linear-gradient(#E4444A 0, #9D1F24 100%);
	-webkit-box-shadow: 0 4px 4px rgba(66, 33, 11, .2);
	box-shadow: 0 4px 4px rgba(66, 33, 11, .2);
	text-shadow: 0 -1px 0 rgba(0, 0, 0, .2);
}
.btn:after {
	position: absolute;
	top: 50%;
	margin-top: -10px;
	content: '';
	border: solid 10px transparent;
}
.btn.next:after {
	right: 10px;
	border-left: solid 10px currentColor;
}
.btn:hover {
	cursor: pointer;
}
button.btn.back {
	color: #333;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0, #ddd), to(#ccc));
	background: -webkit-linear-gradient(#ddd 0, #ccc 100%);
	background: linear-gradient(#ddd 0, #ccc 100%);
}
button.btn.back:after {
	left: 10px;
	border-right: solid 10px #333;
}
.btnNext {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.btnNext li {
	width: 100%;
}
.disc li {
	position: relative;
	padding-left: 1.2em;
}
.disc li:before {
	position: absolute;
	top: 0;
	left: 0;
	content: '●';
	color: #23B5D3;
}
.disc li+li {
	margin-top: 1em;
}
.indent {
	margin-left: 1em;
	text-indent: -1em;
}
.attention {
	color: #008a9c;
	background-color: #ffe33f;
}
header {
	position: relative;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%;
	margin: 0 auto;
	padding: 20px;
}
header h1 {
	position: relative;
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
}
header h1 img {
	display: block;
	width: 160px;
	height: auto;
	margin-left: auto;
}
header .headerInner {
	position: relative;
	max-width: 960px;
	margin: 0 auto;
}
header .kikan {
	max-width: 840px;
	margin: 20px auto;
}
header .item {
	max-width: 840px;
	margin: 0 auto 20px;
}
main {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%;
	padding: 0 20px;
}
main section {
	position: relative;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%;
	padding: 40px 0;
}
main .kikan {
	max-width: 840px;
	margin: 20px auto;
}
main .present {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 840px;
	margin: 20px auto;
}
main .present li+li {
	margin-top: 20px;
}
main .ttlWrap {
	max-width: 840px;
	margin: 0 auto 20px;
}
main .ttl {
	font-size: 160%;
	font-weight: 700;
	position: relative;
	display: block;
	width: 240px;
	margin: 0 auto;
	padding: 10px 20px;
	text-align: center;
	color: #fff;
	background: #23B5D3;
}

header .mainttl {
	font-size: 160%;
	font-weight: 700;
	position: relative;
	display: block;
	width: 83%;
	margin: 0 auto;
	padding: 10px 20px;
	text-align: center;
	color: #fff;
	background: #008a9c;
}
header .mainttl span{
	display: inline-block;
}
header .mainttl:before {
	position: absolute;
	top: 0;
	left: -20px;
	width: 20px;
	height: 100%;
	content: '';
	background: -webkit-gradient(linear, right top, left bottom, color-stop(50%, #008a9c), color-stop(50%, transparent)) top left/100% 50% no-repeat, -webkit-gradient(linear, right bottom, left top, color-stop(50%, #008a9c), color-stop(50%, transparent)) bottom left/100% 50% no-repeat;
	background: -webkit-linear-gradient(top right, #008a9c 50%, transparent 50%) top left/100% 50% no-repeat, -webkit-linear-gradient(bottom right, #008a9c 50%, transparent 50%) bottom left/100% 50% no-repeat;
	background: linear-gradient(to bottom left, #008a9c 50%, transparent 50%) top left/100% 50% no-repeat, linear-gradient(to top left, #008a9c 50%, transparent 50%) bottom left/100% 50% no-repeat;
}
header .mainttl:after {
	position: absolute;
	top: 0;
	right: -20px;
	width: 20px;
	height: 100%;
	content: '';
	background: -webkit-gradient(linear, left top, right bottom, color-stop(50%, #008a9c), color-stop(50%, transparent)) top left/100% 50% no-repeat, -webkit-gradient(linear, left bottom, right top, color-stop(50%, #008a9c), color-stop(50%, transparent)) bottom left/100% 50% no-repeat;
	background: -webkit-linear-gradient(top left, #008a9c 50%, transparent 50%) top left/100% 50% no-repeat, -webkit-linear-gradient(bottom left, #008a9c 50%, transparent 50%) bottom left/100% 50% no-repeat;
	background: linear-gradient(to bottom right, #008a9c 50%, transparent 50%) top left/100% 50% no-repeat, linear-gradient(to top right, #008a9c 50%, transparent 50%) bottom left/100% 50% no-repeat;
}
main .wrap {
	position: relative;
	z-index: 2;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	max-width: 860px;
	margin: 0 auto;
	padding: 20px;
	border-radius: 8px;
	background-color: #fff;
	-webkit-box-shadow: 0 0 4px rgba(66, 33, 11, .1);
	box-shadow: 0 0 4px rgba(66, 33, 11, .1);
}
main .detail h3 {
	font-size: 120%;
	font-weight: 700;
	padding: 2px 6px;
	color: #42210b;
	border-left: 8px solid #23B5D3;
}
main .detail p, main .detail ul {
	padding: 10px;
}
main .detail p+h3 {
	margin-top: 10px;
}
main .detail div{
	display: flex;
}
main .detail div img{
	width: 6%;
	height: auto;
	object-fit: contain;
	object-position: top;
}
main .wrap h3{
	font-weight: 700;
}
main .wrap a{
	color: #EA526F;
	border-bottom: 1px solid #EA526F;
}
form table {
	width: 100%;
	margin: 20px 0;
	border-top: 1px solid #008a9c;
}
form table tr {
	border-bottom: 1px solid #008a9c;
}
form table td, form table th {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	display: block;
	padding: 18px 16px;
}
form table th {
	font-weight: 700;
	position: relative;
	vertical-align: text-top;
}
form dl {
	overflow-y: auto;
	height: 200px;
	border: 1px solid #23B5D3;
}
form dl dt {
	font-weight: 700;
	padding: 5px;
	border-bottom: 1px solid #23B5D3;
	background-color: rgba(35, 181, 211, .2);
}
form dl dd+dt {
	border-top: 1px solid #23B5D3;
}
form dl dd {
	font-size: 90%;
	padding: 10px 10px 20px;
}
form dl::-webkit-scrollbar {
	width: 8px;
	background: rgba(35, 181, 211, .1);
}
form dl::-webkit-scrollbar-thumb {
	border-radius: 4px;
	background: #23B5D3;
}
form .upload {
	font-weight: 700;
	position: relative;
	display: inline-block;
	padding: 10px;
	color: #fff;
	border: 0;
	background-color: #23B5D3;
}
form .upload>input {
	display: none;
}
form .agreement {
	display: block;
	margin-top: 10px;
}
form .example, form .required {
	display: inline-block;
}
form .required {
	font-size: 85%;
	margin-left: 5px;
	padding: 2px 4px;
	color: #ffe33f;
	background-color: #e60012;
}
form .example, form .multi {
	display: inline-block;
}
form .multi {
	font-size: 85%;
	margin-left: 5px;
	padding: 2px 4px;
	color: #ffffff;
	background-color: #e69600;
}
form .example {
	font-size: 80%;
	margin-top: 5px;
}
form .error {
	display: block;
	margin-top: 5px;
	color: #008a9c;
}
.thanks {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%;
	padding: 20px;
}
.thanks dl {
	margin-top: 20px;
	border: 2px solid #23B5D3;
	background-color: #fff;
}
.thanks dl dt {
	font-weight: 700;
	padding: 5px 10px;
	color: #fff;
	background-color: #23B5D3;
}
.thanks dl dd {
	font-size: 90%;
	padding: 10px;
}
.confirm {
	padding: 20px 20px 0 20px;
}
#pagetop {
	position: fixed;
	right: 10px;
	bottom: 10px;
	cursor: pointer;
}
#pagetop:hover {
	opacity: .7;
}
footer {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%;
	max-width: 740px;
	margin: 0 auto;
	padding: 20px 10px;
}
form table th .bd{
	border-left: 8px solid #23B5D3;
	padding: 4px 6px;
}
.movie{
	position:relative;
	width:100%;
	height:0;
	padding-top:60%;
	margin-top: 10px;
}
.movie iframe{
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
}
@media screen and (min-width:768px) {
	form table th {
		display: block;
;	}
	/*form table th:after {
		position: absolute;
		top: 5%;
		right: 0;
		display: block;
		width: 1px;
		height: 90%;
		content: '';
		content: '';
		border-left: 1px solid #008a9c
;	}*/
}
@media print, screen and (min-width:768px) {
	.btn {
		font-size: 180%
;	}
	.btnNext {
		-webkit-box-pack: justify;
		-webkit-justify-content: space-between;
		-ms-flex-pack: justify;
		justify-content: space-between
;	}
	.btnNext li {
		width: calc(50% - 10px)
;	}
}
@media screen and (min-width:769px) {
	.btn:hover {
		-webkit-transform: translateY(2px);
		transform: translateY(2px);
		color: #fff;
		background-color: #e72420
;	}
	button.btn.back:hover {
		color: #333
;	}
}
@media screen and (max-width:767px) {
	header .mainttl {
	font-size: 1.7rem;
	}
	.larger {
		font-size: 110%
;	}
	main section {
		padding: 20px 0
;	}
	form table td, form table th {
		display: block;
		width: 100%;
		padding: 10px
;	}
	
	form table.confirm td {
		padding-top: 0
;	}
	form dl dd {
		font-size: 85%
;	}
}
@media screen and (max-width:767.98px) {
	.btnNext li+li {
		margin-bottom: 20px;
		-webkit-box-ordinal-group: 0;
		-webkit-order: -1;
		-ms-flex-order: -1;
		order: -1
;	}
	header h1 img {
		width: 100px
;	}
}
@media screen and (max-width:639px) {
	.container {
		font-size: 140%
;	}
	.radioWrap li {
		display: block
;	}
}
.select-wrap.single {
	width: 180px;
}