@charset "UTF-8";

/* CSS Document */
html {
	scroll-behavior: smooth;
}

body {
	margin: 0 !important;
	padding: 0 !important;
	font-family: "Montserrat", "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	font-feature-settings: "palt";
	background: rgb(255, 146, 194);
	font-feature-settings: "palt";
	box-sizing: border-box;
}

a:visited {
	color: #000;
}

a img {
	border: 0;
}

hr {
	display: none;
}

form {
	margin: 0;
	padding: 0;
}

.clearfix {
	zoom: 1;
}

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

.wrapper {
	width: 100%;
	margin: 0;
	padding: 0;
	overflow: hidden;
}

header.pc {
	display: block;
}

.pctab {
	display: block
}

.pc {
	display: block
}

.tab {
	display: none;
}

.sp {
	display: none;
}

input,
button,
select,
textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background: transparent;
	border: none;
	border-radius: 0;
	font: inherit;
	outline: none;
}

textarea {
	resize: vertical;
}

input[type='checkbox'],
input[type='radio'] {
	display: none;
}

input[type='submit'],
input[type='button'],
label,
button,
select {
	cursor: pointer;
}

input {
	width: 100%;
}

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

::placeholder {
	color: #ccc;
}

h3 {
	background-color: rgb(255, 146, 194);
	padding: 5px;
	text-align: center;
	color: #fff;
	border-radius: 5px;
	margin-bottom: 5px;
}

.row {
	display: flex;
}

.entry {
	height: auto;
	padding: 0 0 30px;
}

.required {
	font-size: 12px;
	color: red;
	vertical-align: text-top;
	margin-left: 2px;
}

.selectbox-003 {
	display: inline-flex;
	align-items: center;
	position: relative;
}

.selectbox-003::after {
	position: absolute;
	right: 15px;
	width: 10px;
	height: 7px;
	background-color: #535353;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
	content: '';
	pointer-events: none;
}

.selectbox-003 select {
	appearance: none;
	min-width: 297px;
	height: 2.4em;
	padding: .4em calc(.8em + 30px) .4em .8em;
	border: 1px solid #cccccc;
	border-radius: 5px;
	background-color: #fff;
	color: #333333;
	font-size: 1em;
	cursor: pointer;
}

.element_wrap .cup_width select {
	min-width: 117px;
}

.entry h2 {
	max-width: 1000px;
	width: 100%;
	height: 300px;
	margin: 0 auto;
	padding: 0;
	background: url(../images/entry_title.png) no-repeat center center;
	display: block;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
}

.entry_flame,
.promise {
	background-color: #fff;
	width: 100%;
	max-width: 580px;
	padding: 30px;
	border-radius: 20px;
	margin: 0 auto 0;

}

.promise {
	text-align: center;
	margin: -50px auto 70px;
}

.promise a {
	font-weight: bold;
	color: rgb(255, 146, 194);
	text-decoration: none;
	font-size: 25px;
}

.promise a img {
	max-width: 40px;
	vertical-align: bottom;
}

.promise a span {
	font-size: 28px;
}

.entry label {
	display: block;
}

.entry label {
	color: rgb(255, 146, 194);
	font-weight: bold;
}

.entry .element_wrap {
	padding: 10px 0;
	width: 100%;
	max-width: 610px;
}

.c-form-text,
.calender {
	height: 2.4em;
	padding: 0 10px 0 16px;
	border-radius: 4px;
	border: none;
	box-shadow: 0 0 0 1px #ccc inset;
	appearance: none;
	width: 97%;
	box-sizing: border-box;
	-webkit-appearance: none;
	-moz-appearance: none;
}

.c-form-text:focus {
	outline: 0;
	box-shadow: 0 0 0 2px rgb(33, 150, 243) inset;
}

.names .element_wrap {
	flex-basis: 50%;
	width: 100%;
}

.names .element_wrap .c-form-text {
	width: 270px;
}

.styles .element_wrap {
	flex-basis: 33%;
	width: 100%;
}

.styles .element_wrap .c-form-text {
	width: 170px;
}

.entry_flame .element_wrap p img {
	max-width: 580px;
	height: auto;
}

