/* ==================== plastic.css ==================== */

.plastic {
	border: 3px solid #ffcccc;
	border-radius: 1em;
	margin-top: 2em !important;
	padding: 1.5em;
}

.plastic h4 {
	margin: 0;
	color: #d40000;
	font-size: 110%;
}

.plastic p {
	margin: 1em 0 0;
}


@media (max-width: 640px) {
	.plastic p img {
		display: block;
		margin: 1em auto 0;
	}
}


@media (min-width: 641px) {

	.plastic p {
		display: flex;
		align-items: center;
		font-size: 80%;
	}
	.plastic p img {
		margin-right: 1em;
		order: -1;
	}
}


.IE .plastic p {
	width: 100%;
	justify-content: space-between;
}
.IE .plastic p img {
	flex-shrink: 0;
}



/* ==================== recycle-battlegame.css ==================== */

.recycle-battlegame {
	max-width: 36em;
	margin-top: 1em;
}

.recycle-battlegame figure {
	margin: 0;
}

.recycle-battlegame > p {
	margin: 1.5em 0;
}


@media (max-width: 640px) {
	.recycle-battlegame + div {
		width: 20em;
	}
}


@media (min-width: 641px) {
	.recycle-battlegame p {
		font-size: 80%;
	}
}

.IE .recycle-battlegame p {
	max-width: 100%;
}



/* ==================== recycle-paper.css ==================== */

.recycle-paper {
	max-width: 36em;
}

@media (max-width: 640px) {
	.recycle-paper {
		margin-top: 1em;
	}
}


@media (min-width: 641px) {
	.recycle-paper {
		box-sizing: border-box;
		margin-top: 1.5em;
	}

	.recycle-paper p {
		font-size: 80%;
	}

}

.IE .recycle-paper p {
	max-width: 100%;
}



/* ==================== recycle-q.css ==================== */

.recycle-q {
	position: relative;
	margin-top: 1.5em;
	padding: 1.5em;
}

.recycle-q::before {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	box-sizing: border-box;
	width: 100%;
	border: dashed #ffbfbf;
	border-radius: 1em;
}

.recycle-q > * {
	position: relative;
}


.recycle-q .q,
.recycle-q .a {
	display: flex;
}

.recycle-q .q {
	align-items: flex-end;
	border-bottom: 2px solid #ffc7c7;
	padding-bottom: 1em;
}

.recycle-q .a {
	margin-top: 1em;
	align-items: center;
}

.recycle-q h5 {
	display: flex;
	margin: 0;
}

.recycle-q h5 > span:first-child {
	width: 1.5em;
	flex-shrink: 0;
}

.recycle-q .q h5 {
	color: #d40000;
}

.recycle-q .a h5 {
	color: #005fb8;
}

.recycle-q .a p {
	margin: 0.5em 0 0;
}

.recycle-q .image {
	margin-left: auto;
	text-align: center;
}



@media (max-width: 640px) {
	.recycle-q {
		border-width: 2px;
	}
	.recycle-q::before {
		height: 100%;
	}
	.recycle-q h5 {
		font-size: 100%;
	}

	.recycle-q .image {
		padding-left: 1em;
	}

	.recycle-q .image img {
		max-width: none;
		font-size: 80%;
	}
}

@media (min-width: 641px) {
	.recycle-q {
		box-sizing: border-box;
		width: 34em;
		border-width: 3px;
		padding-top: 0;
	}
	.recycle-q::before {
		height: calc(100% - 1em);
	}
	.recycle-q h5 {
		font-size: 100%;
	}
	.recycle-q .q h5 > span span {
		display: block;
	}

	.recycle-q p {
		font-size: 80%;
	}

	.recycle-q .image {
		width: 10em;
	}
}



/* ==================== SDGs__about.css ==================== */

.SDGs .about {
	position: relative;
	margin-top: 2.5em;
}

.SDGs .about::before {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: calc(100% - 2em);
	background: #daf0fa;
	border-radius: 1em;
}

