/* CSS Document */
body{
	min-width: 1020px;
}
.contents{
	max-width: 1600px;
	min-width: 1020px;
	margin: -4px auto 0;
  font-family:"Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	text-align:left;
}
.after-f .contents {
	position: relative;
}
@font-face{
  font-family:"Yu Gothic";
  src:local("Yu Gothic Medium");
  font-weight:100;
}
@font-face{
  font-family:"Yu Gothic";
  src:local("Yu Gothic Medium");
  font-weight:200;
}
@font-face{
  font-family:"Yu Gothic";
  src:local("Yu Gothic Medium");
  font-weight:300;
}
@font-face{
  font-family:"Yu Gothic";
  src:local("Yu Gothic Medium");
  font-weight:400;
}
@font-face{
  font-family:"Yu Gothic";
  src:local("Yu Gothic Bold");
  font-weight:bold;
}
#wrap{
	text-align:left;
	overflow:hidden;
	background-color: #fff;
}
.contents p,
.contents h2,
.contents h3,
.contents h4{
	margin: 0px;
	line-height: 1.2em;
}
.contents ul,
.contents li{
	margin: 0px;
	padding: 0px;
	list-style: none;
}
.contents img{
	max-width: 100%;
	height: auto;
}
.contents a img{
	border:none;
}
.footstepBox{
	position: absolute;
	top: 0;
	left: 50%;
	margin-left: -451px;
	z-index: 1000;
	margin-top: 0px;
	margin-bottom: 40px;
	width: 902px;
}
.footstepBox,
.footstepBox a{
	color: #fff !important;
}
.naviBox{
	position: relative;
	z-index: 10;
}
.footerBox{
	margin-top: 100px;
}
.pc_only{
	display: block;
}
.sp_only{
	display: none;
}
@media screen and (max-width: 740px) {
.footstepBox{
	position: unset;
	width: auto;
	margin: 0px 15px;
}
.footerBox{
	margin-top: 0;
}
.contents {
	min-width:320px;
}
.pc_only{
	display: none;
}
.sp_only{
	display: block;
}
}

/* main */
#main{
	position: relative;
	background: #129E7C;
}
#main .inner{
	display: flex;
	align-items: center;
	height: 400px;
	max-width: 1080px;
	margin: 0 auto;
}
#main .img{
	max-width: 480px;
	padding-top: 40px;
}
#main .txt{
	color: #fff;
	font-feature-settings: "palt";
}
#main .txt p{
	color: #fff;
	font-size: 26px;
	font-weight: bold;
}
#main .txt h1{
	color: #fff;
	font-size: 68px;
	font-weight: bold;
	line-height: 1.2;
}
#main .txt h1 span{
	font-size: 60px;
}
@media screen and (max-width: 740px) {
#main .inner{
	flex-direction: column;
	gap: 0;
	height: auto;
	padding: 20px 20px;
}
#main .img{
	max-width: 280px;
	padding-top: 0;
	margin: 0 auto;
}
#main .txt{
	margin-top: 20px;
	text-align: center;
}
#main .txt p{
	font-size: 16px;
}
#main .txt h1{
	font-size: 40px;
	text-align: center;
}
#main .txt h1 span{
	font-size: 30px;
}
}
/* assessment */
.assessment{
	max-width: 880px;
	margin: 72px auto 0;
}
@media screen and (max-width: 740px) {
	.assessment{
		max-width: 400px;
		margin: 40px auto 0;
		padding: 0 20px;
	}
}

