@charset "utf-8";
/* CSS Document */

/* ヘッダー ----------*/
.customPage .articleHeader h1 {
	background-color: #F6F6F6;
	font-family: "Noto Serif JP", serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-weight: 700;
	padding: 10px 15px;
}
.customPage .articleHeader h1 + div {
	align-items: stretch;
	display: flex;
	justify-content: space-between;
	padding: 5px 0;
}
.customPage .articleHeader .cats {
	display: flex;
	order: 1;
}
.customPage .articleHeader .cats .cat {
	color: #E671B3;
}
.customPage .articleHeader .timestamp {
	order: 2;
	padding: 0;
}
.customPage .articleHeader .lead {
	background-color: unset;
	padding: 0;
	text-align: justify;
}
.customPage .articleHeader .lead .cats .cat a {
	color: #E671B3;
	text-decoration: underline;
}
.customPage .articleHeader .lead p span {
	display: block;
}
@media screen and (max-width: 768px) {
	.customPage .articleHeader h1 {
		padding: 10px 3%;
	}
	.customPage .articleHeader h1 + div {
		padding: 5px 3%;
	}
	.customPage .articleHeader .lead {
		padding: 0 3%;
	}
}

/* セクション（目次） ----------*/
.customPage .toc {
	background-color: #FAFCFC;
	border: 1px solid #DCDCDC;
	margin: clamp(20px,3.9vw,30px) auto;
	border-radius: 5px;
	padding: 20px;
	
}
.customPage .toc div {
	border-bottom: 1px dotted #DCDCDC;
	color: #E671B3;
	font-size: 20px;
	font-weight: 500;
	margin-bottom: 20px;
	padding-bottom: 10px;
	text-align: center;
}
.customPage .toc div span {
	background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgLTk2MCA5NjAgOTYwIiB3aWR0aD0iMjRweCIgaGVpZ2h0PSIyNHB4IiBmaWxsPSIjRTY3MUIzIj48cGF0aCBkPSJNMTIwLTI4MHYtODBoNTYwdjgwSDEyMFptMC0xNjB2LTgwaDU2MHY4MEgxMjBabTAtMTYwdi04MGg1NjB2ODBIMTIwWm02ODAgMzIwcS0xNyAwLTI4LjUtMTEuNVQ3NjAtMzIwcTAtMTcgMTEuNS0yOC41VDgwMC0zNjBxMTcgMCAyOC41IDExLjVUODQwLTMyMHEwIDE3LTExLjUgMjguNVQ4MDAtMjgwWm0wLTE2MHEtMTcgMC0yOC41LTExLjVUNzYwLTQ4MHEwLTE3IDExLjUtMjguNVQ4MDAtNTIwcTE3IDAgMjguNSAxMS41VDg0MC00ODBxMCAxNy0xMS41IDI4LjVUODAwLTQ0MFptMC0xNjBxLTE3IDAtMjguNS0xMS41VDc2MC02NDBxMC0xNyAxMS41LTI4LjVUODAwLTY4MHExNyAwIDI4LjUgMTEuNVQ4NDAtNjQwcTAgMTctMTEuNSAyOC41VDgwMC02MDBaIi8+PC9zdmc+");
	background-position: left top 4px;
	background-repeat: no-repeat;
	background-size: 24px;
	padding-left: 30px;
}
.customPage .toc div span b {
	font-size: 14px;
}
.customPage .toc ul {
	counter-reset: section-counter;
	list-style: none;
	padding-left: 0;
}
.customPage .toc ul > li {
	counter-increment: section-counter;
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 15px;
	position: relative;
}
.customPage .toc ul > li:has(ol) {
	margin-bottom: 0;
}
.customPage .toc ul > li::before {
	align-items: center;
	background-color: #DB9EC8;
	border-radius: 12px;
	color: #FFF;
	content: counter(section-counter);
	display: flex;
	height: 24px;
	justify-content: center;
	margin-right: 10px;
	width: 24px;
}
.customPage .toc ul > li > a {
	width: calc(100% - 34px);
}
.customPage .toc ul li ol {
	margin-bottom: 15px;
	padding: 10px 10px 10px 34px;
	width: 100%;
}
.customPage .toc ul li ol li:not(:last-of-type) {
	margin-bottom: 10px;
}
@media screen and (max-width: 768px) {
	.customPage .toc {
		padding: clamp(10px,2.6vw,20px);
	}
	.customPage .toc ul li ol {
		padding: 10px 10px 10px clamp(5px,1.3vw,10px);
	}
}

/* ポップアップ ----------*/
.popup {
	align-items: center;
	background-color: #FFEBF1;
	border-radius: 100px;
	display: flex;
	justify-content: center;
	margin-bottom: 30px !important;
	padding: 10px 15px !important;
	position: relative;
	text-align: center !important;
	width: 100%;
}
.popup::before {
	background: #FFEBF1;
	bottom: -20px;
	clip-path: polygon(0 0, 100% 0%, 50% 100%);
	content: '';
	display: inline-block;
	height: 30px;
	left: calc((100% - 40px) / 2);
	position: absolute;
	width: 40px;
}
.popup br {
	display: none;
}
@media screen and (max-width: 768px) {
	.popup br {
		display: block
	}
}

