.sticky {
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: -webkit-sticky;
  position: sticky;
  flex-direction: column;
  top: 0;
}

.intro{
  display: flex;
  justify-content:space-between;
  align-items: center;
  width: 100%;
  height: 100%;
}

.intro-box-txt{
    display: flex;
    width: 70%;
    height: 100%;
    margin: 0 auto;
    flex-direction: column;
    justify-content: flex-start;
}

.intro-title{
	display: inline-block;
	font-size: 2.714em;
    color: #8c653f;
    letter-spacing: 0.2em;
}

.intro-txt{
    font-size:  1.143em;
    font-weight: 400;
    line-height: 1.8em;
    text-align: justify;
    padding-bottom: 1em;
}

.intro-txt2{
    font-size: 1.143em;
    font-weight: 400;
    line-height: 1.8em;
    text-align: justify;
    color: #031229;
    padding-bottom: 1em;
}

.stickarrow {
  width: 150px;
  height: 8px;
  border-bottom: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: skew(45deg);
}
.btn-flat-border {
  width: fit-content;
  display: inline-block;
  margin: 0 0 0 auto;
}

.btn-flat-border-txt{
  font-size: 1em;
  letter-spacing: 0.1em;
  text-decoration: none;
  color: #ffffff;
  padding-left:0.5em;
}

.btn-flat-border-txt:hover { 
  color: #8c653f;
}

.stickarrow2 {
  width: 150px;
  height: 8px;
  border-bottom: 1px solid #031229;
  border-right: 1px solid #031229;
  transform: skew(45deg);
}
.btn-flat-border {
  width: fit-content;
  display: inline-block;
  margin: 0 0 0 auto;
}

.btn-flat-border-txt2{
  font-size: 1em;
  letter-spacing: 0.1em;
  text-decoration: none;
  color: #031229;
  padding-left:0.5em;
}

.btn-flat-border-txt:hover { 
  color: #8c653f;
}

.btn-flat-border-txt2:hover { 
  color: #8c653f;
}

.intro-box1{
  width: 45%;
  height: 60%;
}

.intro-box2{
  width: 45%;
  height: 60%;
}

.intro-box img{
  width: auto;
  height: 100%;
  object-fit: cover;
  object-position: 100% 100%;
}

.content_1 {
	background: #031229;
	z-index: 200;
}
.content_2 {
	background: #e3d6cd;
	z-index: 300;
}
.content_3 {
	background: #e3d6cd;
	z-index: 400;
}

