@charset "utf-8";
.pc_none{
display: none !important;
}
/*pc1400設定
----------------------------------------------------------- */
@media(max-width:1400px) {
}

/*pc1024設定
----------------------------------------------------------- */
@media(max-width:1200px) {
.warp{
width: auto;
padding: 0 20px;
}

.fv h2{
margin-bottom: 7px;
}

.fv h2 span {
  padding: 0 5px;
}

.fv h2 span.text01{
font-size: 20px;
line-height: 30px;
}

.fv h2 span.text02 {
  font-size: 40px;
  line-height: 53px;
  margin-top: 8px;
}

.fv p.text01{
margin-bottom: 5px;
font-size: 16px;
}

.fv p.text02{
font-size: 12px;
}
}
/*pc1024設定
----------------------------------------------------------- */
@media(max-width:1024px) {
#top .cont01 .box01{
background: url("../img/img01.jpg") no-repeat -200px center;
background-size: 70% auto;
}
#top .cont01 .box02{
background: url("../img/img02.jpg") no-repeat center right;
background-size: 70% auto;
}
#top .cont01 .box03{
  background: url("../img/cont01_2_img.jpg") no-repeat -200px center;
  background-size: 70% auto;
  }

#top .cont02 ul li {
  margin: 10px 15px 20px;
}
#top .cont02 .box p.btm br{
display: none;
}

.slider02{
width: 90%;
}
#top .cont05 .fl{
  flex-direction: column;
  align-items: center;
}  
#top .cont05 .slick-prev {
  left: -20px;
  top: 175px;
}

#top .cont05 .slick-next {
  right: -20px;
  top: 175px;
}

.fv h2{
margin-bottom: 7px;
}

.fv h2 span {
  padding: 0 5px;
}

.fv h2 span.text01{
font-size: 14px;
line-height: 23px;
}
.fv h2 span.text01 .add {
  padding: 0;
  transform: translateY(-4px);
}

.fv h2 span.text02{
font-size: 28px;
line-height: 43px;
margin-top: 4px;
}

.fv p.text01{
margin-bottom: 10px;
font-size: 14px;
}

.fv p.text02{
font-size: 10px;
}

.accordion_area .accordion_one .ac_header{
padding-right: 50px;
}

#top .cont04 .fl h3 br{
display: none;
}

#top .cont00 h2 {
  font-size: 20px;
  margin-bottom: 15px;
}
#top .cont00 h2 span {
  font-size: 30px;
  display: block;
  position: unset;
  top: unset;
  right: unset;
  bottom: unset;
  left: unset;
  margin: unset;
}
#top .cont00 .inner {
  padding-top: 30px;
  padding-bottom: 20px;
}
#top .cont00 .inner .content .item {
  width: 32%;
}
#top .cont00 .inner .content .item:nth-of-type(2) {
  margin: 0 2%;
}
#top .cont00 .inner .content .item h3 {
  font-size: 15px;
}
#top .cont00 .inner .content .item .img_box {
  width: 100%;
}
#top .cont00 .inner .text {
  width: fit-content;
  margin: 0 auto;
  font-size: 8px;
  margin-top: 15px;
}
#top .cont01_2 {
  width: 95%;
  margin-bottom: 80px;
}
#top .cont01_2 .inner .content {
  margin-top: 0;
  margin-bottom: 0;
}
#top .cont01_2 .inner .content .text {
  width: 90%;
  padding: 0 !important;
}
#top .cont01_2 .inner .content .img {
  width: 90%;
  margin-top: 20px;
}


}


/*tablet設定
----------------------------------------------------------- */
@media(max-width:768px) {
.warp{
padding: 0 30px;
}
.pc_none{
display: block !important;
}

.sp_none{
display: none !important;
}

header{
  height: 44px;
  position: fixed;
  width: 100%;
  background: #fff;
  z-index: 9999;
  top: 0;
}
header h1 {
  padding-top: 10px;
  padding-left: 10px;
}

header h1 img{
  width: 47%;
  max-width: 250px;
}

#menu li {
  height: 44px;
  padding-top: 14px;
  width: 50%;
  max-width: 200px;
}

#menu li a::before {
  top: 15px;
}

.fv{
margin-top: 44px;
}

.fv .sp_none{
display: none !important;
}

.fv h2,
.fv .text_box{
width: 100%;
display: block;
margin-left: 0;
}

