@charset "UTF-8";
/* CSS Document */

/*セクション間余白----------------------------------------------------------- */
section {
  padding: 100px 0;
}

footer {
  padding: 45px 0;
}

/*色関連----------------------------------------------------------- */
.bg_cl1 {
  background-color: #00aabb;
}

.bg_cl2 {
  background-color: #fafafa;
}

.bg_cl3 {
  background-color: #e1f8f8;
}

.cl_base {
  color: #00aabb;
}

.cl_main {
  color: #ef3300;
}

.cl_accent {
  color: #4265a1;
}

.cl_other1 {
  color: #4265a1;
}

.cl_other2 {
  color: #4265a1;
}

/*テキスト関連----------------------------------------------------------- */
.highlight {
  background: -webkit-linear-gradient(transparent 50%, #f9f232 50%);
  background: -o-linear-gradient(transparent 50%, #f9f232 50%);
  background: linear-gradient(transparent 50%, #f9f232 50%);
  font-weight: bold;
}

/*リンク色----------------------------------------------------------- */
a:link,
a:visited {
  color: #162bee;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

/*Page Top----------------------------------------------------------- */
.pagetop a {
  background-color: #00aabb;
}

/*Header----------------------------------------------------------- */
header{
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 99999;
  background-color: #FFF;
}
header .logo {
  height: 60px;
  display: flex;
  align-items: center;
  padding-right: 15px;
}

header .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

header .contact {
  display: flex;
  align-items: center;
  text-align: right;
}
header .contact a:hover img{
  opacity: 1;
}


/*MV----------------------------------------------------------- */
.mv{
  padding: 70px 0;
  background: url(../images/pc_mv_bg.png) no-repeat center;
}
.mv .btn_box{
  background-color: #ff8c00;
  width: 435px;
  height: 200px;
  padding: 30px;
  position: absolute;
  bottom: 0;
  right: -120px;
}

/*230224 追加*/
.mv .btn_box .p2{
	color: white;
	font-weight: bold;
	letter-spacing: .05em;
	font-family: Noto Sans JP;
}
/*CTA----------------------------------------------------------- */
@media ( min-width : 960px ){
.btn_area{
  width: 900px;
  margin: 0 auto;
}
}
.btn_area{
  margin-top: 45px;
}
/*230224 追加*/
.cv_area{
  	width: 100%;
  	height: 357px;
	margin-top: 100px;
	background: repeating-linear-gradient(-45deg, #fff600, #fff600 6px, #fffcb5 0, #fffcb5 12px);
    display: flex;
    align-items: center;
}
@media screen and (max-width: 767px){
	.cv_area{
		margin-top: 40px;
		height: auto;
		padding: 40px 0;
	}
}
.cv_box{
	width: 960px;
	margin: 0 auto;
	padding: 0 15px;
}
@media (min-width: 768px) and (max-width: 959px){
	.cv_box{
		width: 768px;
}
}
.pc_cv_h2 {
	background-color: white;
	height: 171px;
	position: relative;
}
@media screen and (max-width: 767px){
	.pc_cv_h2 {
	height: auto;
}
}
.pc_cv_h2 .cv_img{
	position: absolute;
	left: 22px;
	bottom: 0;
}
@media screen and (max-width: 767px){
	.pc_cv_h2 .cv_img{
		width: 25%;	
		left: 3%;
	}
}

.pc_cv_h2 p{
	position: absolute;
	top:45px;
	left: 285px;
	right: 5%;
}
@media (min-width: 768px) and (max-width: 959px){
	.pc_cv_h2 p{
		top:35%;
}
}
@media screen and (max-width: 767px){
	.pc_cv_h2 p{
		position: static;
		padding: 5% 5% 5% 30%;
}
}

.cv_btn_box{
	background-color: #ff8c00;
	position: relative;
}

.cv_btn_box a{
	text-decoration: none;
	color: white;
}

.cv_btn_box .-inner{
	font-family: Noto Sans JP;
    font-size: 38px;
    font-weight: 600;
	text-align: center;
	padding: 20px 0;
	border-bottom: 8px solid #de2a00;
}
@media screen and (max-width: 767px){
	.cv_btn_box .-inner{
		font-size: max(4vw, 12px);
	}
}

.cv_btn_box .-inner p:after{
	background-image: url(../images/arrow_icon.svg);
    background-repeat: no-repeat;
    content: '';
    display: block;
    position: absolute;
    width: 16px;
    height: 22px;
    top: 37%;
	right: 5%;
	background-size: 90%;
}
@media screen and (max-width: 640px){
	.cv_btn_box .-inner p:after{
		background-size: 50%;
	}
}


/*CTA2----------------------------------------------------------- */


/*sec01----------------------------------------------------------- */
.sec01 h2{
  padding-top: 45px;
}
.sec01 .arrow{
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 47px 143px 0 143px;
  border-color: #00abbb transparent transparent transparent;
  margin: 0 auto;
}
.sec01 .box{
  border: solid 3px #00aabb;
  border-radius: 10px;
  position: relative;
  padding: 30px 30px 30px 150px;
}
.sec01 .icon{
  position: absolute;
  left: 30px;
  top: 0;
}
.sec01 h5{
  padding-bottom: 10px;
}
/*sec02----------------------------------------------------------- */
.sec02 h2{
  padding-bottom: 45px;
}
.sec02 .white_box{
  padding: 40px;
  border-radius: 10px;
}

/*sec03----------------------------------------------------------- */
.sec03 .white_box{
  border-radius: 10px;
  margin-bottom: 45px;
}
.sec03 .fx{
  display: flex;
}
.sec03 .inner{
  padding: 30px;
  background-color: #FFF;
}
.sec03 .inner.bg_cl3{
  background-color: #e1f8f8;
}
.sec03 .box{
  width: calc(100%/ 3);
}
/*sec04----------------------------------------------------------- */
.sec04 .box{
  border: solid 3px #ff8c00;
  border-radius: 10px;
  background-color: #FFF;
}
.sec04 h4{
  background-color: #ff8c00;
  padding: 30px;
}
.sec04 .txt{
  padding: 40px;
}
.sec04 h5{
  padding-bottom: 10px;
}
.sec04 .brett{
  border: solid 3px #00aabb;
  padding: 25px 30px;
}
.sec04 .brett ul{
  margin-top: 0;
}
.sec04 .brett ul li{
  background: none;
  padding-bottom: 0;
  margin-bottom: 0;
  color: #00aabb;
}
.sec04 ul li:last-child{
  margin-bottom: 0;
}

/*sec05----------------------------------------------------------- */
.sec05 h2{
  padding-top: 45px;
}
.sec05 .box{
  background-color: #e1f8f8;
  border-radius: 10px;
  padding: 15px;
  height: 100%;
}
.sec05 .img01{
  position: relative;
  margin-top: -100px;
}
.sec05 h4{
  text-align: center;
  font-weight: bold;
  font-size: 24px;
  margin-top: 15px;
  margin-bottom: 15px;
}
.sec05 .white_box .fx-row{
  justify-content: center;
  margin-left: -8px;
  margin-right: -8px;
}
.sec05 .white_box .f_item{
  margin-top: 100px;
  padding-left: 8px;
  padding-right: 8px;
}
/*sec06----------------------------------------------------------- */
.sec06 .white_box{
  border: solid 3px #00aabb;
  border-radius: 10px;
  padding: 40px;
}

/*sec07----------------------------------------------------------- */
.sec07 h4{
  font-size: 24px;
  font-weight: bold;
}
.sec07 .box{
  border-radius: 10px;
  background-color: #e1f8f8;
  padding: 30px;
}

/*sec08----------------------------------------------------------- */
.sec08 h2{
  padding-top: 45px;
}
.sec08 .f_item{
  padding: 0;
}
.sec08 .txt{
  height: 100%;
  padding: 30px;
}
.sec08 .box{
  padding-left: 15px;
  padding-right: 15px;
}
@media ( min-width : 960px ){
  .fx-col-20-s {
    -ms-flex-preferred-size: 182px;
    flex-basis: 187px;
    max-width: 187px;
}
  .fx-col-80-s {
    -ms-flex-preferred-size: calc(100% - 187px);
    flex-basis: calc(100% - 187px);
    max-width: calc(100% - 187px);
  }
}
/*sec09----------------------------------------------------------- */
.brett{
  background-color: #fff;
  border-radius: 15px;
  padding: 45px;
}
.brett ul{
  margin-top: 30px;
}
.brett ul li {
  padding-bottom: 30px;
  padding: 0;
  text-indent: 0;
  margin: 0;
  font-size: 24px;
  margin-bottom: 20px;
  padding-bottom: 20px;
  font-weight: bold;
  background: url(../images/pc_sec09_line.png) no-repeat bottom center;
  display: flex;
  align-items: center;
}
.brett ul li:last-child{
  margin-bottom: 0;
}
.brett ul li i {
  margin-right: 10px;
  color: #00aabb;
}


/*sec10----------------------------------------------------------- */
.sec10 .f_item{
  margin-top: 45px;
}

/*sec11----------------------------------------------------------- */
.qa .q .txt {
  margin-left: 15px;
  font-size: 24px;
  font-weight: bold;
  color: #00aabb;
}
.qa .a {
  margin-bottom: 30px;
}
.qa .a:last-of-type {
  margin-bottom: 0;
}
.qa .txt {
  margin-left: 15px;
}
.qa .q .txt {
  padding-top: 10px;
}
.qa .a .txt {
  padding-top: 15px;
}
.qa .box:not(:last-child){
  margin-bottom: 30px;
}
.qa .box .a{
  border-bottom:dotted 2px #00aabb;
}
.qa .box_item {
  display: flex;
  align-items: flex-start;
  padding-bottom: 0;
}
.qa .qq .txt {
  margin: 0 auto;
}
.qa .icon {
  width: 60px;
  flex-shrink: 0;
}

/*Footer----------------------------------------------------------- */
footer .copy {
  color: #FFF;
}

.btm_fix {
  background: rgba(255, 255, 255, 0.8);
  padding: 15px;
}
.btm_fix .container{
  display: flex;
  justify-content: center;
}
.btm_fix p{
  margin: 0 15px;
}@charset "utf-8";
/* CSS Document */