.hgroup {
	margin-bottom: 2em;
}
.hgroup h1 {
	font-size: 2em;
}
.begin-text {
	line-height: 1.8em;
}
.guide {
	line-height: 1.8em;
}
[data-appear=""] {
	display: none;
}
[data-appear="true"] {
	display: block;
}

/**/
.recp-parent .steps .step-parent {
	display: none;
}
.recp-parent .steps .step-parent[data-iscurrent="true"] {
	display: block;
}
.step-parent > .hgroup .step-title {
	margin-bottom: 0.6em;
}

/**/
.field-group {
	padding-top: 2em;
	border-top: solid 1px #ddd;
	margin-bottom: 2em;
}
.field-group:nth-child(1){
	border-top: none;
}
.field-group > .hgroup {
	margin-bottom: 1.8em;
}
.field-group > .hgroup .group-title {
	font-size: 1.26em;
	font-weight: 500;
	margin-bottom: 0em;
}
.field-group > .hgroup .begin-text {
	font-size: 1.0em;
	margin-top: 0.3em;
	opacity: 0.7;
}
.field-group > .guide {
	text-align: left;
	margin-top: 2rem;
}

/**/
.fieldcell {
	margin-bottom: 1.0em;
}
.fieldcell dt {
	font-weight: 500;
	line-height: 1.6em;
	margin-bottom: 0.5em;
}
	.fieldcell dt label.input-assist {
		font-weight: inherit;
		font-size: inherit;
		line-height: inherit;
		display: inline-block;
		color: inherit;
		cursor: pointer;
	}
	.fieldcell dt label.input-assist.multiple-target {
		cursor: default;
	}
.fieldcell dd {
	line-height: 1.6em;
	margin-bottom: 1.2em;
}
	.fieldcell fieldset {
		display: block;
	}
	.fieldcell fieldset .unit {
		margin-left: 0.4em;
		font-size: 0.9em;
		opacity: 0.6;
		vertical-align: baseline;
	}
@media only screen and (min-width:640px) {
	
}

/*checkbox*/
.fieldcell[data-type="checkbox"] fieldset {
	background-color: var(--recp-inp-bgcolor);
	color: var(--recp-inp-color);
	font-weight: normal;
	padding: var(--recp-inp-padding);
	border: solid var(--recp-inp-borderwidth) var(--recp-inp-bordercolor);
	box-shadow: var(--recp-inp-boxshadow);
	border-radius: var(--recp-inp-borderradius);
	text-indent: 0em;
	padding: 0.6em 0.8em;
}
.fieldcell[data-type="checkbox"] fieldset label {
	display: inline-block;
	margin: 0.5em 0;
	margin-right: 1.0em;
	font-weight: 500;
}

/*radio*/
.fieldcell[data-type="radio"] fieldset label {
	display: inline-block;
	margin: 0.5em 0;
	margin-right: 1.0em;
	font-weight: 500;
	font-size: 1.05em;
}

/*share override*/
.fieldcell.block-label fieldset label {
	display: block;
}

/*fieldset guide*/
.fieldcell dt > .guide {
	font-size: 0.9em;
	margin-top: 1rem;
	opacity: 0.6;
}
.fieldcell dd .guide-wrap {
	margin-top: 0.9rem;
	margin-bottom: 1.5em;
	padding: 0.0em 0;
	padding-left: 0.8em;
	border-left: solid 0.4em #eee;
}
	.fieldcell dd .guide {
		font-size: 0.9em;
		line-height: 1.6em;
		opacity: 0.9;
	}
	.fieldcell dd .guide > * {
		margin-top: 0.8em;
	}
	.fieldcell dd .guide > *:first-child {
		margin-top: 0;
	}
		.fieldcell dd .guide details > summary {
			font-weight: 500;
		}
		.fieldcell dd .guide details[open] > summary {
			margin-bottom: 0.8em;
		}
	
	.fieldcell dd ul.list {
		margin-top: 0.6rem;
		opacity: 0.9;
		padding-left: 1.45em;
	}
		.fieldcell dd ul.list li {
			font-size: 1.0em;
			line-height: 1.7em;
			margin-bottom: 0.6em;
		}
		.fieldcell dd ul.list > h4 {
			font-size: 1.0em;
			margin-bottom: 0.6em;
			margin-left: -1.45em;
		}
	.fieldcell dd ul.notice {
		margin-top: 0.6rem;
		opacity: 0.7;
	}
		.fieldcell dd ul.notice li {
			font-size: 0.90em;
			line-height: 1.7em;
		}

/*require signs*/
dl > dt label.input-assist::after {
	display: inline-block;
	vertical-align: 0.1em;
	margin-left: 0.6em;
	color: var(--recp-require-color);
	background-color: var(--recp-require-bgcolor);
	font-weight: 500;
	border: solid 1px var(--recp-require-bgcolor);
	font-size: 0.64em;
	line-height: 1.0em;
	padding: 0.4em 0.44em;
	border-radius: 0.2em;
}
dl[data-require=""] dt label.input-assist::after {
	content: "任意";
	color: #636363;
	background-color: #f1f1f1;
	border-color: #ddd;
}
dl[data-require="1"] dt label.input-assist::after {
	content: "必須";
	color: var(--recp-require-color);
	background-color: var(--recp-require-bgcolor);
	border: solid 1px var(--recp-require-bgcolor);
}
dl[data-require="1"] .alert {
	padding-top: 0.5em;
	color: #e10000;
	font-weight: 500;
	display: block;
}

/*error display*/
.fieldcell .error-display {
	display: none;
	color: var(--recp-require-alert-bgcolor);
	background-image: url(/share/im/mrk_alert-red.svg);
	padding-left: 1.3em;
	background-position: left top 0.34em;
	background-size: auto 0.94em;
	line-height: 1.5em;
	font-weight: 500;
	margin-top: 0.5em;
	margin-bottom: 1.4em;
}
dl[data-error="true"] .error-display {
	display: block;
}
dl[data-error="true"] input[type="text"],
dl[data-error="true"] input[type="date"],
dl[data-error="true"] input[type="datetime-local"],
dl[data-error="true"] input[type="email"],
dl[data-error="true"] input[type="month"],
dl[data-error="true"] input[type="number"],
dl[data-error="true"] input[type="password"],
dl[data-error="true"] input[type="search"],
dl[data-error="true"] input[type="time"],
dl[data-error="true"] input[type="datetime"],
dl[data-error="true"] input[type="tel"],
dl[data-error="true"] input[type="url"],
dl[data-error="true"] input[type="week"],
dl[data-error="true"] input[type="file"],
dl[data-error="true"] textarea {
	background-color: #ffd5d1;
	border-color: var(--recp-inp-alert-bordercolor);
	color: #271a00;
	border-width: var(--recp-inp-borderwidth);
}
dl[data-error="true"] ::placeholder {
	color: rgba(225, 0, 0, 0.33);
}
dl[data-error="true"] dt label.input-assist::after {
	color: var(--recp-require-alert-color);
	background-color: var(--recp-require-alert-bgcolor);
	border-color: var(--recp-require-alert-bgcolor);
}