.SDGs .about > * {
	position: relative;
}

.SDGs .about h4 {
	margin: 0;
	font-size: inherit;
}

.SDGs .about h4::before {
	content: '';
	display: block;
	position: absolute;
	right: 100%;
	width: 4.8em;
	height: 4.2em;
	background: url(../images/craft/sdgs_title_chara.svg) no-repeat center center / contain;
}

.SDGs .about p {
	margin: 1em 0 0;
}

.SDGs .about .banner {
	text-align: center;
}
.SDGs .about .banner a {
	display: block;
	margin-top: 0.5em;
	transition: 150ms;
}
.SDGs .about .banner a:hover {
	opacity: 0.6;
}


@media (max-width: 640px) {
	.SDGs .about {
		padding: 0 1.5em 1.5em;
	}
	.SDGs .about h4 {
		transform: translateX(2em);
	}
	.SDGs .about h4::before {
		transform: scale(0.9);
	}

	.SDGs .about .banner img {
		font-size: 120%;
	}
}


@media (min-width: 641px) {
	.SDGs .about {
		padding: 0 2em 2em;
	}
	.SDGs .about h4::before {
		transform: translateX(-1em);
	}
	.SDGs .about p {
		font-size: 70%;
	}
}

.IE .SDGs .about > p {
	width: 100%;
}



/* ==================== SDGs.css ==================== */

.SDGs {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-top: 2em;
}

.SDGs > p {
	font-weight: bold;
}
.SDGs > p strong {
	color: #ff7b00;
}

.SDGs .comment {
	max-width: 26em;
	margin-top: 1.5em;
}

.SDGs .link {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-top: 1em;
}

.SDGs .link.goal-12 {
	color: #d39200;
}
.SDGs .link.goal-14 {
	color: #0076ba;
}
.SDGs .link.goal-15 {
	color: #29a838;
}

.SDGs .link > span {
	display: flex;
	align-items: center;
	justify-content: center;
}
.SDGs .link > span::before,
.SDGs .link > span::after {
	content: '';
	display: block;
	width: 1px;
	height: 1.25em;
	margin: 0 0.75em;
}

.SDGs .link > span::before {
	transform: rotate(-20deg);
}
.SDGs .link > span::after {
	transform: rotate(20deg);
}

.SDGs .link.goal-12 > span::before,
.SDGs .link.goal-12 > span::after {
	background: #d39200;
}
.SDGs .link.goal-14 > span::before,
.SDGs .link.goal-14 > span::after {
	background: #0076ba;
}
.SDGs .link.goal-15 > span::before,
.SDGs .link.goal-15 > span::after {
	background: #29a838;
}

.SDGs .link a {
	display: flex;
	align-items: center;
	border: 1px solid;
	border-radius: 0.25em;
	margin-top: 0.25em;
	padding: 0.5em;
	color: inherit;
	line-height: 1.3;
	text-decoration: none;
}
.SDGs .link.goal-12 a {
	border-color: #d39200;
}
.SDGs .link.goal-14 a {
	border-color: #0076ba;
}
.SDGs .link.goal-15 a {
	border-color: #29a838;
}


.SDGs .link a {
	transition: 150ms;
}
.SDGs .link a:hover {
	opacity: 0.6;
}

.SDGs .link a img {
	margin-right: 0.5em;
}

.SDGs .link a > span {
	display: flex;
	flex-direction: column;
}

.SDGs .link a > span span {
}
.SDGs .link a > span span:nth-of-type(-n+2) {
	font-weight: bold;
}
.SDGs .link a > span span:nth-of-type(3) {
	font-size: 72%;
}


@media (min-width: 641px) {
	.SDGs > p {
		font-size: 80%;
		text-align: center;
	}
	.SDGs > p span {
		display: block;
	}
	.SDGs .link > span {
		font-size: 80%;
	}

	.SDGs .link a > span {
		font-size: 90%;
	}
}



/* ==================== separate-items.css ==================== */

.separate-items {
	margin-top: 1.5em;
}

