@charset "UTF-8";
.point__content h3, .type-select__content h3, .collection__top .wear-lead h3 {
  line-height: 1;
  text-align: center;
}
.point__content h3 span, .type-select__content h3 span, .collection__top .wear-lead h3 span {
  display: inline-block;
  padding: 6px 6px;
  background: #ff8fa7;
  border-radius: 3px;
  line-height: 1;
  letter-spacing: 2px;
  text-box: trim-both cap alphabetic;
  font-family: YakuHanJP, "Zen Maru Gothic", sans-serif;
  font-size: 2.1rem;
  color: #ffffff;
}
@media screen and (min-width: 768px) {
  .point__content h3 span, .type-select__content h3 span, .collection__top .wear-lead h3 span {
    padding: 7px 4px;
    border-radius: 5px;
    letter-spacing: 1.5px;
    font-size: 2.2rem;
  }
}
.point__content h3 span:first-child, .type-select__content h3 span:first-child, .collection__top .wear-lead h3 span:first-child {
  margin-bottom: 8px;
}
@media screen and (min-width: 768px) {
  .point__content h3 span:first-child, .type-select__content h3 span:first-child, .collection__top .wear-lead h3 span:first-child {
    margin-bottom: 6px;
  }
}

.collection__pickup___item.combidress03 .content01::before, .collection__pickup___item.preall03 .content01::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  background-repeat: repeat-x;
  background-position: center;
  background-size: contain;
  z-index: -1;
}

.page-mv__content___ttl::before, .page-mv__content___greeting h2 span::before, .collection__new-arrivals___content:not(:last-child)::before {
  background-repeat: repeat-x;
  background-position: center;
  background-size: 100% 100%;
}

.collection__new-arrivals .new-arrivals {
  width: 100px;
  margin: 0 auto 20px;
  position: relative;
  line-height: 0;
}

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after {
  content: "";
  content: none;
}

q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

select {
  -moz-appearance: none;
  -webkit-appearance: none;
  text-indent: 0.01px;
  text-overflow: "";
  appearance: none;
  border-radius: 0;
  border: 0;
  margin: 0;
  padding: 0;
  background: none transparent;
  vertical-align: middle;
  color: inherit;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
}

select::-ms-expand {
  display: none;
}

em {
  font-style: normal;
}

main {
  display: block;
}

html, body {
  height: 100%;
  width: 100%;
}

html {
  font-size: 62.5%;
}

body {
  background: #fff;
  font-size: 1.4rem;
  font-family: "Noto Sans JP", sans-serif;
  /* font-family: "ヒラギノ角ゴ Pro W6", sans-serif; */
  /* font-family: "Oswald", sans-serif; */
  font-weight: 400;
  color: #000000;
  line-height: 1.8;
  -moz-text-size-adjust: none;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  word-wrap: break-word;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  font-size: 1.6rem;
}
@media screen and (min-width: 768px) {
  body {
    font-size: 1.8rem;
  }
}

a {
  /*transition: all 0.3s linear;*/
  color: #000;
  text-decoration: none;
  -webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}

*, :after, :before {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

*:focus {
  outline: none;
}

img {
  max-width: 100%;
  width: 100%;
  height: auto;
  vertical-align: top;
}

.wrapper {
  overflow-x: hidden;
}

.sp {
  display: block !important;
}
@media screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}

.pc {
  display: none !important;
}
@media screen and (min-width: 768px) {
  .pc {
    display: block !important;
  }
}

header {
  padding: 5.07% 4vw;
}
@media screen and (min-width: 768px) {
  header {
    padding: 30px 0 30px 30px;
  }
}
header > div {
  width: 130px;
}
@media screen and (min-width: 768px) {
  header > div {
    width: 195px;
  }
}
header > div a {
  display: block;
  width: 100%;
  height: 100%;
}

/*-- ファイル読み込み --*/
/* ==========================================================================
   order-obj
========================================================================== */
.order-obj {
  position: relative;
  z-index: 2;
}

