@charset "UTF-8";

@media screen and (min-width: 768px) {
   .wrap {
      width: 100%;
      max-width: 1000px;
   }
}

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

.bg-parallax {
   position: relative;
   z-index: 0;
   min-height: 70vw;
}

.text-latin {
   position: relative;
   text-transform: uppercase;
   padding-left: 30px;
   letter-spacing: 2px;
   margin-bottom: 20px;
}

.text-latin::before {
   content: "";
   background: url('../img/index/floor-deco.png') no-repeat 0 0/100%;
   width: 40px;
   height: 11px;
   left: -20px;
   top: 50%;
   transform: translateY(-50%);
   position: absolute;
}

.text-latin-right {
   position: relative;
   width: -moz-max-content;
   width: max-content;
   margin-left: auto;
   text-transform: uppercase;
   padding-right: 40px;
   letter-spacing: 2px;
   margin-bottom: 20px;
}

.text-latin-right::before {
   content: "";
   background: url('../img/index/shopinfo-deco.png') no-repeat 0 0/100%;
   width: 37px;
   height: 9px;
   right: -20px;
   top: 50%;
   transform: translateY(-50%);
   position: absolute;
}

.btn-t1 a {
   display: block;
   text-align: center;
   background: #30393e;
   padding: 10px;
   box-sizing: border-box;
   width: 280px;
   margin: 0 auto;
   color: #e2e2e2;
   position: relative;
}

.btn-t1 a::after {
   content: "";
   background: url(../img/course/icon_arrow1.png) no-repeat 0 0/100%;
   width: 24px;
   height: 7px;
   left: 0;
   top: 50%;
   transform: translateY(-50%);
   position: absolute;
   transition: 0.5s;
}

.btn-t1 a:hover {
   opacity: 0.7;
}

.btn-t1 a:hover::after {
   left: 5px;
   transition: 0.5s;
}

h2,
h3 {
   font-weight: 600;
   letter-spacing: 2px;
}
@media screen and (max-width: 767px) {
   .text-latin:before {
      left: -6.6vw;
   }
   .text-latin-right {
      padding-right: 30px;
   }
   .text-latin-right:before {
      right: -6.6vw;
   }
}
@media screen and (min-width: 768px) {
   .bg-parallax {
      min-height: 355px;
   }

   .text-latin {
      font-size: 15px;
      padding-left: 55px;
      letter-spacing: 6px;
      margin-bottom: 0;
   }

   .text-latin::before {
      left: 0;
   }

   .text-latin-right {
      font-size: 15px;
      padding-right: 55px;
      margin-bottom: 0;
      letter-spacing: 6px;
   }

   .text-latin-right::before {
      right: -10px;
   }

   .btn-t1 a {
      padding: 2px 0;
      width: 265px;
   }
}

.object-fit-cover {
   position: relative;
}

.object-fit-cover img {
   -o-object-fit: cover;
   object-fit: cover;
   position: absolute;
   top: 0;
   left: 0;
   right: 0;
   height: 100%;
   width: 100%;
}

@media screen and (min-width: 768px) {
   .object-fit-cover-pc {
      position: relative;
   }

   .object-fit-cover-pc img {
      -o-object-fit: cover;
      object-fit: cover;
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      height: 100%;
      width: 100%;
   }
}

#sec1 {
   position: relative;
   overflow: hidden;
   margin-top: 50px;
}

#sec1 .group-photo {
   height: 100vh;
}

#sec1 .group-photo .overlay {
   position: absolute;
   inset: 0;
   background: #000;
   opacity: 0;
   z-index: 5;
}

#sec1 .group-photo .photo-bg {
   height: 100vh;
}

#sec1 .group-photo .photo-bg img {
   height: 100vh;
   width: 100%;
   -o-object-fit: cover;
   object-fit: cover;
   -o-object-position: 50% 80%;
   object-position: 50% 80%;
}

#sec1 .group-content {
   position: absolute;
   top: 40%;
   left: 50%;
   transform: translate(-50%, 120%);
   opacity: 0;
   z-index: 10;
   width: 800px;
   max-width: 90%;
   text-align: center;
}

#sec1 .group-content h2 {
   margin-bottom: 150px;
}

