@charset "utf-8";

/*----------------------------------------------------
 キャンペーン
----------------------------------------------------*/
/* コンテンツカラー表示 */
.campaign #contents_title i,
.campaign #contents_title h2 {
	color: #ff7bac;
}
.campaign_wrapper {
	width: 940px;
	margin: 0 auto;
}

.ad {
	padding: 0;
	background-image: url(../images/sec_bg.jpg);
	position: relative;
}

.sec01 picture {
	display: block;
}
.sec01 .sec_title {
	width: 100%;
	margin: 0 auto;
	text-align: center;
	padding: 0;
}

.sec02 .present {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: auto auto;
	grid-column-gap: 40px;
	grid-row-gap: 36px;
	position: relative;
	z-index: 10;
}
.sec02 .present01 { grid-column: span 2 / span 2; }
.sec02 .present02 { grid-row-start: 2; }
.sec02 .present03 { grid-row-start: 2; }

.sec02 .explanation {
	text-align: center;
	margin: 30px 0;
}

.sec03 .campaign_wrapper {
	background-color: #ffffff;
	border-radius: 24px;
	box-shadow: 0 8px 0 rgba(0,90,159,0.2);
}
.sec03 .description {
	margin: 0 auto 20px;
	display: block;
	width: 749px;
}
.sec03 .entry_type {
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
	margin: 0 45px;
}
.sec03 .entry_type .type_detail {
	width: calc(50% - 15px);
}
.sec03 .entry_caution {
	padding: 20px 45px 25px;
	line-height: 1.2;
}
.sec03 .entry_caution p {
	margin: 0 0 10px;
}
.sec03 .entry_caution span {
	display: inline-block;
	padding: 4px 16px;
	margin: 0 10px 0 0;
	color: #ffffff;
	background-color: #999999;
	text-align: center;
	border-radius: 14px;
}

.sec03 .target {
	padding: 45px 45px 15px;
	margin: 50px 0 0;
}
.sec03 .detail dl {
	display: flex;
	flex-wrap: wrap;
	align-items: start;
	margin: 0 0 30px;
}
.sec03 .detail dl dt {
	background-color: #c26b5b;
	color: #ffffff;
	font-weight: 700;
	padding: 2px 6px;
	width: 134px;
	line-height: 20px;
	height: 26px;
	clip-path: polygon(0% 0%, 95% 0%, 100% 50%, 95% 100%, 0% 100%);
}
.sec03 .detail dl dd {
	flex: 1;
	padding-left: 14px;
	line-height: 1.6;
}
.sec03 .detail dl.where_apply dd {
	font-size: 20px;
	font-weight: 700;
}
.sec03 .detail dl.shipping .list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.sec03 .detail dl.shipping dd ul {
	width: 48%;
	margin: 0 0 10px;
}
.sec03 .detail dl.shipping dd ul li.company {
	font-weight: bold;
	text-indent: -1em;
	padding-left: 1em;
}
.sec03 .detail dl.shipping dd ul li::before {
	content: "・";
	margin-right: 0.25em;
}
.sec03 .detail dl.shipping dd ul li.company::before {
	content: "◆";
	color: #fad7ab;
	margin-right: 0em;
}
.ad .greeting {
	margin: 0;
}

