@charset "utf-8";
/*===========================
add
===========================*/
:root {
	--basic-color:#54b4e7;
}
:root {
	--basic-color2:#358fc0;
}



/*===========================
title-af-none
===========================*/
.title-af-none{
	text-shadow: none;
}
.title-af-none:after{
	content: none;
}

.title-sahdow-none{
	text-shadow: none;
}



/*===========================
title
===========================*/
.titlebox{
  position: relative;
}

.box01 h3{
  margin-bottom: 35px;
  color: var(--basic-color);
}

.box01 h3:after {
	content: '';
	position: absolute;
	bottom: -10px;
	display: inline-block;
	width: 100%;
	height: 14px;
	left: 50%;
	transform: translateX(-50%);
	background-color: #f1faff !important;
	border-radius: 0;
	-webkit-border-radius: 0;
	-moz-border-radius: 0;
}

.title1{
  position: relative;
  padding: 0.5rem 1rem calc(0.5rem + 10px);
  font-size: 1.6em;
  text-align: center;
  margin-bottom: 15px;
}

.title1:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 10px;
  content: '';
  border-top: 2px solid var(--basic-color);
  background-image: -webkit-repeating-linear-gradient(135deg, #54b4e7, #54b4e7 1px, transparent 2px, transparent 5px);
  background-image: repeating-linear-gradient(-45deg, #54b4e7, #54b4e7 1px, transparent 2px, transparent 5px);
  background-size: 7px 7px;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  background-color: none!important;
}

@media screen and (max-width: 768px) {
  .title1{
    font-size: 1.4em;
  }
}

@media screen and (max-width: 600px) {
  .title1{
    font-size: 1.2em;
  }
}



/*===========================
txtInd2
===========================*/
.txtInd2{
  padding-left: 1.7em;
  text-indent: -1.7em;
}


/*===========================

===========================*/
@media screen and (max-width: 768px) {
  ul.tabw100 li{
    width: 100%;
  }
}



/*===========================
f-wrap-cen
===========================*/
.f-wrap-cen .f-item1-3{
  margin-right: 3%;
}

.f-wrap-cen .f-item1-3:nth-child(3n),
.f-wrap-cen .f-item1-3:last-child{
  margin-right: 0 !important;
}



/*===========================
table
===========================*/
.tdColor{
  background-color: #e7e7e7 !important;
}



/*===========================
ptxt01
===========================*/
.ptxt01 {
  position: relative;
  display: inline-block;
  padding: 0 55px;
  font-size: 150%;
  color: var(--basic-color);
  font-weight: bold;
}
.ptxt01:before{
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 44px;
  height: 2px;
  background-color:var(--basic-color);
  -webkit-transform: rotate(-1200deg);
  transform: rotate(-1200deg);
}
.ptxt01:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 44px;
  height: 2px;
  background-color:var(--basic-color);
  -webkit-transform: rotate(-60deg);
  transform: rotate(-60deg);
}
.ptxt01:before {
  left:0;
}
.ptxt01:after {
  right: 0;
}

@media screen and (max-width: 768px) {
  .ptxt01 {
    font-size: 120%;
  }
}




/*===========================
font
===========================*/
.fw-b{font-weight: bold;}



/*===========================
title-af-none
===========================*/
.title-af-none{
	text-shadow: none;
}
.title-af-none:after{
	content: none;
}

.title-sahdow-none{
	text-shadow: none;
}



/*===========================
width
===========================*/
.w150px{
 width: 150px;
}

.w150px-center{
 width: 150px;
 margin: 0 auto;
}

.w200px{
 width: 200px;
}


.w100p,
li.w100p{
	width: 100% !important;
	display: block;
}


@media screen and (max-width: 768px) {
	.w100Tablet{
		width: 100% !important;
		box-sizing: border-box;
	}
	
	.w90Tablet{
		width: 90% !important;
		box-sizing: border-box;
	}

	.w80Tablet{
		width: 80% !important;
		box-sizing: border-box;
	}

  .w70Tablet{
		width: 70% !important;
		box-sizing: border-box;
	}

  .w70Tabletsp{
		width: 70% !important;
		box-sizing: border-box;
	}

	.w50Tablet{
		width: 50% !important;
		box-sizing: border-box;
	}
}

@media screen and (max-width: 600px) {
	.w100sp,
	.w90Tablet,
	.w80Tablet,
  .w70Tablet,
	.w50Tablet{
		width: 100% !important;
		box-sizing: border-box;
	}

 .w90sp{
		width: 90% !important;
		box-sizing: border-box;
	}

	.w70sp{
		width: 70% !important;
		box-sizing: border-box;
	}

	.width-sp-50 img{
		width: 50% !important;
	}
}



/*===========================
wf
===========================*/
.wf-t-all ,ul.wf-t-all {
	width: fit-content;
	margin: auto;
}

@media screen and (min-width: 769px) {
	ul.wf-t,
  ol.wf-t{
		width: fit-content;
		margin: auto;
	}
}

@media screen and (min-width: 601px) {
	p.wf-pcONspOFF,
  ul.wf-pcONspOFF {
		width: fit-content !important;
		margin: auto !important;
	}
}

.wf-t-right ,ul.wf-t-right {
	width: fit-content;
	margin: auto 0 auto auto;
}



/*===========================
margin
===========================*/

@media screen and (min-width: 601px) {
	.mgt-pctablt20{
		padding-top: 20px !important;
	}

  .mgb-sp20{
		margin-bottom: 0 !important;
	}
}

@media screen and (max-width: 768px) {
	.mgt-tablt20{
		padding-top: 20px !important;
	}

 .mgb-tablt10{
		padding-bottom: 10px !important;
	}
 .mgb-tablt20{
		padding-bottom: 20px !important;
	}
}

@media screen and (max-width: 600px) {

  .mgt-sp20{
		margin-top: 20px !important;
	}
  
	.mgb-sp10{
		margin-bottom: 10px !important;
	}

	.mgb-sp20{
		margin-bottom: 20px !important;
	}

	.mgb-sp40{
		margin-bottom: 40px !important;
	}
}



/*===========================
OnOff
===========================*/
.pcOFFtabletONspOFF{display: none !important;}
.pcOFFtabletOFFspON{display: none;}

@media screen and (min-width: 769px) {
	.pcOFFtabletONspON{display: none !important;}
}

@media screen and (max-width: 768px) {
	.pcOFFtabletONspOFF{display: block !important;}
	.pcOFFtabletOFFspON{display: none;}
	.pcONtabletOFFspOFF{display: none !important;}
	.pcONtabletOFFspON{display: none;}
}

@media screen and (max-width: 600px) {
	.pcOFFtabletONspOFF{display: none !important;}
	.pcOFFtabletOFFspON{display: block;}
	.pcONtabletONspOFF{display: none;}
	.pcONtabletOFFspON{display: block;}
	span.pcONtabletOFFspON{display: inline !important;}
}