@charset "utf-8";
/*------------------------------------------------------------
	milk
------------------------------------------------------------*/
#gHeader {
	margin-bottom: 9.8rem;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	position: relative;
}
#gHeader:after {
	width: 73.6rem;
	height: 29.6rem;
	background: url(../img/common/bg02.png) no-repeat;
	background-size: 100% auto;
	position: absolute;
	top: 3.0rem;
	left: -19rem;
	content: "";
}
#gHeader h1 {
	margin: 0;
}
#gHeader .hLink {
	margin: -4rem 0.5rem -4rem 0;
}
#main {
	margin-bottom: 26rem;
	padding-bottom: 1rem;
	position: relative;
}
#main::before {
	position: absolute;
	top: 8.8rem;
	right: 0;
	content: "";
	width: 100%;
	height: calc(100% - 5.8rem);
	z-index: -1;
	transform: skewY(-8.8deg);
	background-color: #F5F5F5;
}
#main .content {
	max-width: 117.7rem;
	color: #231815;
}
#main .catalognameBox {
	margin-bottom: 7rem;
	position: relative;
	padding: 4.6rem 0 0;
	background-color: #fff;
	border: 0.2rem solid #231815;
}
#main p {
	margin-bottom: 3.8rem;
	color: #231815;
}
#main p:last-child {
	margin-bottom: 0 !important;
}
#main .catalognameBox h2 {
	text-align: center;
	font-size: 3.6rem;
	font-weight: 900;
	margin-bottom: 4.1rem;
}
#main .catalognameBox .tag {
	position: absolute;
	top: -0.8rem;
	left: -1.3rem;
	min-width: 18.8rem;
	width: fit-content;
	color: #231815;
	border: 0.2rem solid #F2F2F2;
	border-radius: 6rem;
	font-size: 2.8rem;
	font-weight: 900;
	letter-spacing: 0.1em;
	text-align: center;
	background-color: #ffd232;
}
#main .catalognameBox .tag span {
	display: block;
	padding: 0.5rem 2rem;
	border-radius: 6rem;
	border: 0.2rem solid #231815;
}
#main .catalognameBox .photo img {
	width: 100%;
}
#main .sec01 {
	padding: 2.4rem 8.5rem 14.4rem;
	background: url(../img/milk/bg01.png) no-repeat center bottom/100%;
}
#main .sec01 .midTxt {
	font-size: 1.8rem;
	line-height: 1.78;
	text-align: center;
}
#main .sec01 .imgBox {
	margin: 0 5.1rem 3rem;
}
#main .sec01 .imgBox .phoBox {
	width: 42rem;
}
#main .sec01 .imgBox .phoBox img {
	width: 100%;
}
#main .sec01 .imgBox .txtBox {
	margin: 11rem 0 0 2rem;
	flex: 1;
}
#main .sec01 .imgBox .txtBox p {
	font-size: 1.6rem;
	line-height: 1.88;
}
#main .sec01 .listBox h3 {
	padding: 6.9rem 0 4.2rem;
	color: #ee327d;
	font-weight: 900;
	text-align: center;
	background: url(../img/milk/ttl_bg01.png) no-repeat 0.5rem 2rem/22rem, url(../img/milk/ttl_bg02.png) no-repeat right 1.6rem top/20.1rem;
}
#main .sec01 .listBox .phoList {
	gap: 3.2rem 2.2rem;
}
#main .sec01 .listBox .phoList li {
	width: calc((100% - 8.8rem)/5);
}
#main .sec01 .listBox .phoList a {
	display: block;
	position: relative;
	aspect-ratio: 148/184;
	border: 2px solid #CFCFCF;
	border-radius: 0.5rem;
	overflow: hidden;
}
#main .sec01 .listBox .phoList a:hover {
	opacity: 0.7;
}
#main .sec01 .listBox .phoList img {
	width: 122%;
	height: 122%;
	object-fit: cover;
	object-position: center -2rem;
}
#main .sec01 .listBox .phoList a:after {
	position: absolute;
	right: 0.8rem;
	bottom: 0.8rem;
	width: 3.6rem;
	height: 3.6rem;
	background: url(../img/milk/btn.png) no-repeat left top/100%;
	content: "";
}
#main .sec02 {
	padding: 3.8rem 9.5rem 6rem;
	background: #f0f7e1 url(../img/milk/bg02.png) no-repeat right bottom/30.3rem;
}
#main .sec02 h3 {
	color: #12a85e;
	font-weight: 900;
	text-align: center;
	margin-bottom: 1.7rem;
}
#main .sec02 .midTxt {
	margin-bottom: 2.1rem;
	font-size: 1.6rem;
	line-height: 1.88;
	text-align: center;
}
#main .sec02 .midTxt img {
	height: 1.5rem;
	vertical-align: -0.1rem;
}
#main .sec02 .midTxt .ico02 {
	height: 1.6rem;
	margin-right: 0.3rem;
	vertical-align: -0.3rem;
}
#main .sec02 .photo {
	margin: 0 auto 0.8rem;
	width: 48.8rem;
	transform: translateX(-0.8rem);
}
#main .sec02 .photo02 {
	margin-bottom: 3.9rem;
	width: 50rem;
	transform: translateX(-1.4rem);
}
#main .sec02 .photo03 {
	margin-bottom: 0.4rem;
	width: 47.2rem;
	transform: translateX(0);
}
#main .sec02 .movieBtn {
	margin-bottom: 4rem;
}
#main .sec02 .movieBtn a {
	display: block;
	padding: 0.6rem 6rem 0.6rem 3rem;
	margin: 0 auto;
	width: 30.7rem;
	color: rgba(255, 255, 255, 0.93);
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1.33;
	border-radius: 3rem;
	background: #12a85e url(../img/milk/icon03.png) no-repeat right 0.6rem center/5rem;
}
#main .sec02 .movieBtn a:hover {
	opacity: 0.7;
}
#main .sec02 .movieBtn02 {
	margin-bottom: 3.4rem;
}
#main .sec02 .subBox {
	margin-top: 8.8rem;
}
#main .sec02 h4 {
	margin-bottom: 0.6rem;
	color: #ee327d;
	font-size: 2.4rem;
	line-height: 1.2;
	font-weight: 900;
	text-align: center;
}
#main .sec02 .notes {
	margin-bottom: 2rem;
	font-size: 1.2rem;
	text-align: center;
}
#main .sec02 .shopList {
	margin: 0 auto;
	max-width: 66.5rem;
}
#main .sec02 .shopList li {
	width: 46.3%;
}
#main .sec02 .shopList .imgBox {
	margin: 0 2.6rem;
	align-items: center;
	margin-bottom: 1rem;
}
#main .sec02 .shopList p {
	margin: 0.5rem 0.5rem 0 0;
	flex: 1;
	font-size: 2rem;
	font-weight: 900;
}
#main .sec02 .shopList p img {
	display: block;
	margin-bottom: 0.5rem;
	height: 2.7rem;
}
#main .sec02 .shopList .pho {
	width: 8.1rem;
}
#main .sec02 .shopList .comLink02 {
	margin-bottom: 0;
}
#main .sec02 .shopList .comLink02 a {
	width: auto;
	padding: 1rem 4rem 1rem 2.5rem;
	color: rgba(255, 255, 255, 0.93);
	background: #ee327d url(../img/common/icon08.png) no-repeat right 0.3rem center/4rem;
	border-color: #ee327d;
}
.popBox .subPop {
	padding: 3rem;
}
.popBox .movie {
	margin: 0 auto;
	width: 30rem;
	aspect-ratio: 296/532;
	border-radius: 0.6rem;
	overflow: hidden;
}
.popBox .movie iframe {
	width: 100%;
	height: 100%;
}
.mfp-image-holder .mfp-content {
	max-width: 51.5rem;
}
.mfp-figure figure {
	padding-bottom: 12rem;
	background: #fff;
}
img.mfp-img {
	padding: 0;
}
.mfp-bottom-bar {
	margin-top: -7.5rem;
}
.mfp-title {
	padding-right: 0;
	color: #231815;
	font-size: 2rem;
	font-weight: 900;
	text-align: center;
}
.mfp-close {
	position: absolute !important;
	opacity: 1;
	padding-right: 0 !important;
	width: 4rem !important;
	height: 4rem !important;
	line-height: 0;
	top: auto !important;
	bottom: -1rem;
	right: -1rem !important;
	font-size: 0;
	transition: .3s;
	cursor: pointer !important;
	background: url(../img/milk/close.png) no-repeat left top/100% !important;
}
@media all and (min-width: 897px) {
	#main .content {
		position: relative;
		z-index: 11;
	}
	.mfp-close:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	#gHeader .hLink {
		width: 7.6rem;
		margin-right: -0.2rem;
	}
	#gHeader {
		margin-bottom: 12.9rem;
		justify-content: center;
		padding: 2.5rem 2rem;
	}
	#gFooter {
		margin-top: -2.5rem;
	}
	#main {
		margin-bottom: 0;
		padding-bottom: 0;
	}
	#main .content {
		margin: 0 1.5rem;
	}
	#main::before {
		height: calc(100% + 19.5rem);
		top: -7.3rem;
		transform: skewY(-9.8deg);
	}
	#gHeader::after {
		width: 38.8rem;
		height: 14.2rem;
		left: -10.5rem;
		top: 6.6rem;
		background-image: url(../img/common/bg02_sp.png);
	}
	#main .catalognameBox {
		margin-bottom: 5rem;
		padding: 2.9rem 0 0;
	}
	#main .catalognameBox .tag {
		font-size: 1.6rem;
		letter-spacing: 0.1em;
		min-width: 11rem;
		left: -0.9rem;
		top: -0.8rem;
	}
	#main .catalognameBox .tag span {
		padding: 0.2rem 1rem;
	}
	#main .catalognameBox h2 {
		margin-bottom: 1.9rem;
		font-size: 2.4rem;
	}
	#main p {
		margin-bottom: 2.1rem;
	}
	#main .sec01 {
		padding: 3.3rem 1.7rem 25.8vw;
		background-image: url(../img/milk/bg01_sp.png);
	}
	#main .sec01 .midTxt {
		font-size: 1.6rem;
		line-height: 1.75;
		text-align: left;
	}
	#main .sec01 .imgBox {
		margin: 0 0 1.7rem;
		display: block;
	}
	#main .sec01 .imgBox .phoBox {
		width: auto;
	}
	#main .sec01 .imgBox .txtBox {
		margin: 1rem 0 0;
	}
	#main .sec01 .imgBox .txtBox p {
		font-size: 1.4rem;
		line-height: 1.86;
	}
	#main .sec01 .listBox h3 {
		margin: 0 -1.7rem 2.9rem;
		padding: 6.1rem 0 0;
		font-size: 1.8rem;
		line-height: 1.56;
		background: url(../img/milk/ttl_bg01_sp.png) no-repeat -2.3rem 1.5rem/13.8rem, url(../img/milk/ttl_bg02_sp.png) no-repeat right -0.9rem top/13rem;
	}
	#main .sec01 .listBox .phoList {
		gap: 2.2rem 1.5rem;
	}
	#main .sec01 .listBox .phoList li {
		width: calc((100% - 3rem)/3);
	}
	#main .sec01 .listBox .phoList a {
		border-width: 1px;
	}
	#main .sec01 .listBox .phoList img {
		width: 121%;
		height: 121%;
		object-position: center -1.2rem;
	}
	#main .sec01 .listBox .phoList a:after {
		right: 0.5rem;
		bottom: 0.5rem;
		width: 3rem;
		height: 3rem;
	}
	#main .sec02 {
		padding: 2.5rem 1.7rem 5rem;
		background: #f0f7e1 url(../img/milk/bg02_sp.png) no-repeat right -0.2rem bottom -0.2rem/23.5rem;
	}
	#main .sec02 h3 {
		margin-bottom: 0.9rem;
		font-size: 1.8rem;
		line-height: 1.55;
	}
	#main .sec02 .midTxt {
		margin-bottom: 2.2rem;
		font-size: 1.4rem;
		line-height: 1.86;
		text-align: left;
	}
	#main .sec02 .midTxt img {
		height: 1.3rem;
	}
	#main .sec02 .midTxt .ico02 {
		height: 1.4rem;
		margin-right: 0.1rem;
	}
	#main .sec02 .photo {
		margin: 0 -0.1rem 1rem -0.5rem;
		width: auto !important;
		transform: translateX(0) !important;
	}
	#main .sec02 .photo02 {
		margin: 0 -0.6rem 4rem -1.2rem;
	}
	#main .sec02 .photo03 {
		margin: 0 -0.1rem 1rem;
	}
	#main .sec02 .subBox {
		margin-top: 6.2rem;
	}
	#main .sec02 h4 {
		margin-bottom: 0.6rem;
		font-size: 1.8rem;
	}
	#main .sec02 .notes {
		margin-bottom: 0.5rem;
		line-height: 1.7;
		text-align: left;
	}
	#main .sec02 .shopList {
		display: block;
		max-width: inherit;
	}
	#main .sec02 .shopList li {
		width: auto;
	}
	#main .sec02 .shopList li:not(:last-child) {
		margin-bottom: 4rem;
	}
	#main .sec02 .shopList .imgBox {
		margin: 0 auto;
		max-width: 25.4rem;
		margin-bottom: 1rem;
	}
	#main .sec02 .shopList p {
		margin: 0.5rem 0 0;
		font-size: 2rem;
	}
	#main .sec02 .shopList p img {
		margin-bottom: 0.4rem;
	}
	#main .sec02 .shopList .comLink02 a {
		padding: 1rem 4rem 1rem 2.5rem;
		color: rgba(255, 255, 255, 0.93);
		background: #ee327d url(../img/common/icon08.png) no-repeat right 0.3rem center/4rem;
	}
	.popBox .subPop {
		margin: 0 -2.5rem;
		padding: 1.8rem 4rem;
		border-left: none;
		border-right: none;
	}
	.popBox .close {
		margin-top: 1rem;
	}
	.mfp-container {
		padding: 4rem 2.3rem;
	}
	.mfp-img-mobile .mfp-bottom-bar {
		position: absolute;
		bottom: auto;
		margin-top: -5.3rem;
		background: none;
		padding: 0;
	}
	.mfp-figure figure {
		padding-bottom: 8.5rem;
	}
	.mfp-title {
		font-size: 1.8rem;
	}
	.mfp-img-mobile .mfp-close {
		right: -1rem !important;
		bottom: -1.3rem !important;
	}
}
@media screen and (max-width: 800px) and (orientation: landscape), screen and (max-height: 300px) {
	.mfp-img-mobile .mfp-bottom-bar {
		margin: 0;
		bottom: 3.4rem;
	}
}