@charset "UTF-8";
:root{
  --mainColor:#AE9B4F;
}

a{
  transition: 0.5s;
}

body{
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  letter-spacing: 0.1em;
}

.sp{
  display: none;
}

.nova,.nova *{
  font-family: "Nova Flat", system-ui;
}

.inter-bold,.inter-bold * {
  font-family: "Inter", sans-serif;
  font-optical-sizing: auto;
  font-weight: bold;
  font-style: normal;
}

.min,.min *{
  font-family: "Noto Serif JP", serif;
}

.content{
  width: 90%;
  max-width: 1155px;
  margin: auto;
}

@media screen and (min-width:901px){
  .mainhead{
    position: absolute;
    top:47px;
    right: 77px;
    z-index: 999999;
  } 

  .mainhead .menuBox{
    display: flex;
  }

  .mainhead .menuBox a{
    font-weight: bold;
    display: block;
    color:#ffffff;
    margin-left: 1.5em;
    letter-spacing: 0;
    font-size: 24px;
    position: relative;
    transition: 0.5s;
  }
  
  .mainhead .menuBox a:hover{
    color:#ffffff !important;
  }

  .mainhead .menuBox a:after{
    content:"";
    position: absolute;
    width: 0;
    left: 0;
    bottom: -10px;
    height: 2px;
    background: #ffffff;
    transition: 0.5s;
  }

  .mainhead .menuBox a:hover:after{
    width: 100%;
  }
  
}

.mainVisual{
  height: 700px;
  width: 100%;
  background: url("../images/mainVisual.webp") center;
  background-size: cover;
  background-position: center;
}
  
.sec01{
  padding: 185px 0 175px;
}

.sec01Box{
  background: url("../images/sec01Img.webp") center;
  background-size: cover;
  background-position: center;
  width: calc(100% - (470px + ((100% - 1155px) / 2)));
  position: absolute;
  left: 0;
  height:434px;
}

@media screen and (max-width:1155px){
  .sec01Box{
    width: calc(100% - 470px);  
  }
}

.sec01 .content{
  display: flex;
  justify-content: flex-end;
}

.sec01 .sec01Info{
  width: 470px;
  padding-left: 80px;
}

.Info__title{
  color:var(--mainColor);
  letter-spacing: 0.1em;
  font-size: 50px;
  font-weight: 500;
  margin-bottom: 86px;
  text-align: left;
  line-height: 1.15em;;
}

.sec01 .sec01Info__text{
  letter-spacing: 0;
  font-size: 20px;
  line-height: 2.25em;
}

.sec02{
  padding: 102px 0 63px;
  background: url("../images/sec02Bg.webp") center;
  background-size: cover;
  background-position: center;
}

.sec02title.Info__title{
  color:#ffffff;
  margin-bottom: 49px;
}

.sec02Info__list li{
  color:#ffffff;
  font-size: 20px;
  line-height: 2.25em;
  text-align: left;
}

.sec02Info__list li:before{
  content:"● ";
  color:#ffffff;
}

.sec03{
  padding: 150px 0;
}

.sec03 .sec03Cont{
  display: flex;
  justify-content: space-between;
  margin-bottom: 170px;
}

.sec03 .sec03Cont.pt02{
  flex-flow: row-reverse;
  margin-bottom: 125px;
}  

.sec03 .sec03Cont__Img{
  width: calc(100% - 470px);
  height: 460px;
}

.sec03 .sec03Cont__Img img{
  width: 100%;
  height:100%;
  object-fit: cover;
  object-position: center;
}

.sec03 .Info__title{
  margin-bottom: 45px;
}

.sec03 .sec03Cont__Info{
  width: 395px;
}

.sec03 .sec03Cont__Info--subTitle{
  font-size: 32px;
  line-height: 1.25em;
  margin-bottom: 25px;
}

.sec03 .sec03Cont__Info--text{
  font-size: 20px;
  line-height: 1.25em;
}

.sec03 .sec03SubCont{
  display: flex;
  justify-content: space-between;
}

.sec03 .sec03SubCont__Box{
  width: calc((100% - 75px) / 2);
}  

.sec03 .sec03SubCont__Img{
  width: 100%;
  height: 350px;
  margin-bottom: 25px;
}

.sec03 .sec03SubCont__Img img{
  width: 100%;
  height:100%;
  object-fit: cover;
  object-position: center;
}

