@charset "UTF-8";

/* ===================================
  Intro
+==================================== */
#intro {
  padding-block: 165rem 28rem;
  background: url(../img/top/intro-bg.jpg) #9ad2db no-repeat center top/ 100% auto;
}
#intro h1 {
  width: 54rem;
  margin: 0 auto;
}
#intro p {
  width: 75rem;
  margin: 3.2rem auto 0;
}
@media (max-width: 767px) {
  #intro {
    padding-block: 156rem 45rem;
    background: url(../img/top/intro-bg-sp.png) #9ad2db no-repeat center top/ 100% auto;
  }
  #intro h1 {
    width: 49.4rem;
    margin: 0 auto 7rem;
  }
  #intro p {
    width: 50rem;
    margin: 2.4rem auto 0;
  }
}
/* ===================================
  Give You
+==================================== */
#giveyou {
  margin-top: -14rem;
  padding-block: 13rem 25rem;
  position: relative;
}
#giveyou:after {
  content: "";
  position: absolute;
  inset: 0;
  top: -35rem;
  background: url(../img/top/giveyou-bg-deco.png) no-repeat -11.6rem top/ 155.6rem auto;
  pointer-events: none;
  z-index: 0;
}
#giveyou:before {
  content: "";
  position: absolute;
  inset: 0;
  background: #b7dae1;
  mask: var(--pattern-wave01);
  pointer-events: none;
  z-index: 0;
}
#giveyou h2 {
  width: 60rem;
  margin: 0 auto 6rem;
  position: relative;
  z-index: 1;
}
#giveyou ol {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 76.8rem;
  margin: 0 auto;
  gap: 0 6rem;
  position: relative;
  z-index: 1;
}
#giveyou li {
  flex: 1 1 100%;
  max-width: calc(50% - 4rem);
  padding-top: 8rem;
  background: url(../img/top/giveyou-deco-ribbon.png) no-repeat 8rem top / 20.9rem auto;
  position: relative;
}
#giveyou li:after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}
#giveyou li:nth-of-type(1):after {
  background: url(../img/top/giveyou-deco01.png) no-repeat left 13rem /12.7rem auto;
  left: -4rem;
}
#giveyou li:nth-of-type(2):after {
  background: url(../img/top/giveyou-deco02.png) no-repeat left 10rem /17.5rem auto;
  left: -7rem;
}
#giveyou li:nth-of-type(3):after {
  background: url(../img/top/giveyou-deco03.png) no-repeat left 11rem /14.15rem auto;
  left: -4rem;
}
#giveyou li:nth-of-type(4):after {
  background: url(../img/top/giveyou-deco04.png) no-repeat left 5rem /20.5rem auto;
  left: -7rem;
}
#giveyou li a {
  display: block;
  background: #d35a46;
  margin-left: auto;
  text-align: center;
  color: #fff;
  font-size: 2rem;
  letter-spacing: 0.2em;
  text-decoration: none;
}
#giveyou li:nth-of-type(even) {
  margin-top: 8rem;
}
#giveyou li:nth-of-type(1) a {
  width: 32rem;
  padding-block: 4rem;
  clip-path: polygon(0% 8%, 97% 0%, 91% 93%, 8% 100%);
}
#giveyou li:nth-of-type(2) a {
  background: #256d73;
  width: 33rem;
  padding-block: 3rem 3rem;
  clip-path: polygon(0% 0%, 100% 4%, 91% 100%, 12% 100%);
}
#giveyou li:nth-of-type(3) a {
  background: #256d73;
  width: 31rem;
  padding-block: 3rem 4rem;
  clip-path: polygon(0% 0%, 100% 0%, 93% 93%, 11% 100%);
}
#giveyou li:nth-of-type(4) a {
  width: 33rem;
  padding-block: 3rem;
  clip-path: polygon(0% 3%, 97% 0%, 88% 95%, 8% 98%);
}
#giveyou li a:before {
  content: "";
  display: block;
  height: 6.4rem;
  margin: 0 auto 2rem;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  pointer-events: none;
}
#giveyou li:nth-of-type(1) a::before {
  background-image: url(../img/top/giveyou-num01.svg);
}
#giveyou li:nth-of-type(2) a::before {
  background-image: url(../img/top/giveyou-num02.svg);
}
#giveyou li:nth-of-type(3) a::before {
  background-image: url(../img/top/giveyou-num03.svg);
}
#giveyou li:nth-of-type(4) a::before {
  background-image: url(../img/top/giveyou-num04.svg);
}
#giveyou li a small {
  display: block;
  font-size: 1.5rem;
  font-weight: 400;
}
#giveyou li a img {
  display: block;
  width: 16.5rem;
  margin: 2rem auto 0;
}
@media (max-width: 767px) {
  #giveyou {
    padding-block: 12rem 28rem;
  }
  #giveyou:after {
    top: -26rem;
    background: url(../img/top/giveyou-bg-deco-sp.png) no-repeat 0 top/ 100% auto;
  }
  #giveyou h2 {
    width: auto;
    margin-bottom: 10rem;
  }
  #giveyou li {
    flex: 1 1 100%;
    max-width: 100%;
    z-index: 5;
  }
  #giveyou li:nth-of-type(1):after {
    background-position: 31rem 3rem;
    background-size: 20rem auto;
  }
  #giveyou li:nth-of-type(2):after {
    background-position: 34rem 12rem;
    background-size: 20rem auto;
  }
  #giveyou li:nth-of-type(3):after {
    background-position: 35rem 10rem;
    background-size: 16rem auto;
  }
  #giveyou li:nth-of-type(4):after {
    background-position: 29rem 7rem;
    background-size: 24rem auto;
  }
  #giveyou li a {
    margin: 0;
    font-size: 3rem;
  }
  #giveyou li:nth-of-type(even) {
    margin-top: 0;
    background-position: right 8rem top;
  }
  #giveyou li:nth-of-type(2) {
    margin-top: -14rem;
    z-index: 4;
  }
  #giveyou li:nth-of-type(3) {
    margin-top: -4rem;
    z-index: 3;
  }
  #giveyou li:nth-of-type(4) {
    margin-top: -4rem;
    z-index: 2;
  }
  #giveyou li:nth-of-type(1) a {
    width: 40rem;
    margin-left: -3rem;
    padding-bottom: 5rem;
  }
  #giveyou li:nth-of-type(2) a {
    margin-inline: auto -3rem;
    width: 42rem;
  }
  #giveyou li:nth-of-type(3) a {
    width: 42rem;
    margin-left: -4rem;
    padding-block: 4rem 5rem;
  }
  #giveyou li:nth-of-type(4) a {
    width: 42rem;
    margin-inline: auto -3rem;
    padding-bottom: 5rem;
  }
  #giveyou li a small {
    font-size: 2rem;
  }
  #giveyou li a img {
    width: 20rem;
  }
}
/* ===================================
  For Myself
+==================================== */
#formyself {
  margin-top: -15rem;
  padding-block: 16rem 25rem;
  position: relative;
}
#formyself:after {
  content: "";
  position: absolute;
  inset: 0;
  top: -9rem;
  background: url(../img/top/formyself-bg-deco.png) no-repeat center top/ 100% auto;
  pointer-events: none;
  z-index: 0;
}
#formyself:before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, #a5d0d9 0%, #cfe6eb 100%);
  mask: var(--pattern-wave02);
  pointer-events: none;
  z-index: 0;
}
#formyself h2 {
  width: 60rem;
  margin: 0 auto 7rem;
  position: relative;
  z-index: 1;
}
#formyself .gift-slider {
  position: relative;
  z-index: 1;
}
#formyself .gift-slider .splide__arrow {
  width: 4.8rem;
  height: 4.8rem;
  background: #fff;
  top: 40%;
}
#formyself .gift-slider .splide__arrow svg {
  width: 2.4rem;
  height: auto;
  fill: var(--color-black);
}
#formyself .gift-slider .splide__arrow.splide__arrow--next {
  right: calc(50% - 26rem);
}
#formyself .gift-slider .splide__arrow.splide__arrow--prev {
  left: calc(50% - 26rem);
}
#formyself .gift-slider .splide__slide.is-active a {
  opacity: 1;
  pointer-events: auto;
}
#formyself .gift-slider .splide__slide a {
  opacity: 0.5;
  transition: opacity 0.2s;
  pointer-events: none;
}
#formyself .gift-slider .splide__slide img {
  width: 35rem;
}
#formyself .splide__controls {
  width: fit-content;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 1rem;
  margin: 3rem auto 0;
  padding: 0.6rem 1.6rem 0.6rem 0.6rem;
  border-radius: 999rem;
  background: #fff;
}
#formyself .splide__controls .splide__play-pause {
  width: 4rem;
  height: 4rem;
  border-radius: 999rem;
  background: url(../img/common/ico-pause.svg) #5b5b5b no-repeat center center/ auto 1.6rem;
  color: transparent;
  font-size: 0;
}
#formyself .splide__controls .splide__play-pause.is-paused {

  background: url(../img/common/ico-play.svg) #5b5b5b no-repeat 55% center/ auto 1.2rem;
}
#formyself .splide__controls ul {
  display: flex !important;
  gap: 0 1rem;
  padding: 0;
  position: static;
}
#formyself .splide__controls li button {
  width: 1rem;
  height: 1rem;
  margin: 0;
  vertical-align: bottom;
  transform: none;
  background: var(--color-grey);
  opacity: 1;
}
#formyself .splide__controls li button.is-active {
  background-color: #cd4632;
}
@media (max-width: 767px) {
  #formyself:after {
    top: -3rem;
    background-image: url(../img/top/formyself-bg-deco-sp.png);
  }
  #formyself h2 {
    width: auto;
  }
  #formyself .gift-slider .splide__arrow {
    width: 6rem;
    height: 6rem;
  }
  #formyself .gift-slider .splide__arrow svg {
    width: 3rem;
  }
  #formyself .gift-slider .splide__arrow.splide__arrow--next {
    right: 5rem;
  }
  #formyself .gift-slider .splide__arrow.splide__arrow--prev {
    left: 5rem;
  }
  #formyself .gift-slider .splide__slide a {
    opacity: 1;
  }
  #formyself .gift-slider .splide__slide img {
    width: auto;
  }
  #formyself .splide__controls {
    padding: 1rem 2rem 1rem 1rem;
    gap: 0 2rem;
  }
  #formyself .splide__controls .splide__play-pause {
    width: 6rem;
    height: 6rem;
    background-size: auto 2.4rem;
  }
  #formyself .splide__controls ul {
    gap: 0 1.6rem;
  }
  #formyself .splide__controls li button {
    width: 1.6rem;
    height: 1.6rem;
  }
}
/* ===================================
  Christmas Market
+==================================== */
#market {
  margin-top: -15rem;
  padding-block: 17rem 25rem;
  position: relative;
}
#market:after {
  content: "";
  position: absolute;
  inset: 0;
  top: -13rem;
  background: url(../img/top/market-bg-deco.png) no-repeat center top/ 100% auto;
  pointer-events: none;
  z-index: 0;
}
#market:before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, #a6dbc7 0%, #c5e8dc 100%);
  mask: var(--pattern-wave01);
  pointer-events: none;
  z-index: 0;
}
#market > * {
  position: relative;
  z-index: 1;
}
#market h2 {
  width: 58rem;
  margin: 0 auto 9rem;
}
#market ul {
  display: grid;
  justify-content: center;
  grid-template-columns: repeat(2, 36rem);
  gap: 7rem;
}
#market ul li {
  display: grid;
  grid-row: span 3;
  grid-template-rows: subgrid;
  font-size: 1.4rem;
  font-weight: 400;
  gap: 2rem;
  text-align: justify;
}
#market ul li h3 {
  text-align: center;
  font-family: var(--font-shuei-gothic);
  font-size: 2.4rem;
  font-weight: bold;
}
#market ul li h3 figure img {
  width: auto;
  height: 5rem;
  margin-bottom: 2rem;
}

