/* ==============================
   SIP SAP Subscription Page Ver.3
   Design Language 1.0
   ============================== */

.p-page_article.sip-subscription-v3{
	width:100%;
	max-width:none;
	margin:0;
	padding:0;
	background:#fff;
	color:#2F3A34;
	overflow:hidden;
}

.sip-subscription-v3 *{
	box-sizing:border-box;
}

.sip-subscription-v3 a{
	color:inherit;
	text-decoration:none;
}

.sipv3-inner{
	width:100%;
	max-width:1280px;
	margin:0 auto;
	padding:0 40px;
}

.sipv3-kicker{
	margin:0 0 18px;
	font-size:12px;
	font-weight:600;
	letter-spacing:.18em;
	color:#B89A5A;
	line-height:1.6;
}

.sipv3-section-head{
	text-align:center;
	margin:0 auto 70px;
}

.sipv3-section-head h2,
.sipv3-copy h2,
.sipv3-lifestyle-block h2,
.sipv3-regular-cta h2,
.sipv3-final-cta h2{
	margin:0;
	color:#315A3D;
	font-size:38px;
	font-weight:500;
	letter-spacing:.08em;
	line-height:1.65;
}

.sipv3-section-head > p:not(.sipv3-kicker),
.sipv3-copy p,
.sipv3-regular-cta p,
.sipv3-final-cta p{
	color:#6E746F;
	font-size:15px;
	letter-spacing:.04em;
	line-height:2.1;
}

/* Forest Statement */
.sipv3-forest-statement{
	background:#fff;
	padding:110px 0;
}

.sipv3-two-column{
	display:grid;
	grid-template-columns:1fr 1fr;
	gap:70px;
	align-items:center;
}

.sipv3-image img{
	width:100%;
	display:block;
	border-radius:28px;
	box-shadow:0 12px 36px rgba(0,0,0,.05);
}

.sipv3-copy{
	max-width:520px;
}

.sipv3-copy .sipv3-lead{
	margin:34px 0 24px;
	color:#315A3D;
	font-size:20px;
	line-height:2;
}

/* Why Subscription */
.sipv3-subscription-value{
	background:#FAF8F3;
	padding:110px 0;
}

.sipv3-value-list{
	max-width:1100px;
	margin:0 auto;
	display:grid;
	grid-template-columns:repeat(3,1fr);
	gap:50px;
}

.sipv3-value-item{
	border-top:1px solid #D8CCBA;
	padding-top:34px;
}

.sipv3-value-item span,
.sipv3-support-list span{
	display:block;
	margin-bottom:18px;
	color:#B89A5A;
	font-size:13px;
	font-weight:600;
	letter-spacing:.18em;
}

.sipv3-value-item h3,
.sipv3-support-list h3{
	margin:0 0 18px;
	color:#315A3D;
	font-size:24px;
	font-weight:500;
	letter-spacing:.08em;
	line-height:1.6;
}

.sipv3-value-item p,
.sipv3-support-list p{
	margin:0;
	color:#6E746F;
	font-size:14px;
	line-height:2.1;
	letter-spacing:.04em;
}

/* Flavors */
.sipv3-flavors{
	background:#fff;
	padding:120px 40px;
}

.sipv3-flavor-item{
	max-width:1180px;
	margin:0 auto 120px;
	display:grid;
	grid-template-columns:1fr 1fr;
	gap:80px;
	align-items:center;
}

.sipv3-flavor-item:last-child{
	margin-bottom:0;
}

.sipv3-flavor-item.reverse .sipv3-flavor-image{
	order:2;
}

.sipv3-flavor-image{
	background:#FAF8F3;
	border-radius:32px;
	padding:60px;
	text-align:center;
	box-shadow:0 12px 36px rgba(0,0,0,.05);
}

.sipv3-flavor-image img{
	width:74%;
	max-width:360px;
	display:block;
	margin:0 auto;
}

.sipv3-flavor-copy{
	max-width:430px;
}

.sipv3-flavor-copy h3{
	margin:0 0 24px;
	color:#315A3D;
	font-size:34px;
	font-weight:500;
	letter-spacing:.1em;
	line-height:1.5;
}

.sipv3-flavor-copy p:not(.sipv3-kicker){
	margin:0 0 36px;
	color:#6E746F;
	font-size:16px;
	line-height:2.1;
	letter-spacing:.05em;
}

