@charset "utf-8";

#contents {
	color: #333333;
	text-align: center;
	padding: 0;
	font-size: 14px;
	line-height: 1.6;
}

#contents .inner {
	width: 100%;
}

.display-sp {
	display: none;
}

.display-pc {
	display: block;
}

.content-wrap a {
	color: #0074ff;
	text-decoration: underline;
}

#footer {
	margin-top: 100px;
}

/* 終了対応 */
.end_txt {
	padding: 15px 0 0 0;
	font-weight: bold;
	color: #FF0004;
	font-size: 150%;
}

/* spanテキスト */
span.bold_txt {
	font-weight: bold;
}

span.em_txt {
	color: #ff0000;
}

span.large_txt {
	font-size: 18px;
}

span.caution_txt {
	font-size: 0.7em;
	vertical-align: text-top;
}

/*角丸ブロック*/
.ly-round {
	border-radius: 8px;
}

/* ============== LP =================== */
/*  top  */
.top_ttl {
	background: repeating-linear-gradient(90deg, #93e0ff, #93e0ff 33px, #a4e5ff 33px, #a4e5ff 49px);
	position: relative;
	z-index: 1;
}
@media screen and (min-width: 1200px) {
	.top_ttl::after {
		content: "";
		position: absolute;
		width: 100%;
		height: 63px;
		background-color: #fff;
		top: 21px;
		left: 0;
		right: 0;
		margin: auto;
		z-index: -1;
	}
}

/*  nav */
.nav {
	width: 100%;
	background-color: #d7f3ff;
}

.nav_list {
	display: flex;
	justify-content: center;
	align-items: center;
}

.nav_list_item {
	height: 65px;
	padding: 15px;
	cursor: pointer;
}

.nav_list_item:hover {
	background-color: #f0fbff;
}

.nav_list_item img {
	height: 100%;
}

/* btn共通 */
.btn_wrap {
	width: calc(100% - 60px);
	max-width: 840px;
	margin: 40px auto 0;
}

.btn_list {
	display: flex;
	gap: 20px;
}

.btn a {
	width: 100%;
}

.btn a:hover img {
	opacity: 0.7;
}

.btn_att {
	margin-top: 20px;
	text-align: left;
}

.btn_att .note-txt {
	text-indent: -2.5em;
	padding-left: 2.5em;
}

/* main */
main {
	margin-top: 60px;
}

/* sec共通 */
.sec {
	padding: 0 30px;
}

.sec_inner {
	max-width: 970px;
	margin: 0 auto;
}

/* about */
.about_index {
	white-space: nowrap;
}

.about_panel {
	margin-top: -38px;
	padding: 45px 5px 50px;
	display: flex;
	justify-content: center;
	align-items: flex-end;
	flex-wrap: nowrap;
	gap: 2.5%;
	border: 1px solid #0074be;
	background-image: url(https://pntc.sslcs.cdngc.net/cdn/campaign/research_all/img/bg_about.png);
	background-size: 230px;
	background-position: top 20px center;
}

.about_panel::before {
	content: "";
	display: block;
	width: 102px;
	height: 137px;
	background-image: url(https://pntc.sslcs.cdngc.net/cdn/campaign/research_all/img/pic_phone.png);
	background-size: contain;
	background-position: center bottom;
	;
	background-repeat: no-repeat;
}

.about_txt+.about_txt {
	margin-top: 2rem;
}

/* point */
.point {
	margin-top: 80px;
	padding: 0 0 50px;
	background-color: #d7f3ff;
}

.point_inner {
	width: calc(100% - 60px);
	margin-top: 40px;
}

.point_ttl {
	padding: 20px 0;
	background-color: #0074be;
}

.point_list_item {
	text-align: left;
	overflow: hidden;
}

.point_list_item+.point_list_item {
	margin-top: 40px;
}

.point_list_head {
	padding-right: 30px;
	display: grid;
	grid-template-columns: 120px 1fr 57px;
	justify-content: flex-start;
	align-items: center;
	gap: 25px;
	background-color: #a9e6ff;
}

.point_list_head::after {
	content: "";
	width: 100%;
	height: 40px;
	background-image: url(https://pntc.sslcs.cdngc.net/cdn/campaign/research_all/img/bg_point-ttl.png);
}

.point_list_num {
	padding: 20px 0;
	text-align: center;
	background-color: #93e0ff;
}

.point_list_body {
	padding: 30px 30px 30px 40px;
	display: grid;
	grid-template-columns: auto 50%;
	align-items: center;
	gap: 40px;
	background-color: #fff;
}

.point_list_txt {
	font-size: 16px;
}

.point_list_example {
	display: inline-block;
}

.point_list_example li {
	display: flex;
	gap: 0 1rem;
	white-space: nowrap;
	flex-wrap: wrap;
}

.point_list_item_02 .point_list_example li:first-of-type {
	gap: 0 2.4rem;
}

.point_list_img {
	background-color: #f0f0f0;
	text-align: center;
}

.point_list_item_01 .point_list_img {
	padding: 20px 30px;
}

.point_list_item_02 .point_list_img {
	padding: 20px;
}

.point_list_item_03 .point_list_img {
	padding: 20px 50px 25px 55px;
}

/* att */
.att {
	margin: 80px auto 0;
	text-align: left;
	overflow: hidden;
}

.att_acd {
	border-radius: 8px;
	text-align: center;
	border: 1px solid #006cb6;
	overflow: hidden;
}

.att_acd+.att_acd {
	margin-top: 25px;
}

.att_ttl {
	height: 50px;
	display: flex;
	position: relative;
	justify-content: center;
	flex-direction: column;
	color: #006cb6;
	background-color: #fff;
	text-align: center;
	font-size: 18px;
	font-weight: bold;
	border-radius: 8px;
	line-height: 30px;
	cursor: pointer;
}

.att_ttl.open {
	border-radius: 8px 8px 0 0;
}

.att_ttl::before {
	content: '';
	width: 30px;
	height: 30px;
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	background-color: #0074be;
	border-radius: 50%;
	z-index: 2;
}

.acd_icon {
	position: absolute;
	right: 25px;
	top: 50%;
	transform: translateY(-50%);
	z-index: 3;
}

.acd_icon::before,
.acd_icon::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	background-color: #fff;
	transition: .3s;
}

.acd_icon::before {
	width: 3px;
	height: 18px;
}

.acd_icon::after {
	width: 18px;
	height: 3px;
}

.att_ttl.open .acd_icon::before {
	transform: translate(-50%, -50%) rotate(-90deg);
}

.att_list {
	margin: 0 auto;
	padding: 30px 40px;
	display: none;
	background-color: #fff;
	text-align: left;
	border-top: 1px solid #006cb6;
}

.att_item+.att_item {
	margin-top: 30px;
}

.att_item_ttl {
	margin-bottom: 15px;
	padding-left: 1.5em;
	position: relative;
	font-size: 14px;
	font-weight: bold;
	line-height: 1.3;
}

/*「●」タイプのリスト用*/
.att_item_ttl::before {
	content: "";
	display: block;
	background-color: #025fb4;
	border-radius: 50%;
	width: 14px;
	height: 14px;
	position: absolute;
	top: 2px;
	left: 0;
}

.att_item_inner p {
	margin-top: 10px;
}

.att_item_inner .note-txt {
	margin-top: 0;
}

.att_item_img {
	text-align: center;
	margin: 20px auto;
}

.att_list-style {
	text-indent: -1em;
	margin-top: 10px;
	padding-left: 1em;
}

.att_num-style {
	text-indent: -1.4em;
	margin-top: 10px;
	padding-left: 1.5em;
	counter-reset: number 0;
}

.att_num-style>li::before {
	counter-increment: number 1;
	content: "(" counter(number) ")";
}

.att_small-unit {
	margin: 10px auto;
}

.att_list-style .att_small-unit {
	text-indent: 0;
}

.att_list-style li>.att_list-style,
.att_list-style li>.att_num-style,
.att_num-style li>.att_list-style,
.att_num-style li>.att_num-style,
.att_small-unit .att_list-style,
.att_small-unit .att_num-style {
	margin-top: 0;
	margin-bottom: 10px;
}

.att_list-style li>.att_num-style,
.att_num-style li>.att_num-style {
	transform: translateX(-0.2em);
}

.att_small-unit .att_list-style,
.att_small-unit .att_num-style {
	margin-left: 0.5em;
}

.att_item_fwb {
	font-weight: bold;
}

.att_item_ftem {
	color: #f50028;
	font-weight: bold;
}

.att_img {
	text-align: center;
}

/* info */
.info {
	margin-top: 80px;
	text-align: center;
}

.info_list_item+.info_list_item {
	margin-top: 50px;
}

.info_balloon {
	max-width: 455px;
	margin: 0 auto 25px;
}

.info_list_item_01 .info_balloon {
	max-width: 455px;
}

.info_list_item_01 .info_balloon {
	max-width: 465px;
}

.info_img {
	margin: 0 auto;
	max-width: 730px;
}

.info_img a {
	display: block;
	border: 1px solid #F0F0F0;
}
.info_img a:hover {
	opacity: 0.7;
}

/* follow_btn */
.follow_btn {
	width: 100vw;
	padding: 20px 30px;
	position: fixed;
	bottom: 0;
	background-color: #ffffff99;
	transform: translateY(5px);
	opacity: 0;
	transition: .5s;
	z-index: -1;
}
.follow_btn .btn::before {
	content: "";
	width: 100%;
	height: calc(100% - 6px);
	margin: 2px 0;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	background-color: #fff;
	border-radius: 10px;
	z-index: -1;
}
.follow_btn.show {
	opacity: 1;
	transform: translateY(0);
	z-index: 100;
}

.follow_btn .btn_wrap {
	margin-top: 0;
}

/* コンテンツ（SP：767px以下）
========================================================*/
@media screen and (max-width: 767px) {

	/* ============== 共通 =================== */
	.display-pc {
		display: none;
	}

	.display-sp {
		display: block;
	}

	#footer {
		margin-top: 50px;
	}

	/* spanテキスト */
	span.large_txt {
		font-size: 16px;
	}

	/* ============== LP =================== */
	/* header */
	header {
		margin-top: 30px;
		display: grid;
		gap: 50px;
	}

	/* nav */
	.nav {
		grid-row: 2;
	}

	.nav_list {
		flex-wrap: wrap;
	}

	.nav_list_item {
		flex-basis: 50%;
		border: 0.5px solid #93e0ff;
		outline: 0.5px solid #93e0ff;
	}

	/* btn共通 */
	.btn_wrap {
		width: calc(100% - 30px);
		margin-top: 0;
	}

	.btn_list {
		display: block;
	}

	.btn_list_item+.btn_list_item {
		margin-top: 20px;
	}

	/* sec共通 */
	.sec {
		padding: 0 15px;
	}

	/* about */
	.about_panel {
		margin-top: -6.7%;
		padding: 45px 25px 35px;
		text-align: left;
	}

	.about_panel::before {
		display: none;
	}

	.about_index {
		white-space: inherit;
	}

	.about_ponta {
		display: none;
	}

	/* point */
	.point {
		margin-top: 50px;
		padding: 0 0 40px;
	}

	.point_inner {
		width: calc(100% - 30px);
		margin-top: 30px;
	}

	.point_ttl {
		padding: 15px 25px;
	}

	.point_list_item+.point_list_item {
		margin-top: 30px;
	}

	.point_list_head {
		padding-right: 10px;
		grid-template-columns: 17.9% 1fr 8.4%;
		gap: 10px;
	}

	.point_list_head::after {
		height: 100%;
		background-size: contain;
		background-position: top 6px center;
		background-repeat: no-repeat;
	}

	.point_list_num {
		height: 100%;
		padding: 6px 15px;
	}

	.point_list_num * {
		height: 100%;
	}

	.point_list_body {
		padding: 25px;
		grid-template-columns: 100%;
		gap: 20px;
	}

	.point_list_txt {
		font-size: 14px;
	}

	.point_list_example {
		font-size: 11px;
	}

	.point_list_item_01 .point_list_example li {
		grid-template-columns: 160px auto auto;
	}

	.point_list_item_02 .point_list_example li {
		grid-template-columns: 170px auto auto;
	}

	.point_list_item_01 .point_list_img {
		padding: 10px 30px;
	}

	.point_list_item_02 .point_list_img {
		padding: 10px 20px;
	}

	.point_list_item_03 .point_list_img {
		padding: 15px 40px;
	}

	/* att */
	.att {
		margin-top: 50px;
		padding: 0 15px;
	}

	.att_ttl {
		height: 40px;
		font-size: 14px;
	}

	.att_ttl::before {
		right: 9px;
		width: 22px;
		height: 22px;
	}

	.acd_icon {
		right: 20px;
	}

	.acd_icon::before {
		width: 2px;
		height: 11px;
	}

	.acd_icon::after {
		width: 11px;
		height: 2px;
	}

	.att_list {
		padding: 30px 15px;
	}

	.att_item+.att_item {
		margin-top: 40px;
	}

	.att_item_ttl {
		margin-bottom: 10px;
		padding-left: 1.5em;
	}

	.att_item_inner p,
	.att_list-style {
		margin-top: 5px;
	}

	.att_item+.att_item {
		margin-top: 40px;
	}

	.att_item_ttl {
		margin-bottom: 10px;
		padding-left: 1.5em;
	}

	.att_item_inner p,
	.att_list-style {
		margin-top: 5px;
	}

	/* info */
	.info_list_item+.info_list_item {
		margin-top: 40px;
	}

	.info_img {
		margin-top: 20px;
		flex-direction: column;
	}

	/* follow_btn */
	.follow_btn {
		padding: 10px 17px;
	}

	.follow_btn .btn_wrap {
		width: 100%;
		margin: 0;
	}

	.follow_btn .btn_list_item+.btn_list_item {
		margin-top: 10px;
	}
}