.separate-items > div {
	box-sizing: border-box;
	border: dashed #ffbfbf;
	margin-top: 2em;
	padding: 1.5em;
	border-radius: 1em;
}

.separate-items h4 {
	position: relative;
	margin: 0;
	color: #d40000;
}

.separate-items h4 img {
	position: absolute;
	right: 0;
	bottom: 0;
}

.separate-items h4 + p {
	margin-top: 1em;
}

.separate-items .detail {
	display: grid;
	grid-template-columns: auto auto;
	grid-gap: 0.25em 1em;
	align-items: flex-start;
	margin-top: 1em;
}
.IE .separate-items .detail {
	display: -ms-grid;
	-ms-grid-columns: auto 1em auto;
	-ms-grid-rows: auto 0.25em auto 0.25em auto;
}
.IE .separate-items figure {
	-ms-grid-column: 1;
	-ms-grid-row: 1;
	-ms-grid-row-span: 5;
}
.IE .separate-items h5 {
	-ms-grid-column: 3;
	-ms-grid-row: 1;
}
.IE .separate-items h6 {
	-ms-grid-column: 3;
	-ms-grid-row: 3;
}
.IE .separate-items p {
	-ms-grid-column: 3;
	-ms-grid-row: 5;
}

.separate-items .detail figure,
.separate-items .detail h5,
.separate-items .detail h6,
.separate-items .detail p {
	margin: 0;
}

.separate-items figure {
	grid-column: 1;
	grid-row: 1/4;
}

.separate-items .detail h5 {
	display: flex;
	align-items: center;
}

.separate-items .detail h5::before {
	content: '';
	display: block;
	width: 1em;
	height: 1em;
	border-radius: 50%;
	margin-right: 0.1em;
	transform: scale(0.8);
	background: #d40000;
}

.separate-items .detail h6 {
	color: #d40000;
}

.separate-items .detail figure img {
	width: 3.5em;
}

.separate-items + div {
	margin-top: 1em;
}


@media (max-width: 640px) {
	.separate-items > div {
		width: 100%;
		border-width: 2px;
	}

	.separate-items h4 {
		font-size: 100%;
	}
	.separate-items h5,
	.separate-items h6 {
		font-size: inherit;
	}
}


@media (min-width: 641px) {

	.separate-items > div {
		width: 34em;
		border-width: 3px;
	}

	.separate-items h4 {
		font-size: 100%;
	}

	.separate-items h4 + p {
		font-size: 80%;
	}

	.separate-items .detail h5 {
		font-size: 80%;
	}
	.separate-items .detail h6,
	.separate-items .detail p {
		font-size: 75%;
	}

	.separate-items + div {
		width: 25em;
	}
}



/* ==================== homework.craft/try/&.css ==================== */

.homework.craft .try {
	display: grid;
	grid-gap: 2em;
	justify-items: center;
}



/* ==================== homework.craft/try/flow-video.css ==================== */

.homework.craft .try .flow-video {
	text-align: center;
}

.homework.craft .try .flow-video h4 {
	margin: 0;
}

.homework.craft .try .flow-video > div {
	border: 3px solid #ffd23b;
	background: black;
}

.homework.craft .try .flow-video > div img {
	transition: 150ms;
	cursor: pointer;
}
.homework.craft .try .flow-video > div img:hover {
	opacity: 0.8;
}



/* ==================== homework.craft/try/prepare.css ==================== */

.homework.craft .try .prepare {
	position: relative;
}
.homework.craft .try .prepare::before {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	box-sizing: border-box;
	width: 100%;
	height: calc(100% - 1em);
	border: 0.1em solid #ffcccc;
	border-radius: 1.5em;
}

.homework.craft .try .prepare > * {
	position: relative;
}

.homework.craft .try .prepare h4 {
	margin: 0;
	text-align: center;
}

.homework.craft .try .prepare .materials {
	margin-top: 1em;
}

