/* ==============================
   SIP SAP Trial Page Ver.1.0
   Design Language 1.0
   ============================== */

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

.sip-trial-v1 *{
	box-sizing:border-box;
}

.sip-trial-v1 a{
	color:inherit;
	text-decoration:none;
}

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

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

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

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

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

.spbr{
	display:none;
}

/* Hero */
.sipsap2026-hero{
	width:100%;
	margin:0 0 56px;
	overflow:hidden;
	background:#FAF8F3;
}

.sipsap2026-hero picture,
.sipsap2026-hero img{
	display:block;
	width:100%;
}

.sipsap2026-hero img{
	height:auto;
}

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

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

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

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

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

/* First Set */
.trial-first-set{
	background:#FAF8F3;
	padding:115px 0;
}

.trial-first-visual{
	max-width:980px;
	margin:0 auto 48px;
	padding:28px;
	background:#fff;
	border:1px solid #E8E2D8;
	border-radius:30px;
	box-shadow:0 18px 44px rgba(0,0,0,.06);
}

.trial-first-visual img{
	width:100%;
	display:block;
	border-radius:22px;
}

.trial-flavor-symbols{
	max-width:920px;
	margin:0 auto 28px;
	display:flex;
	flex-wrap:wrap;
	justify-content:center;
	gap:12px;
}

.trial-flavor-symbols span{
	display:inline-flex;
	align-items:center;
	justify-content:center;
	min-width:118px;
	padding:10px 18px;
	border:1px solid #D8CCBA;
	border-radius:999px;
	background:#fff;
	color:#315A3D;
	font-size:12px;
	font-weight:500;
	letter-spacing:.08em;
	line-height:1.4;
}

.trial-small-message{
	margin:0;
	text-align:center;
	color:#B89A5A;
	font-size:14px;
	letter-spacing:.08em;
}

/* Flavors */
.trial-flavors{
	background:#fff;
	padding:115px 0;
}

.trial-flavor-grid{
	display:grid;
	grid-template-columns:repeat(3,1fr);
	gap:30px;
	max-width:1120px;
	margin:0 auto;
}

.trial-flavor-card{
	padding:34px 28px 36px;
	border-radius:28px;
	background:#FAF8F3;
	text-align:center;
	box-shadow:0 12px 36px rgba(0,0,0,.05);
}

.trial-flavor-card img{
	width:100%;
	max-width:260px;
	display:block;
	margin:0 auto 24px;
	border-radius:18px;
}

.trial-flavor-card p{
	margin:0 0 8px;
	color:#B89A5A;
	font-size:11px;
	font-weight:600;
	letter-spacing:.16em;
	line-height:1.5;
}

.trial-flavor-card h3{
	margin:0 0 14px;
	color:#315A3D;
	font-size:22px;
	font-weight:500;
	letter-spacing:.08em;
	line-height:1.5;
}

.trial-flavor-card span{
	display:block;
	color:#6E746F;
	font-size:13px;
	letter-spacing:.04em;
	line-height:1.8;
}

/* Flow */
.trial-flow{
	background:#315A3D;
	color:#fff;
	padding:120px 0;
}

.trial-flow .trial-section-head h2{
	color:#fff;
}

.trial-flow-list{
	display:grid;
	grid-template-columns:repeat(4,1fr);
	gap:22px;
	max-width:1180px;
	margin:0 auto;
}

.trial-flow-list > div{
	position:relative;
	min-height:260px;
	padding:34px 28px;
	border:1px solid rgba(255,255,255,.22);
	border-radius:28px;
	background:rgba(255,255,255,.08);
	box-shadow:0 18px 44px rgba(0,0,0,.12);
}

.trial-flow-list > div:not(:last-child)::after{
	content:"";
	position:absolute;
	top:50%;
	right:-18px;
	width:14px;
	height:14px;
	border-top:1px solid rgba(242,223,174,.8);
	border-right:1px solid rgba(242,223,174,.8);
	transform:translateY(-50%) rotate(45deg);
}

.trial-flow-list span{
	display:block;
	margin-bottom:22px;
	color:#F2DFAE;
	font-size:12px;
	font-weight:600;
	letter-spacing:.16em;
}

.trial-flow-list h3{
	margin:0 0 20px;
	color:#fff;
	font-size:22px;
	font-weight:500;
	letter-spacing:.08em;
	line-height:1.6;
}

.trial-flow-list p{
	margin:0;
	color:rgba(255,255,255,.82);
	font-size:14px;
	letter-spacing:.04em;
	line-height:2;
}

.trial-flow-list strong{
	color:#fff;
	font-size:18px;
	font-weight:500;
}

.trial-note{
	margin:34px auto 0;
	max-width:880px;
	color:#8A8177;
	font-size:12px;
	letter-spacing:.04em;
	line-height:2;
	text-align:center;
}

.trial-flow .trial-note{
	color:rgba(255,255,255,.7);
}

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

