/* SP */
@media screen and (max-width: 768px) {
  #heading .sec-title .en{
    font-size: 10vw;
  }
}

#business-archive .sec-inner{
  padding-top: 130px;
  padding-bottom: 130px;
}
#business-archive .sec-title{
  margin-bottom: 120px;
}
/* TAB */
@media screen and (max-width: 1024px) {
   #business-archive .sec-inner{
    padding-top: 95px;
    padding-bottom: 95px;
  }
  #business-archive .sec-title{
    margin-bottom: 90px;
  }
}
/* SP */
@media screen and (max-width: 768px) {
  #business-archive .sec-inner{
    padding-top: 65px;
    padding-bottom: 65px;
  }
  #business-archive .sec-title{
    margin-bottom: 60px;
  }
}

#business-detail .sec-inner{
  padding-top: 110px;
  padding-bottom: 130px;
}
#business-detail .sec-title{
  font-size: 38px;
  font-weight: 700;
  letter-spacing: .05em;
  padding-left: 35px;
  position: relative;
  margin-bottom: 24px;
}
#business-detail .sec-title::before{
  position: absolute;
  content: "";
  width: 17px;
  aspect-ratio: 1/1;
  background: var(--c-sub);
  border-radius: 50%;
  top: .6em;
  left: 0;
}
#business-detail .sec-text{
  font-size: 18px;
  font-weight: 500;
  line-height: 2;
  margin-bottom: 100px;
}
#business-detail .sec-text:last-child {
	margin-bottom: 0;
}
#business-detail .sec-image{
  margin-bottom: 139px;
}
#business-detail .sec-image:last-child {
	margin-bottom: 0;
}
#business-detail .sec-list .item{
  min-height: 350px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 20px 210px 20px 9.7rem;
  position: relative;
}
#business-detail .sec-list .item:not(:nth-of-type(1)){
  margin-top: 100px;
}
#business-detail .sec-list .item::before{
  content: "";
  position: absolute;
  height: 100%;
  width: 64.28%;
  top: 0;
  left: 0;
  background: linear-gradient(
    to right,
    rgba(235, 235, 235, 1) 0%,
    rgba(235, 235, 235, 1) 76.44%,
    rgba(235, 235, 235, 0) 100%
  );
  z-index: -2;
}
#business-detail .sec-list .item::after{
  content: "";
  position: absolute;
  width: 35.71%;
  height: 197px;
  bottom: 0;
  left: 11.9%;
  background: url(../img/common/logo-rio-gray.svg) center/ contain no-repeat;
  z-index: -1;
}
#business-detail .sec-list .texts{
  max-width: 495px;
  width: 55%;
}
#business-detail .sec-list .title{
  font-size: 36px;
  font-weight: 700;
  letter-spacing: .1em;
  margin-bottom: 34px;
}
#business-detail .sec-list .text{
  font-size: 16px;
  font-weight: 500;
  line-height: 2;
}
#business-detail .sec-list .image{
  position: absolute;
  height: 100%;
  width: auto;
  right: 0;
  top: 0;
  z-index: -3;
}
#business-detail .sec-list .image img{
  object-fit: cover;
  object-position: right;
  width: 100%;
  height: 100%;
}
#business-detail .sec-list .btn{
  position: absolute;
  width: 140px;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 15px 0;
  top: 0;
  right: 6.2rem;
}
#business-detail .sec-list .txt{
  font-size: 16px;
  font-weight: 500;
  color: #fff;
}
#business-detail .sec-list .arrow{
  width: 140px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  box-shadow: inset 0 0 0 2px #fff;
  transition: all .3s;
  position: relative;
}
#business-detail .sec-list .arrow::before{
  position: absolute;
  content: "";
  width: 40px;
  height: 19px;
  background: url("../img/common/arrow-white.svg") center / contain no-repeat;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  z-index: 3;
}
#business-detail .sec-list a.item:hover .arrow::before{
   background: url("../img/common/arrow-blue.svg") center / contain no-repeat;
}
#business-detail .sec-list .arrow::after{
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: #fff;
  opacity: 0;
  transition: opacity .3s;
  left: 0;
  top: 0;
  z-index: -1;
}
#business-detail .sec-list a.item:hover .arrow::after{
  opacity: 1;
}
#business-detail .sec-shop {
	padding: 100px 0 50px;
}
#business-detail .sec-shop .title {
	margin-bottom: 1em;
	font-size: 36px;
	font-weight: bold;
}
#business-detail .sec-shop .list {
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
}
#business-detail .sec-shop .link {
	display: block;
	width: 7.8vw;
	max-width: 140px;
	height: 7.8vw;
	max-height: 140px;
	border: 1px solid #333;
	border-radius: 10px;
	overflow: hidden;
}
/* TAB */
@media screen and (max-width: 1024px) {
    #business-detail .sec-inner{
    padding-top: 80px;
    padding-bottom: 95px;
  }
  #business-detail .sec-title{
    font-size: 33px;
    padding-left: 30px;
    margin-bottom: 20px;
  }
  #business-detail .sec-title::before{
    width: 15px;
  }
  #business-detail .sec-text{
    font-size: 16px;
    margin-bottom: 75px;
  }
  #business-detail .sec-image{
    margin-bottom: 100px;
  }
  #business-detail .sec-list .item{
    min-height: 300px;
    padding: 20px 210px 20px 20px;
  }
  #business-detail .sec-list .item:not(:nth-of-type(1)){
    margin-top: 75px;
  }
   #business-detail .sec-list .item::before{
    width: 52%;
    background: linear-gradient(
      to right,
      rgba(235, 235, 235, 1) 0%,
      rgba(235, 235, 235, 1) 85%,
      rgba(235, 235, 235, 0) 100%
    );
  }
  #business-detail .sec-list .item::after{
    width: 30%;
    left: 30px;
}
  #business-detail .sec-list .title{
    font-size: 31px;
    margin-bottom: 17px;
  }
  #business-detail .sec-list .btn{
    align-items: center;
    gap: 8px 0;
  }
  #business-detail .sec-list .arrow{
    width: 105px;
  }
  #business-detail .sec-list .arrow::before{
    width: 30px;
    height: 15px;
  }
	#business-detail .sec-shop {
		padding: 80px 0 30px;
	}
	#business-detail .sec-shop .title {
		font-size: 31px;
	}
	#business-detail .sec-shop .item {
		width: calc((100% - 60px)/3);
		max-width: 140px;
	}
	#business-detail .sec-shop .link {
		width: 100%;
		height: auto;
		aspect-ratio: 1/1;
	}
}
/* SP */
@media screen and (max-width: 768px) {
  #business-detail .sec-inner{
    padding-top: 55px;
    padding-bottom: 65px;
  }
  #business-detail .sec-title{
    font-size: 29px;
    padding-left: 26px;
    margin-bottom: 16px;
  }
  #business-detail .sec-title::before{
    width: 13px;
  }
  #business-detail .sec-text{
    margin-bottom: 50px;
  }
  #business-detail .sec-image{
    margin-bottom: 70px;
  }
  #business-detail .sec-list .item{
    min-height: auto;
    padding: 0;
  }
  #business-detail .sec-list .item:not(:nth-of-type(1)){
    margin-top: 50px;
  }
  #business-detail .sec-list .item::before{
    display: none;
  }
  #business-detail .sec-list .item::after{
    display: none;
  }
  #business-detail .sec-list .texts{
    max-width: 100%;
    width: 100%;
    position: relative;
    padding: 25px 20px;
  }
  #business-detail .sec-list .texts::before{
    content: "";
    position: absolute;
    height: calc(100% + 40px);
    width: 100%;
    top: 0;
    left: 0;
    background: linear-gradient(
      to bottom,
      rgba(235, 235, 235, 1) 0%,
      rgba(235, 235, 235, 1) 90%,
      rgba(235, 235, 235, 0) 100%
    );
    z-index: -2;
  }
    #business-detail .sec-list .texts::after{
    content: "";
    position: absolute;
    width: 80%;
    max-width: 200px;
    height: auto;
    bottom: 0px;
    aspect-ratio: 500/197;
    left: auto;
    right: 20px;
    background: url(../img/common/logo-rio-gray.svg) center/ contain no-repeat;
    z-index: -1;
  }
  #business-detail .sec-list .title{
    font-size: 27px;
  }
  #business-detail .sec-list .image{
    position: relative;
    height: 200px;
  }
  #business-detail .sec-list .btn{
    width: 100%;
    height: fit-content;
    align-items: center;
    gap: 2px 0;
    top: auto;
    bottom: 16px;
    right: 50%;
    transform: translateX(50%);
  }
  #business-detail .sec-list .txt{
    font-size: 14px;
  }
  #business-detail .sec-list .arrow{
    width: 70px;
  }
  #business-detail .sec-list .arrow::before{
    width: 20px;
    height: 10px;
  }
	#business-detail .sec-shop .title {
		font-size: 27px;
	}
}