.homework.craft .try .prepare h5 {
	margin: 0;
	color: #d40000;
}
.homework.craft .try .prepare dl + h5 {
	margin-top: 1em;
}

.homework.craft .try .prepare dl {
	overflow: hidden;
	position: relative;
	margin: 0;
	padding: 0;
	line-height: 1.3;
}
.homework.craft .try .prepare h5 + dl {
	margin-top: 0.25em;
}

.homework.craft .try .prepare dl::before {
	content: '';
	display: block;
	position: absolute;
	z-index: 1;
	left: 0;
	top: 0;
	width: 2em;
	height: 100%;
	background: white;
}

.homework.craft .try .prepare dl::after {
	content: '';
	display: block;
	clear: both;
}

.homework.craft .try .prepare dt,
.homework.craft .try .prepare dd {
	margin-top: 0.4em;
}

.homework.craft .try .prepare dt {
	position: relative;
	z-index: 2;
	clear: both;
	float: left;
	padding-left: 1.25em;
	padding-right: 0.25em;
	background: white;
}

.homework.craft .try .prepare dt::before {
	content: '●';
	position: absolute;
	left: 0;
	transform: scale(0.5);
	color: #d40000;
}

.homework.craft .try .prepare dd {
	position: relative;
	z-index: 0;
	float: right;
	margin-left: 2em;
}
.homework.craft .try .prepare dd::before {
	content: '';
	position: absolute;
	right: 100%;
	width: 100vw;
	height: 100%;
	transform: translateX(-0.25em);
	background: linear-gradient(to right, gray 33%, white 33%) repeat-x right center / 6px 2px;
}

.homework.craft .try .prepare dd.note {
	clear: both;
	float: left;
	z-index: 2;
	margin-left: 1.25em;
	font-size: 80%;
}
.homework.craft .try .prepare dd.note::before {
	content: none;
}

.homework.craft .try .prepare figure {
	margin: 0;
}


@media (max-width: 640px) {
	.homework.craft .try .prepare {
		width: 100%;
		padding: 0 1.5em 1.5em;
	}

	.homework.craft .try .prepare .pic {
		text-align: center;
		margin-top: 1em;
	}
}

@media (min-width: 641px) {
	.homework.craft .try .prepare .materials {
		display: flex;
		align-items: flex-start;
		justify-content: space-between;
		width: 100%;
	}

	/* for meiji */
	.homework.craft .try .prepare .materials::after {
		content: none;
	}

	.homework.craft .try .prepare {
		padding: 0 2em 2em;
	}
	.homework.craft .try .prepare .materials .list {
		flex-grow: 2;
		margin-right: 2em;
	}

	.homework.craft .try .prepare h5,
	.homework.craft .try .prepare dl {
		min-width: 20em;
		font-size: 80%;
	}

	.homework.craft .try .prepare figure img {
		max-width: none;
	}
}



/* ==================== homework.craft/try/prepare.lanthanm-agro.css ==================== */

.homework.craft .try .prepare.lanthanm-agro::before {
	border: none;
	background: #dce7d2;
}

.homework.craft .try .prepare.lanthanm-agro .list p {
	font-size: 80%;
}


@media (max-width: 640px) {
	.homework.craft .try .prepare.lanthanm-agro {
		box-sizing: border-box;
	}
}



/* ==================== homework.craft/try-option/&.css ==================== */

.homework.craft .try-option {
	display: grid;
	grid-gap: 1.5em;
	position: relative;
	margin-top: 2em;
	padding: 1.5em;
}

.homework.craft .try-option::before {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	box-sizing: border-box;
	width: 100%;
	height: 100%;
	border: 0.15em solid #ffcccc;
	border-radius: 1.5em;
}

.homework.craft .try-option > * {
	position: relative;
}


.homework.craft .try-option .head h4 {
	color: #ff7b00;
	line-height: 1.2;
}
.homework.craft .try-option .head h4 span {
	display: inline-block;
}

.homework.craft .try-option .head p + img {
	display: block;
	margin: 1em auto;
}