.sec04{
  padding: 106px 0 216px;
  background: rgba(174 155 79 / 15%);
}

.m_color{
  color:var(--mainColor);
}

.contTitle{
  text-align: center;
  font-weight: lighter;
  font-size: 96px;
  margin-bottom: 85px;
  line-height: 1.5em;
  letter-spacing: 0.1em;
}

.contTitle small{
  font-size: 32px;
  line-height: 1em;
  font-weight: normal;
  letter-spacing: 0.05em;
}

.sec04Cont{
  display: flex;
  justify-content: space-between;
}

.sec04Cont .sec04Cont__Box{
  width: calc((100% - 65px) / 2);
}

.sec04Cont__Box--Text{
  text-align: center;
  line-height: 1.5em;
  letter-spacing: 0.2em;
  font-size: 20px;
  margin-top: 30px;
}

.sec05{
  padding: 136px 0 140px;
}

.sec05 .sec05__Itemlist a{
  color:#000000;
}

.sec05 .sec05__Itemlist *{
  cursor: pointer;
}

.sec05 .sec05__Itemlist a:hover{
  opacity: 0.7;
}

.sec05 .sec05__Itemlist{
  display: flex;
  flex-wrap: wrap;
}

.sec05 .sec05__Itemlist li{
  width: calc((100% - 140px) / 3);
}

.sec05 .sec05__Itemlist li:nth-child(n + 4){
  margin-top: 160px;
}

.sec05 .sec05__Itemlist li:nth-child(3n + 2){
  margin-left: 70px;
  margin-right: 70px;
}

.sec05 .sec05__Itemlist--Text{
 font-size: 20px;
  line-height: 1.5em;
  margin: 10px 0 40px;
  letter-spacing: 0.001em;
  font-weight: 400;
}

.sec05 .sec05__Itemlist--Btn{
  text-align: right;
}

.sec06{
  padding: 62px 0 70px;
  background: url("../images/sec05Bg.webp") center;
  background-size: cover;
  background-position: center;
}

.sec06 *{
  text-align: center;
  color:#ffffff;
}

.sec06__text{
  font-size: 20px;
  margin: 50px 0 40px;
}

.sec06__text02{
  font-size: 20px;
  margin-top: 26px;
  line-height: 1.8em;
}

.btnCont{
  display: flex;
}

.btnCont--Box{
  width: 50%;
}

.btnCont--Box a{
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  color:#ffffff;
  font-size: 32px;
  height: 265px;
  font-weight: 600;
} 

.btnCont--Box a img{
  display: inline-block;
  margin-right: 20px;
}

.btnCont--Box a:hover{
  opacity: 0.7;
  color:#ffffff !important;
}

.btnCont--Box.pt01 a{
  background: #AE9B4F;
}

.btnCont--Box.pt02 a{
  background: #302D23;
}  

.footWrap{
  padding: 135px 0 145px;
  background: url("../images/footBg.webp") center;
  background-size: cover;
  background-position: center;  
}

.mainFoot .content{
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  color:#ffffff;
}

.mainFoot__Box--Text{
  margin-top: 45px;
  font-size: 25px;
  font-weight: bold;
}

.mainFoot__Box--Text small{
  font-size: 20px;
}

.mainFoot__list{
  display: flex;
}

.mainFoot__list a{
  color:#ffffff;
  display: block;
  margin-left: 1em;
  position: relative;
  font-size: 24px;
}

.mainFoot__list a:hover{
  color:#ffffff !important;
}

.mainFoot__list a:after{
  content:"";
  position: absolute;
  width: 0;
  left: 0;
  bottom: -10px;
  height: 2px;
  background: #ffffff;
  transition: 0.5s;
}

.mainFoot__list a:hover:after{
  width: 100%;
}

.mainFoot .copy{
  text-align: center;
  padding: 20px 0;
  background: #000000;
  font-size: 20px;
  color:#ffffff;
}

  .mainVisual{
    position: relative;
  }

  .mainTitle{
    font-size: 47px;
    font-weight: 500;
    text-align: left;
    color: #ffffff;
    left: 10%;
    position: absolute;
    bottom: 265px;
  }
  
  .mainText{
    font-size: 20px;
    position: absolute;
    left: 10%;
    bottom: 155px;
    color: #ffffff;
    font-weight: bold;
  }