.fv h2{
margin-bottom: 7px;
}

.fv h2 span {
  padding: 0 5px;
}


.fv p.text01{
font-size: 15px;
line-height: 20px;
margin-bottom: 10px;
}

.fv p.text02{
font-size: 10px;
}

.fv .warp {
  bottom: 5%;
  padding: 0;
}

#top h2{
font-size: 64px;
margin: 40px auto 30px;
}

#top h2 span{
font-size: 30px;
top: 22px;
}

#top .cont00 .inner .content .item {
  width: 33%;
}
#top .cont00 .inner .content .item:nth-of-type(2) {
  margin: 0 .5%;
}
#top .cont00 .inner .content .item h3 {
  font-size: 11px;
}

#top .cont01_2 {
  width: 100%;
  margin-top: 0px;
}

#top .cont01_2 .inner .img_box {
  width: 100%;
  position: unset;
  left: unset;
  top: unset;
  transform: unset;
}
#top .cont01_2 .inner .content {
  width: 90%;
  margin: 0 auto;
  margin-top: -50px;
  padding-bottom: 35px;
}

#top .cont01 {
  padding-bottom: 40px;
}

#top .cont01 .warp{
padding: 0;
}

#top .cont01 .box01{
background: url("../img/img01.jpg") no-repeat top left;
background-size: 100% auto;
}
#top .cont01 .box02{
background: url("../img/img02.jpg") no-repeat top right;
background-size: 100% auto;
}
#top .cont01 .box03{
  background: url("../img/cont01_2_img.jpg") no-repeat top left;
  background-size: 100% auto;
  }

#top .cont01 .box01,
#top .cont01 .box02,
#top .cont01 .box03{
height: auto;
padding-top: 53vw;
text-align: center;
background-size: 100% auto;
}

#top .cont01 .box01{
margin-bottom: 40px;
}

#top .cont01 .box02{
background-position: top center;
margin-bottom: 40px;
}

#top .cont01 .box03{
  margin-bottom: 10px;
}


#top .cont01 .box01 .in_box,
#top .cont01 .box02 .in_box,
#top .cont01 .box03 .in_box{
  position: static;
margin: 0 20px;
width: auto;
transform: unset;
}

#top .cont01 .in_box{
width: 100%;
padding: 40px 0px;
}

#top .cont01 .box03 .in_box .img {
  width: 90%;
  margin: 0 auto;
}

#top .cont01 p{
margin-bottom: 20px;
padding:0 18px;
text-align: left;
}

#top .cont01 .in_box p span{
margin-top: 20px;
display: block;
}

#top .cont01 .bule_w{
margin-bottom: 20px;
padding: 0;
text-align: center;
}

#top .cont02{
background: url("../img/bg01_sp.png") no-repeat #0E357F;
background-size: 100% auto;
padding-bottom: 35px;
}

#top .cont02 p.po {
    font-size: 30px;
    top: 54px;
}

#top .cont02 p.top {
  padding: 0 0 20px;
}

#top .cont02 .fl{
display: block;
}

#top .cont02 .box{
width: 100%;
margin-bottom: 20px;
}

#top .cont02 .box h3{
font-size: 20px;
line-height: 30px;
}

#top .cont02 .box img.po {
width: 20%;
}

#top .cont02 .box img.po01 {
width: 18%;
}

#top .cont02 ul{
margin-top: 20px;
}

#top .cont02 ul li {
  margin: 0px 20px 10px;
}

#top .cont03{
/*padding-bottom: 50px;*/
}
	#top .cont03 .section_title{
		font-size: 25px;
	}
	#top .cont03 .section_title br{
		display: block;
	}
	#top .cont03 .tab_select_category a img{
		padding-bottom: 2px;
	}

#top .cont04 {
  padding-bottom: 0px;
}

#top .cont04 .fl{
display: block;
}

#top .cont04 .fl .text_box,
#top .cont04 .img_box{
width: 100%;
padding: 0;
}

#top .cont04 .warp{
padding: 0;
}

#top .cont04 .img_box img{
width: 88%;
margin-left: 12%;
}

#top .cont04 .box01 .img_box img {
}

#top .cont04 h2{
font-size: 54px;
margin-bottom: 70px;
}

#top .cont04 h2 span {
  top: 3px;
  line-height: 43px;
}

