@charset "UTF-8";
/* 文字コードの指定 */
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500;1,600;1,700&family=Noto+Sans+JP&display=swap");
body {
  font-family: 'Times New Roman', 'Cormorant Garamond', "Yu Mincho", "YuMincho", serif;
  font-display: swap;
}

html {
  font-size: 62.5%;
}

body {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 2;
  color: #333333;
  background-color: #F1F1F1;
  overflow-x: visible;
}

.b-character-dress {
  background-color: #FFF9F0 !important;
  width: 100%;
  overflow-x: visible;
}

.b-character-dress body {
  background-color: #FFF9F0;
}

.b-character-dress .b-character-dress-bg {
  background-repeat: repeat;
  background-color: #fff9f0;
  background-image: repeating-linear-gradient(0deg, transparent, transparent 25px, #a0cbeb 25px, #a0cbeb 26px);
  margin: 0 1.6rem 0;
}

img {
  max-width: 100%;
  vertical-align: bottom;
}

ul {
  list-style: none;
}

a {
  text-decoration: none;
}

.l-header .l-header-container {
  z-index: 1000;
  position: fixed;
  height: 4.8rem;
  width: 100%;
  background-color: rgba(255, 255, 255, 0.8);
  padding: .9rem 3.7rem .9rem 3.7rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  top: 0;
  -webkit-transform: translate(-50%, 0%);
          transform: translate(-50%, 0%);
  left: 50%;
  -webkit-transition: .5s;
  transition: .5s;
}

.l-header .l-header-container .l-header-left .l-header-page_top-btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: start;
}

.l-header .l-header-container .l-header-left .l-header-page_top-btn .l-header-disney {
  height: 3rem;
  margin-right: .8rem;
}

.l-header .l-header-container .l-header-left .l-header-page_top-btn .l-header-wedding {
  height: .8rem;
}

.l-header .l-header-container .l-header-left .l-header-page_top-btn:hover {
  opacity: .8;
}

.l-header .l-header-container .l-header-right {
  height: 1.65rem;
  position: relative;
  width: 3.6rem;
}

.l-header .l-header-container .l-header-right .l-header-hamburger {
  display: inline-block;
  height: 100%;
  width: 100%;
  position: absolute;
  left: 0;
  top: 0;
  cursor: pointer;
}

.l-header .l-header-container .l-header-right .l-header-hamburger span {
  position: absolute;
  width: 100%;
  height: .1rem;
  background-color: #333333;
}

.l-header .l-header-container .l-header-right .l-header-hamburger span:first-child {
  top: 0;
  left: 0;
}

.l-header .l-header-container .l-header-right .l-header-hamburger span:last-child {
  bottom: 0;
  left: 0;
}

.l-header .l-header-container .l-header-right .l-header-hamburger:hover {
  opacity: .8;
}

.l-header .l-header-container .l-header-right .l-header-hamburger-close {
  height: 100%;
  width: 100%;
  position: absolute;
  left: 0;
  top: 0;
  cursor: pointer;
}

.l-header .l-header-container .l-header-right .l-header-hamburger-close span {
  position: absolute;
  width: 3.65rem;
  height: 0.1rem;
  background-color: #333333;
}

.l-header .l-header-container .l-header-right .l-header-hamburger-close span:first-child {
  top: 0.825rem;
  -webkit-transform: rotate(30deg);
          transform: rotate(30deg);
}

.l-header .l-header-container .l-header-right .l-header-hamburger-close span:last-child {
  top: 0.825rem;
  -webkit-transform: rotate(-30deg);
          transform: rotate(-30deg);
}

.l-header .l-header-container .l-header-right .l-header-hamburger-close:hover {
  opacity: .8;
}