/* contact */
.contact{
	max-width: 960px;
	margin: 24px auto 0;
	display: table;
	width: 100%;
}
.contact > div{
	display: table-cell;
	vertical-align: middle;
	width: 50%;
	text-align: center;
	padding: 30px 0;
}
.contact .tel{
	background: #EFEFEF;
}
.contact .tel h3{
	font-size: 18px;
}
.contact .tel .number{
	display: inline-block;
	position: relative;
	padding-left: 40px;
	margin-top: 5px;
}
.contact .tel .number img{
	position: absolute;
	left: 0;
	top: 3px;
}
.contact .tel .number p{
	font-size: 48px;
	font-family: 'Oswald', sans-serif;
	line-height: 1;
}
.contact .tel .number a{
	color: #333;
	text-decoration: none;
}
.contact .tel > p{
	font-size: 15px;
	margin-top: 10px;
}
.contact .tel > p a{
	color: #129E7C;
	text-decoration: underline;
}
.contact .tel > p a:hover{
	text-decoration: none;
}
.contact .line{
	background: #07AE3B;
	color: #fff;
}
.contact .line h3{
	font-size: 34px;
}
.contact .line h3 span{
	font-size: 24px;
}
.contact .line h3 + p{
	font-size: 18px;
	font-weight: bold;
}
.contact .line a{
	display: block;
	max-width: 300px;
	margin: 10px auto 0;
	background: #fff;
	font-size: 18px;
	color: #07AE3B;
	font-weight: bold;
	padding: 15px 0;
}
.contact .line a:hover{
	text-decoration: none;
	opacity: .8;
}
.contact .line a + p{
	font-size: 13px;
	margin-top: 5px;
}
@media screen and (max-width: 740px) {
.contact{
	display: block;
	margin: 16px auto 0;
}
.contact > div{
	display: block;
	width: 100%;
	padding: 15px 0;
}
.contact .tel h3{
	font-size: 14px;
}
.contact .tel .number{
	padding-left: 25px;
	margin-top: 3px;
}
.contact .tel .number img{
	top: 3px;
	width: 20px;
}
.contact .tel .number p{
	font-size: 34px;
}
.contact .tel > p{
	font-size: 13px;
	margin-top: 5px;
}
.contact .line h3{
	font-size: 22px;
}
.contact .line h3 span{
	font-size: 18px;
}
.contact .line h3 + p{
	font-size: 14px;
}
.contact .line a{
	max-width: 300px;
	margin: 5px auto 0;
	font-size: 16px;
}
.contact .line a + p{
	font-size: 13px;
	margin-top: 5px;
}
}

/* lead */
#lead{
	text-align: center;
}
#lead p{
	position: relative;
	font-size: 28px;
	font-weight: bold;
	background: #FCE37A;
	padding: 40px 40px 30px 40px;
}
#lead p::before{
	content: "";
	display: block;
	position: absolute;
	left: 50%;
	top: 100%;
	transform: translateX(-50%) rotate(-90deg);
	-ms-transform: translateX(-50%) rotate(-90deg);
	box-sizing: border-box;
	width: 30px;
	height: 30px;
	border: 30px solid transparent;
	border-right: 30px solid #FCE37A;
}
#lead p strong{
	display: block;
	font-size: 45px;
	padding: 5px 0;
	line-height: 1.2;
}
#lead p sup{
	font-size: 20px;
}
#lead p span{
	font-size: 14px;
	font-weight: normal;
}
#lead h2{
	display: inline-block;
	font-size: 70px;
	margin-top: 80px;
	border-bottom: 12px solid #FCE37A;
	line-height: 1.1;
}
#lead h2 span{
	font-size: 50px;
}
@media screen and (max-width: 740px) {
#lead p{
	font-size: 16px;
	padding: 20px 20px 20px 20px;
}
#lead p::before{
	width: 20px;
	height: 20px;
	border: 20px solid transparent;
	border-right: 20px solid #FCE37A;
}
#lead p strong{
	font-size: 30px;
	padding: 5px 0;
}
#lead p sup{
	font-size: 12px;
}
#lead p span{
	font-size: 12px;
}
#lead h2{
	font-size: 40px;
	margin-top: 40px;
	border-bottom: 8px solid #FCE37A;
}
#lead h2 span{
	font-size: 30px;
}
}