.sipv3-flavor-copy a{
	display:inline-block;
	min-width:190px;
	padding:15px 34px;
	border-radius:999px;
	background:#315A3D;
	color:#fff;
	text-align:center;
	font-size:14px;
	letter-spacing:.08em;
	transition:.3s ease;
}

.sipv3-flavor-copy a:hover{
	background:#263F2F;
	transform:translateY(-2px);
}

/* Special */
.sipv3-special{
	background:#315A3D;
	color:#fff;
	padding:120px 0;
}

.sipv3-special .sipv3-section-head h2{
	color:#fff;
}

.sipv3-special-grid{
	display:grid;
	grid-template-columns:1fr 1fr;
	gap:34px;
}

.sipv3-special-card{
	display:grid;
	grid-template-columns:46% 1fr;
	gap:34px;
	align-items:center;
	min-height:360px;
	padding:40px;
	border:1px solid rgba(255,255,255,.18);
	border-radius:28px;
	background:rgba(255,255,255,.06);
	transition:.35s ease;
}

.sipv3-special-card:hover{
	transform:translateY(-5px);
	background:rgba(255,255,255,.1);
}

.sipv3-special-card img{
	width:100%;
	display:block;
}

.sipv3-special-card h3{
	margin:0 0 16px;
	color:#fff;
	font-size:26px;
	font-weight:500;
	letter-spacing:.08em;
	line-height:1.5;
}

.sipv3-special-card p{
	margin:0 0 30px;
	color:rgba(255,255,255,.82);
	font-size:13px;
	letter-spacing:.08em;
}

.sipv3-special-card span{
	color:#F2DFAE;
	font-size:14px;
	letter-spacing:.08em;
}

/* Price */
.sipv3-price{
	background:#FAF8F3;
	padding:120px 0;
}

.sipv3-price-image{
	max-width:1100px;
	margin:0 auto;
}

.sipv3-price-image img{
	width:100%;
	display:block;
	border-radius:28px;
	box-shadow:0 12px 36px rgba(0,0,0,.05);
}

/* Lifestyle */
.sipv3-lifestyle{
	background:#fff;
	padding:130px 40px;
}

.sipv3-lifestyle-block{
	max-width:1180px;
	margin:0 auto 120px;
	display:grid;
	grid-template-columns:58% 1fr;
	gap:70px;
	align-items:center;
}

.sipv3-lifestyle-block:last-child{
	margin-bottom:0;
}

.sipv3-lifestyle-block.reverse img{
	order:2;
}

.sipv3-lifestyle-block img{
	width:100%;
	display:block;
	border-radius:32px;
	box-shadow:0 12px 36px rgba(0,0,0,.05);
}

/* Support */
.sipv3-support{
	background:#FAF8F3;
	padding:120px 0;
}

.sipv3-support-list{
	max-width:980px;
	margin:0 auto;
}

.sipv3-support-list > div{
	display:grid;
	grid-template-columns:100px 180px 1fr;
	gap:30px;
	padding:38px 0;
	border-top:1px solid #D8CCBA;
	align-items:start;
}

.sipv3-support-list > div:last-child{
	border-bottom:1px solid #D8CCBA;
}

.sipv3-support-list .note{
	margin-top:16px;
	color:#B5655C;
	font-size:12px;
}

/* Regular CTA */
.sipv3-regular-cta{
	background:#fff;
	padding:110px 0;
	text-align:center;
}

.sipv3-regular-cta .sipv3-inner{
	max-width:850px;
}

.sipv3-regular-cta a{
	display:inline-block;
	margin-top:32px;
	padding:16px 42px;
	border:1px solid #315A3D;
	border-radius:999px;
	color:#315A3D;
	font-size:14px;
	letter-spacing:.08em;
	transition:.3s ease;
}

.sipv3-regular-cta a:hover{
	background:#315A3D;
	color:#fff;
}

/* Final CTA */
.sipv3-final-cta{
	background:#315A3D;
	padding:120px 0;
	text-align:center;
	color:#fff;
}

.sipv3-final-cta .sipv3-inner{
	max-width:860px;
}

.sipv3-final-cta h2{
	color:#fff;
}

.sipv3-final-cta p{
	color:rgba(255,255,255,.84);
}

.sipv3-final-cta a{
	display:inline-block;
	margin-top:36px;
	padding:17px 46px;
	border-radius:999px;
	background:#fff;
	color:#315A3D;
	font-size:14px;
	letter-spacing:.08em;
	transition:.3s ease;
}

.sipv3-final-cta a:hover{
	transform:translateY(-2px);
}