/* ==========================================================================
   page-mv
========================================================================== */
.page-mv {
  margin-bottom: 90px;
  background: -webkit-gradient(linear, left bottom, left top, color-stop(78%, rgba(199, 240, 249, 0)), to(rgb(199, 240, 249)));
  background: linear-gradient(0deg, rgba(199, 240, 249, 0) 78%, rgb(199, 240, 249));
  position: relative;
}
@media screen and (min-width: 768px) {
  .page-mv {
    margin-bottom: 80px;
  }
}
.page-mv__content {
  width: 100%;
  max-width: 800px;
  margin: 0 auto 0px;
  position: relative;
}
.page-mv__content___ttl {
  margin-bottom: 30px;
}
@media screen and (min-width: 768px) {
  .page-mv__content___ttl {
    margin-bottom: 50px;
    border-radius: 0 0 30px 30px;
    overflow: hidden;
  }
}
.page-mv__content___ttl .page-mv-img {
  opacity: 0;
  -webkit-animation: fdin 0.4s ease-in forwards;
          animation: fdin 0.4s ease-in forwards;
}
.page-mv__content___ttl h1 {
  width: 77%;
  position: absolute;
  left: 50%;
  bottom: 8%;
  -webkit-transform: translateX(-50%) translateZ(0);
          transform: translateX(-50%) translateZ(0);
  -webkit-filter: drop-shadow(0px 0px 2px #b2b2b2);
          filter: drop-shadow(0px 0px 2px #b2b2b2);
  opacity: 0;
  z-index: 2;
  -webkit-animation: fdin 0.4s 0.4s ease-in forwards;
          animation: fdin 0.4s 0.4s ease-in forwards;
}
@media screen and (min-width: 768px) {
  .page-mv__content___ttl h1 {
    width: min(45%, 360px);
    bottom: 5%;
  }
}
.page-mv__content___ttl::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url("../img/top/frame_sp.png");
  opacity: 0;
  z-index: 1;
  -webkit-animation: fdin 0.4s 0.4s ease-in forwards;
          animation: fdin 0.4s 0.4s ease-in forwards;
}
@media screen and (min-width: 768px) {
  .page-mv__content___ttl::before {
    background-image: url("../img/top/frame_pc.png");
  }
}
.page-mv__content___greeting {
  width: 86%;
  max-width: 680px;
  margin: 0 auto 0px;
}
.page-mv__content___greeting h2 {
  margin-bottom: 24px;
  position: relative;
  line-height: 1;
  text-align: center;
  font-family: YakuHanJP, "Zen Maru Gothic", sans-serif;
  font-size: 2.15rem;
  color: #ff8fa7;
}
@media screen and (min-width: 768px) {
  .page-mv__content___greeting h2 {
    margin-bottom: 40px;
    font-size: 2.4rem;
  }
}
.page-mv__content___greeting h2 span {
  display: inline-block;
  padding-bottom: 14px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .page-mv__content___greeting h2 span {
    padding-bottom: 16px;
  }
}
.page-mv__content___greeting h2 span::before {
  content: "";
  width: 100%;
  height: 10px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-image: url("../img/top/line-a_sp.svg");
}
@media screen and (min-width: 768px) {
  .page-mv__content___greeting h2 span::before {
    background-image: url("../img/top/line-a_pc.svg");
  }
}
.page-mv__content___greeting p {
  letter-spacing: 0.3px;
  text-align: justify;
  font-size: 1.4rem;
}
@media screen and (min-width: 768px) {
  .page-mv__content___greeting p {
    font-size: 1.8rem;
  }
}

/* ==========================================================================
   introduction
========================================================================== */
.introduction {
  width: 100%;
  max-width: 560px;
  margin: 0 auto 0px;
}

/* ==========================================================================
   point
========================================================================== */
.point {
  position: relative;
  margin-bottom: 90px;
}
@media screen and (min-width: 768px) {
  .point {
    margin-bottom: 66px;
  }
}
.point__content {
  width: 86%;
  max-width: 560px;
  margin: 0 auto 50px;
}
@media screen and (min-width: 768px) {
  .point__content {
    width: 100%;
  }
}
.point__content .bubble {
  width: 80px;
  margin: 0 auto 10px;
  -webkit-animation: scaling 4s infinite;
          animation: scaling 4s infinite;
}
@media screen and (min-width: 768px) {
  .point__content .bubble {
    width: 72px;
    margin-bottom: 14px;
  }
}
.point__content h3 {
  margin-bottom: 30px;
}
.point__content .point-img {
  margin-bottom: 20px;
  border-radius: 10px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .point__content .point-img {
    margin-bottom: 30px;
    border-radius: 20px;
  }
}
.point__content .point-txt {
  letter-spacing: 0.3px;
  text-align: justify;
}

/* ==========================================================================
   type-select
========================================================================== */
.type-select {
  margin-bottom: 90px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .type-select {
    margin-bottom: 150px;
  }
}
.type-select__content {
  width: 86%;
  max-width: 560px;
  margin: 0 auto 0px;
  position: relative;
}
.type-select__content .bubble {
  width: 120px;
  margin: 0 auto 10px;
  -webkit-animation: scaling 4s infinite;
          animation: scaling 4s infinite;
}
@media screen and (min-width: 768px) {
  .type-select__content .bubble {
    width: 130px;
    margin-bottom: 14px;
  }
}
.type-select__content h3 {
  margin-bottom: 30px;
}
.type-select__content ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.type-select__content ul li {
  width: 46%;
  position: relative;
}
@media screen and (min-width: 768px) {
  .type-select__content ul li {
    width: min(42.2%, 236px);
  }
}
.type-select__content ul li::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -8px;
  margin: auto;
  border-radius: 20px;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .type-select__content ul li::before {
    bottom: -10px;
    border-radius: 30px;
  }
}
.type-select__content ul li a {
  display: block;
  padding: 14px 0 10px;
  width: 100%;
  height: 100%;
  position: relative;
  background: #ffffff;
  border-radius: 20px;
  border-width: 3px;
  border-style: solid;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .type-select__content ul li a {
    padding: 26px 0 18px;
    border-radius: 30px;
    border-width: 5px;
  }
}
.type-select__content ul li a .type-img {
  display: block;
  width: 79%;
  margin: 0 auto 3px;
}
@media screen and (min-width: 768px) {
  .type-select__content ul li a .type-img {
    width: min(72.2%, 166px);
    margin-bottom: 16px;
  }
}
.type-select__content ul li a .txt {
  margin-bottom: 8px;
  etter-spacing: 0.3px;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .type-select__content ul li a .txt {
    margin-bottom: 14px;
  }
}
.type-select__content ul li a .txt .type {
  margin-bottom: 8px;
  line-height: 1;
  font-family: YakuHanJP, "Zen Maru Gothic", sans-serif;
  color: #ff8fa7;
}
@media screen and (min-width: 768px) {
  .type-select__content ul li a .txt .type {
    margin-bottom: 10px;
    font-size: 2.4rem;
  }
}
.type-select__content ul li a .txt .size {
  margin: 0 auto;
  line-height: 0;
}
.type-select__content ul li a .arrow {
  display: block;
  width: 7%;
  margin: 0 auto;
  aspect-ratio: 20/30;
  line-height: 1;
  -webkit-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
          transform: rotate(90deg);
}
@media screen and (min-width: 768px) {
  .type-select__content ul li a .arrow {
    width: 14px;
  }
}
@media screen and (min-width: 768px) {
  .type-select__content ul li a:hover {
    -webkit-transform: translateY(10px);
        -ms-transform: translateY(10px);
            transform: translateY(10px);
  }
}
.type-select__content ul li.type-a::before {
  background: #b7e0e5;
}
.type-select__content ul li.type-a a {
  border-color: #b7e0e5;
}
.type-select__content ul li.type-a a .txt .size {
  width: 47px;
}
@media screen and (min-width: 768px) {
  .type-select__content ul li.type-a a .txt .size {
    width: 70px;
  }
}
.type-select__content ul li.type-a a .arrow svg .arrow-path {
  fill: #b7e0e5;
}
.type-select__content ul li.type-b::before {
  background: #c1e2ac;
}
.type-select__content ul li.type-b a {
  border-color: #c1e2ac;
}
.type-select__content ul li.type-b a .txt .size {
  width: 89px;
}
@media screen and (min-width: 768px) {
  .type-select__content ul li.type-b a .txt .size {
    width: 133px;
  }
}
.type-select__content ul li.type-b a .arrow svg .arrow-path {
  fill: #c1e2ac;
}

