@charset "utf-8";

/*----------------------------------------------------
 牛乳料理コンクール
----------------------------------------------------*/
/* アクティブ表示 */
@media screen and (min-width: 835px) {
	.cooking header .header_nav nav > ul > li:nth-child(5) {
		background-color: #3f80dc;
	}
	.cooking header .header_nav nav > ul > li:nth-child(5)::after {
		opacity: 1;
		transform: translate(0, -17px);
	}
}
/* コンテンツカラー表示 */
.cooking #contents_title i,
.cooking #contents_title h2 {
	color: var(--color-cooking);
}
.cooking .page_content h2 {
	color: var(--color-cooking);
	border-color: var(--color-cooking);
}
.cooking h3.theme_belt {
	background-color: var(--color-cooking);
}

/* 募集時 */
.entry {
	color: #64aa64;
	font-size: 1.875em;
	line-height: 1.4;
	font-weight: 700;
	text-align: center;
	margin: 0 0 40px;
}
.agenda {
	margin: 0 0 40px;
	padding-left: 50px;
	position: relative;
}
.agenda dl {
	display: flex;
	align-items: center;
	margin: 0 0 20px;
}
.agenda dl dt {
	width: 80px;
	height: 80px;
	flex-shrink: 0;
	border-radius: 50%;
	font-weight: 700;
	font-size: 1.125em;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-right: 18px;
}
.agenda dl.deadline dt {
	background-color: var(--color-cooking);
	color: #ffffff;
}
.agenda dl.prize dt {
	background-color: #ffec9f;
	color: var(--color-cooking);
}
.agenda dl.deadline dd {
	font-size: 1.5em;
	font-weight: 700;
	color: var(--color-cooking);
	line-height: 1.4;
}
.agenda dl.deadline dd span {
	font-size: 0.65em;
	display: inline-block;
}
.agenda dl.prize dd {
	font-size: 1.125em;
	line-height: 1.6;
}
.agenda dl.prize dd span {
	color: var(--color-cooking);
}
.agenda .entry_img {
	width: 370px;
	position: absolute;
	right: 0;
	top: 0;
}
.regulation {
	background-color: #fffae7;
	padding: 24px 50px;
	margin: 0 0 40px;
}
.regulation table {
	border-collapse: separate;
	border-spacing: 0 10px;
}
.regulation th {
	background-color: #ffec9f;
	color: var(--color-cooking);
	font-weight: 700;
	font-size: 1.25em;
	width: 220px;
	text-align: center;
	padding: 12px;
	line-height: 1.3;
}
.regulation th span {
	font-weight: 400;
	font-size: 0.8em;
}
.regulation td {
	background-color: #ffffff;
	line-height: 1.6;
}
.regulation td strong {
	font-size: 1.125em;
}
.regulation td ul li {
	text-indent: -0.5em;
	padding-left: 0.5em;
}
.regulation_pdf {
	margin: 0 0 80px;
}

.intro {
	padding-right: 380px;
	margin: 0 0 50px 0;
	position: relative;
	min-height: 190px;
}
.intro strong {
	font-size: 1.5em;
	color: #ec1c24;
	line-height: 1.4;
	margin: 0 0 10px;
	display: block;
}
.intro em {
	font-weight: 700;
}
.intro img {
	position: absolute;
	top: 12px;
	right: 0;
}
.not_entry {
	padding-right: 415px;
}
.not_entry img {
	right: 35px;
}

/* コンクールTOP */
.chosen {
	background-color: var(--color-base);
	padding: 0 0 60px;
	margin: 0 0 60px;
}
.cooking_prize dt {
	position: relative;
}
.cooking_prize .badge {
	position: absolute;
	top: -20px;
	left: 20px;
}
.cooking_prize .badge_right {
	right: 20px;
	left: auto;
}
.cooking_prize .person_info {
	text-align: center;
	margin: 20px 0 0;
	line-height: 1.6;
}
.cooking_prize .person_info .title {
	color: #64aa64;
	font-weight: 700;
}
.cooking_prize .person_info .name span {
	font-weight: 700;
}
.chosen .best_cooking {
	width: 660px;
	margin: 60px auto 0;
}
.chosen .best_cooking .title {
	font-size: 1.625em;
}
.chosen .best_cooking .name span {
	font-size: 1.625em;
}
.chosen .good_cooking {
	width: 500px;
	margin: 60px auto;
}
.chosen .good_cooking .title {
	font-size: 1.25em;
}
.chosen .good_cooking .name span {
	font-size: 1.25em;
}
.backnumber p {
	margin: 0 0 30px;
}

