@charset "utf-8";

html {
  font-size: 62.5%;
}

body {
  font-size: 1.6rem;
  color: #380d00;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
  letter-spacing: 0.02rem;
  overflow-x: hidden;
}

a {
  display: block;
  width: 100%;
  color: #380d00;
}

a:hover {
  color: #380d00;
  text-decoration: none;
}


a img {
  transition: all 0.3s ease;
}

a:hover img {
  text-decoration: none;
  opacity: 0.8;
}



img,
iframe {
  display: block;
  width: 100%;
  max-width: 100%;
}

iframe {
  height: 100%;
}

ul,
ol {
  list-style: none;
  padding: 0;
}

.br_wide {
  display: none;
}



@media print,
screen and (min-width: 812px) {
  .br_wide {
    display: block;
  }

  .kplogo {
    width: 50%;
    margin: 15px auto;
  }
}

@media print,
screen and (min-width: 768px) {
  .br_narrow {
    display: none;
  }
}

/*--------------------------
グローバルナビゲーション
---------------------------*/

@media print,
screen and (max-width: 1023px) {
  .g_nav {
    position: relative;
  }

  .g_nav h1 {
    position: absolute;
    width: 22rem;
    top: 3rem;
    left: 3rem;
  }

  .g_nav h1 img {
    float: left;
    width: 6rem;
  }

  .g_nav h1 p {
    float: right;
    font-size: 1.5rem;
    font-weight: normal;
    line-height: 1.7;
    margin-bottom: 0;
    padding-right: 2rem;
    border-bottom: solid 2px #dabdc4;
  }


  .menu-icon {
    width: 60px;
    height: 50px;
    position: absolute;
    top: 0;
    right: 1rem;
    margin: 2.5rem 1.5rem 0;
    transform: scale(0.8);
    padding: 0;
    cursor: pointer;
    z-index: 20
  }

  .menu-bar {
    width: 100%;
    height: 3px;
    background: #932118;
    position: absolute;
    transition: all 0.3s;
  }

  .menu-bar1 {
    margin-top: 10px
  }

  .menu-bar2 {
    margin-top: 20px
  }

  .menu-bar3 {
    margin-top: 31px
  }

  .menu-icon.hover .menu-bar1 {
    -webkit-transform: rotate(45deg) scaleX(0.7);
    margin-top: 22px;
  }

  .menu-icon.hover .menu-bar2 {
    opacity: 0
  }

  .menu-icon.hover .menu-bar3 {
    -webkit-transform: rotate(-45deg) scaleX(0.7);
    margin-top: 22px;
  }

  nav {
    clear: both;
    width: 100%;
    height: 100%;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    flex-direction: row-reverse;
    padding-top: 10rem
  }

  .menu-con {
    width: 20%;
    -webkit-flex-grow: 1;
    flex-basis: 0;
    flex-grow: 1;
    display: -webkit-flex;
    display: flex;
    justify-content: space-around;
    position: relative;
    top: -33rem;
    transition: all 0.5s;
    background: rgba(255, 255, 255, .9);
    z-index: 3;
  }

  .menu-con p:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;

  }

  .menu-con p {
    padding-top: 5rem;
    color: #380d00;
    font-size: 1.5rem;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    z-index: 2;
    cursor: pointer;
  }

  .menu-con p span {
    padding: 0 1rem 2rem 0;
    font-size: 2rem;
    border-right: solid 2px #dabdc4;
  }

  .menu-con p.n_shop {
    background: url(../img/tenpo_mark.png) 95% 2.5rem/65% no-repeat;
  }

  .menu-con p.n_princess {
    background: url(../img/kimono_mark.png) 90% 2.5rem/50% no-repeat;

  }

  .menu-con p.n_catalog {
    background: url(../img/katarogu_mark.png) 90% 2.5rem/50% no-repeat;

  }

  .kplogo {
    width: 50%;
    margin: 20px auto;
  }

  .pgtp {
    position: fixed;
    right: 15px;
    bottom: 15px;
    max-width: 20px;
  }

  .menu-icon {
    display: none;
  }

  .spnav {
    margin: 15px auto 0;
    text-align: center;
    font-size: 1.3rem;
    color: #932118
  }

  .spnav a {
    display: inline;
    color: #932118
  }
}