#sec1 .group-content .txt {
   color: #fff;
   margin-bottom: 500px;
}

@media (max-width: 767px) {
   #sec1 {
      margin-top: 12vw;
   }

   #sec1 .group-photo .photo-bg img {
      -o-object-position: 25% 80%;
      object-position: 25% 80%;
   }

   #sec1 .group-content h2 {
      width: 125px;
      margin: 0 auto 80px;
   }
}

#sec2 {
   padding: 20vw 0;
   text-align: center;
   position: relative;
}

#sec2::before {
   content: "";
   background: #bcbcbc;
   height: 90%;
   width: 90%;
   left: 50%;
   top: 50%;
   transform: translate(-50%, -50%);
   position: absolute;
   z-index: -1;
}

#sec2 h2 {
   letter-spacing: 2px;
}

#sec2 .price {
   margin-bottom: 40px;
   position: relative;
}

#sec2 .price:after{
   content: '';
   width: 0;
   height: 20px;
   border-left: 1px solid rgba(0, 0, 0, 0.15);
   position: absolute;
   top: 115%;
   left: 50%;
}

#sec2 .price>span {
   display: block;
   font-weight: 600;
}

#sec2 .price>span:first-child {
   font-size: 22px;
   letter-spacing: 2px;
}

#sec2 .desc {
   margin-bottom: 20px;
   font-weight: 600;
}

#sec2 .loop-slider {
   display: flex;
   margin-bottom: 30px;
}

#sec2 .loop-slider li {
   width: 50vw;
   margin: 0 2px;
}

@media screen and (min-width: 768px) {
   #sec2 {
      padding: 220px 0 205px;
   }

   #sec2::before {
      height: 820px;
      width: calc(100% - 200px);
   }

   #sec2 h2 {
      letter-spacing: 10px;
      font-size: 21px;
      margin-bottom: 30px;
   }

   #sec2 .price {
      margin-bottom: 60px;
      position: relative;
   }

   #sec2 .price:after {
      height: 40px;
   }

   #sec2 .price>span:first-child {
      font-size: 30px;
      letter-spacing: 3px;
      margin-bottom: -10px;
   }

   #sec2 .price>span:first-child small {
      font-size: 20px;
   }

   #sec2 .price>span:last-child {
      font-size: 15px;
   }

   #sec2 .desc {
      font-size: 15px;
      margin-bottom: 40px;
   }

   #sec2 .loop-slider {
      margin-bottom: 50px;
   }

   #sec2 .loop-slider li {
      width: 500px;
      margin: 0 2px;
   }
}

#sec3 {
   padding: 10vw 0;
}

#sec3 .row {
   margin-bottom: 40px;
}

#sec3 .row .content h3 {
   font-size: 22px;
   margin-bottom: 20px;
}

#sec3 .row .content .photo {
   position: relative;
   margin-bottom: 15px;
   padding-bottom: 20px;
}

#sec3 .row .content .photo::before {
   content: "";
   background: url(../img/anniversary/sec3_deco1.jpg) repeat 0 0/auto;
   width: calc(100% - 20px);
   height: calc(100% - 20px);
   position: absolute;
}

#sec3 .row.row-1 .content .photo {
   padding-left: 20px;
}

#sec3 .row.row-1 .content .photo::before {
   top: 20px;
   right: 20px;
}

#sec3 .row.row-2 .content .photo {
   padding-right: 20px;
}

#sec3 .row.row-2 .content .photo::before {
   top: 20px;
   left: 20px;
}

#sec3 .box {
   padding: 30px 30px;
   background: #bcbcbc;
}

#sec3 .box .row {
   margin-bottom: 0;
}

#sec3 .box .row .content h3 {
   font-size: 20px;
}

#sec3 .box .row .content .photo-3 {
   margin-bottom: 15px;
}