#top .cont04 .fl{
padding-top: 59vw;
}

#top .cont04 .fl .text_box{
padding: 0 20px;
}

#top .cont04 .fl h3{
font-size: 20px;
margin-bottom: 20px;
}

#top .cont04 .box01 {
  margin-bottom: 50px;
}

#top .cont04 .bg01{
background: url("../img/img06_sp.png") no-repeat;
background-size: 100% auto;
}

#top .cont04 .bg02{
background: url("../img/img07_sp.png") no-repeat;
background-size: 100% auto;
}

#top .cont04 .bg03{
background: url("../img/img08_sp.png") no-repeat;
background-size: 100% auto;
}

#top .cont04 .box02 {
  margin-bottom: 50px;
}

.slider02{
width: auto;
}

#top .cont05 img{
margin: 0 auto;
display: block;
}

#top .cont05 .slick-prev{
left: -10px;
}

#top .cont05 .slick-next{
right: -10px;
}

#top .cont05 .slick-arrow {
  width: 20px;
  height: 20px;
}

#top .cont05{
padding-bottom: 30px;
}

#top .cont06{
padding-top: 1px;
}

#top .cont06 h2{
font-size: 50px;
}

#top .cont06 h2 span {
  top: 18px;
}

#top .cont06 .fl{
padding: 50px 20px;
background: #fff;
}

#top .cont06 .fl .bg_line{
background:url("../img/line_sp02.jpg") no-repeat top left, url("../img/line_sp.svg") repeat-y 20px 30px;
}

#top .cont06 .bule_w{
font-size: 16px;
padding: 0;
margin-right: 5px;
}

#top .cont06 .fl .box {
  display: block;
}

#top .cont06 .fl .box .text_box,
#top .cont06 .fl .box img{
  width: 100%;
}
#top .cont06 .text_box h3 {
  font-size: 20px;
}
#top .cont06 .text_box p.time {
  padding-left: 107px;
  background: url("../img/time.svg") no-repeat 80px 2px;
  margin-bottom: 30px;
}

#top .cont06 .text_box p{
margin-bottom: 20px;
}

#top .cont06 .fl .box{
padding-bottom: 45px;
}

#top .cont06 .text_box p span{
margin-top: 20px;
display:block;
}

#top .cont06 .fl .box img{
width: 90%;
margin-left: 10%;
}

#top .cont07{
padding-bottom: 40px;
}

#top .cont07 h2{
font-size: 62px;
}

#top .cont08 {
  padding-bottom: 40px;
}

#top .cont03 {
  /*padding-bottom: 40px;*/
}

.s_section{
width: 100%;
}

.p-faq__headinner p.p-faq__q-txt {
  margin-right: 40px;
}

.accordion_area .accordion_one .ac_header{
padding: 20px 0;
}

.accordion_area .accordion_one .ac_header .i_box {
  width: 14px;
  height: 14px;
}

.accordion_area .accordion_one .ac_header .i_box::before {
  width: 14px;
}


.accordion_area .accordion_one .ac_header .i_box::after {
  height: 14px;
right: 6px;
}

.p-faq__bodyinner p.p-faq__a-txt{
font-size: 14px;
}

.accordion_area .accordion_one .ac_inner {
  padding: 20px 0 30px;
}

#top .cont04 .fl h3 br{
display: block;
}

a.btn{
color: #fff;
line-height:100px;
padding-left: 45px;
padding-right: 10px;
width: auto;
height: 100px;
background: #8A2026;
font-size: 22px;
font-weight: bold;
margin: 100px auto;
display:block;
position: relative;
}

a.btn::before{
content: url("../img/ico03.svg");
position: absolute;
top: 37px;
left: 50%;
width: 28px;
height: auto;
line-height: 0;
margin-left: -150px;
}


}
@media(max-width:500px) {
  #top .cont05 .slick-prev {
    top: 17%;
  }
  #top .cont05 .slick-next {
    top: 17%;
  }
}
/*sp設定
----------------------------------------------------------- */
@media(max-width:375px) {
.warp{
padding: 0 20px;
}

#top .cont06 .fl .box img {
  width: 82%;
  margin-left: 18%;
}

#top .cont04 .fl h3 br {
  display: block;
}

.pct_none{
display: none !important;
}

.spt_none{
display: block !important;
}

}