@media print,
screen and (max-width: 480px) {
  .spnav {
    margin: 15px auto 0;
    text-align: center;
    font-size: 1.0rem;
    color: #932118
  }

  .spnav a {
    display: inline;
    color: #932118
  }

  .pgtp {
    position: fixed;
    right: 15px;
    bottom: 15px;
    max-width: 20px;
  }

  .g_nav h1 {
    width: 18.5rem;
    top: 3rem;
    left: 2rem;
  }

  .g_nav h1 img {
    float: left;
    width: 5rem;
  }

  .g_nav h1 p {
    float: right;
    font-size: 1.3rem;
    font-weight: normal;
    line-height: 1.7;
    margin-bottom: 0;
    padding-right: 2rem;
    border-bottom: solid 2px #dabdc4;
  }

  nav {
    padding-top: 9rem
  }

  .menu-icon {
    margin: 2.5rem .5rem 0 0;
  }

  .kplogo {
    width: 80%;
    margin: 15px auto;
  }
}


@media print,
screen and (min-width: 1024px) {
  .spnav {
    display: none;
  }

  .g_nav {
    position: fixed;
    width: 18%;
    height: 100%;
    top: 0;
    left: 0;
    padding: 3rem 1rem 1rem 1rem;
    border-right: solid 1px #ddd;
  }

  .g_nav h1 {
    width: 55%;
    margin: 0 auto;
  }

  .g_nav h1 p {
    margin-top: .5rem;
    padding-bottom: .3rem;
    font-size: 1.1rem;
    text-align: center;
    line-height: 1.7;
    border-bottom: solid 2px #dabdc4;
  }

  .g_nav nav {
    margin: 3rem 0 0 1rem;
  }

  .g_nav nav div.menu-con p {
    font-size: 1.1rem;
    padding-left: 2.8rem;
  }

  .g_nav nav div.menu-con:nth-child(2),
  .g_nav nav div.menu-con:nth-child(3) {
    margin-left: 2.5rem;
  }

  .g_nav nav div.menu-con:nth-child(4) {
    margin-top: 2.5rem;
  }

  .g_nav nav div.menu-con p span {
    font-size: 1.5rem;
  }

  .g_nav nav div.menu-con p.n_shop {
    background: url(../img/tenpo_mark.png) 0 .5rem no-repeat;
    background-size: 2.5rem;
  }

  .g_nav nav div.menu-con p.n_princess {
    background: url(../img/kimono_mark.png) .3rem .5rem no-repeat;
    background-size: 2rem;
  }

  .g_nav nav div.menu-con p.n_catalog {
    background: url(../img/katarogu_mark.png) .3rem .6rem no-repeat;
    background-size: 2rem;
  }

}

@media print,
screen and (min-width: 1280px) {
  .spnav {
    display: none;
  }

  .g_nav {
    width: 22rem;
  }

  .g_nav nav {
    margin: 3rem 0 0 2rem;
  }

  .g_nav nav div.menu-con p {
    padding-left: 3rem;
  }

  nav div.menu-con p span {
    position: relative;
    padding-bottom: .2rem;
    line-height: 1.8;
  }

  nav div.menu-con span:hover:before {
    width: 100%;
    border-bottom: 1px solid #380d00;
  }

  nav div.menu-con span:after {
    content: '';
    width: 0;
    bottom: -.2rem;
    transition: all 0.3s ease;
    border-bottom: 1px solid #380d00;
    position: absolute;
    display: block;
  }

  nav div.menu-con span:hover:after {
    width: 100%;
    border-bottom: 1px solid #380d00;
  }

  .g_nav nav div.menu-con p.n_shop {
    background: url(../img/tenpo_mark.png) 0 .7rem no-repeat;
    background-size: 2.5rem;
  }

  .g_nav nav div.menu-con p.n_princess {
    background: url(../img/kimono_mark.png) .3rem .7rem no-repeat;
    background-size: 2rem;
  }

  .g_nav nav div.menu-con p.n_catalog {
    background: url(../img/katarogu_mark.png) .3rem .8em no-repeat;
    background-size: 2rem;
  }

}

/*--------------------------
header
---------------------------*/

.wrap {
  margin-top: -24rem;
}

header {
  position: relative;
}

header p {
  position: absolute;
  top: 4rem;
  right: 0;
  padding: 1rem 0;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-weight: bold;
  font-family: YuMincho, 'Yu Mincho', serif;
  background: #fff;
  z-index: 2;
}

header p.credit {
  top: auto;
  top: 1rem;
  left: 1rem;
  margin-bottom: .5rem;
  padding: 0;
  background: rgba(255, 255, 255, .6);
  padding: .5rem 1rem;
  writing-mode: horizontal-tb;
  text-align: right;
  width: 25rem;
}

header p.kawakita {
  width: 30rem;
}

header div.swiper-slide {
  height: 48rem;
}

.swiper-container-horizontal>.swiper-pagination-bullets,
.swiper-pagination-custom,
.swiper-pagination-fraction {
  bottom: 20px;
}