/* バックナンバー */
.winner {
	padding: 20px 0 0;
}
.winner .column_2 {
	margin: 0 0 100px;
}
.winner .column_2 dl {
	margin: 0 0 20px;
}
.winner .column_2 .title,
.recipe .column_2 .title {
	font-size: 1.625em;
	margin: 0 0 14px;
	line-height: 1.4;
}
.winner .column_2 .title span,
.recipe .column_2 .title span {
	font-size: 0.8em;
}
.winner .column_2 .name span,
.recipe .column_2 .name span {
	font-size: 1.625em;
}
.winner .column_3 .title {
	font-size: 1.25em;
	line-height: 1.4;
	margin: 0 0 4px;
}
.winner .column_3 .title span {
	font-size: 0.8em;
}
.winner .column_3 .name span {
	font-size: 1.25em;
}

/* 入選レシピ */
.recipe {
	position: relative;
	border-top: 6px solid var(--color-cooking);
}
.recipe .person_info {
	align-self: center;
}
.recipe .print {
	position: absolute;
	top: 10px;
	right: 0;
}
.recipe .print a {
	width: 156px;
	text-align: right;
	padding-right: 13px;
}
.recipe .print a:before {
	content: none;
}
.recipe .print a i {
	color: #fff;
	width: 30px;
	height: 30px;
	background-color: var(--color-main);
	position: absolute;
	text-align: center;
	left: 10px;
	top: 6px;
	line-height: 30px;
	border-radius: 100%;
}

.recipe .person_info {
	text-align: center;
}
.recipe .person_info .prize {
	font-size: 1.125em;
	font-weight: 700;
	margin: 0 0 6px;
	color: var(--color-cooking);
}
.recipe .person_info .comment {
	text-align: justify;
	margin: 30px 0 0;
}
.recipe .image {
	padding: 65px 0 0;
}

.recipe .material {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	margin: 0 0 40px;
}
.recipe .material h3 {
	font-size: 1.25em;
	padding: 16px 10px;
	text-align: right;
	background-color: var(--color-cooking);
	color: #ffffff;
	width: 160px;
}
.recipe .material .detail {
	width: calc(100% - 160px);
	border-left: 1px solid var(--color-cooking);
	padding: 16px 0 0 24px;
	line-height: 1.4;
}
.recipe .material .detail h4 {
	font-size: 1.25em;
	font-weight: 700;
	padding: 0 0 16px;
	border-bottom: 1px solid #cccccc;
	margin: 0 0 16px;
}
.recipe .material .detail h4 span {
	font-weight: 400;
	font-size: 0.8em;
}
.recipe .material .detail ul {
	display: flex;
	flex-wrap: wrap;
	margin-right: -50px;
}
.recipe .material .detail ul li {
	width: calc(33.33% - 50px);
	margin-right: 50px;
}
.recipe .material .detail ul li .caution {
	font-size: 0.9375em;
	margin: 0 0 6px;
}
.recipe .material .detail ul li .asterisk {
	color: #ff0000;
}

.recipe .material .detail .classify {
	font-weight: 700;
	margin: 0 0 6px;
}
.recipe .material .detail dl {
	display: flex;
	justify-content: space-between;
	margin: 0 0 8px;
	padding: 0 0 4px;
	border-bottom: 1px dashed #cccccc;
}
.recipe .material .detail dl dt span {
	font-size: 0.9em;
}
.recipe .material .detail dl dd {
	white-space: nowrap;
}
.recipe .howto {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	margin: 0 0 60px;
}
.recipe .howto h3 {
	font-size: 1.25em;
	padding: 16px 10px;
	text-align: right;
	background-color: #ffec9f;
	color: var(--color-cooking);
	width: 160px;
	align-self: stretch;
}
.recipe .howto .procedure {
	width: calc(100% - 160px);
	border-left: 1px solid var(--color-cooking);
	line-height: 1.4;
	padding: 16px 24px 0 24px;
	background-color: #fffae7;
}
.recipe .howto .procedure li {
	border-bottom: 1px dashed #cccccc;
	padding: 0 0 10px;
	margin: 0 0 10px;
}
.recipe .howto .procedure li:last-child {
	border: none;
}
.recipe .howto .procedure dl {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
}
.recipe .howto .procedure dl dt {
	width: 40px;
	height: 40px;
	line-height: 40px;
	color: #ffffff;
	background-color: var(--color-cooking);
	text-align: center;
	border-radius: 100%;
	font-size: 1.25em;
	font-weight: 700;
}
.recipe .howto .procedure dl dd {
	padding: 8px 0 8px 10px;
	width: calc(100% - 40px);
	text-align: justify;
}

.recipe .howto .procedure .sub_procedure h4 {
	font-size: 1.0625em;
	margin-bottom: 0.1em;
}
.recipe .howto .procedure .sub_procedure dl {
	align-items: center;
}
.recipe .howto .procedure .sub_procedure dl dt {
	width: 28px;
	height: 28px;
	line-height: 28px;
	font-size: 1em;
}
.recipe .howto .procedure .sub_procedure dl dd {
	padding: 6px 0 6px 10px;
	width: calc(100% - 30px);
}


/* 2022年度調整用 */
.contest_2022 .cooking_prize .badge {
	left: -10px;
}


