:root {
	--white:     #ffffff;
	--dwblue:    #009CDE;
	--blue:      #A3DCF3;
	--bgblue:    #D9F0FA;
	--lightblue: #E5F5FC;
	--lightgray: #F8F7F5;
	--linegray:  #cccccc;
	--gray:      #999999;
	--bggray:    #F9F9F9;
	--darkgray:  #595757;
	--red:       #F53131
}
html {
scroll-padding-top: 137px;
scroll-behavior: smooth;
}
#service .sp{display: block;}
#service .pc{display: none;}
#service section{margin-bottom: 25% !important;}
#service{
	padding: 0;
	overflow: hidden;
}
#service .note{font-size: 10px;}
#service .strong-txt{
	color: var(--dwblue);
	font-weight: bold;
	padding: 1em; font-size: 120%;
	margin-bottom: 1em;
	width: 100%; margin: 0 auto;
	text-align: center;
}
#service strong{font-weight: bold!important; font-size: 120%!important;}
#service .tx-blue{color: var(--dwblue);}
#service .line-gray{border: 1px solid var(--linegray); margin: 5% 0;}

#service .btn-list{
	display: flex;
  justify-content: center;
  align-items: center;
	
}
#service .btn-list li{margin: 0 5px; width: 50%;}
#service .btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;max-width: 300px;
	margin: 0 auto;
  height: 50px;
  background: #fff;
  border: 1px solid var(--darkgray);
  border-radius: 30px;
  box-sizing: border-box;
  padding: 0;
  color: var(--darkgray);
  line-height: 1.2;
  text-align: left;
  text-decoration: none;
  transition-duration: 0.3s;
}
#service .btn:hover {
  background: #fff;
  color: var(--darkgray);
}
#service .btn.bg-blue{background-color: #8ED9FC; color: #fff; border: none;}
#service .btn.bg-blue:hover {
  background: #fff;
  color: #8ED9FC;
	border: 2px solid #8ED9FC;
}
#service .mb{margin-bottom: 5% !important;}
.main-visual{margin-bottom: 2rem;}
.main-txt{margin-bottom: 2rem;font-size: 18px!important;font-weight: bold; color: var(--dwblue); text-align: center;}
.service-index{
	width: 100%;
	margin: 0 auto 15%;
	display: flex;
	justify-content: space-between;
	align-items:stretch;
	flex-wrap: wrap;
	text-align: center;
}
.service-index li{
	width: calc(96% / 2);
	font-size: 12px;
	margin: 0 1% .5rem;
	border: 1px solid var(--darkgray);
	border-radius: 30px;
	text-align: center;
	display: flex;
	align-items: center;
	position: relative;
}
.service-index li a{
	width: 100%; height: 100%;
	display: block; margin: 0 auto;
	padding: .5rem 1rem;text-align: center;
}
.service-index li a::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 14px;
  width: 5px;
  height: 5px;
  margin: auto;
  border-top: 1px solid var(--darkgray);
  border-right: 1px solid var(--darkgray);
  transform: translateY(-2px) rotate(135deg);
  box-sizing: border-box;
}
.service-index li.faq a::after{
	border-left: 1px solid var(--darkgray) !important;
	border-right: none !important;
} 
#service h2{
	line-height: 1;
	color: var(--darkgray);
	font-size: 18px;
	font-weight: bold;
	margin: 0 0 1.5rem;
	padding: 50px  0 20px;
	text-align: center;
	letter-spacing: 2px;
	position: relative;
	border-radius: 30px 30px 0 0;
	background-color: var(--lightgray);
}
#service h2 img {
  font-size: 30px;
  font-size: 3rem;
  line-height: 40px;
  position: absolute;
  z-index: 1;
  top: -40px;
  left: calc(50% - 40px);
  width: 80px;
  height: 80px;
  text-align: center;
}
#service h2 span {
  position: relative;
  z-index: 1;
}

#service-line{
	width: 96%;
	margin: 0 auto;
	max-width: 1200px;
}
.service-contents{
	display: flex;
	max-width: 900px; margin: 0 auto;
	justify-content: flex-start;
	flex-wrap:wrap;
	align-items: flex-start;;
}
.service-contents-box--img{width: 20%; margin-right: 2%;}
.service-contents-box--txt{width: 78%;}

.service-contents-txt{
	margin-bottom: 1rem;
}

.point-table {
	width: 100%;
	margin: 2.5% auto 5%;
	border-spacing: 1px 0;
	border-collapse: separate;
	border-spacing: 5px 0;
}
.point-table th, .point-table td {
	padding: 10px;
}
/*Headerブロック*/
.point-table th {
	position: relative;
	z-index: 1;
	width: 125px;
	height: 50px;
	text-align: center;
	vertical-align: middle;
	border-radius: 5px 5px 0 0;
}
.point-table th:after {
	font-size: 10px;
	position: absolute;
	z-index: -1;
	bottom: -10px;
	left: 46%;
	content: '';
	width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
}
.point-table th.group1 {
	background:var(--linegray); color: var(--darkgray);
}
.point-table th.group1:after {
	border-top: 10px solid var(--linegray);
}
.point-table th.group2 {
	background:  var(--dwblue); color: var(--white);
}
.point-table th.group2:after {
	border-top: 10px solid var(--dwblue);
}
/*メインブロック*/
.point-table tr td {
	padding-top: 15px;
	text-align: center;
	border: none;
}
.point-table tr:last-child td {
	border-radius: 0 0 5px 5px;
}
.point-table tr:nth-child(2n+1) td.group1 {
	background: var(--lightgray); color: var(--darkgray);
}
.point-table tr:nth-child(2n+0) td.group1 {
	background: var(--lightgray); color: var(--darkgray);
}
.point-table tr:nth-child(2n+1) td.group2 {
	background: var(--dwblue); color: var(--white);
}
.point-table tr:nth-child(2n+0) td.group2 {
	background: var(--blue); color: var(--dwblue); font-weight: bold; font-size: 120%;
}

		@media screen and (min-width: 1200px){
			#service .pc{display: inline-block;}
			#service .sp{display: none;}
			#service .note{font-size: 12px;}
			#service .btn{
				 font-size: 16px; letter-spacing: 0.1em;
				line-height: 1.3;
			}
			#service .strong-txt{font-size: 16px;}
			#service section{margin-bottom: 10% !important;}
			#service-line{width: 100%;margin: 0 auto;}
			#service h2{font-size: 24px;padding: 42px  1.5rem;}
			.main-txt{margin-bottom: 2rem;font-size: 24px!important;}
			#service .btn-list li{margin: 0 20px; width: 25%;}
			.service-index{
				width: 100%;
				margin: 0 auto 5%;
				justify-content: flex-start;
			}
			.service-index li{
				width: calc(92% / 4);
				margin:0 1% 1rem;
				font-size: 14px;
			}
			.service-index li a::after {
			  right: 27px;
			  width: 7px;
			  height: 7px;
			  border-top: 2px solid var(--darkgray);
			  border-right: 2px solid var(--darkgray);
			}
			.service-index li.faq a::after{
				border-left: 2px solid var(--darkgray) !important;
				border-right: none !important;
			}
			.service-contents-box--img{width: 15%; margin-right: 20px;}
			.service-contents-box--txt{width: calc(85% - 20px);}
		}