/* 共通
----------------------------------*/
* {
  box-sizing: border-box;
}
main {
  overflow: hidden
}
body {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
  line-height: 1.8;
  font-size: 18px;
  color: #544a47;
}
h2 {
  font-size: 50px;
  font-weight: 500;
  color: #575582;
  margin: 0 0 30px 0;
}
h3 {
  font-size: 38px;
  font-weight: 600;
  color: #575582;
  text-align: center;
}
h4 {
  font-size: 38px;
  font-weight: 600;
  color: #544a47;
  text-align: center;
  padding: 0;
  margin: 30px 0 20px 0;
}
p {
  margin: 0 0 30px 0;
}
p:last-of-type {
  margin-bottom: 0;
}
dd {
  padding: 0;
  margin: 0;
}
.inner {
  width: 90%;
  max-width: 1200px;
  margin: 0 auto;
}
.right {
  text-align: right;
}
#info {
  height:
    1000px
}
ul, li {
  list-style: none;
  padding: 0;
  margin: 0
}

img{max-width: 100%}

figure{margin: 0;
padding: 0}


a{text-decoration: none;
color: #575582}



/* hero
----------------------------------*/

#hero{background-image:url("../img/hero_bg.jpg") ;
background-repeat: no-repeat;
background-size: cover}

#hero .heroinner{display: flex;
	height: 1145px
}

#hero .title{width: 680px;
margin: 225px 0 0 125px}

#hero .title p{font-size:27px;
font-weight: 300;
color: #575582;
margin: 40px 0 0 0;
line-height: 2.2}

#hero .heroinner figure{width: calc(100% - 680px) ;
text-align: right;
	margin: 225px 0 0 0
	
}

#hero figure img{max-height: 910px}

#hero .left{
	position:relative;
	top: -200px;
	width: 49%;
	
}

#hero .right{width: 51%;
padding: 0 140px}

#hero .herounder{display:flex;
justify-content: space-between;
align-items: flex-end}

/* about
----------------------------------*/
#about {
  position: relative;
  padding: 250px 0 215px 0;
}
#about:before {
  content: "";
  position: absolute;
  top: 0;
  left: -15px;
  width: 644px;
  height: 758px;
  background-image: url(../img/about_bg_left.svg);
  background-repeat: no-repeat;
  background-size: 100%;
  z-index: -1
}
#about:after {
  content: "";
  position: absolute;
  bottom: 0;
  right: -15px;
  width: 644px;
  height: 758px;
  background-image: url(../img/about_bg_right.svg);
  background-repeat: no-repeat;
  background-size: 100%;
  z-index: -1
}
#about h2 {
  font-size: 38px
}
/* zitakusou
----------------------------------*/
#zitakusou {
  padding: 150px 0 180px 0;
  position: relative;
  background-color: #edf4eb
}

#zitakusou .zitakusoubg{width: 1920px;
height: 158px;
position: absolute;
top:-158px;
left:0}


#zitakusou h2 {
  text-align: center
}


#zitakusou rt{font-size:14px;
               font-weight: 500}
#zitakusou dt {
  color: #575582;
  font-size: 25px;
  font-weight: 300;
  margin: 0 0 10px 0;
}
#zitakusou dl {
  margin: 0 0 30px 0;
}
#zitakusou .img-wrap {
  position: absolute;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

#zitakusou dd{margin: 0 0 30px 0}

#zitakusou .img-wrap li:nth-of-type(1) {
  position: absolute;
  top: -490px;
  left: -110px;
}
#zitakusou .img-wrap li:nth-of-type(2) {
  position: absolute;
  top: 10px;
  right: -70px;
}
#zitakusou .img-wrap li:nth-of-type(3) {
  position: absolute;
  bottom: 460px;
  left: -90px;
}
#zitakusou .img-wrap li:nth-of-type(4) {
  position: absolute;
  bottom: 210px;
  right: 50px;
}
#zitakusou .support ul {
  display: flex;
  flex-wrap: wrap;
  gap: 50px;
}
#zitakusou .support li {
  width: calc((100% - 150px) / 4);
  position: relative;
  background-color: #ffffff;
  border-radius: 10px;
}
#zitakusou .support li:before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto 0;
  right: -42px;
  width: 33px;
  height: 25px;
  background-image: url(../img/zitakusou_support_yazirushi.svg);
  background-repeat: no-repeat;
  background-size: 100%;
}
#zitakusou .support li:last-of-type:before {
  content: none
}