@media screen and (max-width: 834px) {
	.entry {
		font-size: 1.4em;
		margin: 0 0 20px;
	}
	.agenda {
		padding-left: 0;
	}
	.agenda dl {
		margin: 0 0 10px;
	}
	.agenda dl dt {
		width: 60px;
		height: 60px;
		margin-right: 12px;
	}
	.agenda dl.deadline dd {
		font-size: 1.25em;
		line-height: 1.2;
	}
	.agenda dl.prize dd {
		font-size: 0.975em;
		line-height: 1.5;
	}
	.agenda dl.prize dd li {
		text-indent: -1.0em;
		padding-left: 1.0em;
	}
	.agenda p {
		line-height: 1.6;
	}
	.agenda .entry_img {
		width: 80%;
		max-width: 370px;
		position: static;
		display: block;
		margin: 20px auto 30px;
	}
	.regulation {
		padding: 0 10px;
		margin: 0 0 20px;
	}
	.regulation th,
	.regulation td {
		display: block;
		width: 100%;
	}
	.regulation th {
		text-align: left;
		padding: 6px 8px;
		font-size: 1.05em;
	}
	.regulation th br {
		display: none;
	}
	.regulation_pdf {
		margin: 0 0 40px;
	}


	.intro {
		padding: 0;
		line-height: 1.6;
		min-height: auto;
	}
	.intro strong {
		font-size: 1.1em;
	}
	.intro em {
		display: block;
		margin: 8px 0 0;
	}
	.intro img {
		position: static;
		width: 80%;
		max-width: 480px;
		display: block;
		margin: 20px auto 40px;
	}
	.not_entry {
		padding: 0 15px;
	}

	.chosen {
		padding: 0 0 30px;
		margin: 0 0 50px;
	}
	.chosen .cooking_prize {
		max-width: 600px;
		width: 100% !important;
		padding: 0 15px;
		margin: 40px auto 20px !important;
	}
	.cooking_prize .badge {
		left: 10px;
	}
	.cooking_prize .badge_right {
		right: 10px;
		left: auto;
	}
	.cooking_prize .person_info {
		margin: 10px 0 0;
		line-height: 1.4;
	}
	.chosen	.cooking_prize .title,
	.chosen	.cooking_prize .name span {
		font-size: 1.15em;
	}
	.chosen .linkBtn a,
	.backnumber .linkBtn a {
		max-width: 240px;
	}
	.winner {
		padding: 0;
	}
	.winner .column_2 {
		margin: 0 0 60px;
	}
	.winner .column_2 dl {
		max-width: 600px;
		margin: 20px auto;
	}
	.winner .column_3 dl {
		max-width: 600px;
		margin: 20px auto 0;
	}
	.recipe .column_2 {
		grid-gap: 0;
	}
	.winner .column_2 .title,
	.winner .column_2 .name span,
	.winner .column_3 .title,
	.winner .column_3 .name span,
	.recipe .column_2 .title,
	.recipe .column_2 .name span {
		font-size: 1.15em;
	}
	.recipe .print {
		position: static;
		text-align: right;
	}
	.recipe .print a {
		width: auto;
		padding: 0;
		border: none;
	}
	.recipe .print a:hover::after {
		background-color: inherit;
	}
	.recipe .print a i {
		position: static;
	}
	.recipe .print a span {
		display: none;
	}
	.recipe .person_info .comment {
		text-align: justify;
		margin: 20px 0 0;
	}
	.recipe .image {
		padding: 30px 0 0;
		max-width: 600px;
		width: 80%;
		margin: 0 auto;
	}
	.recipe .material,
	.recipe .howto {
		display: block;
	}
	.recipe .material h3,
	.recipe .howto h3 {
		font-size: 1.125em;
		padding: 6px 10px;
		text-align: left;
		width: auto;
		display: inline-block;
	}
	.recipe .material .detail,
	.recipe .howto .procedure {
		width: 100%;
		border-left: none;
		border-top: 1px solid var(--color-cooking);
		padding: 16px 0 0;
		margin: 0;
	}
	.recipe .material .detail h4 {
		font-size: 1.125em;
		padding: 0 0 10px;
		margin: 0 0 10px;
	}
	.recipe .material .detail ul {
		display: block;
		margin-right: 0;
	}
	.recipe .material .detail ul li {
		width: 100%;
		margin-right: 0;
	}
	.recipe .material .detail ul li .classify {
		margin: 16px 0 6px;
	}
	.recipe .howto .procedure {
		padding: 10px 10px 0;
	}
	.recipe .howto .procedure dl dt {
		width: 30px;
		height: 30px;
		line-height: 30px;
		font-size: 1.125em;
	}
	.recipe .howto .procedure dl dd {
		padding: 5px 0 5px 10px;
		width: calc(100% - 30px);
	}
	.recipe .howto .procedure .sub_procedure {
		display: block;
	}
	.recipe .howto .procedure .sub_procedure h4 {
		font-size: 1.0625em;
		margin: 0 0 0.5em 0;
	}
	.recipe .howto .procedure .sub_procedure .process {
		flex-basis: 100%;
	}
	

}