/* section */
section{
	margin-top: 100px;
}
section .inner{
	padding: 80px 40px 0;
	margin: 0 auto;
}
section .ttl{
	position: relative;
	background: #129E7C;
	text-align: center;
	color: #fff;
	padding: 40px 0;
}
section .ttl::before{
	content: "";
	display: block;
	position: absolute;
	left: 50%;
	top: 100%;
	transform: translateX(-50%) rotate(-90deg);
	-ms-transform: translateX(-50%) rotate(-90deg);
	box-sizing: border-box;
	width: 30px;
	height: 30px;
	border: 30px solid transparent;
	border-right: 30px solid #129E7C;
}
section .ttl h2{
	font-size: 40px;
}
@media screen and (max-width: 740px) {
section{
	margin-top: 60px;
}
section .inner{
	padding: 40px 20px 0;
}
section .ttl{
	padding: 30px 0;
}
section .ttl::before{
	width: 20px;
	height: 20px;
	border: 20px solid transparent;
	border-right: 20px solid #129E7C;
}
section .ttl h2{
	font-size: 22px;
}
}

/* sec1 */
#sec1 .inner{
	max-width: 960px;
}
#sec1 h3{
	text-align: center;
	color: #129E7C;
	font-size: 26px;
}
#sec1 .img{
	text-align: center;
	margin-top: 40px;
}
#sec1 p{
	font-size: 16px;
	line-height: 2;
	margin-top: 30px;
}
@media screen and (max-width: 740px) {
#sec1{
	margin-top: 0;
}
#sec1 h3{
	font-size: 18px;
}
#sec1 .img{
	margin-top: 20px;
}
#sec1 p{
	font-size: 14px;
	line-height: 1.8;
	margin-top: 20px;
}
}

/* sec2 */
#sec2 .inner{
	max-width: 1100px;
}
#sec2 ul{
	font-size: 0;
	margin-top: -4%;
}
#sec2 ul li{
	display: inline-block;
	vertical-align: top;
	width: 22.274%;
	margin: 40px 3.634% 0 0;
}
#sec2 ul li:nth-child(4n){
	margin-right: 0;
}
#sec2 ul li h3{
	font-size: 16px;
	margin-top: 5px;
}
#sec2 ul li p{
	font-size: 14px;
	margin-top: 5px;
}
#sec2 ul li p span{
	color: #129E7C;
	font-weight: bold;
	font-size: 18px;
}
@media screen and (max-width: 740px) {
#sec2 ul li{
	width: 48%;
	margin: 20px 4% 0 0;
}
#sec2 ul li:nth-child(2n){
	margin-right: 0;
}
#sec2 ul li h3{
	font-size: 14px;
	margin-top: 5px;
}
#sec2 ul li p{
	font-size: 13px;
	margin-top: 3px;
}
#sec2 ul li p span{
	font-size: 16px;
}
}

/* sec3 */
#sec3 h3{
	text-align: center;
	color: #129E7C;
	font-size: 26px;
}
#sec3 .img{
	text-align: center;
	max-width: 800px;
	margin: 30px auto 0;
	text-align: right;
}
#sec3 ul{
	display: inline-block;
	margin: 10px 0 0 auto;
	text-align: right;
}
#sec3 ul li{
	text-align: left;
	font-size: 12px;
	margin-top: 5px;
}
#sec3 ul li:first-child{
	margin-top: 0;
}
@media screen and (max-width: 740px) {
#sec3{
	margin-top: 0;
}
#sec3 h3{
	font-size: 18px;
}
#sec3 .img{
	max-width: 375px;
	margin: 30px auto 0;
}
#sec3 ul li{
	font-size: 11px;
	margin-top: 2px;
}
}