@media screen and (min-width: 1024px) {
  .l-header .l-header-container {
    height: 5.6rem;
    padding: 1.2rem 11.8rem 1.2rem 11.8rem;
  }
  .l-header .l-header-container .l-header-left .l-header-page_top-btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: start;
  }
  .l-header .l-header-container .l-header-left .l-header-page_top-btn .l-header-disney {
    height: 3.6rem;
    margin-right: 3.2rem;
  }
  .l-header .l-header-container .l-header-left .l-header-page_top-btn .l-header-wedding {
    height: 1.45rem;
  }
  .l-header .l-header-container .l-header-right {
    width: 4.8rem;
  }
  .l-header .l-header-container .l-header-right .l-header-hamburger-close span {
    position: absolute;
    width: 4.75rem;
  }
}

.l-footer {
  margin: 8rem auto 0;
}

.l-footer .l-footer-decoration-wrapper {
  max-width: 31.4rem;
  width: 100%;
  margin: 0 auto;
}

.l-footer .l-footer-company-wrapper {
  margin: 4.8rem auto;
  text-align: center;
}

.l-footer .l-footer-company-wrapper .l-footer-kuraudia-btn {
  display: block;
  width: 9.8rem;
  margin: 0 auto;
}

.l-footer .l-footer-company-wrapper .l-footer-kuraudia-btn:hover {
  opacity: .8;
}

.l-footer .l-footer-company-wrapper .l-footer-shop-btn {
  display: block;
  width: 15rem;
  margin: 1.6rem auto 0;
}

.l-footer .l-footer-company-wrapper .l-footer-shop-btn:hover {
  opacity: .8;
}

.l-footer .l-footer-copy {
  margin-top: 4.8rem;
  padding-bottom: 3.2rem;
  text-align: center;
}

@media screen and (min-width: 1024px) {
  .l-footer .l-footer-company-wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: 32rem;
  }
}

.l-header .l-menu-wrapper {
  position: fixed;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  top: 0;
  left: 0;
  height: calc( var(--vh) * 100);
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
  display: none;
  background-color: #F1F1F1;
  z-index: 100;
  padding: 8.8rem 3.7rem 0;
  width: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.l-header .l-menu-wrapper .l-menu-item-wrapper {
  max-width: 31.8rem;
  margin: 0 auto;
}

.l-header .l-menu-wrapper .l-menu-item-wrapper .l-menu-item {
  font-size: 1.6rem;
  margin-top: 2.4rem;
  display: block;
  line-height: 2rem;
}

.l-header .l-menu-wrapper .l-menu-item-wrapper .l-menu-item:first-child {
  margin-top: 0;
}

.l-header .l-menu-wrapper .l-menu-item-wrapper .l-menu-item i {
  margin-right: .8rem;
}

.l-header .l-menu-wrapper .l-menu-item-wrapper .l-menu-item:after {
  -webkit-transition: .3s ease;
  transition: .3s ease;
  display: block;
  content: "";
  width: 100%;
  border-top: 0.1rem #333333 solid;
}

.l-header .l-menu-wrapper .l-menu-item-wrapper .l-menu-item:hover:after {
  width: 75%;
}

.l-menu-link-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 1.6rem auto 0;
}

.l-menu-link-wrapper .l-menu-shop-btn {
  margin: 0;
  width: 15rem;
}

.l-menu-link-wrapper .l-menu-shop-btn:first-child {
  margin: 0 .8rem 0 0;
}

.l-menu-link-wrapper .l-menu-shop-btn:hover {
  opacity: .8;
}

.l-menu-link-wrapper .l-menu-shop-btn img {
  width: 100%;
}

@media screen and (min-width: 1024px) {
  .l-header .l-menu-wrapper {
    padding: 10.8rem 35.3rem 0;
    width: 100%;
  }
  .l-header .l-menu-wrapper .l-menu-item-wrapper .l-menu-item {
    font-size: 2rem;
    margin-top: 2.4rem;
    line-height: 2.4rem;
  }
  .l-menu-link-wrapper {
    margin: 2.4rem auto 0;
  }
}