/* ==========================================================================
   product
========================================================================== */
.collection__top {
  margin-bottom: 70px;
  position: relative;
}
.collection__top::before {
  content: "";
  display: block;
  width: 100%;
  height: 10px;
  position: absolute;
  top: 10px;
  left: 0;
  -webkit-mask-image: url("../img/top/wave_sp.svg");
          mask-image: url("../img/top/wave_sp.svg");
  -webkit-mask-size: 375px;
          mask-size: 375px;
  -webkit-mask-repeat: repeat-x;
          mask-repeat: repeat-x;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .collection__top::before {
    height: 20px;
    aspect-ratio: auto;
    -webkit-mask-image: url("../img/top/wave_pc.svg");
            mask-image: url("../img/top/wave_pc.svg");
    -webkit-mask-size: 1440px;
            mask-size: 1440px;
  }
}
.collection__top::after {
  content: "";
  display: block;
  width: 100%;
  height: 20px;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #ffffff;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .collection__top::after {
    height: 30px;
    aspect-ratio: auto;
  }
}
.collection__top___content {
  width: 86%;
  max-width: 560px;
  margin: 0 auto 0px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .collection__top___content {
    width: 100%;
  }
}
.collection__top .sec-ttl {
  width: 100%;
  max-width: 560px;
  margin: 0 auto 14px;
  position: relative;
  text-align: center;
  z-index: 2;
}
.collection__top .sec-ttl p {
  width: 90px;
  margin: 0 auto 14px;
  -webkit-animation: scaling 4s infinite;
          animation: scaling 4s infinite;
}
.collection__top .sec-ttl h2 {
  letter-spacing: 2px;
  font-weight: 500;
  color: #6b6b6b;
}
@media screen and (min-width: 768px) {
  .collection__top .sec-ttl h2 {
    line-height: 2.3;
    font-size: 1.4rem;
  }
}
.collection__top .sec-ttl h2 span {
  margin-bottom: 12px;
  line-height: 1;
  font-family: YakuHanJP, "Zen Maru Gothic", sans-serif;
  font-size: 3.4rem;
  color: #ff8fa7;
  text-shadow: 2px 2px 0px rgb(255, 255, 255);
}
@media screen and (min-width: 768px) {
  .collection__top .sec-ttl h2 span {
    font-size: 3.6rem;
    text-shadow: 3px 3px 0px rgb(255, 255, 255);
  }
}
.collection__top .wear-lead {
  width: 100%;
  max-width: 560px;
  margin: 0 auto 0px;
  position: relative;
}
.collection__top .wear-lead h3 {
  margin-bottom: 30px;
}
@media screen and (min-width: 768px) {
  .collection__top .wear-lead h3 {
    margin-bottom: 40px;
  }
}
.collection__top .wear-lead p {
  text-align: justify;
}
.collection__top .wear-lead__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 3px;
  margin-bottom: 24px;
  padding: 14px 0;
  background: #ffffff;
  border-radius: 20px;
  border-width: 3px;
  border-style: solid;
}
@media screen and (min-width: 768px) {
  .collection__top .wear-lead__content {
    gap: 0 36px;
    padding: 20px 0 16px;
    border-radius: 30px;
    border-width: 5px;
  }
}
.collection__top .wear-lead__content > div {
  width: 42%;
}
@media screen and (min-width: 768px) {
  .collection__top .wear-lead__content > div {
    width: min(34%, 190px);
  }
}
.collection__top .wear-lead__content > div .name {
  margin-top: 6px;
  line-height: 1;
  font-family: YakuHanJP, "Zen Maru Gothic", sans-serif;
  text-align: center;
  font-size: 1.3rem;
  color: #ff8fa7;
}
@media screen and (min-width: 768px) {
  .collection__top .wear-lead__content > div .name {
    margin-top: 8px;
    font-size: 1.8rem;
  }
}
.collection__top .wear-lead__content .arrow {
  display: block;
  width: 3%;
  line-height: 1;
}
@incldue pc_css {
  .collection__top .wear-lead__content .arrow {
    width: 3.3%;
  }
}
.collection__top___01 {
  background: -webkit-gradient(linear, left bottom, left top, from(rgba(223, 243, 249, 0)), to(rgb(223, 243, 249)));
  background: linear-gradient(0deg, rgba(223, 243, 249, 0), rgb(223, 243, 249));
}
@media screen and (min-width: 768px) {
  .collection__top___01 {
    margin-bottom: 60px;
  }
}
.collection__top___01::before {
  background: #dff3f9;
}
.collection__top___01 .wear-lead__content {
  border-color: #b7e0e5;
}
.collection__top___02 {
  background: -webkit-gradient(linear, left bottom, left top, from(rgba(235, 248, 215, 0)), to(rgb(235, 248, 215)));
  background: linear-gradient(0deg, rgba(235, 248, 215, 0), rgb(235, 248, 215));
}
@media screen and (min-width: 768px) {
  .collection__top___02 {
    margin-bottom: 140px;
  }
}
.collection__top___02::before {
  background: #ebf8d7;
}
.collection__top___02 .wear-lead__content {
  border-color: #c1e2ac;
}
.collection__pickup {
  width: 100%;
  max-width: 800px;
  margin: 0 auto 125px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .collection__pickup {
    margin-bottom: 130px;
  }
}
@media screen and (min-width: 768px) {
  .collection__pickup___item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.collection__pickup___item:not(last-child) {
  margin-bottom: 75px;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item:not(last-child) {
    margin-bottom: 100px;
  }
}
.collection__pickup___item .content01 {
  margin-bottom: 7.7%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item .content01 {
    margin-bottom: 30px;
  }
}
.collection__pickup___item .img-b {
  position: absolute;
  border-radius: 50%;
  border-width: 3px;
  border-style: solid;
  z-index: 2;
  -webkit-transition-delay: 0.1s;
          transition-delay: 0.1s;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item .img-b {
    border-width: 4px;
  }
}
.collection__pickup___item .img-b.type-a {
  border-color: #b7e0e5;
}
.collection__pickup___item .img-b.type-b {
  border-color: #c1e2ac;
}
.collection__pickup___item .content02 {
  width: 86%;
  max-width: 560px;
  margin: 0 auto 0px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item .content02 {
    margin: 0;
    max-width: 100%;
  }
}
.collection__pickup___item .content02 .shapes {
  position: relative;
}
.collection__pickup___item .content02 .point {
  width: 80px;
  position: absolute;
  -webkit-animation: scaling 4s infinite;
          animation: scaling 4s infinite;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item .content02 .point {
    width: 90px;
  }
}
.collection__pickup___item .content02 .txt {
  margin-bottom: 26px;
  text-align: justify;
  font-size: 1.4rem;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item .content02 .txt {
    font-size: 1.6rem;
  }
}
.collection__pickup___item .content02 .price {
  line-height: 1;
  text-align: center;
  font-family: YakuHanJP, "Zen Maru Gothic", sans-serif;
  font-size: 1.7rem;
  color: #6b6b6b;
  clear: both;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item .content02 .price {
    text-align: left;
    font-size: 2rem;
  }
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress01 {
    width: 96%;
    max-width: 660px;
    margin-left: 60px;
  }
}
.collection__pickup___item.combidress01 .content01 {
  width: 80%;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress01 .content01 {
    width: min(64%, 326px);
    margin: 0;
  }
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress01 .content02 {
    width: min(46.2%, 310px);
    margin-bottom: 12px;
  }
}
.collection__pickup___item.combidress01 .content02 .shapes {
  width: 43%;
  aspect-ratio: 270/180;
  shape-outside: polygon(0 0, 100% 0, 70% 100%, 0% 100%);
  float: left;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress01 .content02 .shapes {
    width: 34%;
    aspect-ratio: 88/98;
    shape-outside: polygon(0 0, 100% 0, 60% 100%, 0% 100%);
  }
}
.collection__pickup___item.combidress01 .content02 .shapes .img-b {
  width: 93.7%;
  top: -80%;
  left: -10%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress01 .content02 .shapes .img-b {
    width: 146px;
    top: -93px;
    left: -72px;
  }
}
.collection__pickup___item.combidress01 .content02 .point {
  top: -38%;
  right: -4%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress01 .content02 .point {
    top: -60px;
    left: 105px;
  }
}
.collection__pickup___item.combidress01 .content02 .txt {
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress02 {
    width: 96%;
    max-width: 726px;
    margin-left: auto;
  }
}
.collection__pickup___item.combidress02 .content01 {
  width: 93%;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress02 .content01 {
    width: min(76%, 388px);
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress02 .content02 {
    width: min(42.5%, 308px);
    margin-top: 30px;
    -webkit-box-ordinal-group: 1;
        -ms-flex-order: 0;
            order: 0;
  }
}
.collection__pickup___item.combidress02 .content02 .shapes {
  width: 44%;
  aspect-ratio: 234/180;
  shape-outside: polygon(0 0, 100% 0, 100% 100%, 25% 100%);
  float: right;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress02 .content02 .shapes {
    width: 36%;
    aspect-ratio: 88/102;
  }
}
.collection__pickup___item.combidress02 .content02 .shapes .img-b {
  width: 91.5%;
  top: -52%;
  right: -10%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress02 .content02 .shapes .img-b {
    width: 146px;
    top: -64px;
    right: -84px;
  }
}
.collection__pickup___item.combidress02 .content02 .point {
  top: -36%;
  left: -4%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress02 .content02 .point {
    top: -60px;
    left: -12px;
  }
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress03 {
    width: 96%;
    max-width: 736px;
    margin-left: 50px;
  }
}
.collection__pickup___item.combidress03 .content01 {
  width: 80%;
  margin-right: auto;
  margin-left: auto;
  position: relative;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress03 .content01 {
    width: min(76%, 326px);
    margin: 0;
  }
}
.collection__pickup___item.combidress03 .content01::before {
  width: 110%;
  aspect-ratio: 637/627;
  background-image: url("../img/top/bg-a.png");
}
.collection__pickup___item.combidress03 .img-b {
  width: 34.7%;
  top: 47.5%;
  left: 4%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress03 .img-b {
    width: 146px;
    top: 30px;
    left: 263px;
  }
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress03 .content02 {
    width: min(50%, 356px);
    margin-top: 100px;
  }
}
.collection__pickup___item.combidress03 .content02 .point {
  top: -60%;
  right: -4%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.combidress03 .content02 .point {
    top: -60px;
    right: auto;
    left: 39px;
  }
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall01 {
    width: 708px;
    margin: 0 0 120px 30px;
  }
}
.collection__pickup___item.preall01 .content01 {
  width: 86%;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall01 .content01 {
    width: 354px;
    margin: 0;
  }
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall01 .content02 {
    width: 340px;
    margin-bottom: 50px;
  }
}
.collection__pickup___item.preall01 .content02 .shapes {
  width: 45%;
  aspect-ratio: 270/180;
  shape-outside: polygon(0 0, 100% 0, 70% 100%, 0% 100%);
  float: left;
}
.collection__pickup___item.preall01 .content02 .shapes .img-b {
  width: 89.5%;
  top: -62%;
  left: -10%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall01 .content02 .shapes .img-b {
    width: 146px;
    left: -30px;
  }
}
.collection__pickup___item.preall01 .content02 .point {
  top: -38%;
  right: -4%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall01 .content02 .point {
    top: -60px;
    right: 102px;
  }
}
.collection__pickup___item.preall01 .content02 .txt {
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall02 {
    width: 740px;
  }
}
.collection__pickup___item.preall02 .content01 {
  width: 93%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall02 .content01 {
    width: 393px;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall02 .content02 {
    width: 290px;
    margin-top: 40px;
    -webkit-box-ordinal-group: 1;
        -ms-flex-order: 0;
            order: 0;
  }
}
.collection__pickup___item.preall02 .content02 .shapes {
  width: 43%;
  aspect-ratio: 234/180;
  shape-outside: polygon(0 0, 100% 0, 100% 100%, 25% 100%);
  float: right;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall02 .content02 .shapes {
    width: 30%;
    aspect-ratio: 120/100;
    shape-outside: polygon(0 0, 100% 0, 100% 100%, 36% 100%);
  }
}
.collection__pickup___item.preall02 .content02 .shapes .img-b {
  width: 93.7%;
  top: -60%;
  right: -10%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall02 .content02 .shapes .img-b {
    width: 146px;
    top: -74px;
    right: -86px;
  }
}
.collection__pickup___item.preall02 .content02 .point {
  top: -38%;
  left: -4%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall02 .content02 .point {
    top: -60px;
    left: -12px;
  }
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall03 {
    width: 686px;
    margin-left: 10px;
  }
}
.collection__pickup___item.preall03 .content01 {
  width: 80%;
  margin-right: auto;
  margin-left: auto;
  margin-bottom: 14.4%;
  position: relative;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall03 .content01 {
    width: 326px;
    margin: 0;
  }
}
.collection__pickup___item.preall03 .content01::before {
  width: 100.5%;
  aspect-ratio: 637/627;
  background-image: url("../img/top/bg-b.png");
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall03 .content01::before {
    width: 102%;
    left: 53%;
  }
}
.collection__pickup___item.preall03 .img-b {
  width: 34.7%;
  top: 49%;
  left: 4%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall03 .img-b {
    width: 146px;
    top: 22px;
    left: 263px;
  }
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall03 .content02 {
    width: 356px;
    margin-top: 150px;
  }
}
.collection__pickup___item.preall03 .content02 .point {
  top: -60%;
  right: -4%;
}
@media screen and (min-width: 768px) {
  .collection__pickup___item.preall03 .content02 .point {
    top: -60px;
    right: auto;
    left: 90px;
  }
}
.collection__new-arrivals {
  margin-bottom: 100px;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals {
    margin-bottom: 160px;
  }
}
.collection__new-arrivals .new-arrivals {
  width: 131px;
  margin-bottom: 16px;
  -webkit-animation: scaling 4s infinite;
          animation: scaling 4s infinite;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals .new-arrivals {
    width: 158px;
    margin-bottom: 34px;
  }
}
.collection__new-arrivals .ttl {
  margin-bottom: 18px;
  line-height: 1;
  text-align: center;
  font-family: YakuHanJP, "Zen Maru Gothic", sans-serif;
  font-size: 2.2rem;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals .ttl {
    font-size: 3.3rem;
  }
}
.collection__new-arrivals .ttl__01 {
  color: #7cc6c2;
}
.collection__new-arrivals .ttl__02 {
  color: #9fd57b;
}
.collection__new-arrivals___content {
  width: 100%;
  max-width: 900px;
  margin: 0 auto 0px;
}
.collection__new-arrivals___content:not(:last-child) {
  margin-bottom: 40px;
  padding-bottom: 50px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content:not(:last-child) {
    margin-bottom: 60px;
    padding-bottom: 100px;
  }
}
.collection__new-arrivals___content:not(:last-child)::before {
  content: "";
  width: 86%;
  height: 10px;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  background-image: url("../img/top/line-b_sp.svg");
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content:not(:last-child)::before {
    width: 822px;
    height: 12px;
    background-image: url("../img/top/line-b_pc.svg");
  }
}
.collection__new-arrivals___content h4 {
  margin: 0 auto 20px;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content h4 {
    margin-bottom: 36px;
  }
}
.collection__new-arrivals___content h4.category {
  line-height: 1;
  text-align: center;
  font-family: YakuHanJP, "Zen Maru Gothic", sans-serif;
  font-size: 2.6rem;
  color: #ff8fa7;
}
.collection__new-arrivals___content h4.price-699 {
  width: 195px;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content h4.price-699 {
    width: 292px;
  }
}
.collection__new-arrivals___content h4.price-899 {
  width: 196px;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content h4.price-899 {
    width: 294px;
  }
}
.collection__new-arrivals___content h4.price-1299 {
  width: 240px;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content h4.price-1299 {
    width: 361px;
  }
}
.collection__new-arrivals___content .annotation {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 20px;
  line-height: 1;
  font-size: 1.4rem;
}
.collection__new-arrivals___content .annotation img {
  display: block;
  width: 14px;
  margin-right: 4px;
}
.collection__new-arrivals___content .annotation {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 20px;
  line-height: 1;
  font-size: 1.4rem;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content .annotation {
    margin-bottom: 40px;
    font-size: 2.1rem;
  }
}
.collection__new-arrivals___content .annotation img {
  display: block;
  width: 14px;
  margin-right: 4px;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content .annotation img {
    width: 21px;
  }
}
.collection__new-arrivals___content .product-list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 2vw 2%;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content .product-list ul {
    gap: 15px 1.6%;
  }
}
.collection__new-arrivals___content .product-list ul li {
  width: 32%;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content .product-list ul li {
    width: 18.66%;
  }
}
.collection__new-arrivals___content .product-list ul li a {
  display: block;
  position: relative;
  overflow: hidden;
}
.collection__new-arrivals___content .product-list ul li a img {
  -webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}
.collection__new-arrivals___content .product-list ul li a:before {
  content: "";
  display: block;
  width: 4vw;
  height: 4vw;
  position: absolute;
  bottom: 0;
  right: 0;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content .product-list ul li a:before {
    width: 23px;
    height: 23px;
  }
}
.collection__new-arrivals___content .product-list ul li a .star {
  display: block;
  width: 12%;
  aspect-ratio: 28/32;
  position: absolute;
  top: 0;
  left: 8.5%;
  background: url("../img/common/bookmark.svg") no-repeat top/contain;
  line-height: 0;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content .product-list ul li a .star {
    width: min(11.4%, 19px);
    left: 10px;
  }
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content .product-list ul li a:hover img {
    -webkit-transform: scale(1.05);
        -ms-transform: scale(1.05);
            transform: scale(1.05);
  }
}
.collection__new-arrivals___content____01 .product-list ul li a::before {
  background-image: url("../img/common/item-arrow-a.svg");
}
.collection__new-arrivals___content____02 h4.price-699 {
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) {
  .collection__new-arrivals___content____02 h4.price-699 {
    margin-bottom: 20px;
  }
}
.collection__new-arrivals___content____02 .product-list ul li a::before {
  background-image: url("../img/common/item-arrow-b.svg");
}

/* ==========================================================================
   Banner
========================================================================== */
.banner {
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) {
  .banner {
    margin-bottom: 70px;
  }
}
.banner__item {
  width: 92%;
  max-width: 514px;
  margin: 0 auto 0px;
}
.banner__item a {
  display: block;
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 768px) {
  .banner__item a a:hover {
    opacity: 0.7;
  }
}

/* ==========================================================================
   parts
========================================================================== */
.parts {
  display: block;
  position: absolute;
  line-height: 1;
}
.parts__01 {
  width: 54.8%;
  bottom: -14%;
  left: -20%;
}
@media screen and (min-width: 768px) {
  .parts__01 {
    width: min(29.3%, 234px);
    bottom: -19%;
    left: 0.2%;
  }
}
.parts__02 {
  width: 73.9%;
  top: -18%;
  right: -40%;
}
@media screen and (min-width: 768px) {
  .parts__02 {
    width: min(57%, 319px);
    top: -5%;
    right: -28%;
  }
}
.parts__03 {
  width: 36.2%;
  left: 12%;
  bottom: -12%;
}
@media screen and (min-width: 768px) {
  .parts__03 {
    width: min(27.4%, 153px);
    left: -3%;
    bottom: -15%;
  }
}
.parts__04 {
  width: 68%;
  top: -6%;
  right: -40%;
}
@media screen and (min-width: 768px) {
  .parts__04 {
    width: min(55.8%, 312px);
    top: -1%;
    right: -24%;
  }
}
.parts__05 {
  width: 78.1%;
  bottom: -17%;
  left: -47%;
}
@media screen and (min-width: 768px) {
  .parts__05 {
    width: min(64.2%, 359px);
    left: -30%;
  }
}
.parts__06 {
  width: 49.5%;
  top: 18%;
  right: -11%;
}
.parts__07 {
  width: 41.3%;
  bottom: -7%;
  left: 1%;
}
@media screen and (min-width: 768px) {
  .parts__07 {
    width: min(41.8%, 234px);
    bottom: -17.5%;
    left: -15%;
  }
}
.parts__08 {
  width: 75.2%;
  top: 13.8%;
  right: -24%;
}
@media screen and (min-width: 768px) {
  .parts__08 {
    width: min(40.5%, 324px);
    top: 5.8%;
    right: -7%;
  }
}
.parts__09 {
  width: 57.7%;
  top: 38%;
  left: -26%;
}
@media screen and (min-width: 768px) {
  .parts__09 {
    width: min(31%, 248px);
    top: 30%;
    left: -6%;
  }
}
.parts__10 {
  width: 53.9%;
  top: 55%;
  right: -26%;
}
@media screen and (min-width: 768px) {
  .parts__10 {
    width: min(28.9%, 231px);
    top: 56%;
    right: 8.8%;
  }
}
.parts__11 {
  width: 52.6%;
  bottom: -13.6%;
  left: -13%;
}
@media screen and (min-width: 768px) {
  .parts__11 {
    width: min(21%, 168px);
    right: 22%;
    bottom: -14.2%;
    left: auto;
  }
}
.parts__12 {
  width: 58.5%;
  top: 15%;
  left: -27%;
}
@media screen and (min-width: 768px) {
  .parts__12 {
    width: min(38.4%, 215px);
    top: 17%;
    left: -8%;
  }
}
.parts__13 {
  width: 33.4%;
  bottom: -8%;
  right: 8%;
}
@media screen and (min-width: 768px) {
  .parts__13 {
    width: min(25.2%, 141px);
    bottom: -10.5%;
    right: 5%;
  }
}
.parts__14 {
  width: 59.5%;
  top: 22.8%;
  left: -22%;
}
@media screen and (min-width: 768px) {
  .parts__14 {
    width: min(31.9%, 255px);
    top: 12.7%;
    left: auto;
    right: 24%;
  }
}
.parts__15 {
  width: 65.9%;
  top: 46.3%;
  right: -31%;
}
@media screen and (min-width: 768px) {
  .parts__15 {
    width: min(35.5%, 284px);
    top: 34%;
    right: auto;
    left: -4%;
  }
}
.parts__16 {
  width: 49.5%;
  bottom: -4%;
  left: -19%;
}
@media screen and (min-width: 768px) {
  .parts__16 {
    width: min(26.6%, 212px);
    bottom: 24.5%;
    left: auto;
    right: 13%;
  }
}
.parts__17 {
  width: 58.3%;
  bottom: -12.5%;
  right: -16%;
}
@media screen and (min-width: 768px) {
  .parts__17 {
    width: min(31.3%, 250px);
    bottom: -16%;
    right: 13.5%;
  }
}

/* ==========================================================================
   feature
========================================================================== */
.feature {
  padding: 30px 0 50px;
  background: -webkit-gradient(linear, left bottom, left top, from(rgb(220, 244, 249)), to(rgb(255, 240, 246)));
  background: linear-gradient(0deg, rgb(220, 244, 249), rgb(255, 240, 246));
}
@media screen and (min-width: 768px) {
  .feature {
    padding: 70px 0;
  }
}
.feature h3 {
  margin-bottom: 34px;
  line-height: 1.4;
  text-align: center;
  font-family: YakuHanJP, "Zen Maru Gothic", sans-serif;
  font-size: 2.1rem;
  color: #ff8fa7;
}
@media screen and (min-width: 768px) {
  .feature h3 {
    margin-bottom: 24px;
    font-size: 2rem;
  }
}
.feature p {
  width: 86%;
  max-width: 560px;
  margin: 0 auto 30px;
  font-size: 1.5rem;
}
@media screen and (min-width: 768px) {
  .feature p {
    text-align: center;
    font-size: 1.6rem;
  }
}
.feature .feature-link {
  width: min(90%, 326px);
  margin: 0 auto;
}
.feature .feature-link a {
  display: block;
  width: 100%;
  height: 100%;
  background: #ff8fa7;
  padding: 20px 0;
  position: relative;
  border-radius: 40px;
  border: 2px solid #ff8fa7;
  line-height: 1.4;
  text-box: trim-both cap alphabetic;
  text-align: center;
  font-family: YakuHanJP, "Zen Maru Gothic", sans-serif;
  font-size: 1.5rem;
  color: #ffffff;
}
.feature .feature-link a .win-icon {
  width: 17px;
  position: absolute;
  top: 50%;
  right: 30px;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
@media screen and (min-width: 768px) {
  .feature .feature-link a .win-icon {
    right: 24px;
  }
}
.feature .feature-link a .win-icon .window-path {
  fill: #ffffff;
}
@media screen and (min-width: 768px) {
  .feature .feature-link a:hover {
    background: #ffffff;
    color: #ff8fa7;
  }
}
@media screen and (min-width: 768px) {
  .feature .feature-link a:hover .win-icon .window-path {
    fill: #ff8fa7;
  }
}

/* ==========================================================================
   Footer
========================================================================== */
#footer {
  min-width: 320px;
  position: relative;
}
#footer .recommend {
  min-width: 320px;
}
#footer .recommend .recommend-inner {
  margin: 35px auto;
  padding: 0 8vw;
}
@media screen and (min-width: 768px) {
  #footer .recommend .recommend-inner {
    width: min(96%, 1100px);
    margin: 80px auto;
    padding: 0;
  }
}
#footer .recommend .recommend-inner .recommend-title {
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  font-size: 1.4rem;
  text-align: center;
  padding: 0 0 15px;
}
@media screen and (min-width: 768px) {
  #footer .recommend .recommend-inner .recommend-title {
    font-size: 2rem;
    padding: 0 0 35px;
  }
}
#footer .recommend .recommend-inner ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 4.5vw 0;
  width: min(100%, 620px);
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  #footer .recommend .recommend-inner ul {
    width: min(92%, 860px);
    /*   justify-content: center;*/
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 30px 2%;
  }
}
#footer .recommend .recommend-inner ul li {
  width: 47.5%;
}
@media screen and (min-width: 768px) {
  #footer .recommend .recommend-inner ul li {
    width: 23.5%;
  }
}
@media screen and (min-width: 768px) {
  #footer .recommend .recommend-inner ul li:last-child {
    margin-right: 0;
  }
}
@media screen and (min-width: 768px) {
  #footer .recommend .recommend-inner ul li:nth-of-type(4n) {
    margin-right: 0;
  }
}
@media screen and (min-width: 768px) {
  #footer .recommend .recommend-inner ul li a:hover {
    opacity: 0.7;
  }
}
#footer .recommend .recommend-inner ul li a img {
  border-radius: 8px;
}
#footer .footer-inner {
  padding: 30px 4vw 10px;
  background-color: #f4f4f4;
  text-align: center;
}
@media screen and (min-width: 768px) {
  #footer .footer-inner {
    padding: 50px 0 10px;
    margin: 0 auto;
  }
}
#footer .footer-inner .footer-btn {
  position: relative;
  width: 250px;
  height: 75px;
  background-color: #fff;
  border-radius: 75px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  #footer .footer-inner .footer-btn {
    width: 390px;
    height: 120px;
    border-radius: 120px;
    -webkit-transition: 0.2s ease-in-out;
    transition: 0.2s ease-in-out;
  }
}
#footer .footer-inner .footer-btn::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 15px;
  width: 8px;
  height: 8px;
  margin-top: -4px;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