.entry input[type=radio] {
	display: none;
}

.entry input[type=radio]:checked+.label {
	background: rgb(255, 146, 194);
	color: #fff;
}

.entry .label {
	display: inline-block;
	margin: 5px 0;
	width: 260px;
	height: 45px;
	padding-left: 5px;
	padding-right: 5px;
	color: #333;
	text-align: center;
	line-height: 45px;
	cursor: pointer;
	border-radius: 5px;
	background-color: rgb(255, 236, 245);
	font-weight: normal;
}

.entry .label:hover {
	background-color: rgb(254, 207, 229);
}


.textbox-003 {
	width: 97%;
	padding: 8px 10px;
	border: none;
	border-radius: 5px;
	color: #333;
	font-size: 1em;
	line-height: 1.5;
	box-shadow: 0 0 0 1px #ccc inset;
}

.textbox-003::placeholder {
	color: #999;
}

.idcard_desc {
	font-size: 14px;
}

.idcard_desc ol {
	margin: 0;
	padding-left: 20px;
}

.fileup input {
	display: block;
	padding: 5px 0;
}

.fileup p {
	margin-top: 0;
	margin-bottom: 0;
	font-size: 14px;
	font-weight: normal;
	color: #333;
}

.check_page {
	border: 1px solid #ccc;
	padding: 3px;
	border-radius: 5px;
	width: 90%;
	margin-top: 0;
}

.e_button {
	display: block;
	border-radius: 5px;
	font-size: 16pt;
	text-align: center;
	cursor: pointer;
	padding: 18px 64px;
	background: rgb(255, 146, 194);
	color: #ffffff;
	line-height: 1em;
	transition: .3s;
	border: 2px solid rgb(255, 146, 194);
	margin: 30px auto 0;
}

.e_button:hover {
	color: rgb(255, 146, 194);
	background: #ffffff;
}

.back_btn {
	display: inline-block;
	border-radius: 5px;
	font-size: 16pt;
	text-align: center;
	cursor: pointer;
	padding: 18px 60px;
	background: #777;
	color: #ffffff;
	line-height: 1em;
	transition: .3s;
	border: 2px solid #777;
	margin: 30px auto 0;
}

.back_btn:hover {
	color: #777;
	background: #ffffff;
}

.send_btn {
	display: inline-block;
	border-radius: 5px;
	font-size: 16pt;
	text-align: center;
	cursor: pointer;
	padding: 18px 60px;
	background: rgb(255, 146, 194);
	color: #ffffff;
	line-height: 1em;
	transition: .3s;
	border: 2px solid rgb(255, 146, 194);
	margin: 30px auto 0;
}

.send_btn:hover {
	color: rgb(255, 146, 194);
	background: #ffffff;
}

.fileup {
	margin-bottom: 20px;
}

.fileup div {
	background-color: #eee;
	padding: 10px;
}

.fileup div ol {
	margin-top: 0;
	margin-bottom: 0;
	padding-left: 20px;
}

.fileup div ol li {
	color: #333;
}

.policy_agree {
	background-color: rgb(255, 236, 245);
	padding: 10px;
	border-radius: 5px;
	text-align: center;
}

.policy_agree p {
	margin: 5px 0;
}

.agree_btn {
	padding-left: 40px;
	position: relative;
	cursor: pointer;
	width: 220px;
	margin: 0 auto;
}

.agree_btn::before,
.agree_btn::after {
	content: "";
	display: block;
	border-radius: 50%;
	position: absolute;
	transform: translateY(-50%);
	top: 50%;
}

.agree_btn::before {
	background-color: #fff;
	border: 1px solid #ddd;
	border-radius: 50%;
	width: 20px;
	height: 20px;
	left: 5px;
}

.agree_btn::after {
	background-color: rgb(255, 146, 194);
	border-radius: 50%;
	opacity: 0;
	width: 16px;
	height: 16px;
	left: 8px
}

.agree_checked:checked+.agree_btn::after {
	opacity: 1;
}

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

.submit_end_desc a {
	text-align: center;
	color: rgb(255, 146, 194);
	font-size: 24px;
	display: block;
}