/* セクション共通 ----------*/
.customPage section:not(.toc):not(.section_related) a:not(.btn) {
    color: #004DFE;
    text-decoration: underline;
}
.customPage section:not(.socialMedia) h2 {
	background: linear-gradient(to right, #DF89B5, #BFD9FE);
	color: #FFF;
	letter-spacing: 0.06em;
	padding: 8px;
	text-align: justify;
}
.customPage section:not(.socialMedia) h2 span {
	font-size: 12px;
	font-weight: 400;
	margin-left: 10px;
}
.customPage section h3 {
	text-align: justify;
}
.customPage section:not(.section_faq) h3 {
	border-bottom: 1px dashed #000;
	margin-bottom: 10px;
	padding-bottom: 5px;
	width: 100%;
}
.customPage section p {
	margin-bottom: 10px;
}
.customPage section p:last-of-type {
	margin-bottom: 0;
}
.customPage section .checkMark {
	bottom: -1px;
	color: #FF1493;
	font-size: 120%;
	font-weight: 900;
	margin-right: 5px;
	position: relative;
}
.customPage section > img {
	margin: 10px auto 20px auto;
}
.customPage .scrollArea:has(table) {
	margin: 20px auto;
}
/*テーブル*/
.customPage section table {
	border-top: 1px solid #CCC;
	border-collapse: separate;
	border-spacing: 0;
	width: 100%;
}
.customPage section table thead {
	background-color: #F5F5F5;
}
.customPage section table thead tr th {
	min-width: 100px;
	text-align: center;
}
.customPage section table thead tr th,
.customPage section table tbody tr td {
	border-bottom: 1px solid #CCC;
	border-right: 1px solid #CCC;
	padding: 10px;
}
.customPage section table thead tr th:first-of-type,
.customPage section table tbody tr td:first-of-type {
	background-color: #F5F5F5;
	border-left: 1px solid #CCC;
	border-right: 1px solid #CCC;
	left: 0;
	position: sticky;
	width: 100px;
}
.customPage section table tbody tr td:first-of-type {
	text-align: center;
}
@media screen and (max-width: 480px) {
	.customPage section h2 {
		padding: 8px 2%;
	}
	.customPage section table {
		min-width: max-content;
	}
	.customPage section table thead tr th:not(:first-of-type),
	.customPage section table tbody tr td:not(:first-of-type) {
		max-width: 250px;
	}
}

/* セクション（おすすめのブラ） ----------*/
.customPage .section_recommend .prods .prod h3 {
	margin-bottom: 15px;
	padding-bottom: 10px;
}
.customPage .section_recommend .prods .prod h3 span {
	font-weight: 400;
}
.customPage .section_recommend .prods .prod {
	margin-bottom: 30px;
}
.customPage .section_recommend .prods .prod .prodImgs {
	align-items: flex-start;
	display: flex;
	justify-content: space-between;
	margin-bottom: 10px;
}
.customPage .section_recommend .prods .prod .prodImgs img {
	border-radius: 5px;
	width: 49%;
}
.customPage .section_recommend .prods .prod .prodDesc {
	margin-bottom: 15px;
}
.customPage .section_recommend .prods .prod .btn {
	max-width: 200px;
}
.customPage .section_recommend .prods .prod .btn span {
	background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgLTk2MCA5NjAgOTYwIiB3aWR0aD0iMjRweCIgaGVpZ2h0PSIyNHB4IiBmaWxsPSIjRkZGIj48cGF0aCBkPSJNMjIzLjUtMTAzLjVRMjAwLTEyNyAyMDAtMTYwdDIzLjUtNTYuNVEyNDctMjQwIDI4MC0yNDB0NTYuNSAyMy41UTM2MC0xOTMgMzYwLTE2MHQtMjMuNSA1Ni41UTMxMy04MCAyODAtODB0LTU2LjUtMjMuNVptNDAwIDBRNjAwLTEyNyA2MDAtMTYwdDIzLjUtNTYuNVE2NDctMjQwIDY4MC0yNDB0NTYuNSAyMy41UTc2MC0xOTMgNzYwLTE2MHQtMjMuNSA1Ni41UTcxMy04MCA2ODAtODB0LTU2LjUtMjMuNVpNMjQ2LTcyMGw5NiAyMDBoMjgwbDExMC0yMDBIMjQ2Wm0tMzgtODBoNTkwcTIzIDAgMzUgMjAuNXQxIDQxLjVMNjkyLTQ4MnEtMTEgMjAtMjkuNSAzMVQ2MjItNDQwSDMyNGwtNDQgODBoNDgwdjgwSDI4MHEtNDUgMC02OC0zOS41dC0yLTc4LjVsNTQtOTgtMTQ0LTMwNEg0MHYtODBoMTMwbDM4IDgwWm0xMzQgMjgwaDI4MC0yODBaIi8+PC9zdmc+");
	background-position: left 50%;
	background-repeat: no-repeat;
	background-size: auto 100%;
	padding-left: 25px;
}

/* セクション（よくある質問） ----------*/
.customPage .section_faq .acc dl:not(:last-of-type) {
	margin-bottom: 10px;
}

.customPage .section_faq .acc dt {
	background-color: #EEE;
	cursor: pointer;
	padding: 10px;
}
.customPage .section_faq .acc dt h3 {
	font-size: clamp(12px,1.8vw,14px);
	font-weight: 400;
	margin-bottom: 0;
}
.customPage .section_faq .acc dd {
	background-color: #F5F5F5;
	cursor: pointer;
	max-height: 0;
	overflow: hidden;
	padding: 0 10px;
	transition: max-height 0.3s ease, padding 0.3s ease;
}
.customPage .section_faq .acc dl.is-open dd {
	max-height: 500px;
	padding: 10px;
}
.customPage .section_faq .acc dt h3 span,
.customPage .section_faq .acc dd p span {
	color: #FA226E;
	margin-right: 5px;
}