@media screen and (min-width: 1366px) {
  .l-header .l-menu-wrapper {
    padding: 12.8rem 35.3rem 0;
    width: 100%;
  }
  .l-header .l-menu-wrapper .l-menu-item-wrapper .l-menu-item {
    font-size: 2rem;
    margin-top: 3.2rem;
    line-height: 2.4rem;
  }
}

.l-section-mt64 {
  margin-top: 6.4rem;
}

.l-section-mt80 {
  margin-top: 8rem;
}

.l-section {
  padding-right: 3.7rem;
  padding-left: 3.7rem;
}

.l-section .l-section-ttl {
  text-align: center;
  font-size: 2rem;
  margin: 0;
  line-height: 2rem;
}

@media screen and (min-width: 1024px) {
  .l-section-mt64 {
    margin-top: 8rem;
  }
  .l-section {
    padding-right: 0;
    padding-left: 0;
    margin-right: auto;
    margin-left: auto;
    width: 65.45rem;
  }
  .l-section .l-section-ttl {
    font-size: 2.5rem;
    line-height: 3rem;
  }
}

.l-dress-ttl-wrapper {
  position: relative;
  width: 100%;
  height: 32rem;
}

.l-dress-ttl-wrapper .l-dress-ttl-img {
  position: absolute;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
  z-index: 2;
  width: 13.4rem;
}

.l-dress-ttl-wrapper .l-dress-ttl-bg {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-image: url(../img/8th_mv_bg.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center bottom;
  opacity: .32;
}

.l-dress-ttl-wrapper .l-dress-ttl-bg::before {
  content: '';
  position: absolute;
  /* 輪郭がぼやけてしまうのでブラー範囲を広げる */
  top: -10px;
  bottom: -5px;
  left: -10px;
  right: -10px;
  background: inherit;
  -webkit-filter: blur(10px);
          filter: blur(10px);
}

.l-dress-content-wrapper {
  margin-top: 8rem;
  padding-right: 2.9rem;
  padding-left: 2.9rem;
}

@media screen and (min-width: 1024px) {
  .l-dress-ttl-wrapper {
    height: 40rem;
  }
  .l-dress-ttl-wrapper .l-dress-ttl-img {
    width: 20rem;
  }
  .l-dress-ttl-wrapper .l-dress-ttl-bg {
    background-position: center;
  }
  .l-dress-content-wrapper {
    width: 80rem;
    padding-right: 0;
    padding-left: 0;
    margin-right: auto;
    margin-left: auto;
  }
}

.o-slider {
  position: relative;
  z-index: 0;
  /*↑z-indexの値をh1のz-indexの値よりも小さくして背景に回す*/
  height: 100%;
  /*スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
}

/* 背景画像設定 */
.o-slider-item {
  width: 100%;
  /*各スライダー全体の横幅を画面の高さいっぱい（100%）にする*/
  height: 100%;
  /*各スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
  background-repeat: no-repeat;
  /*背景画像をリピートしない*/
  background-position: center;
  /*背景画像の位置を中央に*/
  background-size: cover;
  /*背景画像が.slider-item全体を覆い表示*/
}

.slick-list {
  height: 100%;
}

.slick-list .slick-track {
  height: 100%;
}

.o-view_more-btn-wrapper {
  text-align: center;
  margin-top: 1.6rem;
}

.o-view_more-btn-wrapper .o-view_more-btn-white {
  border: 0.1rem solid #5A5A5A;
  margin: 0 auto;
  display: block;
  width: 18.4rem;
  font-size: 1.2rem;
  -webkit-transition: .3s ease;
  transition: .3s ease;
}

.o-view_more-btn-wrapper .o-view_more-btn-white p {
  margin-top: 1.2rem;
  line-height: 1.5rem;
}

.o-view_more-btn-wrapper .o-view_more-btn-white span {
  position: relative;
  display: block;
  width: 8rem;
  border-top: 0.05rem solid #5A5A5A;
  margin: .4rem auto 1.1rem 5.2rem;
  -webkit-transition: .3s ease;
  transition: .3s ease;
}

.o-view_more-btn-wrapper .o-view_more-btn-white span:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  -webkit-transform-origin: right bottom;
          transform-origin: right bottom;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  width: 0.4rem;
  border-top: 0.05rem solid #5A5A5A;
}

.o-view_more-btn-wrapper .o-view_more-btn-white:hover {
  background-color: #5A5A5A;
}

.o-view_more-btn-wrapper .o-view_more-btn-white:hover p {
  color: #F1F1F1;
}

.o-view_more-btn-wrapper .o-view_more-btn-white:hover span {
  width: 9.8rem;
  border-top: 0.05rem solid #F1F1F1;
}

.o-view_more-btn-wrapper .o-view_more-btn-white:hover span:after {
  border-top: 0.05rem solid #F1F1F1;
}

.o-view_more-btn-wrapper .o-view_more-btn-gold {
  border: 0.1rem solid #DF9A4A;
  background-color: #DF9A4A;
  margin: 0.8rem auto;
  display: block;
  width: 18.4rem;
  height: 4.4rem;
  font-size: 1.2rem;
  -webkit-transition: .3s ease;
  transition: .3s ease;
  font-style: normal;
  cursor: pointer;
}

.o-view_more-btn-wrapper .o-view_more-btn-gold p {
  margin-top: 1.2rem;
  line-height: 1.5rem;
  color: #F1F1F1;
}

.o-view_more-btn-wrapper .o-view_more-btn-gold span {
  position: relative;
  display: block;
  width: 8rem;
  border-top: 0.05rem solid #F1F1F1;
  margin: .4rem auto 1.1rem 5.2rem;
  -webkit-transition: .3s ease;
  transition: .3s ease;
}

.o-view_more-btn-wrapper .o-view_more-btn-gold span:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  -webkit-transform-origin: right bottom;
          transform-origin: right bottom;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  width: 0.4rem;
  border-top: 0.05rem solid #F1F1F1;
}