/* Tablet */
@media screen and (max-width:1080px){

	.sipv3-two-column,
	.sipv3-flavor-item,
	.sipv3-lifestyle-block{
		gap:48px;
	}

	.sipv3-section-head h2,
	.sipv3-copy h2,
	.sipv3-lifestyle-block h2,
	.sipv3-regular-cta h2,
	.sipv3-final-cta h2{
		font-size:32px;
	}

	.sipv3-value-list{
		gap:28px;
	}

}

/* Smartphone */
@media screen and (max-width:768px){

	.sipv3-inner{
		padding:0 22px;
	}

	.sipv3-section-head{
		margin-bottom:44px;
	}

	.sipv3-section-head h2,
	.sipv3-copy h2,
	.sipv3-lifestyle-block h2,
	.sipv3-regular-cta h2,
	.sipv3-final-cta h2{
		font-size:25px;
		line-height:1.75;
		letter-spacing:.06em;
	}

	.sipv3-kicker{
		font-size:11px;
		margin-bottom:14px;
	}

	.sipv3-forest-statement,
	.sipv3-subscription-value,
	.sipv3-special,
	.sipv3-price,
	.sipv3-support,
	.sipv3-regular-cta,
	.sipv3-final-cta{
		padding:72px 0;
	}

	.sipv3-two-column{
		grid-template-columns:1fr;
		gap:34px;
	}

	.sipv3-copy{
		max-width:none;
		text-align:left;
	}

	.sipv3-copy .sipv3-lead{
		font-size:17px;
		line-height:1.9;
	}

	.sipv3-value-list{
		display:block;
	}

	.sipv3-value-item{
		padding:28px 0;
	}

	.sipv3-value-item:last-child{
		border-bottom:1px solid #D8CCBA;
	}

	.sipv3-value-item h3,
	.sipv3-support-list h3{
		font-size:20px;
	}

	.sipv3-flavors{
		padding:72px 22px;
	}

	.sipv3-flavor-item{
		grid-template-columns:1fr;
		gap:28px;
		margin-bottom:82px;
	}

	.sipv3-flavor-item.reverse .sipv3-flavor-image{
		order:0;
	}

	.sipv3-flavor-image{
		padding:38px 24px;
		border-radius:24px;
	}

	.sipv3-flavor-image img{
		width:82%;
		max-width:300px;
	}

	.sipv3-flavor-copy{
		max-width:none;
		text-align:left;
	}

	.sipv3-flavor-copy h3{
		font-size:26px;
		margin-bottom:18px;
	}

	.sipv3-flavor-copy p:not(.sipv3-kicker){
		font-size:14px;
		line-height:2;
		margin-bottom:26px;
	}

	.sipv3-flavor-copy a{
		width:100%;
		padding:15px 20px;
	}

	.sipv3-special-grid{
		grid-template-columns:1fr;
		gap:22px;
	}

	.sipv3-special-card{
		grid-template-columns:44% 1fr;
		min-height:230px;
		padding:24px;
		gap:20px;
		border-radius:22px;
	}

	.sipv3-special-card h3{
		font-size:18px;
	}

	.sipv3-special-card p,
	.sipv3-special-card span{
		font-size:11px;
	}

	.sipv3-price-image img{
		border-radius:20px;
	}

	.sipv3-lifestyle{
		padding:72px 22px;
	}

	.sipv3-lifestyle-block{
		grid-template-columns:1fr;
		gap:28px;
		margin-bottom:78px;
	}

	.sipv3-lifestyle-block.reverse img{
		order:0;
	}

	.sipv3-lifestyle-block img{
		border-radius:24px;
	}

	.sipv3-support-list > div{
		display:block;
		padding:34px 0;
	}

	.sipv3-support-list span{
		margin-bottom:10px;
	}

	.sipv3-support-list h3{
		margin-bottom:14px;
	}

	.sipv3-support-list p{
		font-size:13px;
		line-height:2;
	}

	.sipv3-regular-cta a,
	.sipv3-final-cta a{
		width:100%;
		padding:16px 20px;
	}

}

/* ==============================
   Ver.3 Hotfix 01
   PC/SP display control
   Layout alignment
   ============================== */

/* PC/SP画像の表示制御 */
.sip-subscription-v3 .spbr{
	display:none !important;
}

.sip-subscription-v3 .pcbr{
	display:block !important;
}

/* 価格画像がPC/SP両方出る問題を修正 */
.sipv3-price-image img.spbr{
	display:none !important;
}

