@charset "utf-8";
/* CSS Document */

/* ==========================================
	seal ▼
========================================== */

dt,dd {
	line-height: 3rem;
}

.top-bg {
	/*background: #f2f2f2;*/
	text-align: center;
	margin: 0 -999rem;
	padding: 5.0rem 999rem 4rem;
}
.top-img + dl {
	text-align: center;
	padding: 6.0rem 0 7.5rem;
}
.top-img + dl dt {
	border-bottom: 4px solid #7bd779;
	display: inline-block;
	font-size: 2.3rem;
	font-weight: 900;
	letter-spacing: 0.6rem;
	padding:  0 2.0rem 2.0rem;
	margin-bottom: 5.0rem;
}
.top-img + dl dd {
	font-size: 1.6rem;
	text-align: left;
}
h2 {
	font-size: 2.3rem;
	font-weight: 900;
	padding-bottom: 2rem;
}
h2 span {
	display: block;
	font-size: 5.7rem;
	font-weight: 400;
}
h2 span:first-letter {
	color: #7bd779;
}
h2+p {
	font-size: 2.0rem;
  padding: 0 1.5rem;
}

.title-w {
	background: url(../img/seal-title-bg.jpg) repeat -50px;
	margin: 0 -999rem;
	padding: 0 999rem;
}

h3 {
	color: #fff;
	font-size: 1.5rem;
	font-weight: 400;
	letter-spacing: 0.3rem;
	padding: 3.0rem 8.5rem;
}
h3 span {
	display: block;
	font-size: 2.9rem;
	font-weight: 900;
}
/* ==========================================
	point-01 ▼
========================================== */
.point-01 h3 {
	background: url(../img/seal-point-01.jpg) no-repeat left center;
}
.point-01 > dl::before {
	content: "";
	background: url(../img/seal-bg-02.jpg) no-repeat center center;
	background-size: contain;
	display: block;
	margin: 0 -999rem 6.5rem;
	padding: 0 999rem 0rem;
  height: 495px;
}

.point-01 > dl dt {
	font-size: 2.0rem;
	font-weight: 900;
	margin-bottom: 1rem;
}
.point-01 > dl dd {
	font-size: 1.6rem;
	padding: 2.0rem 0 5.0rem;
}
.point-01 > dl dd span {
  color: #e00a14;
  display: block;
  font-size: 1.8rem;
}

.point-01 > ul li > dl {
	padding-bottom: 8rem;
}
.point-01 > ul li > dl::after {
	content: "などさまざま";
	font-size: 1.8rem;
}
.point-01 > ul li > dl dt {
	background: url(../img/seal-check-01.jpg) no-repeat center left;
	background-position: 0px 0px;
	border-bottom: 3px solid #7bd779;
	font-size: 2.0rem;
	font-weight: 600;
	height: 7.5rem;
	padding: 0 0 0 11rem;
	margin-bottom: 2.5rem;
	vertical-align: middle;
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center; /* 縦方向中央揃え（Safari用） */
	align-items: center; /* 縦方向中央揃え */
	bottom: 1rem;
}
.point-01 > ul:nth-of-type(1) li > dl dt {
	padding-bottom: 1rem;
}
.point-01 > ul:nth-of-type(2) li:last-child > dl dt {
	padding-bottom: 1rem;
}
.point-01 > ul li:nth-of-type(2) > dl dt {
	background: url(../img/seal-check-02.jpg) no-repeat center left;
	background-position: 0px 0px;
}
.point-01 > ul li:nth-of-type(3) > dl dt {
	background: url(../img/seal-check-03.jpg) no-repeat center left;
	background-position: 0px 0px;
}
.point-01 > ul:nth-of-type(2) li:nth-of-type(1) > dl dt {
	background: url(../img/seal-check-04.jpg) no-repeat center left;
	background-position: 0px 0px;
}
.point-01 > ul:nth-of-type(2) li:nth-of-type(2) > dl dt {
	background: url(../img/seal-check-05.jpg) no-repeat center left;
	background-position: 0px 0px;
}
.point-01 > ul:nth-of-type(2) li:nth-of-type(3) > dl dt {
	background: url(../img/seal-check-06.jpg) no-repeat center left;
	background-position: 0px 0px;
}
.point-01 > ul li > dl dd {
	font-size: 2.0rem;
	padding-left: 5.0rem;
}
.point-01 > ul li > dl dd {
	margin-bottom: 2.0rem;
}
.point-01 > ul li > dl dd span {
	font-size: 1.6rem;
}

.check {
	background: url(../img/check.jpg) no-repeat center left;
}
.check-none {
	background: url(../img/check-none.jpg) no-repeat center left;
}


/* ==========================================
	point-02 ▼
========================================== */
.point-02 {
}
.point-02 h3 {
	background: url(../img/seal-point-02.jpg) no-repeat left center;
}

.point-02-w {
	background: url(../img/decoration-bg.jpg) repeat center;
	margin: 0 -999rem;
	padding: 11.5rem 999rem 13.0rem;
}
.point-02-w > table {
	background: #fff;
}
.point-02-w > table th {
	border: 1px solid #7bd779;
	font-size: 2.0rem;
	font-weight: 400;
	text-align: center;
	padding: 3.0rem 0;
}
.point-02-w > table td {
	border: 1px solid #7bd779;
	padding: 3.0rem;
}
.point-02-w > table td span {
	display: block;
	font-size: 1.6rem;
	margin-top: 1rem;
}
.point-02-w > table td span b {
	font-size: 1.6rem;
  font-weight: 600;
}