#zitakusou .support p {
  text-align: center;
  font-size: 26px;
  font-weight: 300;
}




/* qa
----------------------------------*/
.qa {
	padding:150px 0;
	background-image: linear-gradient(0deg, rgba(255, 255, 255, 1), rgba(237, 244, 235, 1));
    }

.qa .inner{max-width: 1300px;
	padding: 150px 170px 50px 170px;
background: #fff;
border-radius: 10px;}

.qa h2{text-align:center;}

    .acc {
      border: 1px solid #575582;
      border-radius: 10px;
      overflow: hidden;
      margin: 0 0 40px 0;
    }

    .acc__btn {
      width: 100%;
      appearance: none;
      background: transparent;
      border: 0;
      padding: 14px 16px;
      cursor: pointer;
      display: flex;
      align-items: center;
	text-align: left;
		

    }

    .badge {
      flex: 0 0 auto;
      width: 35px;
      display: grid;
      place-items: center;
    }

    .badge--a {
      color: #059669;
      background: #ecfdf5;
    }

    .acc__q {
      flex: 1 1 auto;
      font-weight: 400;
	  color: #544a47;
		padding: 0 0 0 25px;
    }

    /* 右側の＋/− */
    .acc__icon {
      flex: 0 0 auto;
      display: grid;
      place-items: center;
      position: relative;
    }

.qa .is-open .acc__icon {transform: rotateX(180deg)}

    .acc.is-open .acc__icon::after {
      transform: rotate(0deg);
      opacity: 0;
      /* −に見せる */
    }

    .acc__panel {
      border-top: 1px solid #575582;
      padding: 0 16px;
      /* 開閉アニメ用に上下paddingはJSで */
      height: 0;
      /* JSでscrollHeightに */
      overflow: hidden;
    }

    .acc__inner {
      padding: 18px 0 20px 0;
      /* パネル内の余白はinnerに持たせると綺麗 */
      color: var(--text);
		 position: relative;
    }
.acc__inner p {padding: 0 30px 0 60px;}

.acc__inner:before{  
	content: "";
  position: absolute;
  top: 12px;
  left: 0;
  margin: 0;
  width: 35px;
  height: 35px;
  background-image: url(../img/a.svg);
  background-repeat: no-repeat;
  background-size: 100%;
	
}

    .acc__btn:focus-visible {
      outline: 3px solid rgba(37, 99, 235, .25);
      outline-offset: 2px;
      border-radius: calc(var(--radius) - 4px);
    }

    @media (prefers-reduced-motion: reduce) {
      .acc__panel {
        transition: none !important;
      }
    }

/* company
----------------------------------*/
#company {
  padding: 150px 0 0 0;
  background-color: #f8f8fc
}

#company h2 {
  text-align: center
	  
}

#company dl{display: flex;
border-bottom: solid 1px #575582;
margin: 0;
padding: 20px 10px 20px 10px;
	font-weight: 300;

}

#company dt{width: 150px}

#company dd{width: calc(100% - 150px)}

#company dl:first-of-type{border-top: solid 1px #575582;}

#company .address{display: flex}

#company .address a img{width: 143px;
padding: 0 0 0 20px}

#company .area{padding:0 0 200px 0}

#company .area h3 {font-size: 20px;
font-weight: 300;
text-align: left;
margin: 50px 0 10px 0 }

#company .area p{font-size: 20px;}

#company iframe{width: 100%;
height: 860px;}



/* footer
----------------------------------*/

footer{
	padding: 30px 0 30px 0;
	background-color: #9e9fc4;
	
}


footer h2{text-align: center;
color: #FFFFFF;
font-size:30px;
font-weight: 500;
margin: 0;
}

footer h3{
text-align: center;
	font-size: 20px;
	font-weight: 300;
	color: #FFFFFF;
	margin: 0;
	padding: 0 0 50px 0;
}

footer p{text-align: center;
color: #FFFFFF;
		font-size: 12px;
	font-weight: 300;
	margin: 0 0 50px 0;

}

