@charset "utf-8";

/* ----------------------------------------------------
    共通
---------------------------------------------------- */
html {
	scroll-behavior: smooth;
}
body {
	max-width: inherit;
	height: 100%;
	background-attachment: fixed;
}
.main {
	font-family: 'ヒラギノ角ゴシック','Hiragino Sans','Meiryo UI',sans-serif;
	font-weight: 400;
	line-height: 1.7;
	font-size: 20px;
	color:#333;
	background-color: #fff;
	text-align: justify;
	font-feature-settings: "palt";
	overflow-x: hidden;
	max-width: 600px; /*横幅調整*/
	margin: 0 auto;
	box-shadow: 0 0 8px #ccc;
}
img {
	margin: 0 auto;
	width: 100%;
	height: auto;
}
.inner {
	width: 724px;
	margin: 0 auto;
}

@media screen and (max-width: 640px) {
	img {
		max-width: 100%;
		height: auto;
	}
	body {
		width: 100%;
	}
	.inner {
		width: 94%;
	}
}

/* ----------------------------------------------------
    CTA
---------------------------------------------------- */
.btn {
	transition: all .2s;
	filter: drop-shadow(5px 5px 5px rgba(153,153,153,0.75));
	position: absolute;
	width: 85%; /*要調整*/
	left: 50%;
	transform: translateX(-50%);
	bottom: 22%; /*要調整*/
}
.btn:hover {
	opacity: 0.8;
}
.cta02 .btn {
	bottom: 23%; /*要調整*/
}
.cta03 .btn {
	bottom: 20.5%; /*要調整*/
}
.cta {
	position: relative;
}

/* ----------------------------------------------------
    footer
---------------------------------------------------- */
.footer {
	background-color: #3A6C99;
	color: #fff;
	padding: 30px 0;
	font-size: 14px;
	font-weight: 200;
	text-align: center;
	font-family: 'ヒラギノ角ゴシック','Hiragino Sans','Meiryo UI',sans-serif;
}
.footer-link {
	width: 92%;
	margin: 0 auto;
}
.footer-link a {
	color: #fff;
	text-decoration: none;
	display: inline-block;
}
.copy-right {
	margin-top: 16px;
	text-align: center;
}

/* ----------------------------------------------------
    商品情報（お支払い方法・商品詳細・ご注意・販売元）
---------------------------------------------------- */
.product-info {
	background-color: #fff;
	padding: 0 0 2em;
	font-size: 16px;
	color: #333;
}
.product-info .info-block {
	margin-bottom: 0;
}
.product-info .info-heading {
	font-size: 1em;
	font-weight: 600;
	background-color: #d4e8f0;
	color: #333;
	margin: 0;
	padding: 0.75em 1em;
	border: none;
}
.product-info .info-block > *:not(.info-heading) {
	padding: 1em 1em 1.2em;
	margin: 0;
	background-color: #fff;
}
.product-info .info-list {
	list-style: none;
	padding-left: 1em;
	margin: 0;
}
.product-info .info-list li {
	position: relative;
	padding-left: 1em;
	margin-bottom: 0.4em;
}
.product-info .info-list li:last-child {
	margin-bottom: 0;
}
.product-info .info-list-square li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.5em;
	width: 0.35em;
	height: 0.35em;
	background-color: #333;
}
.product-info .info-list-hyphen li::before {
	content: "－";
	position: absolute;
	left: 0;
	color: #333;
}
.product-info .product-detail {
	display: block;
	margin: 0;
	border-top: 1px solid #ddd;
}
.product-info .product-detail dt,
.product-info .product-detail dd {
	margin: 0;
	padding: 0.6em 0;
	display: block;
}
.product-info .product-detail dt {
	font-weight: 600;
	float: left;
	width: 8em;
	min-height: 1px;
	clear: left;
	line-height: 1.6;
}
.product-info .product-detail dd {
	position: relative;
	margin-left: 8em;
	padding: 0.6em 0 0.6em 0.5em;
	overflow: visible;
	line-height: 1.6;
}
.product-info .product-detail dd::after {
	content: "";
	position: absolute;
	left: -8em;
	right: 0;
	bottom: 0;
	border-bottom: 1px solid #ddd;
}
.product-info .info-text {
	margin: 0;
}

/* ----------------------------------------------------
    購入確認ボタン（lp03用）
---------------------------------------------------- */
.buy-conf {
	display: block !important;
	margin: 20px auto 0 !important;
	width: 100% !important;
	height: 50px !important;
	line-height: 10px !important;
	cursor: pointer !important;
	font-size: 22px !important;
	font-family: inherit !important;
	font-weight: bold !important;
	vertical-align: middle !important;
	border-radius: 5px !important;
	text-decoration: none !important;
	color: #fff !important;
	background: linear-gradient(#64d549, #28a108) !important;
	border: 1px solid #41b723 !important;
}

.lp03-confirm-btn {
	display: block;
	margin: 0 auto;
	width: 100%;
	height: 50px;
	line-height: 10px;
	cursor: pointer;
	font-size: 22px;
	font-family: inherit;
	font-weight: bold;
	vertical-align: middle;
	border-radius: 5px;
	text-decoration: none;
	color: #fff;
	background: linear-gradient(#64d549, #28a108);
	border: 1px solid #41b723;
	margin-top: 20px;
}