/* ==========================================
	point-03 ▼
========================================== */
.point-03 h3 {
	background: url(../img/seal-point-03.jpg) no-repeat left center;
}

.point-03-w {
	background: #fff;
	border: 1px solid #7bd779;
	margin: 8.0rem 0 12rem;
}
.point-03-w > label {
	border-bottom: 1px solid #7bd779;
	display: block;
	font-size: 2.0rem;
	padding: 2.0rem;
}
.point-03-w > dl dt {
  font-size: 1.8rem;
  font-weight: 400;
}
.point-03-w > dl dt img {
  margin: 0;
}
.point-03-w > dl dd {
	font-size: 1.6rem;
}
.point-03-w .finish {
  padding: 4.0rem 0 2.0rem;
}
.point-03-w .finish::after {
  content: "";
  clear: both;
  display: table;
}
.point-03-w .finish dt {
  background: #f2f1ef;
  display: inline-block;
  font-size: 2.0rem;
  font-weight: 500;
  padding: 0.5rem 2.0rem;
  margin-bottom: 2.0rem;
}


/* ドロップダウン ▼ */
label::before {
		font-family: 'FontAwesome';
    content: "\f13a";
    color: #7bd779;
    font-size: 24px;
    margin-right: 5.0rem;
}
input[type="checkbox"].on-off{
	display: none;
}
.point-03-w dl {
	-webkit-transition: all 0.5s;
	-moz-transition: all 0.5s;
	-ms-transition: all 0.5s;
	-o-transition: all 0.5s;
	transition: all 0.5s;
}
input[type="checkbox"].on-off + label + dl {
	height: 0;
	overflow: hidden;
}
input[type="checkbox"].on-off:checked + label + dl {
	height: auto;
	padding: 5.0rem 3.0rem;
}
input[type="checkbox"].on-off:checked + label::before {
		font-family: 'FontAwesome';
    content: "\f139";
}

/* ==========================================
	point-04 ▼
========================================== */
.point-04 {
	background: url(../img/decoration-bg.jpg) repeat center;
  margin: 0 -999rem;
  padding: 0 999rem 12rem;
}
.point-04 h3 {
	background: url(../img/seal-point-04.jpg) no-repeat left center;
}


.point-04-w {
	background: #fff;
	border: 1px solid #7bd779;
	margin-top: 8rem;
}
.point-04-w > label {
	border-bottom: 1px solid #7bd779;
	display: block;
	font-size: 2.5rem;
	padding: 3.0rem;
}
.point-04-inner > dl {
	margin-bottom: 3rem;
}
.point-04-inner > dl dd {
	font-size: 2.0rem;
}
.point-04-inner > dl dd strong {
	display: block;
	font-size: 2.0rem;
}

/* ドロップダウン ▼ */
label::before {
		font-family: 'FontAwesome';
    content: "\f13a";
    color: #7bd779;
    font-size: 24px;
    margin-right: 5.0rem;
}
input[type="checkbox"].on-off{
	display: none;
}
.point-04-inner  {
	-webkit-transition: all 0.5s;
	-moz-transition: all 0.5s;
	-ms-transition: all 0.5s;
	-o-transition: all 0.5s;
	transition: all 0.5s;
}
input[type="checkbox"].on-off + label + .point-04-inner {
	height: 0;
	overflow: hidden;
}
input[type="checkbox"].on-off:checked + label + .point-04-inner {
	height: auto;
	padding: 5.0rem 3.0rem;
}
input[type="checkbox"].on-off:checked + label::before {
		font-family: 'FontAwesome';
    content: "\f139";
}

/* ==========================================
	Ipad～ ▼
========================================== */

@media (max-width: 767px) {
	.top-bg {
		padding: 4rem 999rem;
	}
	.top-img + dl,
	.point-01 > dl
	{
		padding-right:  1.5rem;
		padding-left:  1.5rem;
	}
  .point-01 > dl::before {
  object-fit: cover;
  height: 200px;
  height: 30vh;
  }
	.point-02-w > table
	{
    margin: 0 1.5rem;
	}
	.point-03-w {
    margin: 8.0rem 1.5rem 12rem;
	}
	.point-04-w {
		margin: 8rem 1.5rem 0;
	}
	.point-01 h3,
	.point-02 h3,
	.point-03 h3,
	.point-04 h3
	{
		background: #7bd779;
		padding: 1.0rem;
	}
	h3::before {
		content: "POINT1";
		background: #fff;
		-webkit-border-radius: 5px;/* for Safari and Chrome */
		-moz-border-radius: 5px; /* for Firefox */
		-o-border-radius: 5px; /* for opera */
		border-radius: 5px;
		color: #4f7ad2;
		display: inline-block;
		font-weight: 600;
		padding: 0.3rem;
		margin-right: 0.5rem;
	}
	.point-02 h3::before {
		content: "POINT2";
	}
	.point-03 h3::before {
		content: "POINT3";
	}
	.point-04 h3::before {
		content: "POINT4";
	}
	h3 span {
		font-size: 2.3rem;
	}
	
	.point-02-w > table th {
    padding: 1rem 0;
	}
	.point-02-w > table td {
    padding: 1rem;
}
}

/* ==========================================
	iphone5～ ▼
========================================== */

/*@media (max-width: 375px) {
	h3 span {
		font-size: 2.0rem;
	}
}*/
@media (max-width: 320px) {
	h3 span {
		font-size: 1.7rem;
	}
}