.homework.craft .try-option .head figure {
	margin: 0;
}

/*
.homework.craft .try-option .image {
	margin-top: 1em;
}
*/


@media (max-width: 640px) {
	.homework.craft .try-option::before {
		height: calc(100% - 2.5em);
	}

	.homework.craft .try-option .head figure {
		text-align: center;
	}

	.homework.craft .try-option .head h4 {
		font-size: 120%;
		text-align: center;
	}

}


@media (min-width: 641px) {

	.homework.craft .try-option::before {
		height: calc(100% - 2.5em);
	}
	.homework.craft .try-option::after {
		content: none;
	}

	.homework.craft .try-option .head {
		display: flex;
		align-items: flex-start;
	}

	.homework.craft .try-option .head figure {
		order: 2;
		transform: rotate(2deg);
	}
	.homework.craft .try-option .head figure img {
		max-width: none;
	}

	.homework.craft .try-option .head .text {
		margin-top: 2.5em;
	}
	.homework.craft .try-option .head .text > * {
		padding-right: 1em;
	}

	.homework.craft .try-option .head h4 {
		margin-bottom: 0.5em;
		padding-bottom: 0.5em;
		background: linear-gradient(to right, #ffcccc 50%, transparent 50%) repeat-x left bottom / 0.4em 0.1em;
		font-size: 100%;
	}

	.homework.craft .try-option .head p {
		margin: 0;
		font-size: 80%;
	}

}


.IE .homework.craft .try-option > * {
	box-sizing: border-box;
	max-width: 100%;
}



/* ==================== homework.craft/try-option/agro.css ==================== */

.homework.craft .try-option .agro {
	display: flex;
	flex-direction: column;
	align-items: center;
	position: relative;
	padding: 0 1em 1em;
	color: #00462c;
}

.homework.craft .try-option .agro::before {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: calc(100% - 1.5em);
	background: #dce7d2;
	border-radius: 0.5em;
}

.homework.craft .try-option .agro > * {
	position: relative;
}

.homework.craft .try-option .agro h5 {
	margin: 0;
	line-height: 1.2;
}
.homework.craft .try-option .agro h5 span {
	display: block;
}

.homework.craft .try-option .agro p {
	margin: 1em 0 0;
}

.homework.craft .try-option .agro p.banner {
	display: flex;
	flex-direction: column;
	align-items: center;
	color: #d40000;
	font-weight: bold;
}

.homework.craft .try-option .agro p.banner span {
	display: flex;
	align-items: center;
	margin-bottom: 0.25em;
}
.homework.craft .try-option .agro p.banner span::before,
.homework.craft .try-option .agro p.banner span::after {
	content: '';
	display: block;
	width: 0;
	height: 1.25em;
	border-left: 2px solid #d40000;
	margin: 0 0.5em;
}

.homework.craft .try-option .agro p.banner span::before {
	transform: rotate(-20deg);
}
.homework.craft .try-option .agro p.banner span::after {
	transform: rotate(20deg);
}

.homework.craft .try-option .agro p.banner a {
	transition: 150ms;
}
.homework.craft .try-option .agro p.banner a:hover {
	opacity: 0.6;
}


@media (max-width: 640px) {
	.homework.craft .try-option .agro h5 {
		font-size: 95%;
		text-align: center;
	}
	.homework.craft .try-option .agro h5 > span {
		margin-top: 1em;
	}

	.homework.craft .try-option .agro p {
		font-size: 95%;
	}
}


@media (min-width: 641px) {
	.homework.craft .try-option .agro h5 {
		display: flex;
		align-items: center;
		font-size: 90%;
	}
	.homework.craft .try-option .agro h5 > span {
		margin-top: 0.5em;
		margin-left: 1em;
	}
	.homework.craft .try-option .agro p {
		font-size: 70%;
	}
}


.IE .homework.craft .try-option .agro > * {
	box-sizing: border-box;
	width: 100%;
}

.IE .homework.craft .try-option .agro h5 {
	justify-content: center;
}