.background_1 {
    background: url(https://img21.shop-pro.jp/PA01467/377/etc/top-bg.jpg?cmsp_timestamp=20210430164243)top center / cover no-repeat;
    z-index: 200;
}

.mainlogo{
  width: 100%;
  text-align: center; 
}
.mainlogo img{
  width: 40%;
  margin: 0 auto;
}

.background_2 {
    background: url(https://img21.shop-pro.jp/PA01467/377/etc/brands-bg.jpg?cmsp_timestamp=20210428110708)top center / cover no-repeat;
    z-index: 400;
}

.brands{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 80%;
  height: 50vh;
  background-color:rgba(3,18,41,0.8);
}

.brands-box-txt{
  display: flex;
  width: 80%;
  height: 100%;
  margin: 0 auto;
  flex-direction: column;
  justify-content: flex-start;
}

.brands-box1{
  width: 70%;
  height: 80%;
}

.brands-box2{
  width: 30%;
}

.brands-box2 img{
  width: 80%;
  height: auto;
  object-fit: cover;
}

.onlineshop-intro{
  display: flex;
  width: 100%;
  height: 50vh;
  text-align: center;
  flex-direction: column;
  justify-content: space-evenly;
}

.online-title{
	display: block;
	font-size: 3em;
    color: #8c653f;
    letter-spacing: 0.2em;
}

.online-txt{
    font-size: 1.143em;
    line-height: 1.8em;
	display: block;
    color: #031229;
    letter-spacing: 0.2em;
}

.online-txt-sp{
  display: none;
}

.onlineshop-intro hr{
  height: 1px;
  width: 5%;
  margin: 0 auto;
  border: none;
  background-color: #8c653f;
  color: #8c653f;
}

.customer-box{
  display: flex;
  justify-content: space-evenly;
  align-items: flex-start;
  width: 100%;
  height: 50vh;
}

.customer-inner{
  position: relative;
  width: 25%;
  overflow: hidden;
}
.customer-inner:before{
  content: "";
  display: block;
  padding-top: 100%;
}

.customer-inner img{
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  object-fit: cover;
  transition: 0.3s;
}

.customer-inner img:hover{
  transform: scale(1.3);
}

.customer-inner p{
  display: inline-block;
  position: absolute;
  right: 20px;
  bottom: 16px;
  font-size: 1.143em;
}

/*以下で線を表示*/
.customer-inner .border1:before {
  content: '';
  position: absolute;
  right: 0;
  top: -15px;/*線の上下位置*/
  display: inline-block;
  width: 60px;/*線の長さ*/
  height: 6px;/*線の太さ*/
  margin-left: auto;/*位置調整*/
  background-color: #e21c21;/*線の色*/
}

.customer-inner .border2:before {
  content: '';
  position: absolute;
  right: 0;
  top: -15px;/*線の上下位置*/
  display: inline-block;
  width: 60px;/*線の長さ*/
  height: 6px;/*線の太さ*/
  margin-left: auto;/*位置調整*/
  background-color: #0b4398;/*線の色*/
}

.customer-inner .border3:before {
  content: '';
  position: absolute;
  right: 0;
  top: -15px;/*線の上下位置*/
  display: inline-block;
  width: 60px;/*線の長さ*/
  height: 6px;/*線の太さ*/
  margin-left: auto;/*位置調整*/
  background-color: #8e653f;/*線の色*/
}

@media screen and (max-width: 767px) {
  .intro{
  display: flex;
  justify-content:flex-start;
  flex-direction: column;
  align-items: center;
  width: 100%;
  height: 100%;
  }
  
  .sp{
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
  width: 100%;
  height: 100%;
  }
  
  .intro-box1{
  width: 100%;
  height: 60%;
  }
  
  .intro-box2{
  width: 100%;
  height: 40%;
  }
  
  .intro-box-txt{
    display: flex;
    width: 90%;
    height: 60%;
    margin: 0 auto;
    flex-direction: column;
    justify-content: space-evenly;
  }

  .intro-title{
	display: inline-block;
	font-size: 2em;
    font-weight: 600;
    color: #8c653f;
    letter-spacing: 0.2em;
  }

  .intro-txt{
    font-size:  1.071em;
    line-height: 1.8em;
    text-align: justify;
    padding: 0;
  }

  .intro-txt2{
    font-size: 1.071em;
    line-height: 1.8em;
    text-align: justify;
    color: #031229;
    padding: 0;
  }
  
  .intro-box2 img{
  width: 100%;
  height: 90%;
  object-fit: cover;
  object-position: 100% 100%;
  }
  
  .mainlogo img{
  width: 80%;
  text-align: center;
  }
  
  .stickarrow {
  width: 120px;
  height: 8px;
  border-bottom: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: skew(45deg);
}
.btn-flat-border {
  width: fit-content;
  display: inline-block;
  margin: 0 0 0 auto;
}

.btn-flat-border-txt{
  font-size: 1em;
  letter-spacing: 0.1em;
  text-decoration: none;
  color: #ffffff;
  padding-left:0.5em;
}

.btn-flat-border-txt:hover { 
  color: #8c653f;
}

.stickarrow2 {
  width: 120px;
  height: 8px;
  border-bottom: 1px solid #031229;
  border-right: 1px solid #031229;
  transform: skew(45deg);
}
.btn-flat-border {
  width: fit-content;
  display: inline-block;
  margin: 0 0 0 auto;
}

.btn-flat-border-txt2{
  font-size: 1em;
  letter-spacing: 0.1em;
  text-decoration: none;
  color: #031229;
  padding-left:0.5em;
}

.btn-flat-border-txt:hover { 
  color: #8c653f;
}

.btn-flat-border-txt2:hover { 
  color: #8c653f;
}
  
  .brands{
  display: flex;
  justify-content:center;
  flex-direction: column-reverse;
  align-items: center;
  width: 100%;
  height: 80vh;
  background-color:rgba(3,18,41,0);
  }
  
  .brands-box1{
  width: 94%;
  height: 60%;
  background-color:rgba(3,18,41,0.8);
  }

  .brands-box2{
  width: 94%;
  height: 40%;
  text-align: center;
  background: linear-gradient(180deg, rgba(3,18,41,0) 70%,
    rgba(3,18,41,0.8) 30%);
  }
  
  .brands-box2 img{
  width: auto;
  height: 100%;
  object-fit: cover;
  object-position: 100% 100%;
 }
  
 .brands-box-txt{
  display: flex;
  width: 93%;
  height: 90%;
  margin: 0 auto;
  justify-content: flex-start;
  }
  
  .onlineshop-intro {
    display: flex;
    width: 100%;
    height: 60vh;
    text-align: center;
    flex-direction: column;
    justify-content: center;
  }
  
  .online-title{
	display: inline-block;
	font-size: 2em;
    font-weight: 600;
    color: #8c653f;
    letter-spacing: 0.2em;
  }
  
    .online-txt{
    display: none;
  }

  .online-txt-sp{
    display: block;
    width: 90%;
    font-size: 1.071em;
    line-height: 1.8em;
    text-align: left;
    color: #031229;
    margin: 0 auto;
    padding-top: 1.357em;
  }
  
  .onlineshop-intro hr{
  height: 1px;
  width: 20%;
  margin: 0 auto;
  border: none;
  background-color: #8c653f;
  color: #8c653f;
  }
  
  .customer-box{
  display: flex;
  align-items: center;
  width: 100%;
  height: 40vh;
  flex-direction: column;
  justify-content: flex-start;
  }
  
  .customer-inner {
  position: relative;
  width: 90%;
  height: 25%;
  overflow: hidden;
    margin-bottom: 1em;
  }
  
  .customer-inner p {
  display: inline-block;
  position: absolute;
  right: 10px;
  bottom: 0px;
  font-size: 1.071em;
  }
}

@media screen and (min-width:768px) and ( max-width:1024px) {  
  .mainlogo img{
  width: 80%;
  text-align: center;
  }
  
  .intro{
  display: flex;
  justify-content:flex-start;
  flex-direction: column;
  align-items: center;
  width: 100%;
  height: 100%;
  }
  
  .sp{
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
  width: 100%;
  height: 100%;
  }
  
  .intro-box1{
  width: 100%;
  height: 60%;
  }
  
  .intro-box2{
  width: 100%;
  height: 40%;
  }
  
  .intro-box-txt {
    display: flex;
    width: 90%;
    height: 80%;
    margin: 0 auto;
    flex-direction: column;
    justify-content: flex-start;
}

  .intro-title{
	display: inline-block;
	font-size: 2.286em;
    font-weight: 600;
    color: #8c653f;
    letter-spacing: 0.2em;
  }

  .intro-txt{
    font-size:  1.143em;
    line-height: 1.8em;
    text-align: justify;
    padding: 0 0 2em 0;
  }

  .intro-txt2{
    font-size: 1.143em;
    line-height: 1.8em;
    text-align: justify;
    color: #031229;
    padding: 0 0 2em 0;
  }
  
  .intro-box2 img{
  width: 100%;
  height: 90%;
  object-fit: cover;
  object-position: 100% 100%;
  }
  
  .mainlogo{
  width: 70%;
  text-align: center;
  }
  
  .stickarrow {
  width: 150px;
  height: 8px;
  border-bottom: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: skew(45deg);
}
.btn-flat-border {
  width: fit-content;
  display: inline-block;
  margin: 0 0 0 auto;
}

.btn-flat-border-txt{
  font-size: 1em;
  letter-spacing: 0.1em;
  text-decoration: none;
  color: #ffffff;
  padding-left:0.5em;
}

.btn-flat-border-txt:hover { 
  color: #8c653f;
}

.stickarrow2 {
  width: 150px;
  height: 8px;
  border-bottom: 1px solid #031229;
  border-right: 1px solid #031229;
  transform: skew(45deg);
}
.btn-flat-border {
  width: fit-content;
  display: inline-block;
  margin: 0 0 0 auto;
}

.btn-flat-border-txt2{
  font-size: 1em;
  letter-spacing: 0.1em;
  text-decoration: none;
  color: #031229;
  padding-left:0.5em;
}

.btn-flat-border-txt:hover { 
  color: #8c653f;
}

.btn-flat-border-txt2:hover { 
  color: #8c653f;
}
  
  .brands{
  display: flex;
  justify-content:center;
  flex-direction: column-reverse;
  align-items: center;
  width: 100%;
  height: 80vh;
  background-color:rgba(3,18,41,0);
  }
  
  .brands-box1{
  width: 94%;
  height: 50%;
  background-color:rgba(3,18,41,0.8);
  }

  .brands-box2{
  width: 94%;
  height: 50%;
  text-align: center;
  background: linear-gradient(180deg, rgba(3,18,41,0) 70%,
    rgba(3,18,41,0.8) 30%);
  }
  
  .brands-box2 img{
  width: auto;
  height: 100%;
  object-fit: cover;
  object-position: 100% 100%;
 }
  
 .brands-box-txt{
  display: flex;
  width: 93%;
  height: 90%;
  margin: 0 auto;
  justify-content: flex-start;
  }
  
  .onlineshop-intro {
    display: flex;
    width: 100%;
    height: 40vh;
    text-align: center;
    flex-direction: column;
    justify-content: space-evenly;
  }
  
  .online-title{
	display: inline-block;
	font-size: 2.286em;
    font-weight: 600;
    color: #8c653f;
    letter-spacing: 0.2em;
    margin: 0 0 -10px 0;
  }
  
    .online-txt{
    display: none;
  }

  .online-txt-sp{
    display: block;
    width: 90%;
    font-size: 1.143em;
    line-height: 1.8em;
    text-align: left;
    color: #031229;
    margin: 0 auto;
  }
  
  .onlineshop-intro hr{
  height: 1px;
  width: 10%;
  margin: 0 auto;
  border: none;
  background-color: #8c653f;
  color: #8c653f;
  }
  
  .customer-box{
  display: flex;
  align-items: center;
  width: 100%;
  height: 60vh;
  flex-direction: column;
  justify-content: flex-start;
  }
  
  .customer-inner {
  position: relative;
  width: 90%;
  height: 25%;
  overflow: hidden;
    margin-bottom: 1em;
  }
  
  .customer-inner p {
  display: inline-block;
  position: absolute;
  right: 10px;
  bottom: 0px;
  font-size: 1em;
  }
}

/*フェードイン*/
.fade-in {
   opacity: 0;
   animation-name: fadein;
   animation-duration: 1.8s;
   animation-timing-function: ease-out;
   animation-fill-mode: forwards;
}
@keyframes fadein {
   0% {
      opacity: 0;
      transform: translateY(0px);
   }
   100% {
      opacity: 1;
      transform: translateY(0);
   }
}