footer .box{
	display: flex;
  flex-wrap: wrap;
  gap: 20px;
justify-content:center;
align-items: center}

footer .tel{text-align: center}

footer .tel p{font-size:15px;
font-weight: 300;
}

footer .tel a{color: #fff;
font-weight: 300;
font-size: 40px;
line-height: 1;}

footer .time p{border: solid 1px #fff;
	border-radius: 10px;
	width: 90px;
	padding: 5px 0;
}

footer .cr p{
	margin: 50px 0 0 0 ;
	
}

/* header
----------------------------------*/

header{position:fixed;
top:0;
	left:50px;
z-index: 999;
}

header .menu-inner{display: flex;
justify-content: center;
align-items: center}


header .name_btn{color: #fff;
}

header .name_btn rt{font-size: 11px;
font-weight: 500}

header p.name{
font-size:39px;
font-weight: 500
}

header nav{margin: 0 40px}


header ul{display: flex;
	flex-wrap: wrap;
	gap:75px;
font-size:18px;
font-weight: 300;
color: #575582;
background: #fff;
width:800px;
	height: 60px;
border-radius: 10px;
justify-content: center;
align-items: center;
}

header .soudan{margin:18px; 	
	background-color: #aa0000;
	border-radius: 10px;}

header .soudan dl{display: flex;
flex-wrap: wrap;
gap:18px;
width: 215px;
	height: 75px;
	justify-content: center;
	align-items: center;
	margin: 0;
}

header .soudan dt{color: #fff;
	      font-size: 18px;
	font-weight:400;
}

header .soudan dd{color: #fff;
	font-size:40px;
font-weight: 300}

header .telbun dl{
	text-align: center;
	line-height: 1;
	color: #FFFFFF;
margin: 0;
}

header .telbun dt{
	font-size:15px;

}

header .telbun dd{font-size:40px;
}

header .tel_red a{display: flex;
height: 75px;
gap:10px;
	align-items: center
}

header .tel_red{display: flex;
	gap:15px;
	width: 435px;
background-color: #aa0000;
	border-radius: 10px;
justify-content: center;
align-items: center}

header .time_red {
	display: flex;
	justify-content: center;
	align-items: center;
	color: #aa0000;
	width: 90px;
	text-align:center;
	background-color: #fff;
	border-radius: 5px;
		font-size:15px;
	margin: 10px　20px
}


		 



header .openbtn {
	display: none;
}

@media screen and (max-width:1280px) {
	
/* アニメーション前のメニューの状態 */
header .menu {
position: fixed;
top: 56px;
left: 0;
pointer-events: none;
transition: opacity .3s linear;
width: 100%;
height: calc(100vh - 50px);
opacity: 1;
background-color: #f1f1f1;
transform: translateX(-100%);
transition: all .5s ease;
}

/* アニメーション後のメニューの状態 */
header .menu.is-active {
pointer-events: auto;
transform: translateX(0);
transition: all .5s ease;
overflow: auto;
}

header .menu .menu-inner {
display: block;
position: relative;
width: 100%;
margin: auto;
}

header .menu-btn {
position: relative;
display: flex;
height: 56px;
}

header .openbtn {
position: relative;
cursor: pointer;
top: 0;
bottom: 0;
left: 0;
right: 0;
margin: auto;
	display: block;
}

header .openbtn>div {
position: relative;
width: 40px;
height: 9px;
}

header .openbtn>p {
margin-top: 6px;
font-family: var(--mincho-font_family);
font-weight: 500;
font-size: 12px;
line-height: 1;
}

/*ボタン内側*/
header .openbtn span {
display: inline-block;
transition: all .4s;
/*アニメーションの設定*/
position: absolute;
height: 1px;
background: #000;
width: 40px;
}

header .openbtn span:nth-of-type(1) {
top: 0;
}

header .openbtn span:nth-of-type(2) {
bottom: 0;
}

header .openbtn.active span:nth-of-type(1) {
transform: translateY(2px) rotate(-20deg);
top: 3px;
}

header .openbtn.active span:nth-of-type(2) {
transform: translateY(-4px) rotate(20deg);
}
}


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
