.o-view_more-btn-wrapper .o-view_more-btn-gold:hover {
  background-color: #B56100;
  border: 0.05rem solid #B56100;
}

.o-view_more-btn-wrapper .o-view_more-btn-gold:hover span {
  width: 9.8rem;
}

@media screen and (min-width: 1024px) {
  .p-btn-flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .p-btn-flex .p-btn-flex-resize {
    margin: 0.8rem;
  }
  .p-btn-flex .p-btn-flex-resize-gold {
    margin: 0.8rem;
  }
}

.o-shop-btn-wrapper {
  position: relative;
}

.o-coming-soon {
  position: absolute;
  width: 100%;
  max-width: 31.8rem;
  height: 5.6rem;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
  background-color: #333333;
  opacity: .7;
}

.o-coming-soon p {
  color: #ffffff;
  position: absolute;
  right: 0.8rem;
  bottom: 0.4rem;
}

.o-youtube-btn {
  margin: 0 auto;
  display: block;
  width: 100%;
  max-width: 31.8rem;
  height: 5.6rem;
  font-size: 1.6rem;
  font-style: italic;
  -webkit-transition: .3s ease;
  transition: .3s ease;
  text-align: center;
  background-image: url(../img/youtube.png);
  background-repeat: no-repeat;
  background-position: 30%, 50%;
  background-size: 30%;
  cursor: pointer;
  padding: 1.6rem 0;
  background-color: #D9D9D9;
}

.o-youtube-btn p {
  line-height: 2rem;
}

.o-youtube-btn span {
  position: relative;
  display: block;
  width: 8rem;
  border-top: 0.05rem solid #5A5A5A;
  margin: .4rem auto 0;
  -webkit-transition: .3s ease;
  transition: .3s ease;
}

.o-youtube-btn span:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  -webkit-transform-origin: right bottom;
          transform-origin: right bottom;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  width: 0.4rem;
  border-top: 0.05rem solid #5A5A5A;
}