@media screen and (min-width: 768px) {
  #footer .footer-inner .footer-btn::after {
    right: 25px;
    width: 14px;
    height: 14px;
    margin-top: -7px;
    border-top: 2px solid #000;
    border-right: 2px solid #000;
  }
}
@media screen and (min-width: 768px) {
  #footer .footer-inner .footer-btn:hover {
    opacity: 0.7;
  }
}
#footer .footer-inner .footer-btn a {
  display: block;
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 768px) {
  #footer .footer-inner .footer-btn a {
    display: block;
    width: 100%;
    height: 100%;
  }
}
#footer .footer-inner .footer-btn a img {
  width: 117px;
  margin: 12px auto 0;
}
@media screen and (min-width: 768px) {
  #footer .footer-inner .footer-btn a img {
    width: 195px;
    margin: 15px auto 0;
  }
}
#footer .footer-inner .footer-btn a p {
  font-size: 1rem;
  font-weight: 700;
  padding: 2px 0 0;
  font-family: YuGothic, "Yu Gothic", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;
}
@media screen and (min-width: 768px) {
  #footer .footer-inner .footer-btn a p {
    font-size: 1.5rem;
    padding: 5px 0 0;
  }
}
#footer .footer-inner .copyright {
  font-size: 0.9rem;
  padding: 20px 0 0;
  font-family: YuGothic, "Yu Gothic", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;
  color: #000000;
}
@media screen and (min-width: 768px) {
  #footer .footer-inner .copyright {
    font-size: 1.1rem;
    padding: 50px 0 0;
  }
}