@media screen and (max-width:599px) {
	.sp {
		display: block;
	}

	.entry {
		background-color: rgb(255, 146, 194);
		height: auto;
		padding: 0 0 30px;
	}

	.entry h2 {
		width: 100%;
		height: 200px;
		margin: 0 auto;
		padding: 0;
		background: url(../images/entry_title.png) no-repeat center center;
		background-size: contain;
		display: block;
		text-indent: 100%;
		white-space: nowrap;
		overflow: hidden;
	}

	.entry_flame,
	.promise {
		background-color: #fff;
		width: 100%;
		max-width: 300px;
		padding: 30px;
		border-radius: 20px;
		margin: 0 auto;
	}

	.promise {
		text-align: center;
		margin: -50px auto 40px;
	}

	.promise a {
		font-weight: bold;
		color: rgb(255, 146, 194);
		text-decoration: none;
	}

	.promise a span {
		font-size: 28px;
	}

	.entry .element_wrap {
		padding: 10px 0;
		width: 100%;
		max-width: 290px;
	}

	.c-form-text,
	.calender {
		height: 2.4em;
		padding: 0 0 0 16px;
		border-radius: 4px;
		border: none;
		box-shadow: 0 0 0 1px #ccc inset;
		appearance: none;
		width: 97%;
		-webkit-appearance: none;
		-moz-appearance: none;
	}

	.c-form-text:focus {
		outline: 0;
		box-shadow: 0 0 0 2px rgb(33, 150, 243) inset;
	}

	.calender {
		padding: 0 8px 0 8px;
	}

	.names .element_wrap {
		flex-basis: 50%;
		width: 100%;
	}

	.names .element_wrap .c-form-text {
		width: 130px;
	}

	.styles .element_wrap {
		flex-basis: 34%;
		width: 100%;
	}

	.styles .element_wrap .c-form-text {
		width: 72px;
	}

	.entry .label {
		width: 132px;
	}

	.entry .idcard_css {
		width: 280px;
	}

	.textbox-003::placeholder {
		color: #999;
	}

	.idcard_desc {
		font-size: 14px;
	}

	.idcard_desc ol {
		margin: 0;
		padding-left: 20px;
	}

	.fileup input {
		display: block;
		padding: 5px 0;
	}

	.fileup p {
		margin-top: 0;
		margin-bottom: 0;
		font-size: 14px;
		font-weight: normal;
		color: #333;
	}

	.check_page {
		border: 1px solid #ccc;
		padding: 3px;
		border-radius: 5px;
		width: 90%;
		margin-top: 0;
	}

	.e_button {
		display: inline-block;
		border-radius: 5px;
		font-size: 16pt;
		text-align: center;
		cursor: pointer;
		padding: 20px 50px;
		margin-top: 30px;
		background: rgb(255, 146, 194);
		color: #ffffff;
		line-height: 1em;
		transition: .3s;
		border: 2px solid rgb(255, 146, 194);
	}

	.e_button:hover {
		color: rgb(255, 146, 194);
		/* 背景色     */
		background: #ffffff;
		/* 文字色     */
	}

	.back_btn {
		display: inline-block;
		border-radius: 5px;
		font-size: 16pt;
		text-align: center;
		cursor: pointer;
		padding: 18px 40px;
		background: #777;
		color: #ffffff;
		line-height: 1em;
		transition: .3s;
		border: 2px solid #777;
		margin: 30px auto 0;
	}

	.back_btn:hover {
		color: #777;
		/* 背景色     */
		background: #ffffff;
		/* 文字色     */
	}

	.send_btn {
		display: inline-block;
		border-radius: 5px;
		font-size: 16pt;
		text-align: center;
		cursor: pointer;
		padding: 18px 40px;
		background: rgb(255, 146, 194);
		color: #ffffff;
		line-height: 1em;
		transition: .3s;
		border: 2px solid rgb(255, 146, 194);
		margin: 30px auto 0;
	}

	.send_btn:hover {
		color: rgb(255, 146, 194);
		/* 背景色     */
		background: #ffffff;
		/* 文字色     */
	}

	.fileup div ol li {
		font-size: 14px;
	}

	.policy_agree p {
		font-size: 14px;
	}
}