@media screen and (min-width: 768px) {
   #sec3 {
      padding: 0 0 100px;
   }

   #sec3 .wrap {
      max-width: 1500px;
   }

   #sec3 .row {
      min-height: 500px;
      position: relative;
   }

   #sec3 .row .content {
      width: 390px;
   }

   #sec3 .row .content h3 {
      font-size: 40px;
      margin-bottom: 20px;
      letter-spacing: 6px;
   }

   #sec3 .row .content .photo {
      position: absolute;
      margin-bottom: 0;
      padding-bottom: 0;
      height: 500px;
   }

   #sec3 .row .content .photo::before {
      width: 100%;
      height: 100%;
   }

   #sec3 .row.row-1 {
      margin-bottom: 100px;
   }

   #sec3 .row.row-1 .content {
      margin-left: calc(50% + 205px);
      padding-top: 125px;
   }

   #sec3 .row.row-1 .content h3 {
      margin-bottom: 40px;
   }

   #sec3 .row.row-1 .content .photo {
      padding-left: 0;
      left: 100px;
      right: calc(50% - 105px);
      top: -10px;
   }

   #sec3 .row.row-1 .content .photo::before {
      top: 40px;
      right: 40px;
   }

   #sec3 .row.row-2 {
      margin-bottom: 160px;
   }

   #sec3 .row.row-2 .content {
      margin-right: calc(50% + 190px);
      padding-top: 165px;
      margin-left: auto;
      width: 410px;
      padding-left: 30px;
      box-sizing: border-box;
   }

   #sec3 .row.row-2 .content h3 {
      margin-bottom: 40px;
   }

   #sec3 .row.row-2 .content .photo {
      padding-left: 0;
      right: 100px;
      left: calc(50% - 105px);
      top: 25px;
   }

   #sec3 .row.row-2 .content .photo::before {
      top: 40px;
      left: 40px;
   }

   #sec3 .box {
      padding: 70px 30px;
      max-width: 1300px;
      margin: 0 auto;
      box-sizing: border-box;
   }

   #sec3 .box .row {
      width: 1000px;
      position: relative;
      margin: 0 auto;
      min-height: auto;
   }

   #sec3 .box .row .content {
      width: 425px;
      padding-top: 20px;
      margin-left: auto;
   }

   #sec3 .box .row .content h3 {
      font-size: 30px;
      margin-bottom: 30px;
      letter-spacing: 5px;
   }

   #sec3 .box .row .content .photo-3 {
      margin-bottom: 15px;
      position: absolute;
      left: 0;
      top: 0;
      right: 50%;
      height: 320px;
   }
}

#sec4 {
   padding: 10vw 0;
}

#sec4 .row-1 {
   margin-bottom: 40px;
}

#sec4 .row-1 .photo-1 {
   margin-bottom: 15px;
   position: relative;
   padding-right: 20px;
   padding-bottom: 20px;
}

#sec4 .row-1 .photo-1::before {
   content: "";
   background: url(../img/anniversary/sec3_deco1.jpg) repeat 0 0/auto;
   width: calc(100% - 20px);
   height: calc(100% - 20px);
   position: absolute;
   bottom: 0;
   right: 0;
}

#sec4 .row-1 .content h3 {
   margin-bottom: 10px;
}

#sec4 .row-1 .content h3 span {
   display: block;
   line-height: 40px;
   font-weight: 600;
}

#sec4 .row-1 .content h3 span:first-child {
   font-size: 20px;
}

#sec4 .row-1 .content h3 span:last-child {
   font-size: 24px;
}

#sec4 .row-2 {
   margin-bottom: 40px;
}

#sec4 .row-2 .photo-2 {
   margin-bottom: 15px;
}

#sec4 .row-2 .content dl {
   display: flex;
   justify-content: space-between;
   width: 250px;
   font-weight: 600;
}

#sec4 .row-2 .content .row-desc {
   margin-top: 5px;
}

#sec4 .row-3 .content h3 {
   margin-bottom: 15px;
}

#sec4 .row-3 .content h3 span {
   display: block;
   line-height: 40px;
}

#sec4 .row-3 .content h3 span:first-child {
   font-size: 20px;
}

#sec4 .row-3 .content h3 span:last-child {
   font-size: 24px;
}

#sec4 .row-3 .content .sec4-slide {
   margin-bottom: 15px;
}