/* ==========================================================================
   Backtotop
========================================================================== */
#backtotop {
  cursor: pointer;
  width: 45px;
  height: 45px;
  border-radius: 50%;
  position: fixed;
  right: 2%;
  bottom: 15px;
  -webkit-transition: 0.1s;
  transition: 0.1s;
  z-index: 998;
}
@media screen and (min-width: 768px) {
  #backtotop {
    width: 60px;
    height: 60px;
    right: 50px;
    bottom: 50px;
  }
}
#backtotop::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 12px;
  height: 12px;
  margin: -3px 0 0 -7px;
  border-top: 1px solid #fff;
  border-left: 1px solid #fff;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
@media screen and (min-width: 768px) {
  #backtotop::after {
    width: 15px;
    height: 15px;
    margin: -5px 0 0 -9px;
    border-top: 2px solid #fff;
    border-left: 2px solid #fff;
  }
}
#backtotop.ended {
  bottom: 130px;
}
@media screen and (min-width: 768px) {
  #backtotop.ended {
    bottom: 220px;
  }
}
@media screen and (min-width: 768px) {
  #backtotop:hover {
    opacity: 0.8;
  }
}

#backtotop {
  background-color: #ff8fa7;
}

/*-- ファイル読み込み --*/
/*-------------------------------------
動き関連
-------------------------------------*/
.fdin {
  opacity: 0;
  -webkit-transition: 0.4s ease-in;
  transition: 0.4s ease-in;
}
.fdin.scroll {
  opacity: 1;
}
.fdin__cut {
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.fdin__cut.scroll {
  opacity: 1;
}
.fdin__top {
  opacity: 0;
  -webkit-transition: 0.4s linear;
  transition: 0.4s linear;
  -webkit-transform: translateY(-50px);
      -ms-transform: translateY(-50px);
          transform: translateY(-50px);
}
.fdin__top.scroll {
  opacity: 1;
  -webkit-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
}
.fdin__bottom {
  opacity: 0;
  -webkit-transition: 0.4s linear;
  transition: 0.4s linear;
  -webkit-transform: translateY(40px);
      -ms-transform: translateY(40px);
          transform: translateY(40px);
}
.fdin__bottom.scroll {
  opacity: 1;
  -webkit-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
}
.fdin__left {
  opacity: 0;
  -webkit-transition: 0.4s linear;
  transition: 0.4s linear;
  -webkit-transform: translateX(-50px);
      -ms-transform: translateX(-50px);
          transform: translateX(-50px);
}
.fdin__left.scroll {
  opacity: 1;
  -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
          transform: translateX(0);
}
.fdin__right {
  opacity: 0;
  -webkit-transition: 0.4s linear;
  transition: 0.4s linear;
  -webkit-transform: translateX(50px);
      -ms-transform: translateX(50px);
          transform: translateX(50px);
}
.fdin__right.scroll {
  opacity: 1;
  -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
          transform: translateX(0);
}
.fdin__scale-in {
  opacity: 0;
  -webkit-transform: scale(1.15);
      -ms-transform: scale(1.15);
          transform: scale(1.15);
}
.fdin__scale-in.scroll {
  opacity: 1;
  -webkit-transform: scale(1);
      -ms-transform: scale(1);
          transform: scale(1);
}
.fdin__scale-out {
  opacity: 0;
  -webkit-transform: scale(0.5);
      -ms-transform: scale(0.5);
          transform: scale(0.5);
}
.fdin__scale-out.scroll {
  -webkit-animation: zoom-bound 0.4s forwards;
          animation: zoom-bound 0.4s forwards;
}

@-webkit-keyframes fdin {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes fdin {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes fdin-btm {
  0% {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes fdin-btm {
  0% {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@-webkit-keyframes fall01 {
  0% {
    opacity: 0;
  }
  5% {
    -webkit-transform: translate(0, 40px) rotate(45deg);
            transform: translate(0, 40px) rotate(45deg);
    opacity: 1;
  }
  10% {
    -webkit-transform: translate(10px, 80px) rotate(90deg);
            transform: translate(10px, 80px) rotate(90deg);
    opacity: 1;
  }
  20% {
    -webkit-transform: translate(-10px, 160px) rotate(180deg);
            transform: translate(-10px, 160px) rotate(180deg);
  }
  30% {
    -webkit-transform: translate(20px, 240px) rotate(270deg);
            transform: translate(20px, 240px) rotate(270deg);
  }
  40% {
    -webkit-transform: translate(-40px, 320px) rotate(360deg);
            transform: translate(-40px, 320px) rotate(360deg);
  }
  50% {
    -webkit-transform: translate(-40px, 400px) rotate(360deg);
            transform: translate(-40px, 400px) rotate(360deg);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fall01 {
  0% {
    opacity: 0;
  }
  5% {
    -webkit-transform: translate(0, 40px) rotate(45deg);
            transform: translate(0, 40px) rotate(45deg);
    opacity: 1;
  }
  10% {
    -webkit-transform: translate(10px, 80px) rotate(90deg);
            transform: translate(10px, 80px) rotate(90deg);
    opacity: 1;
  }
  20% {
    -webkit-transform: translate(-10px, 160px) rotate(180deg);
            transform: translate(-10px, 160px) rotate(180deg);
  }
  30% {
    -webkit-transform: translate(20px, 240px) rotate(270deg);
            transform: translate(20px, 240px) rotate(270deg);
  }
  40% {
    -webkit-transform: translate(-40px, 320px) rotate(360deg);
            transform: translate(-40px, 320px) rotate(360deg);
  }
  50% {
    -webkit-transform: translate(-40px, 400px) rotate(360deg);
            transform: translate(-40px, 400px) rotate(360deg);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@-webkit-keyframes fall02 {
  0% {
    opacity: 0;
  }
  5% {
    -webkit-transform: translate(0, 40px) rotate(-45deg);
            transform: translate(0, 40px) rotate(-45deg);
    opacity: 1;
  }
  10% {
    -webkit-transform: translate(-8px, 80px) rotate(-90deg);
            transform: translate(-8px, 80px) rotate(-90deg);
    opacity: 1;
  }
  20% {
    -webkit-transform: translate(8px, 160px) rotate(-180deg);
            transform: translate(8px, 160px) rotate(-180deg);
  }
  30% {
    -webkit-transform: translate(-20px, 240px) rotate(-270deg);
            transform: translate(-20px, 240px) rotate(-270deg);
  }
  40% {
    -webkit-transform: translate(40px, 320px) rotate(-360deg);
            transform: translate(40px, 320px) rotate(-360deg);
  }
  50% {
    -webkit-transform: translate(-40px, 400px) rotate(-360deg);
            transform: translate(-40px, 400px) rotate(-360deg);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fall02 {
  0% {
    opacity: 0;
  }
  5% {
    -webkit-transform: translate(0, 40px) rotate(-45deg);
            transform: translate(0, 40px) rotate(-45deg);
    opacity: 1;
  }
  10% {
    -webkit-transform: translate(-8px, 80px) rotate(-90deg);
            transform: translate(-8px, 80px) rotate(-90deg);
    opacity: 1;
  }
  20% {
    -webkit-transform: translate(8px, 160px) rotate(-180deg);
            transform: translate(8px, 160px) rotate(-180deg);
  }
  30% {
    -webkit-transform: translate(-20px, 240px) rotate(-270deg);
            transform: translate(-20px, 240px) rotate(-270deg);
  }
  40% {
    -webkit-transform: translate(40px, 320px) rotate(-360deg);
            transform: translate(40px, 320px) rotate(-360deg);
  }
  50% {
    -webkit-transform: translate(-40px, 400px) rotate(-360deg);
            transform: translate(-40px, 400px) rotate(-360deg);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@-webkit-keyframes fall03 {
  0% {
    -webkit-transform: translate(20px, 0) rotate(0);
            transform: translate(20px, 0) rotate(0);
    opacity: 0;
  }
  15% {
    opacity: 1;
  }
  75% {
    -webkit-transform: translate(-20px, 400px) rotate(360deg);
            transform: translate(-20px, 400px) rotate(360deg);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fall03 {
  0% {
    -webkit-transform: translate(20px, 0) rotate(0);
            transform: translate(20px, 0) rotate(0);
    opacity: 0;
  }
  15% {
    opacity: 1;
  }
  75% {
    -webkit-transform: translate(-20px, 400px) rotate(360deg);
            transform: translate(-20px, 400px) rotate(360deg);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@-webkit-keyframes scaling {
  80% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  90% {
    -webkit-transform: scale(1.08);
            transform: scale(1.08);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@keyframes scaling {
  80% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  90% {
    -webkit-transform: scale(1.08);
            transform: scale(1.08);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@-webkit-keyframes rotation {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@keyframes rotation {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
/*-- ファイル読み込み --*/