.trial-price-box{
	max-width:1080px;
	margin:0 auto;
	padding:58px 60px;
	border:1px solid #E8E2D8;
	border-radius:32px;
	background:#fff;
	text-align:center;
	box-shadow:0 18px 44px rgba(0,0,0,.06);
}

.trial-price-box h2{
	margin-bottom:44px;
}

.trial-price-grid{
	display:grid;
	grid-template-columns:1fr 1fr;
	gap:28px;
}

.trial-price-grid > div{
	padding:38px 28px;
	border-radius:26px;
	background:#FAF8F3;
}

.trial-price-grid span{
	display:block;
	margin-bottom:14px;
	color:#B89A5A;
	font-size:12px;
	font-weight:600;
	letter-spacing:.16em;
}

.trial-price-grid h3{
	margin:0 0 12px;
	color:#315A3D;
	font-size:30px;
	font-weight:500;
	letter-spacing:.08em;
}

.trial-price-grid p{
	margin:0 0 18px;
	color:#6E746F;
	font-size:14px;
	letter-spacing:.06em;
}

.trial-price-grid strong{
	color:#315A3D;
	font-size:30px;
	font-weight:500;
	letter-spacing:.04em;
}

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

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

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

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

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

.trial-lifestyle-block > div{
	display:flex;
	flex-direction:column;
	justify-content:center;
	min-height:260px;
}

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

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

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

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

.trial-support-list span{
	display:block;
	color:#B89A5A;
	font-size:13px;
	font-weight:600;
	letter-spacing:.18em;
}

.trial-support-list h3{
	margin:0;
	color:#315A3D;
	font-size:22px;
	font-weight:500;
	letter-spacing:.08em;
	line-height:1.6;
}

.trial-support-list p{
	margin:0;
	max-width:620px;
	color:#6E746F;
	font-size:14px;
	line-height:2.1;
	letter-spacing:.04em;
}

.trial-guide-links{
	margin:44px auto 0;
	display:flex;
	justify-content:center;
	gap:16px;
}

.trial-guide-links a{
	display:inline-block;
	padding:14px 30px;
	border:1px solid #315A3D;
	border-radius:999px;
	color:#315A3D;
	font-size:13px;
	letter-spacing:.08em;
	transition:.3s ease;
}

.trial-guide-links a:hover{
	background:#315A3D;
	color:#fff;
}

/* Final CTA */
.trial-final-cta{
	background:linear-gradient(135deg,#315A3D,#213528);
	padding:125px 0 135px;
	text-align:center;
	color:#fff;
}

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

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

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

.trial-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;
}

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

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

	.trial-two-column,
	.trial-lifestyle-block{
		gap:48px;
	}

	.trial-section-head h2,
	.trial-copy h2,
	.trial-price-box h2,
	.trial-lifestyle-block h2,
	.trial-final-cta h2{
		font-size:32px;
	}

	.trial-flow-list{
		grid-template-columns:repeat(2,1fr);
	}

	.trial-flow-list > div:not(:last-child)::after{
		display:none;
	}
}

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

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

	.spbr{
		display:block;
	}

	.sipsap2026-hero{
		margin-bottom:44px;
	}

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

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

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

	.trial-statement,
	.trial-first-set,
	.trial-flavors,
	.trial-flow,
	.trial-price,
	.trial-support,
	.trial-final-cta{
		padding:72px 0;
	}

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

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

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

	.trial-first-visual{
		padding:12px;
		border-radius:22px;
		margin-bottom:32px;
	}

	.trial-first-visual img{
		border-radius:16px;
	}

	.trial-flavor-symbols{
		gap:8px;
		margin-bottom:24px;
	}

	.trial-flavor-symbols span{
		min-width:auto;
		padding:8px 13px;
		font-size:11px;
	}

	.trial-flavor-grid{
		grid-template-columns:1fr;
		gap:22px;
	}

	.trial-flavor-card{
		padding:26px 20px 30px;
		border-radius:22px;
	}

	.trial-flavor-card img{
		max-width:300px;
	}

	.trial-flow-list{
		grid-template-columns:1fr;
		gap:18px;
	}

	.trial-flow-list > div{
		min-height:auto;
		padding:28px 24px;
		border-radius:22px;
	}

	.trial-flow-list h3{
		font-size:20px;
	}

	.trial-price-box{
		padding:34px 22px;
		border-radius:24px;
	}

	.trial-price-grid{
		grid-template-columns:1fr;
		gap:18px;
	}

	.trial-price-grid > div{
		padding:30px 20px;
		border-radius:20px;
	}

	.trial-price-grid h3,
	.trial-price-grid strong{
		font-size:25px;
	}

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

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

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

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

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

	.trial-support-list > div{
		display:block;
		padding:32px 0;
	}

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

	.trial-support-list h3{
		margin-bottom:14px;
		font-size:20px;
	}

	.trial-support-list p{
		max-width:none;
		font-size:13px;
		line-height:2;
	}

	.trial-guide-links{
		display:block;
	}

	.trial-guide-links a{
		display:block;
		width:100%;
		text-align:center;
		margin-bottom:12px;
	}

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