.swiper-container div.swiper-wrapper div.slide01 {
  background: url(../img/top_slide/top_slide1_2021.jpg) center 40%/cover no-repeat;
}

.swiper-container div.swiper-wrapper div.slide02 {
  background: url(../img/top_slide/top_slide2_2020.jpg) center 10%/cover no-repeat;
}

.swiper-container div.swiper-wrapper div.slide03 {
  background: url(../img/top_slide/top_slide3_2020.jpg) center no-repeat;
  background-size: 230%;
}

.swiper-container div.swiper-wrapper div.slide04 {
  background: url(../img/top_slide/top_slide4_2020.jpg) center 30%/cover no-repeat;
}

@media print,
screen and (min-width: 481px) {


  .swiper-container div.swiper-wrapper div.slide03 {
    background: url(../img/top_slide/top_slide3_2020.jpg) center no-repeat;
    background-size: 160%;
  }
}

@media print,
screen and (min-width: 768px) {

  header p {
    top: 0;
    right: 2rem;
    font-size: 2.5rem;
  }

  header p.credit {
    right: 2rem;
    margin-bottom: 1rem;
  }

  .swiper-container div.swiper-wrapper div.slide01 {
    background: url(../img/top_slide/top_slide1_2021.jpg) center 40%/cover no-repeat;
  }

  .swiper-container div.swiper-wrapper div.slide02 {
    background: url(../img/top_slide/top_slide2_2020.jpg) center 20%/cover no-repeat;
  }

  .swiper-container div.swiper-wrapper div.slide03 {
    background: url(../img/top_slide/top_slide3_2020.jpg) center no-repeat;
    background-size: 130%;
  }

  .swiper-container div.swiper-wrapper div.slide04 {
    background: url(../img/top_slide/top_slide4_2020.jpg) center 40%/cover no-repeat;
  }

  .kplogo {
    width: 80%;
    margin: 15px auto;
  }
}

@media print,
screen and (min-width: 1024px) {

  .wrap {
    width: 82%;
    margin: 0 0 0 18%;
  }

  .swiper-container div.swiper-wrapper div.slide01 {
    background: url(../img/top_slide/top_slide1_2021.jpg) center 35%/cover no-repeat;
  }

  .swiper-container div.swiper-wrapper div.slide02 {
    background: url(../img/top_slide/top_slide2_2020.jpg) center 15%/cover no-repeat;
  }

  .swiper-container div.swiper-wrapper div.slide03 {
    background: url(../img/top_slide/top_slide3_2020.jpg) center 50%/cover no-repeat;
  }

  .swiper-container div.swiper-wrapper div.slide04 {
    background: url(../img/top_slide/top_slide4_2020.jpg) center 35%/cover no-repeat;
  }

  .pgtp {
    position: fixed;
    left: 30px;
    bottom: 30px;
    max-width: 20px;
  }

}

@media print,
screen and (min-width: 1280px) {

  .wrap {
    width: calc(100% - 22rem);
    margin: 0 0 0 22rem;
  }

  header div.swiper-slide {
    height: 90rem;
  }

  header p {
    padding: 10rem 0 2rem;
    font-size: 4rem;
  }

  header p.credit {
    width: 35rem;
  }

  .swiper-container div.swiper-wrapper div.slide01 {
    background: url(../img/top_slide/top_slide1_2021.jpg) center 40%/cover no-repeat;
  }

  .swiper-container div.swiper-wrapper div.slide02 {
    background: url(../img/top_slide/top_slide2_2020.jpg) center 20%/cover no-repeat;
  }

  .swiper-container div.swiper-wrapper div.slide03 {
    background: url(../img/top_slide/top_slide3_2020.jpg) center no-repeat;
    background-size: 150%;
  }

  .swiper-container div.swiper-wrapper div.slide04 {
    background: url(../img/top_slide/top_slide4_2020.jpg) center 40%/cover no-repeat;
  }

  .pgtp {
    position: fixed;
    left: 30px;
    bottom: 30px;
    max-width: 20px;
  }



}

/*--------------------------
main
---------------------------*/
.container {
  margin: 3rem auto 0;
}

@media print,
screen and (min-width: 1280px) {
  .container {
    margin-top: 5rem;
  }


}

/*button*/

.button ul.jump_button {
  width: 93%;
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
}

.button ul.jump_button li {
  position: relative;
  width: 48%;
  overflow: hidden;
}

.button ul.jump_button li p {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  color: #fff;
  font-size: 1.5rem;
  font-family: YuMincho, 'Yu Mincho', serif;
  text-align: center;
  background: transparent;
  z-index: 8;
}