@media screen and (min-width: 768px) {
   #sec4 {
      padding: 15px 0 100px;
   }

   #sec4 .wrap {
      max-width: 1500px;
   }

   #sec4 .row-1 {
      margin-bottom: 85px;
      position: relative;
      min-height: 630px;
      display: flex;
      align-items: flex-end;
   }

   #sec4 .row-1 .photo-1 {
      margin-bottom: 0;
      position: absolute;
      right: 0;
      left: 510px;
      padding-right: 0;
      padding-bottom: 0;
      height: 630px;
      top: -25px;
   }

   #sec4 .row-1 .photo-1::before {
      width: 100%;
      height: 100%;
      bottom: -50px;
      right: -50px;
   }

   #sec4 .row-1 .content {
      width: 380px;
      margin-left: 60px;
      margin-bottom: 12px;
   }

   #sec4 .row-1 .content h3 {
      margin-bottom: 50px;
   }

   #sec4 .row-1 .content h3 span {
      line-height: 40px;
   }

   #sec4 .row-1 .content h3 span:first-child {
      font-size: 30px;
      margin-bottom: 15px;
      letter-spacing: 6px;
   }

   #sec4 .row-1 .content h3 span:last-child {
      font-size: 40px;
      letter-spacing: 9px;
   }

   #sec4 .row-2 {
      margin-bottom: 40px;
      position: relative;
      max-width: 1200px;
      padding: 0 10px;
      margin: 0 auto 80px;
      min-height: 400px;
   }

   #sec4 .row-2 .photo-2 {
      margin-bottom: 15px;
      position: absolute;
      top: 0;
      left: 10px;
      right: 50%;
      height: 400px;
   }

   #sec4 .row-2 .content {
      width: 335px;
      margin-left: calc(50% + 165px);
      padding-top: 115px;
   }

   #sec4 .row-2 .content dl {
      width: 335px;
      font-size: 20px;
      letter-spacing: 3px;
   }

   #sec4 .row-2 .content .row-desc {
      margin-top: 10px;
      margin-left: 10px;
   }

   #sec4 .row-3 {
      min-height: 500px;
      position: relative;
   }

   #sec4 .row-3 .content {
      width: 435px;
      margin-left: auto;
      margin-right: calc(50% + 190px);
      padding-top: 105px;
      padding-left: 25px;
      box-sizing: border-box;
   }

   #sec4 .row-3 .content h3 {
      margin-bottom: 40px;
   }

   #sec4 .row-3 .content h3 span {
      line-height: 40px;
   }

   #sec4 .row-3 .content h3 span:first-child {
      font-size: 30px;
      margin-bottom: 20px;
      letter-spacing: 6px;
   }

   #sec4 .row-3 .content h3 span:last-child {
      font-size: 40px;
      letter-spacing: 9px;
   }

   #sec4 .row-3 .content .sec4-slide {
      margin-bottom: 15px;
      position: absolute;
      height: 500px;
      right: 50px;
      left: calc(50% - 45px);
      top: 0;
   }

   #sec4 .row-3 .content .sec4-slide .slick-slide {
      height: 500px;
   }
}

/* Dots */
.slick-dots {
   position: absolute;
   bottom: 3%;
   display: block;
   width: 100%;
   padding: 0;
   margin: 0;
   list-style: none;
   text-align: center;
}

.slick-dots li {
   position: relative;
   display: inline-block;
   width: 20px;
   height: 20px;
   margin: 10px 5px;
   padding: 0;
   cursor: pointer;
}

.slick-dots li button {
   font-size: 0;
   line-height: 0;
   display: block;
   width: 15px;
   height: 15px;
   padding: 5px;
   cursor: pointer;
   color: transparent;
   border: 0;
   outline: none;
   background: transparent;
}

.slick-dots li button:hover,
.slick-dots li button:focus {
   outline: none;
}

.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
   opacity: 1;
}

.slick-dots li button:before {
   font-family: "slick";
   font-size: 6px;
   line-height: 20px;
   position: absolute;
   top: 0;
   left: 0;
   width: 12px;
   height: 12px;
   content: "•";
   text-align: center;
   background: transparent;
   border: 1px solid #fff;
   border-radius: 15px;
   -webkit-font-smoothing: antialiased;
   -moz-osx-font-smoothing: grayscale;
}

.slick-dots li.slick-active button:before {
   background: #fff;
}

@media (min-width: 768px) and (max-width: 1300px) {
   #sec3 .row.row-1 .content {
      margin-left: calc(50% + 140px);
   }
}