.o-youtube-btn:hover {
  background-size: 35%;
}

.o-youtube-btn:hover span {
  width: 9.8rem;
}

.o-shoplist-btn {
  margin: 0 auto;
  display: block;
  width: 100%;
  max-width: 31.8rem;
  height: 5.6rem;
  font-size: 1.6rem;
  font-style: italic;
  text-align: center;
  background-image: url(../img/shop.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  -webkit-transition: .3s ease;
  transition: .3s ease;
  cursor: pointer;
  padding: 1.6rem 0;
  background-color: #FBD2D8;
}

.o-shoplist-btn p {
  line-height: 2rem;
}

.o-shoplist-btn p span {
  margin-left: 0.4rem;
  font-size: 1.2rem;
}

.o-shoplist-btn span {
  position: relative;
  display: block;
  width: 8rem;
  border-top: 0.05rem solid #5A5A5A;
  margin: .4rem auto 0;
  -webkit-transition: .3s ease;
  transition: .3s ease;
}

.o-shoplist-btn span:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  -webkit-transform-origin: right bottom;
          transform-origin: right bottom;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  width: 0.4rem;
  border-top: 0.05rem solid #5A5A5A;
}

.o-shoplist-btn:hover {
  background-size: 45%;
}

.o-shoplist-btn:hover span {
  width: 9.8rem;
}

.o-instagram-btn {
  margin: 1.6rem auto 0;
  display: block;
  width: 100%;
  max-width: 31.8rem;
  height: 5.6rem;
  font-size: 1.6rem;
  font-style: italic;
  -webkit-transition: .3s ease;
  transition: .3s ease;
  text-align: center;
  background-image: url(../img/insta_ph.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  cursor: pointer;
  padding: 1.6rem 0;
  background-color: #FBD2D8;
}

.o-instagram-btn p {
  color: #F1F1F1;
  line-height: 2rem;
}

.o-instagram-btn span {
  position: relative;
  display: block;
  width: 8rem;
  border-top: 0.05rem solid #F1F1F1;
  margin: .4rem auto 0;
  -webkit-transition: .3s ease;
  transition: .3s ease;
}

.o-instagram-btn span:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  -webkit-transform-origin: right bottom;
          transform-origin: right bottom;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  width: 0.4rem;
  border-top: 0.05rem solid #F1F1F1;
}

.o-instagram-btn:hover {
  background-size: 110%;
}

.o-instagram-btn:hover span {
  width: 9.8rem;
}

.o-slider-detail {
  max-width: 100% !important;
}

.o-dots-none {
  pointer-events: none;
}

.o-dots-none .slick-dots {
  display: none !important;
}

/* 背景画像設定 */
.o-slider-item-dress {
  position: relative;
  width: 100%;
  /*各スライダー全体の横幅を画面の高さいっぱい（100%）にする*/
  height: 100%;
  /*各スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
  background-repeat: no-repeat;
  /*背景画像をリピートしない*/
  background-position: center;
  /*背景画像の位置を中央に*/
  background-size: contain;
  /*背景画像が.slider-item全体を覆い表示*/
  position: relative;
}

.o-slider-item-dress .o-zoom-btn {
  position: absolute;
  display: block;
  width: 4.8rem;
  height: 4.8rem;
  border-radius: 50%;
  top: 1.6rem;
  left: 1.6rem;
  background-color: rgba(255, 255, 255, 0.8);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
}

.o-slider-item-dress .o-zoom-btn img {
  width: 2.4rem;
  height: 2.4rem;
}

.o-slider-item-dress .o-zoom-character {
  position: absolute;
  display: block;
  width: 4.8rem;
  height: 4.8rem;
  border-radius: 50%;
  border: 2px solid #00509D;
  top: 1.6rem;
  left: 1.6rem;
  background-color: rgba(255, 255, 255, 0.8);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
}