.button ul.jump_button li a {
  transition: all 0.2s ease;
}

.button ul.jump_button li a:hover {
  transform: scale(1.1, 1.1);
}

@media print,
screen and (min-width: 768px) {
  .button ul.jump_button li p {
    font-size: 2rem;
  }

  .kplogo {
    width: 50%;
    margin: 20px auto;
  }
}

@media print,
screen and (min-width: 1024px) {
  .button ul.jump_button li p {
    font-size: 2rem;
  }

  .kplogo {
    width: 60%;
    margin: 20px auto;
  }

}

@media print,
screen and (min-width: 1280px) {

  .button ul.jump_button li p {
    font-size: 3.1rem;
    letter-spacing: .8rem;
  }

  .button ul.jump_button li:hover p {
    width: 80%;
    padding: 2% 0;
    border: solid 1px #fff;
  }

  .kplogo {
    width: 50%;
    margin: 20px auto;
  }
}

main h2 {
  position: relative;
  width: 93%;
  margin: 3rem auto 0;
  padding: 2rem 0 .6rem;
  font-size: 1.5rem;
  font-weight: normal;
  text-align: center;
  line-height: 1.2;
  border: solid 1px #dabdc4;
}

main h2 span {
  display: block;
  font-size: 1.2rem;
}

main h2 span::before {
  position: absolute;
  top: .2rem;
  left: 50%;
  transform: translateX(-50%);
  width: 20px;
  height: 20px;
  content: '';
  background: url(../img/tenpo_mark.png) center/100% no-repeat;
}

@media print,
screen and (min-width: 1280px) {
  main h2 {
    padding: 3.5rem 0 2rem;
    margin: 5rem auto 0;
    font-size: 2.4rem;

  }

  main h2 span {
    font-size: 1.5rem;
  }

  main h2 span::before {
    top: .7rem;
    width: 30px;
    height: 30px;
  }

}


/*shop*/
.shop {
  margin-top: 8rem;
  padding-bottom: 8rem;
  background: #fff;
}

.shop ul {
  width: 93%;
  margin: 0 auto;
}

.shop ul li h3 {
  margin-bottom: 0;
  font-family: YuMincho, 'Yu Mincho', serif;
}

.shop ul li.shop_txt h3 {
  font-size: 3.1rem;
}

.shop ul li.shop_txt {
  margin-top: 5rem;
}

.shop ul li.shop_txt img {
  width: 25rem;
}

.shop ul li.shop_txt p {
  margin-top: 1rem;
}

.shop ul li.shop_txt dl div.dl_container {
  display: flex;
  margin-bottom: 1.5rem;
}

.shop ul li.shop_txt dl {
  margin-top: 3rem;
}

.shop ul li.shop_txt dl dt {
  width: 7rem;
  font-weight: normal;
  border-right: solid 1px #380d00;
}

.shop ul li.shop_txt dl dd {
  margin-bottom: 0;
  padding-left: .5rem;
}

.shop ul li.shop_txt dl dd .freedial,
.shop ul li.shop_txt dl dd .handyphone {
  display: block;
}

.shop ul li.shop_txt dl dd .freedial::before {
  content: '';
  display: inline-block;
  width: 2.8rem;
  height: 1.4rem;
  margin-right: .2rem;
  vertical-align: -.1rem;
  background: url(../img/freetel_buttun.jpg) center/cover no-repeat;
}

.shop ul li.shop_txt dl dd .handyphone::before {
  content: '';
  display: inline-block;
  width: 1.5rem;
  height: 1.5rem;
  margin-right: .2rem;
  background: url(../img/tel_button.jpg) center/cover no-repeat;
}

.shop ul li.shop_img div.shop_img_container {
  width: 80%;
  margin-left: 5%;
}

.shop ul li.shop_img {
  position: relative;
  height: 90vw;
  background: url(../img/gara.png) right bottom/85% no-repeat;
}

.shop ul li.shop_img h3 {
  position: absolute;
  top: -4rem;
  right: 0;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  padding: 1.5rem .2rem;
  color: #fff;
  font-family: YuMincho, 'Yu Mincho', serif;
  background: #d0b3ba;
}

@media print,
screen and (min-width: 768px) {
  .shop ul {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-around;
    margin: 0 auto;
  }

  .shop ul li {
    width: 49%;
  }

  .shop ul li.shop_txt {
    margin-top: 0;
    margin-left: 8rem;
  }

  .shop ul li.shop_img {
    height: 30rem;
  }

  .shop ul li.shop_img div.shop_img_container {
    width: 70%;
  }

  .shop ul li.shop_img h3 {
    position: absolute;
    top: -4rem;
    right: 7rem;
  }

  .shop ul li.shop_txt h3 {
    line-height: 1;
    margin-bottom: 1rem;
  }

}