/* sec4 */
#sec4 .inner{
	max-width: 960px;
	margin: 0 auto;
}
#sec4 ul{
	font-size: 0;
	margin-top: -40px;
}
#sec4 ul li{
	position: relative;
	display: inline-block;
	vertical-align: top;
	width: 33.333%;
	margin-top: 40px;
}
#sec4 ul li::before{
	content: "";
	position: absolute;
	right: 100%;
	top: 75px;
	width: 56px;
	height: 56px;
	background-image: url("../images/arrow_icon_01.svg");
	transform: translateX(50%);
}
#sec4 ul li:first-child::before{
	display: none;
}
#sec4 ul li .icon{
	width: 192px;
	height: 192px;
	background: #F1F9F7;
	margin: 0 auto;
	border-radius: 50%;
}
#sec4 ul li .txt{
	margin-top: 15px;
}
#sec4 ul li .txt h3{
	font-size: 20px;
	text-align: center;
}
#sec4 ul li .txt p{
	font-size: 14px;
	line-height: 2;
	margin-top: 5px;
	padding: 0 30px
}
#sec4 ul li .txt p a{
	color: #129E7C;
	text-decoration: underline;
}
#sec4 ul li .txt p a:hover{
	text-decoration: none;
}
@media screen and (max-width: 740px) {
#sec4 ul{
	margin-top: -20px;
}
#sec4 ul li{
	display: block;
	width: 100%;
	margin-top: 20px;
	box-sizing: border-box;
	padding-left: 120px;
	min-height: 110px;
}
#sec4 ul li::before{
	right: auto;
	left: 33px;
	top: 95px;
	width: 35px;
	height: 35px;
	background-size: cover;
	transform: translateX(0) rotate(90deg);
}
#sec4 ul li:first-child::before{
	display: block;
}
#sec4 ul li:last-child::before{
	display: none;
}
#sec4 ul li .icon{
	position: absolute;
	left: 0;
	top: 0;
	width: 100px;
	height: 100px;
}
#sec4 ul li .txt{
	margin-top: 0;
	padding-top: 10px;
}
#sec4 ul li .txt h3{
	font-size: 16px;
	text-align: left;
}
#sec4 ul li .txt p{
	font-size: 13px;
	line-height: 1.8;
	margin-top: 5px;
	padding: 0;
}
}

/* sec5 */
#sec5 .inner{
	max-width: 960px;
	margin: 0 auto;
}
#sec5 .col2{
	display: table;
	width: 100%;
	border-left: 2px solid #e4e4e4;
}
#sec5 .col2 .col{
	display: table-cell;
	vertical-align: top;
	width: 50%;
	box-sizing: border-box;
	padding: 30px 50px;
	border-right: 2px solid #e4e4e4;
}
#sec5 .col2 .col h3{
	font-size: 20px;
	line-height: 1;
}
#sec5 .col2 .col.check h3{
	color: #129E7C;
}
#sec5 .col2 .col h3 img{
	position: relative;
	top: -2px;
	vertical-align: middle;
	margin-right: 15px;
}
#sec5 .col2 .col ul{
	margin-top: 30px;
}
#sec5 .col2 .col ul li{
	font-size: 16px;
	font-weight: bold;
	line-height: 1.2;
	margin-top: 10px;
	margin: 15px 0 0 1.3em;
	text-indent: -1.3em;
}
#sec5 .col2 .col ul li:first-child{
	margin-top: 0;
}
#sec5 .col2 .col ul li::before{
	content: "● ";
}
#sec5 .col2 .col.check ul li::before{
	color: #129E7C;
}
@media screen and (max-width: 740px) {
#sec5{
	margin-top: 0;
}
#sec5 .col2{
	display: block;
	border-bottom: 2px solid #e4e4e4;
	border-left: none;
}
#sec5 .col2 .col{
	display: block;
	width: 100%;
	padding: 30px 20px;
	border-top: 2px solid #e4e4e4;
	border-right: none;
}
#sec5 .col2 .col h3{
	font-size: 16px;
}
#sec5 .col2 .col h3 img{
	width: 30px;
}
#sec5 .col2 .col ul{
	margin-top: 20px;
}
#sec5 .col2 .col ul li{
	font-size: 14px;
	margin: 15px 0 0 1.3em;
}
}