.o-slider-item-dress .o-zoom-character img {
  width: 2.4rem;
  height: 2.4rem;
}

.slick-dots {
  position: absolute;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  bottom: -0.5rem;
  left: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  max-width: 45rem;
  opacity: .7;
}

.slick-dots li {
  width: 100%;
  height: 0.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
}

.slick-dots li button {
  width: 100%;
  height: 100%;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
  border: none;
  background-color: #ffffff;
  border-radius: 0 !important;
  padding: 0;
  margin: 0;
}

.slick-dots .slick-active button {
  background-color: #494C78;
}

.o-slider-character .slick-dots .slick-active button {
  background-color: #000 !important;
}

.slick-list {
  height: 100%;
}

.slick-list .slick-track {
  height: 100%;
}

.o-slider-princess-snow_white-item1 {
  background-image: url(../img/carousel/princess/princess-snow-white1.jpg);
  background-position: bottom right;
}

.o-slider-princess-snow_white-item2 {
  background-image: url(../img/carousel/princess/princess-snow-white2.jpg);
  background-position: bottom right;
}

.o-slider-princess-snow_white-item3 {
  background-image: url(../img/carousel/princess/princess-snow-white3.jpg);
  background-position: bottom right;
}

.o-slider-princess-cinderella-item1 {
  background-image: url(../img/carousel/princess/princess-cinderella1.jpg);
  background-position: bottom right;
}

.o-slider-princess-cinderella-item2 {
  background-image: url(../img/carousel/princess/princess-cinderella2.jpg);
  background-position: bottom right;
}

.o-slider-princess-cinderella-item3 {
  background-image: url(../img/carousel/princess/princess-cinderella3.jpg);
  background-position: bottom right;
}

.o-slider-princess-belle-item1 {
  background-image: url(../img/carousel/princess/princess-belle1.jpg);
  background-position: bottom right;
}

.o-slider-princess-belle-item2 {
  background-image: url(../img/carousel/princess/princess-belle2.jpg);
  background-position: bottom right;
}

.o-slider-princess-belle-item3 {
  background-image: url(../img/carousel/princess/princess-belle3.jpg);
  background-position: bottom right;
}

.o-slider-princess-rapunzel-item1 {
  background-image: url(../img/carousel/princess/princess-rapunzel1.jpg);
  background-position: bottom right;
}

.o-slider-princess-rapunzel-item2 {
  background-image: url(../img/carousel/princess/princess-rapunzel2.jpg);
  background-position: bottom right;
}

.o-slider-princess-rapunzel-item3 {
  background-image: url(../img/carousel/princess/princess-rapunzel3.jpg);
  background-position: bottom right;
}

.o-slider-princess-tiana-item1 {
  background-image: url(../img/carousel/princess/princess-tiana1.jpg);
  background-position: bottom right;
}

.o-slider-princess-tiana-item2 {
  background-image: url(../img/carousel/princess/princess-tiana2.jpg);
  background-position: bottom right;
}

.o-slider-princess-tiana-item3 {
  background-image: url(../img/carousel/princess/princess-tiana3.jpg);
  background-position: bottom right;
}

.o-slider-princess-ariel-item1 {
  background-image: url(../img/carousel/princess/princess-ariel1.jpg);
  background-position: bottom right;
}

.o-slider-princess-ariel-item2 {
  background-image: url(../img/carousel/princess/princess-ariel2.jpg);
  background-position: bottom right;
}

.o-slider-princess-ariel-item3 {
  background-image: url(../img/carousel/princess/princess-ariel3.jpg);
  background-position: bottom right;
}

.o-princess-dress-item {
  margin: 5.6rem auto 0;
  width: 100%;
  max-width: 45rem;
}

.o-princess-dress-item .o-princess-dress-container {
  position: relative;
}

.o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper {
  position: absolute;
  padding-top: 1.6rem;
  padding-left: 3.2rem;
  top: 0;
  left: 0;
}