@media print,
screen and (min-width: 1280px) {
  .shop {
    margin-top: 15rem;
  }

  .shop ul li.shop_img h3 {
    top: -6rem;
    right: 10vw;
    padding: 2rem 0;
    font-size: 3rem;
  }

  .shop ul li.shop_img {
    width: 49%;
    height: 30vw;
    background: url(../img/gara.png) right bottom/25vw no-repeat;
  }

  .shop ul li.shop_txt {
    width: 36rem;
    margin-left: 12vw;
  }

  .shop ul li.shop_img div.shop_img_container {
    width: 25vw;
  }

  .shop ul li.shop_txt dl {
    margin-top: 5rem;
  }

  .shop ul li.shop_txt dl dt,
  .shop ul li.shop_txt dl dd {
    line-height: 1;
  }


  .shop ul li.shop_txt dl dt {
    width: 9rem;
  }

  .shop ul li.shop_txt dl dd {
    padding-left: 2.5rem;
  }

  .shop ul li.shop_txt dl dd .freedial {
    margin-bottom: 1.5rem;
  }

  .kplogo {
    width: 60%;
    margin: 50px auto 0;
  }
}

/*map*/
.shop .map_container {
  position: relative;
  margin-top: 6rem;
  padding: 3rem 0 2rem;
  text-align: center;
  background: #d0b3ba;
}

.shop .map_container img {
  width: 5%;
  margin: 0 auto;
}

.shop .map_container::before {
  content: '';
  position: absolute;
  top: -2rem;
  left: 50%;
  transform: translateX(-50%);
  width: .2rem;
  height: 2rem;
  background: #d0b3ba;
}

.shop .map_container::after {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: .2rem;
  height: 2rem;
  background: #fff;
}


.shop .map_container h4 {
  margin-bottom: 2.5rem;
  font-size: 1.5rem;
  font-weight: normal;
  letter-spacing: .5rem;
}

.shop .map_container h4 span {
  display: block;
  font-size: 1.2rem;
  letter-spacing: 0;
}

.shop .map_container .map {
  width: 85%;
  margin: auto;
}

@media print,
screen and (min-width: 768px) {
  .shop .map_container {
    position: relative;
    margin-top: 6rem;
    padding: 3.5rem 0 3rem;
    text-align: center;
    background: #d0b3ba;
  }

  .shop .map_container img {
    width: 2rem;
    margin: 1rem auto 0;
  }

  .shop .map_container::before {
    top: -3rem;
    height: 3rem;
  }

  .shop .map_container::after {
    height: 3rem;
  }

  .shop .map_container .map {
    width: 85%;
    height: 30rem;
    margin: auto;
  }

}

@media print,
screen and (min-width: 1280px) {
  .shop .map_container h4 {
    margin-bottom: 4rem;
  }

  .shop .map_container .map {
    height: 378px;

  }

  .shop .map_container img {
    margin: 3rem auto 0;
  }

  .shop .map_container::before {
    top: -4rem;
    height: 4rem;

  }

  .shop .map_container::after {
    height: 4rem;

  }
}

main .princess .transparent_container {
  padding: 5rem 0;
  background: transparent;
}

.parallax-window {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 40vw;
  background: transparent;
  background-position: center !important;
}

.parallax-slider {
  top: -80px;
  left: 0;
}


/*
@font-face {
  font-family: 'Cochin';
  src: url('./font/cochin.ttc') format("truetype");
}
*/
.parallax-window p {
  margin-bottom: 0;
  color: #fff;
  font-size: 5.9rem;
  font-family: YuMincho, 'Yu Mincho', serif;

}


@media print,
screen and (min-width: 768px) {
  .parallax-slider {
    top: -20vw;
    left: 0;
  }

}

@media print,
screen and (min-width: 1024px) {
  .parallax-window {
    min-height: 40vh;
  }

  .parallax-slider {
    top: 0;
    left: 0;
  }

}

@media print,
screen and (min-width: 1280px) {
  .parallax-window {
    min-height: 50vh;
  }
}


/*--------------------------
footer
---------------------------*/
footer {
  padding-top: 5rem;
  background: #fff;
}

footer div {
  height: 2rem;
  background: url(../img/gara2.jpg) 100%/contain;
}

footer p {
  margin-bottom: 0;
  padding: .5rem 0 2rem;
  color: #fff;
  text-align: center;
  background: #dabdc4;
}