.sec04 {
	border-bottom: 4px solid #0068b6;
}
.sec04 .line_entry {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	padding: 34px 0;
}
.sec04 .line_entry .milk_icon picture {
	display: block;
	width: 156px;
}
.sec04 .line_entry .entry_title picture {
	display: block;
	width: 549px;
}
.sec04 .line_entry .line-icon picture {
	display: block;
	width: 148px;
	margin-left: 8px;
}
.sec04 .entry_detail {
	display: flex;
	flex-wrap: wrap;
	align-items: start;
	justify-content: space-between;
	gap: 40px;
	padding: 0 0 38px;
}
.sec04 .entry_detail .detail {
	flex: 1;
}
.sec04 .entry_detail .detail > p {
	line-height: 1.8;
}
.sec04 .entry_detail .detail dl {
	margin: 20px 0 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
.sec04 .entry_detail .detail dl dt span {
	background-color: #008565;
	padding: 10px 12px;
	border-radius: 16px;
	text-align: center;
	line-height: 1.2;
	font-size: 1.25em;
	font-weight: 700;
	color: #ffffff;
	display: block;
	margin-right: 16px;
}
.sec04 .entry_detail .detail dl dd {
	flex: 1;
	font-size: 1.125em;
	font-weight: 700;
	line-height: 2.0;
}
.sec04 .entry_detail .detail dl dd span {
	color: #ffffff;
	display: inline-block;
	margin-right: 0.25em;
	text-align: center;
	border-radius: 100%;
	position: relative;
	width: 26px;
	z-index: 2;
}
.sec04 .entry_detail .detail dl dd span::before {
	content: "";
	height: 26px;
	width: 26px;
	background-color: #ff931e;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	border-radius: 100%;
	z-index: -1;
}
.sec04 .entry_detail .qr_entry {
	width: 148px;
}

.sec05 .sponsored {
	text-align: center;
	padding: 30px 0 0;
	line-height: 1.6;
}
.sec05 .sponsored span {
	font-size: 16px;
}
.sec05 .sponsored h2 {
	font-size: 30px;
	margin: 0 0 12px;
	font-weight: 400;
}
.sec05 .sponsored img {
	width: 50px;
}
.sec05 .sponsored h3 {
	font-size: 26px;
	font-weight: 400;
}

@media screen and (max-width: 834px) {
	body {
		padding: 54px 0 0;
	}
	.campaign_wrapper {
		width: 100%;
	}
	.ad {
		margin: 0 -15px;
	}
	.sec01 {
		background-size: 100%;
	}
	.sec01 .sec_title {
		width: 100%;
		margin: 0 auto;
		padding: 0;
	}

	.sec02 {
		padding: 10px 15px;
		background-size: 100%;
	}
	.sec02 .present {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		flex-direction: row;
		gap: 30px;
		padding: 0;
		margin: 0 0 20px;
	}

	.sec03 {
		padding: 0 15px;
	}
	.sec03 .description {
		max-width: 450px;
		width: 70%;
	}
	.sec03 .entry_type {
		flex-direction: column;
		gap: 30px;
		margin: 0 15px;
	}
	.sec03 .entry_type .type_detail {
		width: 100%;
	}
	.sec03 .entry_type .line_sp .fit_img {
		display: block;
	}
	.sec03 .entry_type .line_sp a {
		margin: 20px 0 0;
		display: block;
	}
	.sec03 .entry_caution {
		padding: 15px;
		line-height: 1.4;
	}
	.sec03 .entry_caution span {
		display: block;
	}
	.sec03 .target {
		padding: 20px 20px 2px;
		margin: 40px 0 0;
	}
	.sec03 .detail dl {
		display: block;
	}
	.sec03 .detail dl dd {
		padding: 10px 0 0 0;
	}
	.sec03 .entry_detail {
		display: block;
	}
	.sec03 .entry_detail .line_pc {
		display: none;
	}
	.sec03 .detail dl.where_apply dd {
		font-size: 1.05em;
		font-weight: 700;
	}
	.sec03 .detail dl.shipping .list {
		display: block;
	}
	.sec03 .detail dl.shipping dd ul {
		width: 100%;
	}
	.ad .greeting {
		margin: 20px 0 0;
	}

	.sec04 {
		margin: 0 -15px;
		padding: 0 15px;
	}
	.sec04 .line_entry {
		display: grid;
		grid-template-columns: auto auto;
		grid-template-rows: auto auto;
		grid-column-gap: 4vw;
		grid-row-gap: 4vw;
		justify-content: center;
	}
	.sec04 .line_entry .milk_icon {
		grid-area: 1 / 1 / 2 / 2;
		justify-self: end;
	}
	.sec04 .line_entry .milk_icon picture {
		width: 30vw;
		max-width: 156px;
	}
	.sec04 .line_entry .entry_title {
		grid-area: 2 / 1 / 3 / 3;
	}
	.sec04 .line_entry .entry_title picture {
		width: 90vw;
		max-width: 549px;
	}
	.sec04 .line_entry .line-icon {
		grid-area: 1 / 2 / 2 / 3;
	}
	.sec04 .line_entry .line-icon picture {
		width: 30vw;
		max-width: 156px;
		margin-left: 0;
	}
	.sec04 .entry_detail {
		display: block;
		padding: 0 0 26px;
	}
	.sec04 .entry_detail .detail dl {
		flex-direction: column;
		margin: 28px 0 0;
	}
	.sec04 .entry_detail .detail dl dt {
		flex: 1;
		width: 100%;
	}
	.sec04 .entry_detail .detail dl dt span {
		width: 100%;
		padding: 8px 0;
		margin: 0 0 14px;
		font-size: 1.125em;
		border-radius: 0;
	}
	.sec04 .entry_detail .detail dl dd {
		line-height: 1.6;
		font-size: 1.0em;
	}
	.sec04 .entry_detail .detail dl dd p {
		text-indent: -30px;
		padding-left: 30px;
		margin: 0 0 6px;
	}
	.sec04 .entry_detail .detail dl dd span {
		padding-left: 30px;
		margin-right: 0;
	}
	.sec04 .entry_detail .qr_entry {
		width: 100%;
	}
	.sec04 .entry_detail .qr_entry a {
		display: block;
		border: 4px solid #ffffff;
		background-color: #06c755;
		color: #ffffff;
		font-weight: 700;
		font-size: 1.4em;
		text-align: center;
		margin: 16px auto;
		padding: 30px 10px;
		width: 100%;
		max-width: 380px;
		border-radius: 16px;
		filter: drop-shadow(0 1px 8px rgba(0,0,0,0.2));
	}

	.sec05 .sponsored {
		padding: 30px 0 0;
		line-height: 1.8;
	}
	.sec05 .sponsored span {
		font-size: 14px;
	}
	.sec05 .sponsored h2 {
		font-size: 22px;
	}
	.sec05 .sponsored h3 {
		font-size: 18px;
	}
}