.o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-ttl-wrapper {
  position: relative;
  z-index: 1;
}

.o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-ttl-wrapper .o-dress-ttl {
  height: 2.4rem;
}

.o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-caption {
  position: relative;
  z-index: 1;
  margin-top: 1.6rem;
  font-size: 1.2rem;
  color: #BEBEBE;
  line-height: 1.5;
}

.o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-view_more-btn-wrapper-pc {
  position: relative;
  display: none;
  z-index: 1;
}

.o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-txt-bg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: calc(100% / 2);
  max-width: 22.5rem;
  height: calc((166 * (100vw - 56px)) / 173);
  max-height: 44rem;
}

.o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-txt-bg-snow-white {
  background-color: #FFE8E8;
}

.o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-txt-bg-cinderella {
  background-color: #d9ffff;
}

.o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-txt-bg-belle {
  background-color: #fff5de;
}

.o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-txt-bg-rapunzel {
  background-color: #f0e0ff;
}

.o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-txt-bg-tiana {
  background-color: #d9ffe3;
}

.o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-txt-bg-ariel {
  background-color: #f0e0ff;
}

.o-princess-dress-item .o-princess-dress-container .o-dress-list-carousel-wrapper {
  position: relative;
  width: calc(100% - 32px);
  height: calc((100vw - 90px) * 1523 / 1075);
  max-height: 59.22rem;
  z-index: 2;
  top: 7.2rem;
  right: 0;
  margin-right: 0;
  margin-left: auto;
}

.o-princess-dress-item .o-princess-dress-container .o-dress-list-carousel-wrapper .o-list-slider-dress {
  margin: 0 0 0 auto;
  position: relative;
  width: 100%;
  height: 100%;
  -webkit-clip-path: inset(0 round calc((100vw - 90px) / 2) calc((100vw - 90px) / 2) 0 0);
          clip-path: inset(0 round calc((100vw - 90px) / 2) calc((100vw - 90px) / 2) 0 0);
}

@media screen and (min-width: 1024px) {
  .o-princess-dress-item {
    width: 80rem;
    max-width: initial;
  }
  .o-princess-dress-item .o-princess-dress-container {
    position: relative;
  }
  .o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper {
    position: absolute;
    padding-top: 0;
    padding-left: 4rem;
    padding-bottom: 4.8rem;
    bottom: 0;
    top: auto;
  }
  .o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-ttl-wrapper {
    z-index: 1;
  }
  .o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-ttl-wrapper .o-dress-ttl {
    height: 3.2rem;
  }
  .o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-caption {
    margin-top: 8em;
    width: 35.2rem;
  }
  .o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-view_more-btn-wrapper-pc {
    display: block;
    margin-top: 7.2rem;
  }
  .o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-view_more-btn-wrapper-pc .o-view_more-btn {
    margin-left: 0;
  }
  .o-princess-dress-item .o-princess-dress-container .o-princess-dress-txt-wrapper .o-dress-txt-bg {
    bottom: 0;
    top: auto;
    width: 52.8rem;
    max-width: initial;
    height: 40rem;
    max-height: initial;
  }
  .o-princess-dress-item .o-princess-dress-container .o-dress-list-carousel-wrapper {
    position: relative;
    width: 39rem;
    height: calc(390px * 1523 / 1075);
    max-height: initial;
    top: 0;
  }
  .o-princess-dress-item .o-view_more-btn-wrapper {
    display: none;
  }
}

.m-invisible {
  display: none !important;
}

.m-noscroll {
  overflow: hidden;
}

.j-header-hide {
  -webkit-transform: translate(-50%, -100%) !important;
          transform: translate(-50%, -100%) !important;
}

.p-princess-all-ttl {
  width: 13.4rem;
}

@media screen and (min-width: 1024px) {
  .p-princess-all-ttl {
    width: 20rem;
  }
}
/*# sourceMappingURL=8th-princessdress.css.map */