section {
	border-top: 3px dotted #F2BA1D;
	margin: 3em auto 0;
}
section:nth-of-type(1) {
	margin-top: 1.5em;
}

section h3 {
	margin: 1.5em 0 0;
	color: #8A5500;

}
section h3 + p {
	margin: 1em 0 0;
	line-height: 1.4;
}

section > div:nth-of-type(n+2) {
	border-top: 1px solid #F2BA1D;
	margin-top: 2em;
}

section h4 {
	margin: 1.5em 0 0;

}

section .body > div {
	position: relative;
	padding: 1em;
	padding-top: 2.5em;
	background: #FFEFD1;
}

section .body h5 {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	margin: 0;
	transform: translateY(-50%);
}

section .body figure {
	margin: 1em auto 0;
	text-align: center;
}

@media all and (max-width: 640px) {
	section {
		width: 23em;
	}
	section h3 {
		font-size: 1.4em;
	}
	section:nth-of-type(2) h3 + p {
		text-align: left;
	}
	section:nth-of-type(2) h3 + p br {
		display: none;
	}
	section h4 {
		font-size: 1.2em;
	}
	section .body > div {
		margin-top: 4em;
	}
	section .body h5 img {
		transform: scale(1.2);
	}
}

@media all and (min-width: 641px) {
	section {
		width: 46em;
	}
	section h3 {
		font-size: 1.2em;
	}
	section h3 + p {
		font-size: 0.8em;
	}
	section:nth-of-type(1) h3 + p br {
		display: none;
	}
	section h4 {
		font-size: 1em;
	}
	section .body > div {
		display: inline-block;
		vertical-align: top;
		box-sizing: border-box;
		width: 49%;
		margin-top: 3em;
	}
	section .body > div:nth-of-type(n+2) {
		margin-left: 2%;
	}
}

/* ==================== 材料 ==================== */

.materials dl {
	position: relative;
	margin: 0;
}

.materials figure + dl {
	margin-top: 1em;
}

.materials dl {
	border-top: 1px solid #E6BB6E;
	margin: 1em 0 0;
}

.materials dt,
.materials dd {
	padding: 0.5em;
	line-height: 1.4;
}
.materials dt {
	position: absolute;
	left: 0;
	text-align: left;
}
.materials dd {
	border-bottom: 1px solid #E6BB6E;
	margin: 0;
	text-align: right;
}

.body4 .materials dd:nth-of-type(1)::before {
	content: '';
	display: block;
	height: 1.4em;
}

@media all and (max-width: 640px) {
	.materials dl {
		font-size: 0.9em;
	}
}

@media all and (min-width: 641px) {
	.materials dl {
		font-size: 0.7em;
	}
}

/* ==================== 作り方 ==================== */

.steps ol,
.steps ul {
	border-top: 1px solid #E6BB6E;
	margin: 1em 0 0;
	padding: 0;
	list-style-type: none;
}
.steps li {
	border-bottom: 1px solid #E6BB6E;
	padding: 1em 0;
	text-align: left;
}

.steps ol li {
	position: relative;
	padding-left: 2em;
}
.steps ol li::before {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	width: 1.5em;
	height: 1.5em;
	background: no-repeat center center;
	background-size: contain;
}
.steps ol li:nth-of-type(1)::before {
	background-image: url(../images/soup_step_num_1.svg);
}
.steps ol li:nth-of-type(2)::before {
	background-image: url(../images/soup_step_num_2.svg);
}
.steps ol li:nth-of-type(3)::before {
	background-image: url(../images/soup_step_num_3.svg);
}
.steps ol li:nth-of-type(4)::before {
	background-image: url(../images/soup_step_num_4.svg);
}
.steps ol li:nth-of-type(5)::before {
	background-image: url(../images/soup_step_num_5.svg);
}
.steps ol li:nth-of-type(6)::before {
	background-image: url(../images/soup_step_num_6.svg);
}
.steps ol li:nth-of-type(7)::before {
	background-image: url(../images/soup_step_num_7.svg);
}
.steps ol li:nth-of-type(8)::before {
	background-image: url(../images/soup_step_num_8.svg);
}
.steps ol li:nth-of-type(9)::before {
	background-image: url(../images/soup_step_num_9.svg);
}

.steps li h6 {
	margin: 0 0 0.5em;
	color: #8A5500;
	font-size: 115%;

	text-align: center;
}

.steps .note {
	margin-top: 1em;
	color: #8A5500;
	text-align: left;
}

@media all and (max-width: 640px) {
	.steps li,
	.steps .note {
		font-size: 0.9em;
	}
}

@media all and (min-width: 641px) {
	.steps li,
	.steps .note {
		font-size: 0.7em;
	}
}

/* ==================== 保存 ==================== */

.stock {
	border: 4px solid #FFCFCF;
	border-radius: 1em;
	margin: 3em auto 0;
}

.stock .text h5 {
	margin: 0;
	color: #FF5454;

}
.stock .text p {
	margin: 1em 0 0;
	text-align: left;
}
.stock .text p strong {
	display: block;
	margin-top: 1em;
	background: #FFF100;

	line-height: 2;
	text-align: center;
}
.stock .image figure {
	margin: 0;
}

@media all and (max-width: 640px) {
	.stock {
		padding: 1em;
	}
	.stock .text h5 {
		font-size: 1.2em;
	}
	.stock .text p strong {
		font-size: 105%;
	}
	.stock .image {
		margin-top: 1em;
	}
}

@media all and (min-width: 641px) {
	.stock {
		display: table;
		width: 30.5em;
		border-spacing: 1em;
	}
	.stock > div {
		display: table-cell;
		vertical-align: top;
	}
	.stock .text h5 {
		font-size: 0.95em;
	}
	.stock .text p {
		font-size: 0.7em;
	}
	.stock .text p strong {
		font-size: 120%;
	}
	.stock .image img {
		max-width: none;
	}
}