#key {
  background: url("../img/anniversary/key.jpg") no-repeat center top/cover;
}

#sec1 {
  padding: 134px 0 102px;
  position: relative;
  z-index: 1;
}
#sec1::before {
  content: "";
  position: absolute;
  background: url(../img/anniversary/sec1_deco1.png) no-repeat;
  background-size: contain;
  width: 354px;
  height: 314px;
  top: 0;
  left: calc(50% + 396px);
  z-index: -1;
}
#sec1 .row {
  margin-bottom: 159px;
  position: relative;
  z-index: 1;
}
#sec1 .row::before {
  content: "";
  position: absolute;
  background: url(../img/anniversary/sec1_deco2.png) no-repeat;
  background-size: contain;
  width: 367px;
  height: 362px;
  bottom: -139px;
  left: 59px;
  z-index: -1;
}
#sec1 .img {
  margin: 0 -73px;
  height: 656px;
}
#sec1 .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#sec1 h2 {
  font-size: 45px;
  font-weight: 400;
  font-family: var(--ship);
  letter-spacing: 0.18em;
  line-height: 1.2em;
  position: absolute;
  top: 62px;
  left: 0;
}
#sec1 h2::before {
  content: "";
  position: absolute;
  background: url(../img/anniversary/sec1_t1_deco.png) no-repeat;
  background-size: contain;
  width: 477px;
  height: 7px;
  bottom: 1px;
  left: 3px;
}
#sec1 h2 .small {
  font-size: 35px;
}
#sec1 .txt {
  margin: -140px 20px 0 auto;
  width: 400px;
  height: 278px;
  line-height: 2.2em;
  position: relative;
}
#sec1 .txt::before {
  content: "";
  position: absolute;
  background-color: #fff;
  height: 1px;
  width: 345px;
  bottom: -57px;
  right: -75px;
}
#sec1 .txt::after {
  content: "";
  position: absolute;
  background-color: #fff;
  height: 188px;
  width: 1px;
  bottom: -109px;
  right: -51px;
}
#sec1 .list {
  display: flex;
  justify-content: center;
  gap: 48px;
}

#sec2 {
  padding: 140px 0 150px;
  position: relative;
  z-index: 1;
}
#sec2::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: #fff;
  opacity: 0.05;
  z-index: -1;
}
#sec2 .row1 {
  margin-bottom: 56px;
}
#sec2 .row1 h2 {
  text-align: center;
  font-size: 40px;
  font-weight: 400;
  font-family: var(--ship);
  letter-spacing: 0.15em;
  line-height: 1.4em;
  margin-bottom: 60px;
  position: relative;
}
#sec2 .row1 h2::before {
  content: "";
  position: absolute;
  background: url(../img/anniversary/sec2_t1_deco.png) no-repeat;
  background-size: contain;
  width: 419px;
  height: 6px;
  bottom: 3px;
  left: calc(50% - 10px);
  transform: translateX(-50%);
}
#sec2 .row1 h2 .small {
  font-size: 30px;
}
#sec2 .row1 .txt {
  line-height: 2.2em;
  text-align: center;
  margin-bottom: 59px;
}
#sec2 .row1 .img {
  text-align: center;
  position: relative;
  margin-bottom: 63px;
}
#sec2 .row1 .img::before, #sec2 .row1 .img::after {
  content: "";
  position: absolute;
  background: url(../img/anniversary/sec2_deco1.png) no-repeat;
  background-size: contain;
  width: 490px;
  height: 421px;
  z-index: -1;
}
#sec2 .row1 .img::before {
  top: -322px;
  left: -250px;
}
#sec2 .row1 .img::after {
  background-image: url(../img/anniversary/sec2_deco2.png);
  width: 265px;
  height: 265px;
  bottom: -108px;
  right: -180px;
}
#sec2 .row1 .note {
  text-align: center;
}
#sec2 .list {
  margin: 0 -161px 131px;
  display: flex;
  justify-content: center;
  gap: 36px;
}
#sec2 .list .item {
  box-sizing: border-box;
  padding: 70px 35px 50px;
  width: 50%;
  border: 1px solid #fff;
}
#sec2 .list .tit {
  font-family: var(--ship);
  font-size: 35px;
  line-height: 1.6em;
  letter-spacing: 0.2em;
  margin-bottom: 10px;
  text-align: center;
}
#sec2 .list .price {
  font-family: var(--ship);
  font-size: 25px;
  line-height: 1.6em;
  letter-spacing: 0.05em;
  padding-bottom: 43px;
  text-align: center;
  background: url(../img/shared/line.jpg) no-repeat center bottom;
}
#sec2 .list .dish {
  align-content: space-between;
  max-height: 165px;
  max-width: 492px;
  position: relative;
  display: flex;
  flex-flow: column wrap;
  padding: 21px 0 21px;
  margin: 0 auto;
}
#sec2 .list .dish li {
  line-height: 2.2em;
}
#sec2 .list .direct {
  padding-left: 32px;
  padding-top: 31px;
  background: url(../img/shared/line.jpg) no-repeat center top;
}
#sec2 .list .direct p {
  line-height: 2.2em;
}
#sec2 .row2 {
  display: flex;
  margin-bottom: 100px;
}
#sec2 .row2 .img {
  height: 610px;
  margin-left: -100px;
}
#sec2 .row2 .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#sec2 .row2 .desc {
  display: flex;
  align-items: flex-start;
  flex-direction: row-reverse;
  margin: 79px -111px 0 76px;
}
#sec2 .row2 h2 {
  width: 56px;
  height: 192px;
  font-size: 40px;
  font-weight: 400;
  font-family: var(--ship);
  letter-spacing: 0.2em;
  line-height: 1.4em;
  margin-left: 30px;
}
#sec2 .row2 .txt {
  width: 99px;
  height: 364px;
  line-height: 2.2em;
  margin-top: 43px;
}