#market ul li p:has(strong) {
  text-align: center;
  font-family: var(--font-shuei-gothic);
  font-size: 2.4rem;
}
#market ul li p:has(strong) small {
  font-size: 1.8rem;
}
#market > p {
  width: 51.5rem;
  margin: 8rem auto 3rem;
}
#market > a {
  display: grid;
  justify-content: center;
  align-items: center;
  width: 39rem;
  height: 6rem;
  margin: 0 auto;
  border-radius: 0.8rem;
  background: #4da090;
}
#market > a img {
  width: 20rem;
}
@media (max-width: 767px) {
  #market {
    background: linear-gradient(to bottom, transparent 100rem, #c1e5da 100rem);
  }
  #market:after {
    top: -14rem;
    background-image: url(../img/top/market-bg-deco-sp.png);
  }
  #market h2 {
    width: 65rem;
    margin-bottom: 12rem;
  }
  #market ul {
    grid-template-columns: 1fr;
    margin: 0 5rem;
    gap: 10rem;
  }
  #market ul li {
    font-size: 2.8rem;
    gap: 4rem;
  }
  #market ul li h3 {
    font-size: 3.3rem;
  }
  #market ul li h3 figure img {
    height: 8rem;
    margin-bottom: 3rem;
  }
  #market > p {
    width: 65rem;
  }
  #market > a {
    width: 65rem;
    height: 10rem;
  }
  #market > a img {
    width: 31rem;
  }
}