/* sec6 */
#sec6 .inner{
	max-width: 1000px;
	margin: 0 auto;
	font-size: 0;
}
#sec6 .col2 .col{
	display: inline-block;
	vertical-align: top;
	width: 48%;
	margin-right: 4%;
}
#sec6 .col2 .col:nth-child(2n){
	margin-right: 0;
}
#sec6 .col2 .col h3{
	font-size: 18px;
	margin: 60px 0 0 1.3em;
	text-indent: -1.3em;
}
#sec6 .col2 .col p{
	font-size: 14px;
	margin-top: 10px;
	line-height: 1.2;
}
#sec6 .col2 .col ul{
	margin-top: 10px;
}
#sec6 .col2 .col ul li{
	font-size: 14px;
	line-height: 1.2;
	margin: 10px 0 0 1em;
	text-indent: -1em;
}
@media screen and (max-width: 740px) {
#sec6 .col2 .col{
	display: block;
	width: 100%;
	margin-right: 0;
}
#sec6 .col2 .col:first-child h3:first-child{
	margin-top: 0;
}
#sec6 .col2 .col h3{
	font-size: 14px;
	margin: 30px 0 0 1.3em;
	text-indent: -1.3em;
}
#sec6 .col2 .col p{
	font-size: 13px;
	margin-top: 10px;
}
#sec6 .col2 .col ul{
	margin-top: 10px;
}
#sec6 .col2 .col ul li{
	font-size: 13px;
	line-height: 1.2;
}
}

/* pageTop */
#pageTop{
	padding:0px 10px 10px;
	background-color:#00a3d9;
	position:fixed;
	bottom:40px;
	right:0px;
	cursor:pointer;
	color:#FFF;
	font-weight:bold;
	line-height:1.2em;
	text-align:center;
	z-index:300;
}
#pageTop i{
	display:block;
	font-size:24px;
	line-height:1.2em;
}
#pageTop span{
	font-family: 'Open Sans', sans-serif;
	font-size:14px;
}
@media screen and (max-width: 740px) {
#pageTop{
	bottom:0px;
}
#pageTop i{
	font-size:20px;
	line-height:1em;
}
#pageTop span{
	font-size:10px;
}
#pageTop span br{
	display:none;
}
}

html:has(body.inquiry) {
  margin-top: 80px;
}
body.inquiry #msHeader {
  height: 80px;
  box-shadow: none;
}
body.inquiry #msHeader .hInner {
  padding-top: 0;
}
body.inquiry #msHeader .hLogo {
  top: 32px;
}
@media screen and (max-width: 750px) {
  html:has(body.inquiry) {
    margin-top: 48px;
  }
  body.inquiry #msHeader {
    height: 48px;
  }
  body.inquiry #msHeader .hLogo {
    top: 24px;
    left: 0;
    width: 220px;
    height: 20px;
  }
  body.inquiry #msHeader .hLogo a {
    height: 20px;
  }
  body.inquiry #msHeader .hLogo a::before {
    width: 220px;
    height: 20px;
  }
}
body.inquiry .floating {
  display: none;
}
body.inquiry .inner {
  position: relative;
  max-width: 1600px;
  margin: auto;
}

body.inquiry .footstepBox {
  width: 620px;
  margin-bottom: 24px;
  font-size: 10px;
  color: #333;
  overflow-x: auto;
}

body.inquiry .footstepBox a {
  color: #333;
}

body.inquiry .footstepBox a:visited {
  color: #333;
}

@media screen and (max-width: 960px) {
  body.inquiry .inner {
    padding: 0;
  }
  body.inquiry .footstepBox {
    width: 95%;
    left: 10px;
  }
}