#sec3 {
  color: #000;
  background: url(../img/shared/bg2.jpg) repeat;
  background-position: center top;
  padding: 180px 0 140px;
  position: relative;
  z-index: 1;
}
#sec3::before {
  content: "";
  position: absolute;
  background: url(../img/anniversary/sec3_deco1.png) no-repeat;
  background-size: contain;
  width: 1023px;
  height: 595px;
  top: 0;
  left: calc(50% - 273px);
  z-index: -1;
}
#sec3 .row1 {
  margin-bottom: 59px;
  display: flex;
}
#sec3 .row1 img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#sec3 .row1 .left {
  margin-right: 53px;
}
#sec3 .row1 .left h2 {
  text-align: left;
  font-size: 40px;
  font-weight: 400;
  font-family: var(--ship);
  letter-spacing: 0.15em;
  line-height: 1.45em;
  margin-left: 88px;
  margin-bottom: 69px;
  position: relative;
}
#sec3 .row1 .left h2::before {
  content: "";
  position: absolute;
  background: url(../img/anniversary/sec3_t1_deco.png) no-repeat;
  background-size: contain;
  width: 419px;
  height: 6px;
  bottom: 9px;
  left: 0;
}
#sec3 .row1 .left h2 .small {
  font-size: 30px;
}
#sec3 .row1 .left .img {
  margin-left: -150px;
  height: 560px;
}
#sec3 .row1 .right {
  margin-top: 333px;
  margin-right: -111px;
  width: 428px;
}
#sec3 .row1 .right .txt {
  width: 300px;
  line-height: 2.2em;
  margin: 0 auto 66px;
}
#sec3 .row1 .right .img {
  height: 286px;
}
#sec3 .note {
  text-align: center;
  margin-bottom: 31px;
}
#sec3 .box {
  padding: 50px 104px 39px;
  border: 1px solid #000;
  box-sizing: border-box;
  margin-bottom: 150px;
  position: relative;
  z-index: 1;
}
#sec3 .box::before {
  content: "";
  position: absolute;
  background: url(../img/anniversary/sec3_deco2.png) no-repeat;
  background-size: contain;
  width: 488px;
  height: 421px;
  bottom: -310px;
  right: -409px;
  z-index: -1;
}
#sec3 .box .desc {
  display: flex;
  align-items: center;
  margin: 0 -20px 33px -10px;
}
#sec3 .box .desc h3 {
  font-size: 35px;
  font-weight: 400;
  letter-spacing: 0.2em;
  line-height: 1.55em;
  font-family: var(--ship);
  margin-right: 96px;
}
#sec3 .box .desc h3 .small {
  font-size: 25px;
  letter-spacing: 0.05em;
}
#sec3 .box .desc .txt {
  line-height: 2.2em;
}
#sec3 .box .dish {
  background: url(../img/shared/line.jpg) no-repeat center top, url(../img/shared/line.jpg) no-repeat center bottom;
  align-content: space-between;
  max-height: 132px;
  position: relative;
  display: flex;
  flex-flow: column wrap;
  padding: 22px 124px 21px 44px;
  margin: 0 auto;
}
#sec3 .box .dish li {
  line-height: 2.2em;
}
#sec3 .row3 {
  position: relative;
  margin-bottom: 112px;
}
#sec3 .row3 img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#sec3 .row3 .img1 {
  position: absolute;
  height: 561px;
  top: 0;
  left: -197px;
  z-index: 1;
}
#sec3 .row3 .img1::before {
  content: "";
  position: absolute;
  background: url(../img/anniversary/sec3_deco3.png) no-repeat;
  background-size: contain;
  width: 265px;
  height: 265px;
  bottom: -123px;
  left: -66px;
  z-index: -1;
}
#sec3 .row3 .btn-all {
  position: absolute;
  bottom: 52px;
  left: 61px;
}
#sec3 .row3 .group {
  padding-top: 50px;
  margin-right: -160px;
  width: 540px;
  margin-left: auto;
}
#sec3 .row3 .group h3 {
  font-size: 40px;
  font-weight: 400;
  font-family: var(--ship);
  letter-spacing: 0.2em;
  line-height: 1.5em;
  margin-bottom: 50px;
  margin-left: 22px;
}
#sec3 .row3 .group .txt {
  line-height: 2.2em;
  width: 396px;
  margin-bottom: 80px;
  margin-left: 27px;
}
#sec3 .row3 .group .img2 {
  height: 390px;
}
#sec4 {
  padding: 145px 0 102px;
  position: relative;
  z-index: 1;
}
#sec4::before, #sec4::after {
  content: "";
  position: absolute;
  background: url(../img/anniversary/sec4_deco1.png) no-repeat;
  background-size: contain;
  width: 367px;
  height: 364px;
  z-index: -1;
}
#sec4::before {
  top: -9px;
  right: calc(50% + 250px);
}
#sec4::after {
  background-image: url(../img/anniversary/sec4_deco2.png);
  width: 436px;
  height: 342px;
  bottom: 0;
  left: calc(50% + 313px);
}
#sec4 .row1 {
  display: flex;
  margin-bottom: -38px;
}
#sec4 .row1 .desc {
  position: relative;
  z-index: 1;
  margin-top: 125px;
}
#sec4 .row1 .desc h2 {
  font-size: 40px;
  font-weight: 400;
  font-family: var(--ship);
  letter-spacing: 0.15em;
  line-height: 1.4em;
  margin-left: 14px;
  margin-bottom: 71px;
  position: relative;
}
#sec4 .row1 .desc h2::before {
  content: "";
  position: absolute;
  background: url(../img/anniversary/sec4_t1_deco.png) no-repeat;
  background-size: contain;
  width: 399px;
  height: 6px;
  bottom: -1px;
  left: -49px;
}
#sec4 .row1 .desc .txt {
  width: 435px;
  line-height: 2.2em;
}
#sec4 .row1 .img {
  margin-right: -248px;
  margin-left: -87px;
  height: 600px;
}
#sec4 .row1 .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#sec4 .row2 {
  display: flex;
  gap: 78px;
  margin-bottom: 50px;
}
#sec4 .row2 img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#sec4 .row2 .img1 {
  margin-left: -43px;
  height: 360px;
}
#sec4 .row2 .img2 {
  margin-top: 152px;
  height: 290px;
}
#sec4 .btn-all {
  margin: 0 auto;
}

@media screen and (min-width: 768px) and (max-width: 1260px) {
  #sec2 .list {
    margin: 0 -50px 131px;
  }
  #sec2 .list .item {
    padding: 70px 25px 50px;
  }
  #sec2 .row2 .desc {
    margin-right: 0;
  }
  #sec3 .row1 .right {
    margin-right: 0;
  }
  #sec3 .row3 .img1 {
    left: -257px;
  }
  #sec3 .row3 .group {
    margin-right: -100px;
  }
}