.sipv3-price-image img.pcbr{
	display:block !important;
}

/* 左右ブロックの文字位置を統一 */
.sipv3-flavor-copy{
	display:flex;
	flex-direction:column;
	justify-content:center;
	min-height:420px;
}

.sipv3-flavor-item.reverse .sipv3-flavor-copy{
	margin-left:auto;
	text-align:left;
}

/* 商品セクションの間延びを少し圧縮 */
.sipv3-flavors{
	padding:100px 40px;
}

.sipv3-flavor-item{
	margin-bottom:88px;
}

.sipv3-flavor-image{
	padding:46px;
}

/* 画像のサイズを少し強める */
.sipv3-flavor-image img{
	width:82%;
	max-width:390px;
}

/* Lifestyleの左右位置を統一 */
.sipv3-lifestyle-block > div{
	display:flex;
	flex-direction:column;
	justify-content:center;
	min-height:260px;
}

.sipv3-lifestyle-block.reverse > div{
	text-align:left;
}

/* スマホ */
@media screen and (max-width:768px){

	.sip-subscription-v3 .pcbr{
		display:none !important;
	}

	.sip-subscription-v3 .spbr{
		display:block !important;
	}

	.sipv3-price-image img.pcbr{
		display:none !important;
	}

	.sipv3-price-image img.spbr{
		display:block !important;
	}

	.sipv3-flavors{
		padding:64px 22px;
	}

	.sipv3-flavor-item{
		margin-bottom:64px;
	}

	.sipv3-flavor-copy{
		min-height:auto;
	}

	.sipv3-flavor-item.reverse .sipv3-flavor-copy{
		margin-left:0;
	}

	.sipv3-flavor-image{
		padding:30px 22px;
	}

	.sipv3-flavor-image img{
		width:88%;
		max-width:320px;
	}

	.sipv3-lifestyle-block > div{
		min-height:auto;
	}
}

/* ==============================
   Ver.3 Hotfix 02
   Flavor layout refinement
   ============================== */

.sipv3-flavors{
	padding:90px 40px;
}

.sipv3-flavor-item{
	max-width:1080px;
	grid-template-columns:52% 38%;
	gap:70px;
	margin-bottom:76px;
}

.sipv3-flavor-item.reverse{
	grid-template-columns:38% 52%;
}

.sipv3-flavor-copy{
	width:100%;
	max-width:390px;
	min-height:auto;
	display:flex;
	flex-direction:column;
	justify-content:center;
}

.sipv3-flavor-item:not(.reverse) .sipv3-flavor-copy{
	margin-left:0;
	margin-right:auto;
	text-align:left;
}

.sipv3-flavor-item.reverse .sipv3-flavor-copy{
	margin-left:auto;
	margin-right:0;
	text-align:left;
}

.sipv3-flavor-image{
	padding:42px;
	border-radius:28px;
}

.sipv3-flavor-image img{
	width:86%;
	max-width:410px;
}

.sipv3-flavor-copy h3{
	font-size:31px;
	margin-bottom:18px;
}

.sipv3-flavor-copy p:not(.sipv3-kicker){
	font-size:15px;
	margin-bottom:28px;
}

/* Special Collectionを少し軽く */
.sipv3-special-card{
	min-height:300px;
	padding:34px;
}

.sipv3-special-card img{
	max-width:260px;
	margin:0 auto;
}

/* 最後のCTAを少し強く */
.sipv3-final-cta{
	padding:135px 0;
}

.sipv3-final-cta h2{
	font-size:42px;
}

/* スマホ調整 */
@media screen and (max-width:768px){

	.sipv3-flavors{
		padding:64px 22px;
	}

	.sipv3-flavor-item,
	.sipv3-flavor-item.reverse{
		grid-template-columns:1fr;
		gap:24px;
		margin-bottom:58px;
	}

	.sipv3-flavor-copy,
	.sipv3-flavor-item.reverse .sipv3-flavor-copy,
	.sipv3-flavor-item:not(.reverse) .sipv3-flavor-copy{
		max-width:none;
		margin:0;
		text-align:left;
	}

	.sipv3-flavor-image{
		padding:28px 20px;
		border-radius:22px;
	}

	.sipv3-flavor-image img{
		width:92%;
		max-width:320px;
	}

	.sipv3-final-cta{
		padding:82px 0;
	}

	.sipv3-final-cta h2{
		font-size:27px;
	}
}