@charset "UTF-8";

/*Font Awesomeの読み込み
---------------------------------------------------------------------------*/
@import url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.2/css/all.min.css");


html {
  font-size: 62.5%
}

body {
  overflow: visible;
  overflow-x: hidden;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 400;
  position: relative;
  font-size: 13px;
  font-size: 1.3rem;
  color: #222;
  z-index: 0
}

@media screen and (min-width:768px) {
  body {
    overflow-x: hidden;
    font-size: 16px;
    font-size: 1.6rem
  }
}

h1, h2, h3, h4, h5 {
  font-weight: 500
}

a {
  text-decoration: none;
  color: inherit;
  outline: none;
  font-weight: 500
}

a:hover {
  outline: none
}

:focus, :active {
  outline: none;
  outline-offset: 0
}

p[class$=-txt], p[class*=-txt] {
  line-height: 1.7
}

.google-link, .txt-link, .txt-tellink a {
  color: #3178b0;
  text-decoration: underline;
  transition: color .3s
}

@media screen and (min-width:768px) {
  .google-link:hover, .txt-link:hover, .txt-tellink a:hover {
    text-decoration: none;
    color: #4892cc
  }
}

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

.SvgIcon {
  position: absolute;
  width: 0;
  height: 0
}

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

@font-face {
  font-family: font;
  src: url("../fonts/font.eot");
  src: url("../fonts/font-.eot#iefix") format("embedded-opentype"), url("../fonts/font.woff") format("woff"), url("../fonts/font.ttf") format("truetype"), url("../fonts/font.svg#untitled-font-1") format("svg")
}

[data-icon]:before, [data-icon]:after, [class^=icon]:before, [class*=" icon"]:before, [class^=icon]:after, [class*=" icon"]:after {
  font-family: font!important;
  font-style: normal!important;
  font-weight: 400!important;
  font-variant: normal!important;
  text-transform: none!important;
  speak: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale
}

.icon-arrow-l:before {
  content: "\61"
}

.icon-arrow-r:before {
  content: "\62"
}

.icon-tel:before {
  content: "\63";
  font-size: .8em;
  margin-right: .1em;
  margin-top: .2em
}

.icon-blank:after {
  content: "\65";
  margin-left: 3px;
  font-size: .9em!important
}

.l-max {
  width: 100%;
  padding: 0 16px
}

@media screen and (min-width:768px) {
  .l-max {
    margin: 0 auto;
    padding: 0
  }
}

.l-contents {
  width: 100%;
  padding: 0 16px
}

@media screen and (min-width:768px) {
  .l-contents {
    width: 1120px;
    margin: 0 auto;
    padding: 0
  }
}

.l-outside {
  width: 100%;
  padding: 0 16px
}

@media screen and (min-width:768px) {
  .l-outside {
    max-width: 1400px;
    min-width: 1120px;
    margin: 0 auto;
    padding: 0
  }
}

.l-inside {
  width: 100%;
  padding: 0 16px
}

@media screen and (min-width:768px) {
  .l-inside {
    width: 960px;
    margin: 0 auto;
    padding: 0
  }
}

.l-1200 {
  width: 100%;
  padding: 0 16px
}

@media screen and (min-width:768px) {
  .l-1200 {
    width: 1200px;
    margin: 0 auto;
    padding: 0
  }
}

.l-1118 {
  width: 100%;
  padding: 0 16px
}

@media screen and (min-width:768px) {
  .l-1118 {
    max-width: 1118px;
    margin: 0 auto;
    padding: 0
  }
}

.l-inside1000 {
  width: 100%;
  padding: 0 16px
}

@media screen and (min-width:768px) {
  .l-inside1000 {
    width: 1000px;
    margin: 0 auto;
    padding: 0
  }
}

.l-inside800 {
  width: 100%;
  padding: 0 16px
}

@media screen and (min-width:768px) {
  .l-inside800 {
    width: 800px;
    margin: 0 auto;
    padding: 0
  }
}

.l-float-l {
  float: left
}

.l-float-r {
  float: right
}

.l-wrap {
  margin: 0 -16px
}

.l-wrap:after {
  content: "";
  display: block;
  float: none;
  clear: both
}

.l-map {
  width: 100%;
  margin: 0 auto;
  position: relative;
  padding-bottom: 80%;
  overflow: hidden
}

@media screen and (min-width:768px) {
  .l-map {
    padding-bottom: 55.55%
  }
}

.l-map iframe, .l-map object, .l-map embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.l-btn-index-service {
  margin-top: 20px
}

@media screen and (min-width:768px) {
  .l-btn-index-service {
    display: none
  }
}

.l-btn {
  padding-top: 30px;
  padding-bottom: 25px
}

.l-btn a {
  display: table;
  margin: auto
}

@media screen and (min-width:768px) {
  .l-btn {
    padding-top: 50px;
    padding-bottom: 20px
  }
}

.l-btn-root {
  margin: 30px 0
}

.l-btn-root a {
  margin-bottom: 20px
}

@media screen and (min-width:768px) {
  .l-btn-root {
    margin: 70px 0 0;
    display: flex;
    flex-wrap: wrap
  }
}

.l-btn-caution {
  margin: 30px 0
}

@media screen and (min-width:768px) {
  .l-btn-caution {
    margin: 50px 0 70px
  }
}

.l-form-btn {
  margin-top: 30px
}

.l-form-btn button {
  margin-bottom: 16px!important
}

@media screen and (min-width:768px) {
  .l-form-btn {
    display: flex;
    width: 700px;
    margin: 70px auto 0
  }
  .l-form-btn button {
    width: 300px!important
  }
}

.l-btn--info a {
  margin: auto
}

@media screen and (max-width:768px) {
  .l-btn--info {
    width: 85vmin;
    margin: 30px auto -20px
  }
}

@media screen and (min-width:768px) {
  .l-btn--info {
    margin: 50px 0 -20px
  }
}

.l-btn-googlemap {
  margin: 20px 0
}

@media screen and (min-width:768px) {
  .l-btn-googlemap {
    margin: 30px 0
  }
  .l-btn-googlemap a {
    margin: auto
  }
}

.l-header {
  position: relative
}

@media screen and (min-width:768px) {
  .l-header {
    position: relative;
    width: 1120px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}

@media screen and (max-width:768px) {
  .l-spmenu {
    background: #f4f4f4;
    width: calc(100% - 50px);
    position: absolute;
    top: 0;
    right: 0;
    transform: translate(100%, 0);
    transition: transform .3s;
    visibility: hidden
  }
}

.menuopen .l-spmenu {
  transform: translate(0, 0);
  visibility: visible;
  min-height: 100vh
}

.l-footer {
  padding-top: 40px
}

@media screen and (min-width:768px) {
  .l-footer {
    display: flex;
    flex-wrap: wrap;
    width: 710px;
    margin: 0 auto
  }
}

.l-blog-wrap {
  display: flex;
  flex-direction: column
}

@media screen and (max-width:768px) {
  .l-blog-wrap a.btn-return.blog {
    order: -1
  }
  .l-blog-wrap.main {
    padding-bottom: 30px
  }
}

@media screen and (min-width:768px) {
  .l-blog-wrap {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between
  }
}

.l-bloglist-main {
  flex-shrink: 0;
  order: -1
}

@media screen and (min-width:768px) {
  .l-bloglist-main {
    width: 820px;
    flex: 0 0 820px
  }
}

@media screen and (min-width:768px) {
  .l-bloglist-side {
    flex-shrink: 0;
    min-width: 260px;
    max-width: 260px
  }
}

.l-pagenation {
  margin-left: auto;
  margin-right: auto
}

.l-flex {
  display: flex
}

.l-flex-sb {
  display: flex;
  justify-content: space-between
}

.l-flex-aic {
  display: flex;
  align-items: center
}

.l-row {
  display: flex;
  flex-wrap: wrap;
  margin-left: -16px;
  margin-right: -16px
}

.l-row [class^=l-col-], .l-row [class*=l-col-] {
  padding-left: 16px;
  padding-right: 16px
}

.l-align-items-center {
  align-items: center
}

.l-align-self-center {
  align-self: center
}

.l-align-self-end {
  align-self: flex-end
}

@media screen and (max-width:768px) {
  .l-gutter-sm0 {
    display: flex;
    flex-wrap: wrap;
    margin-left: 0;
    margin-right: 0
  }
  .l-gutter-sm0 [class^=l-col-], .l-gutter-sm0 [class*=l-col-] {
    padding-left: 0;
    padding-right: 0
  }
  .l-gutter-sm5 {
    display: flex;
    flex-wrap: wrap;
    margin-left: -2.5px;
    margin-right: -2.5px
  }
  .l-gutter-sm5 [class^=l-col-], .l-gutter-sm5 [class*=l-col-] {
    padding-left: 2.5px;
    padding-right: 2.5px
  }
  .l-gutter-sm10 {
    display: flex;
    flex-wrap: wrap;
    margin-left: -5px;
    margin-right: -5px
  }
  .l-gutter-sm10 [class^=l-col-], .l-gutter-sm10 [class*=l-col-] {
    padding-left: 5px;
    padding-right: 5px
  }
  .l-gutter-sm16 {
    display: flex;
    flex-wrap: wrap;
    margin-left: -8px;
    margin-right: -8px
  }
  .l-gutter-sm16 [class^=l-col-], .l-gutter-sm16 [class*=l-col-] {
    padding-left: 8px;
    padding-right: 8px
  }
  .l-gutter-sm20 {
    display: flex;
    flex-wrap: wrap;
    margin-left: -10px;
    margin-right: -10px
  }
  .l-gutter-sm20 [class^=l-col-], .l-gutter-sm20 [class*=l-col-] {
    padding-left: 10px;
    padding-right: 10px
  }
  .l-col-sm1, .l-col-sm2, .l-col-sm5of1, .l-col-sm3, .l-col-sm4, .l-col-sm5, .l-col-sm6, .l-col-sm7, .l-col-sm8, .l-col-sm9, .l-col-sm10, .l-col-sm11, .l-col-sm12 {
    position: relative;
    width: 100%;
    min-height: 1px
  }
  .l-col-sm12 {
    flex: 0 0 100%;
    max-width: 100%
  }
  .l-col-sm11 {
    flex: 0 0 91.666667%;
    max-width: 91.666667%
  }
  .l-col-sm10 {
    flex: 0 0 83.333333%;
    max-width: 83.333333%
  }
  .l-col-sm9 {
    flex: 0 0 75%;
    max-width: 75%
  }
  .l-col-sm8 {
    flex: 0 0 66.666667%;
    max-width: 66.666667%
  }
  .l-col-sm7 {
    flex: 0 0 58.333333%;
    max-width: 58.333333%
  }
  .l-col-sm6 {
    flex: 0 0 50%;
    max-width: 50%
  }
  .l-col-sm5 {
    flex: 0 0 41.666667%;
    max-width: 41.666667%
  }
  .l-col-sm4 {
    flex: 0 0 33.333333%;
    max-width: 33.333333%
  }
  .l-col-sm3 {
    flex: 0 0 25%;
    max-width: 25%
  }
  .l-col-sm5of1 {
    flex: 0 0 20%;
    max-width: 20%
  }
  .l-col-sm2 {
    flex: 0 0 16.666667%;
    max-width: 16.666667%
  }
  .l-col-sm1 {
    flex: 0 0 8.333333%;
    max-width: 8.333333%
  }
}

@media screen and (min-width:768px) {
  .l-flex-md {
    display: flex
  }
  .l-aligncenter-md {
    align-items: center
  }
  .l-wrap-md {
    flex-wrap: wrap
  }
  .l-gutter-md0 {
    display: flex;
    flex-wrap: wrap;
    margin-left: 0;
    margin-right: 0
  }
  .l-gutter-md0 [class^=l-col-], .l-gutter-md0 [class*=l-col-] {
    padding-left: 0;
    padding-right: 0
  }
  .l-gutter-md5 {
    display: flex;
    flex-wrap: wrap;
    margin-left: -2.5px;
    margin-right: -2.5px
  }
  .l-gutter-md5 [class^=l-col-], .l-gutter-md5 [class*=l-col-] {
    padding-left: 2.5px;
    padding-right: 2.5px
  }
  .l-gutter-md10 {
    display: flex;
    flex-wrap: wrap;
    margin-left: -5px;
    margin-right: -5px
  }
  .l-gutter-md10 [class^=l-col-], .l-gutter-md10 [class*=l-col-] {
    padding-left: 5px;
    padding-right: 5px
  }
  .l-gutter-md16 {
    display: flex;
    flex-wrap: wrap;
    margin-left: -8px;
    margin-right: -8px
  }
  .l-gutter-md16 [class^=l-col-], .l-gutter-md16 [class*=l-col-] {
    padding-left: 8px;
    padding-right: 8px
  }
  .l-gutter-md20 {
    display: flex;
    flex-wrap: wrap;
    margin-left: -10px;
    margin-right: -10px
  }
  .l-gutter-md20 [class^=l-col-], .l-gutter-md20 [class*=l-col-] {
    padding-left: 10px;
    padding-right: 10px
  }
  .l-gutter-md40 {
    display: flex;
    flex-wrap: wrap;
    margin-left: -20px;
    margin-right: -20px
  }
  .l-gutter-md40 [class^=l-col-], .l-gutter-md40 [class*=l-col-] {
    padding-left: 20px;
    padding-right: 20px
  }
  .l-gutter-md50 {
    display: flex;
    flex-wrap: wrap;
    margin-left: -25px;
    margin-right: -25px
  }
  .l-gutter-md50 [class^=l-col-], .l-gutter-md50 [class*=l-col-] {
    padding-left: 25px;
    padding-right: 25px
  }
  .l-col-md1, .l-col-md2, .l-col-md5of1, .l-col-md7of1, .l-col-md7of3, .l-col-md3, .l-col-md4, .l-col-md5, .l-col-md6, .l-col-md7, .l-col-md8, .l-col-md9, .l-col-md10, .l-col-md11, .l-col-md12, .l-col-md-auto {
    position: relative;
    width: 100%;
    min-height: 1px
  }
  .l-col-md-auto {
    flex: 0 0 auto;
    max-width: 100%
  }
  .l-col-md12 {
    flex: 0 0 100%;
    max-width: 100%
  }
  .l-col-md11 {
    flex: 0 0 91.666667%;
    max-width: 91.666667%
  }
  .l-col-md10 {
    flex: 0 0 83.333333%;
    max-width: 83.333333%
  }
  .l-col-md9 {
    flex: 0 0 75%;
    max-width: 75%
  }
  .l-col-md8 {
    flex: 0 0 66.666667%;
    max-width: 66.666667%
  }
  .l-col-md7 {
    flex: 0 0 58.333333%;
    max-width: 58.333333%
  }
  .l-col-md6 {
    flex: 0 0 50%;
    max-width: 50%
  }
  .l-col-md5 {
    flex: 0 0 41.666667%;
    max-width: 41.666667%
  }
  .l-col-md4 {
    flex: 0 0 33.333333%;
    max-width: 33.333333%
  }
  .l-col-md3 {
    flex: 0 0 25%;
    max-width: 25%
  }
  .l-col-md1of5 {
    flex: 0 0 20%;
    gap: 10% 5%!important;
    min-width: 30%;
  }
  .l-col-md2 {
    flex: 0 0 16.666667%;
    max-width: 16.666667%
  }
  .l-col-md1 {
    flex: 0 0 8.333333%;
    max-width: 8.333333%
  }
}

header {
  position: fixed;
  padding: 5px 16px 0;
  z-index: 9000;
  width: 100%;
  height: 80px;
  transition: background .3s;
  background-color: #fff;
  top: 0;
  box-shadow: 0 2px 4px rgba(0, 0, 0, .2)
}

@media screen and (min-width:768px) {
  header {
    width: 100%;
    padding: 0;
    height: 110px
  }
}

.index-header header {
  color: #fff;
  background-color: transparent;
  transition: background .3s, opacity .3s, visibility .3s
}

.index-header header.alpha {
  background-color: #fff
}

@media screen and (min-width:768px) {
  .index-header header.alpha {
    color: #222
  }
}

.index-header.hidden {
  opacity: 0;
  visibility: hidden
}

@media screen and (min-width:768px) {
  .header-left {
    display: flex;
    align-items: center;
    flex: 0 0 700px;
    height: 65px
  }
}

@media screen and (min-width:768px) {
  .header-right {
    display: flex;
    align-items: center;
    flex: 0 0 auto
  }
}

.l-logo-header {
  margin-top: 5px
}

@media screen and (min-width:768px) {
  .l-logo-header {
    flex: 0 0 250px;
    margin-top: 13px;
    image-rendering: -webkit-optimize-contrast
  }
}

.logo-header {
  width: 192px;
  height: 40px;
  position: relative
}

@media screen and (min-width:768px) {
  .logo-header {
    width: 250px;
    height: 50px
  }
}

.header-copy {
  font-size: 1rem;
  width: 100%;
  flex-basis: 100%;
  color: #666
}

@media screen and (min-width:768px) {
  .header-copy {
    font-size: 1.2rem;
    margin: -2px 0 0 20px
  }
}

@media screen and (max-width:768px) {
  .header-tel {
    text-indent: 100%;
    width: 50px;
    height: 50px;
    overflow: hidden;
    background: url("../img/common/header-tel.webp") no-repeat;
    background-size: 100%;
    white-space: nowrap;
    position: absolute;
    right: 60px;
    top: 8px;
  }
  .header-tel a {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0
  }
  .header-tel-title {
    display: none
  }
}

@media screen and (min-width:768px) {
  .header-tel {
    font-family: Noto Serif JP, serif;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #601986;
    font-size: 3rem;
    line-height: 1.3;
    letter-spacing: .1em
  }
  .header-tel .txt-tellink a {
    text-decoration: none;
    color: #601986
  }
  .header-tel-title {
    font-size: 1.4rem;
    margin: 11px 10px 0 0;
    letter-spacing: 0
  }
}

@media screen and (min-width:768px) {
  .menu {
    flex: 0 0 100%
  }
}

.main-menu {
  list-style-type: none;
  padding: 0;
  font-weight: 500
}

@media screen and (max-width:768px) {
  .main-menu {
    border-top: solid 1px #dddfde
  }
}

@media screen and (min-width:768px) {
  .main-menu {
    display: flex;
    font-size: 1.5rem;
    position: relative
  }
  .main-menu:after {
    content: "";
    position: absolute;
    right: 0;
    background: #dddfde;
    width: 1px;
    bottom: 12px;
    top: 10px;
    display: block
  }
}

.main-menu-list {
  position: relative;
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  letter-spacing: 0
}

@media screen and (max-width:768px) {
  .main-menu-list {
    border-bottom: solid 1px #dddfde;
    font-size: 1.3rem;
    color: #fff;
    background: #601986
  }
  .main-menu-list a {
    display: block;
    padding: .9em 20px
  }
  .main-menu-list a:before {
    display: none
  }
  .main-menu-list a[href="#"] {
    pointer-events: none
  }
  .main-menu-list:before {
    position: absolute;
    right: 16px;
    top: 14px;
    font-size: 1rem;
    transition: transform .3s
  }
  .main-menu-list.icon-role:before {
    transform: rotate(90deg)
  }
}

@media screen and (min-width:768px) {
  .main-menu-list {
    font-size: 1.6rem;
    max-height: 80px;
    flex: 0 0 20%;
    text-align: center
  }
  .main-menu-list>a {
    display: block;
    position: relative;
    padding: 13px 10px 17px;
    line-height: 16px
  }
  .main-menu-list>a:before {
    content: "";
    position: absolute;
    left: 0;
    background: #dddfde;
    width: 1px;
    bottom: 12px;
    top: 10px;
    display: block
  }
  .main-menu-list:before {
    display: none
  }
  .main-menu-list:not(.nomega):after {
    transition: opacity .3s, bottom .3s;
    height: 30px;
    position: absolute;
    bottom: -2px;
    opacity: 0;
    left: calc(50% - 7px);
    pointer-events: none;
    content: "";
    font-size: 0;
    border: 7px solid transparent;
    border-bottom-color: #601986;
    border-bottom-width: 8px
  }
  .main-menu-list.nomega:before {
    content: "";
    display: block;
    width: 0;
    border-bottom: 2px solid #601986;
    height: 30px;
    bottom: 0;
    left: 0;
    position: absolute;
    pointer-events: none
  }
  .main-menu-list:hover {
    color: #601986
  }
  .main-menu-list:hover:after {
    opacity: 1;
    bottom: 0
  }
  .main-menu-list:hover.nomega:before {
    transition: width .2s cubic-bezier(.165, .84, .44, 1);
    bottom: 0;
    width: 100%
  }
}

@media screen and (max-width:768px) {
.main-menu-list-sns-area pc-none{
  background: rgb(247, 232, 250);
  padding: 2% 0;
}

.main-menu-list-sns-title {
  font-family: 'Times New Roman',serif;
  color: #601986;
  gap: 40px;
  font-size: 2.4rem;
  text-align: center;
  margin-bottom:0%;
}

.main-menu-list-sns {
  list-style: none;
  display: flex;
  color: #601986;
  gap: 24px;
  font-size: 4.5rem;
  justify-content:center;
}
}

.submenu {
  display: none;
  list-style-type: none;
  border-top: solid 1px #dddfde
}

@media screen and (min-width:768px) {
  .submenu {
    background: linear-gradient(to bottom, rgba(96, 25, 134, .80) 50%, rgba(48, 10, 80, .80));
    border-top: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    position: fixed;
    top: 80px;
    left: 50%;
    transform: translateX(-50%);
    z-index: -1;
    padding: 30px 40px 20px;
    visibility: hidden;
    opacity: 0;
    transition: opacity .3s ease-in-out, visibility .3s ease-in-out, top ease-in-out .3s;
    width: 101%;
    top: 108px
  }
  .submenu.submenu-open {
    visibility: visible!important;
    opacity: 1;
    top: 110px
  }
}

.submenu-list {
  color: #601986;
  position: relative;
  border-bottom: solid 1px #dddfde;
  font-weight: 400;
  background: #fff
}

.submenu-list:last-of-type {
  border-bottom: none
}

@media screen and (max-width:768px) {
  .submenu-list:before, .submenu-list:after {
    color: #601986;
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1rem
  }
}

.submenu-list a {
  display: block;
  padding: .9em 32px;
  font-weight: 400
}

@media screen and (min-width:768px) {
  .submenu-list {
    flex: 0 0 140px;
    max-width: 140px;
    min-width: 140px;
    border: none;
    color: #fff;
    background: transparent;
    display: block;
    font-size: 1.4rem;
    font-family: Noto Sans JP, sans-serif;
    padding: 0 10px
  }
  .submenu-list:before {
    display: none
  }
  .submenu-list a {
    padding: 0 0 10px;
    display: block;
    position: relative;
    height: 100%;
    transition: color .3s
  }
  .submenu-list a:hover {
    color: rgba(255, 255, 255, .7)
  }
  .submenu-list a:hover span:before {
    transform: scale(1.05)
  }
  .submenu-list a span {
    overflow: hidden;
    display: block;
    max-height: 120px;
    margin-bottom: 10px
  }
  .submenu-list a span:before {
    content: "";
    width: 120px;
    background: #601986;
    height: 120px;
    display: block;
    position: relative;
    z-index: -2;
    transition: transform .3s cubic-bezier(0, 0, .1, 1)
  }
}

@media screen and (min-width:768px) {
  .submenu-list a[href*=buy01] span:before {
    image-rendering: -webkit-optimize-contrast;
    background-image: url("../img/buy/buy01.webp");
    background-size: 100%;
    background-repeat: no-repeat
  }
  .submenu-list a[href*=buy02] span:before {
    image-rendering: -webkit-optimize-contrast;
    background-image: url("../img/buy/buy02.webp");
    background-size: 100%;
    background-repeat: no-repeat
  }
  .submenu-list a[href*=buy03] span:before {
    image-rendering: -webkit-optimize-contrast;
    background-image: url("../img/buy/buy03.webp");
    background-size: 100%;
    background-repeat: no-repeat
  }
  .submenu-list a[href*=buy04] span:before {
    image-rendering: -webkit-optimize-contrast;
    background-image: url("../img/buy/buy04.webp");
    background-size: 100%;
    background-repeat: no-repeat
  }
  .submenu-list a[href*=buy05] span:before {
    image-rendering: -webkit-optimize-contrast;
    background-image: url("../img/buy/buy05.webp");
    background-size: 100%;
    background-repeat: no-repeat
  }
  .submenu-list a[href*=buy06] span:before {
    image-rendering: -webkit-optimize-contrast;
    background-image: url("../img/buy/buy06.webp");
    background-size: 100%;
    background-repeat: no-repeat
  }
  .submenu-list a[href*=buy07] span:before {
    image-rendering: -webkit-optimize-contrast;
    background-image: url("../img/buy/buy07.webp");
    background-size: 100%;
    background-repeat: no-repeat
  }
  .submenu-list a[href*=rental01] span:before {
    image-rendering: -webkit-optimize-contrast;
    background-image: url("../img/rental/rental01.webp");
    background-size: 100%;
    background-repeat: no-repeat
  }
  .submenu-list a[href*=rental02] span:before {
    image-rendering: -webkit-optimize-contrast;
    background-image: url("../img/rental/rental02.webp");
    background-size: 100%;
    background-repeat: no-repeat
  }
  .submenu-list a[href*=rental03] span:before {
    image-rendering: -webkit-optimize-contrast;
    background-image: url("../img/rental/rental03.webp");
    background-size: 100%;
    background-repeat: no-repeat
  }
  .submenu-list a[href*=rental04] span:before {
    image-rendering: -webkit-optimize-contrast;
    background-image: url("../img/rental/rental04.webp");
    background-size: 100%;
    background-repeat: no-repeat
  }
  .submenu-list a[href*=rental05] span:before {
    image-rendering: -webkit-optimize-contrast;
    background-image: url("../img/rental/rental05.webp");
    background-size: 100%;
    background-repeat: no-repeat
  }
  .submenu-list a[href*=rental06] span:before {
    image-rendering: -webkit-optimize-contrast;
    background-image: url("../img/rental/rental06.webp");
    background-size: 100%;
    background-repeat: no-repeat
  }
}

@media screen and (max-width:768px) {
  .main-menu-list.menu-active {
    background: #601986;
    color: #fff
  }
  .main-menu-list.menu-active:before {
    color: #fff
  }
  .main-menu-list.menu-active .submenu-list {
    color: #222
  }
}

@media screen and (min-width:768px) {
  .main-menu-list.menu-active {
    color: #601986
  }
  .main-menu-list.menu-active:before {
    display: block;
    content: "";
    border-bottom: 2px solid #601986;
    border-color: #601986;
    transition: width .2s cubic-bezier(.165, .84, .44, 1);
    bottom: 0;
    left: 0;
    position: absolute;
    width: 100%;
    opacity: 1
  }
  .main-menu-list.menu-active:hover {
    color: #601986
  }
  .main-menu-list.menu-active:hover:before {
    border-color: #601986
  }
}

.menu-btn {
  font-family: Bellefair, serif;
  letter-spacing: .1em;
  font-weight: 400;
  display: block;
  text-align: center;
  height: 50px;
  width: 50px;
  position: fixed;
  top: 13px;
  right: 16px;
  vertical-align: bottom;
  z-index: 9999;
  background: #601986
}

.menu-btn span {
  color: #fff;
  display: block;
  width: 38px;
  height: 2px;
  position: absolute;
  left: 6px;
  transition: all .3s
}

.menu-btn span:nth-of-type(1) {
  top: 8px;
  background: #fff
}

.menu-btn span:nth-of-type(2) {
  top: 18px;
  background: #fff
}

.menu-btn span:nth-of-type(3) {
  top: 28px;
  background: #fff
}

.menu-btn span.menu-txt {
  bottom: 16px
}

.menu-btn span.menu-txt:before {
  height: 10px;
  width: 40px;
  margin: 0 -10px;
  content: "MENU";
  font-size: 1rem;
  z-index: 9995
}

.open {
  background: #601986
}

.open span {
  color: #fff
}

.open span:nth-of-type(1) {
  top: 18px;
  transform: rotate(35deg);
  background: #fff
}

.open span:nth-of-type(2) {
  background: rgba(255, 255, 255, 0)
}

.open span:nth-of-type(3) {
  top: 18px;
  transform: rotate(-35deg);
  background: #fff
}

.open span.menu-txt:before {
  content: "CLOSE"
}

@media screen and (max-width:768px) {
  .spmenu {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    pointer-events: none
  }
}

@media screen and (max-width:768px) {
  .spmenu.menuopen {
    display: block;
    background-color: rgba(0, 0, 0, .7);
    z-index: 9996;
    pointer-events: auto
  }
}

.quick-menu {
  display: flex;
  align-self: flex-end;
  height: 80px;
  color: #fff
}

.sp-title {
  font-family: Bellefair, serif;
  font-weight: 400;
  letter-spacing: .1em;
  color: #601986;
  font-size: 2rem;
  height: 75px;
  padding-left: 25px;
  display: flex;
  align-items: center;
  background: #fff
}

.sp-contact-box {
  padding: 16px 16px 20px
}

.sp-contact-name {
  font-weight: 500;
  margin-bottom: 5px;
  font-size: 1.5rem;
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  text-align: center;
  color: #601986
}

.sp-contact-tel {
  font-family: Noto Serif JP, serif;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #601986;
  font-size: 2.5rem;
  line-height: 1.3;
  letter-spacing: .1em
}

.sp-contact-tel .txt-tellink a {
  text-decoration: none;
  color: #601986
}

.sp-contact-tel a {
  text-decoration: none;
  color: #601986;
  font-weight: 400
}

.sp-contact-address {
  text-align: center;
  font-size: 1.1rem;
  line-height: 1.7
}

.sp-sns-area {
  background: #fff;
  color: #222;
  text-align: center;
  padding: 20px 20px 50px
}

.sp-sns-area h4 {
  font-size: 1.4rem
}

.sp-sns-area .l-flex {
  margin-top: 20px;
  justify-content: center
}

.sp-sns-area a {
  display: block;
  flex: 0 0 80px;
  padding: 0 15px
}

.sp-sns-area .sns-icon {
  width: 50px
}

@media screen and (max-width:768px) {
  .sp-sns-area .btn-index--newssite {
    display: flex;
    align-items: center;
    color: #fff;
    width: 100%;
    height: 90px;
    background-size: 28vmin;
    font-size: 1.5rem;
    margin-top: 20px;
    padding: 20px
  }
}

.btn-sp-contact {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  position: relative;
  display: block;
  background: #fff;
  color: #fff;
  font-size: 1.7rem;
  font-weight: 500;
  text-align: center;
  margin: auto;
  padding: .6em 20px;
  color: #601986;
  border: 1px solid #601986;
  padding: .5em 16px;
  margin-top: 16px
}

.btn-sp-contact:before {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  font-size: 1rem
}

@media screen and (min-width:768px) {
  .btn-sp-contact {
    cursor: pointer;
    display: table;
    min-width: 350px;
    font-size: 1.8rem;
    padding: .65em 20px;
    transition: background .3s, color .3s;
    margin: 0
  }
  .btn-sp-contact:before {
    right: 20px
  }
  .btn-sp-contact:hover {
    background: #fff
  }
}

footer {
  display: block
}

.footer-contact {
  background: url("../img/common/footer-bg.webp");
  padding: 40px 0
}

@media screen and (min-width:768px) {
  .footer-contact {
    padding: 50px 0
  }
}

.h-footer-contact {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  text-align: center;
  font-size: 1.5rem
}

@media screen and (min-width:768px) {
  .h-footer-contact {
    font-size: 2rem
  }
}

.footer-contact-tel {
  text-align: center;
  color: #601986
}

@media screen and (min-width:768px) {
  .footer-contact-tel {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 20px
  }
}

.footer-contact-title {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  font-size: 1.5rem;
  margin-top: 16px
}

@media screen and (min-width:768px) {
  .footer-contact-title {
    font-size: 2rem;
    margin-right: 16px;
    padding-bottom: 10px
  }
}

.footer-contact-telno {
  font-family: Noto Serif JP, serif;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #601986;
  font-size: 2.5rem;
  line-height: 1.3;
  letter-spacing: .1em
}

.footer-contact-telno .txt-tellink a {
  text-decoration: none;
  color: #601986
}

.footer-contact-telno:before {
  margin-top: 5px
}

@media screen and (min-width:768px) {
  .footer-contact-telno {
    font-size: 3.6rem
  }
}

.footer-contact-address {
  text-align: center;
  margin-top: 10px;
  line-height: 1.7
}

@media screen and (min-width:768px) {
  .footer-contact-address {
    margin-top: 20px;
    font-size: 1.4rem
  }
}

.footer-info {
  padding: 30px 0
}

@media screen and (min-width:768px) {
  .footer-info {
    text-align: left;
    display: flex;
    flex-wrap: wrap;
    background: url("../img/common/footer_kamon02@2x.webp") no-repeat;
    background-size: 190px;
    background-position: right 90px top 30px
  }
}

.footer-copy {
  color: #666;
  font-size: 1.2rem;
  text-align: center
}

@media screen and (min-width:768px) {
  .footer-copy {
    text-align: left;
    flex: 0 0 100%
  }
}

.h-footer-list {
  color: #601986;
  font-family: Bellefair, serif;
  font-weight: 400;
  letter-spacing: .1em;
  font-size: 1.8rem;
  margin-top: 30px;
  flex: 0 0 100%
}

.footer-list {
  display: flex;
  flex-wrap: wrap
}

.footer-list ul {
  list-style-type: none;
  margin-right: 40px
}

.footer-list li {
  font-size: 1.4rem;
  color: #3178b0
}

.footer-list .sub:before {
  content: "-";
  margin-right: 3px
}

.footer-list a {
  padding: 5px 0;
  display: inline-block;
  font-weight: 400;
  transition: color .3s
}

.footer-list a:hover {
  color: #4892cc
}

.footer-logo {
  width: 212px;
  display: block;
  margin: 16px auto 3px
}

@media screen and (min-width:768px) {
  .footer-logo {
    width: 190px;
    margin: 20px 0 5px;
    image-rendering: -webkit-optimize-contrast
  }
}

@media screen and (min-width:768px) {
  .footer-info-data {
    flex: 0 0 360px;
    margin-top: 10px
  }
}

.footer-info-tel {
  font-family: Noto Serif JP, serif;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #601986;
  font-size: 2.3rem;
  line-height: 1.3;
  letter-spacing: .1em
}

.footer-info-tel .txt-tellink a {
  text-decoration: none;
  color: #601986
}

@media screen and (min-width:768px) {
  .footer-info-tel {
    text-align: left;
    display: block;
    font-size: 2rem
  }
}

.footer-info-address {
  text-align: center;
  font-size: 1.2rem;
  margin-top: 8px
}

.footer-info-sns-title {
  font-family: 'Times New Roman',serif;
  color: #601986;
  gap: 10px;
  font-size: 2.5rem;
  text-align: center;
}

.footer-info-sns {
  list-style: none;
  display: flex;
  color: #601986;
  gap: 24px;
  font-size: 3rem;
  justify-content:center;
}

@media screen and (min-width:768px) {
  .footer-info-address {
    text-align: left;
    font-size: 1.4rem
  }
  .footer-info-sns-title {
    text-align: left;
  }
  .footer-info-sns {
    justify-content:flex-start;
  }
}

footer.ipad .footer-list li, footer.ipad .footer-info-address {
  font-size: 1.2rem
}

.copyright {
  background: #601986;
  text-align: center;
  color: #fff;
  font-size: 1rem;
  padding: 5px 0
}

@media screen and (min-width:768px) {
  .copyright {
    font-size: 1.2rem;
    padding: 10px 0
  }
}

.footer-link {
  padding: 16px 0 6px
}

@media screen and (min-width:768px) {
  .footer-link {
    padding: 20px 0 15px
  }
}

.top-btn {
  position: fixed;
  right: 5px;
  bottom: 10px;
  width: 50px;
  height: 50px;
  transition: opacity .3s, visibility .3s;
  opacity: 0;
  visibility: hidden;
  z-index: 8000
}

.top-btn img {
  width: 100%
}

@media screen and (min-width:768px) {
  .top-btn {
    cursor: pointer;
    width: 60px;
    height: 60px;
    right: 10px;
    bottom: 20px
  }
  .top-btn:hover {
    opacity: .9
  }
}

.fade-btn {
  opacity: 1;
  visibility: visible
}

.btn-fix {
  position: absolute;
  bottom: 35px
}

@media screen and (min-width:768px) {
  .btn-fix {
    bottom: 57px
  }
}

.modal-bg {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: fixed;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  background: rgba(68, 68, 68, .7);
  visibility: hidden;
  z-index: 1;
  opacity: 0;
  transition: opacity .3s, visibility .3s
}

.modal-bg>div {
  background: #fff;
  padding: 20px
}

.modal-bg .modal-contact-tel {
  padding: 20px;
  border: none
}

.modal-bg .modal-contact-cap {
  font-size: 1.5rem;
  text-align: center;
  color: #601986;
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em
}

.modal-bg .modal-contact-telno {
  margin-bottom: 5px;
  font-family: Noto Serif JP, serif;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #601986;
  font-size: 2.5rem;
  line-height: 1.3;
  letter-spacing: .1em
}

.modal-bg .modal-contact-telno .txt-tellink a {
  text-decoration: none;
  color: #601986
}

.modal-bg .modal-contact-note {
  font-size: 1.2rem
}

.modal-bg.modalopen {
  z-index: 9998;
  visibility: visible;
  opacity: 1
}

.btn-modal-close {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  position: relative;
  display: block;
  background: #fff;
  color: #fff;
  font-size: 1.7rem;
  font-weight: 500;
  text-align: center;
  margin: auto;
  padding: .6em 20px;
  color: #222;
  margin: 20px 0 0
}

.btn-modal-close:before {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  font-size: 1rem
}

@media screen and (min-width:768px) {
  .btn-modal-close {
    cursor: pointer;
    display: table;
    min-width: 350px;
    font-size: 1.8rem;
    padding: .65em 20px;
    transition: background .3s, color .3s;
    margin: 0
  }
  .btn-modal-close:before {
    right: 20px
  }
  .btn-modal-close:hover {
    background: #fff
  }
}

.index-main, .page-main {
  margin-top: 75px
}

@media screen and (min-width:768px) {
  .index-main, .page-main {
    margin-top: 110px
  }
}

.contents-area {
  padding: 40px 0 0
}

@media screen and (min-width:768px) {
  .contents-area {
    padding: 50px 0 0
  }
}

@media screen and (min-width:768px) {
  .sidemenu-row {
    display: flex;
    flex-wrap: wrap;
    width: 1120px;
    margin: 0 auto
  }
}

.breadcrumb {
  font-size: 1.0rem;
  height: 30px;
  overflow-y: hidden;
  margin: -30px 0 0;
  background: rgba(255, 255, 255, .5);
  color: #666
}

.breadcrumb ol {
  list-style: none;
  overflow-x: scroll;
  white-space: nowrap;
  padding: 8px 4px 15px
}

.breadcrumb a {
  color: #3178b0
}

.breadcrumb li {
  display: inline
}

.breadcrumb li:before {
  content: "＞";
  margin: 0 .5em
}

.breadcrumb li:first-of-type:before {
  display: none
}

@media screen and (min-width:768px) {
  .breadcrumb {
    font-size: 1.2rem;
    padding: 9px 0;
    margin: -35px 0 0;
    height: auto
  }
  .breadcrumb ol {
    overflow-x: auto;
    white-space: auto;
    padding: 0
  }
  .breadcrumb a {
    transition: color .3s
  }
  .breadcrumb a:hover {
    color: #4892cc
  }
}

.btn-default {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  position: relative;
  display: block;
  background: #601986;
  color: #fff;
  font-size: 1.7rem;
  font-weight: 500;
  text-align: center;
  margin: auto;
  padding: .6em 20px
}

.btn-default:before {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  font-size: 1rem
}

@media screen and (min-width:768px) {
  .btn-default {
    cursor: pointer;
    display: table;
    min-width: 350px;
    font-size: 1.8rem;
    padding: .65em 20px;
    transition: background .3s, color .3s;
    margin: 0
  }
  .btn-default:before {
    right: 20px
  }
  .btn-default:hover {
    background: #935ba9
  }
}

.btn-default--side {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  position: relative;
  display: block;
  background: #601986;
  color: #fff;
  font-size: 1.7rem;
  font-weight: 500;
  text-align: center;
  margin: auto;
  padding: .6em 20px
}

.btn-default--side:before {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  font-size: 1rem
}

@media screen and (min-width:768px) {
  .btn-default--side {
    cursor: pointer;
    display: table;
    min-width: 350px;
    font-size: 1.8rem;
    padding: .65em 20px;
    transition: background .3s, color .3s;
    margin: 0
  }
  .btn-default--side:before {
    right: 20px
  }
  .btn-default--side:hover {
    background: #534683
  }
}

@media screen and (min-width:768px) {
  .btn-default--side {
    min-width: 100%;
    width: 100%;
    margin-top: 10px
  }
  .btn-default--side:before {
    right: 12px
  }
}

.btn-shop--side {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  position: relative;
  display: block;
  background: #7a7247;
  color: #fff;
  font-size: 1.7rem;
  font-weight: 500;
  text-align: center;
  margin: auto;
  padding: .6em 20px
}

.btn-shop--side:before {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  font-size: 1rem
}

@media screen and (min-width:768px) {
  .btn-shop--side {
    cursor: pointer;
    display: table;
    min-width: 350px;
    font-size: 1.8rem;
    padding: .65em 20px;
    transition: background .3s, color .3s;
    margin: 0
  }
  .btn-shop--side:before {
    right: 20px
  }
  .btn-shop--side:hover {
    background: #8a8150
  }
}

@media screen and (min-width:768px) {
  .btn-shop--side {
    min-width: 100%;
    width: 100%;
    margin-top: 10px
  }
  .btn-shop--side:before {
    right: 12px
  }
}

.btn-map {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  position: relative;
  display: block;
  background: #fff;
  color: #fff;
  font-size: 1.7rem;
  font-weight: 500;
  text-align: center;
  margin: auto;
  padding: .6em 20px;
  font-family: Noto Sans JP, sans-serif;
  color: #3178b0;
  border: 1px solid #3178b0;
  font-size: 1.1rem;
  min-width: 90px;
  width: 90px;
  padding: 3px 0;
  letter-spacing: 0;
  margin: 3px 0 8px
}

.btn-map:before {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  font-size: 1rem
}

@media screen and (min-width:768px) {
  .btn-map {
    cursor: pointer;
    display: table;
    min-width: 350px;
    font-size: 1.8rem;
    padding: .65em 20px;
    transition: background .3s, color .3s;
    margin: 0
  }
  .btn-map:before {
    right: 20px
  }
  .btn-map:hover {
    background: #3178b0
  }
}

@media screen and (min-width:768px) {
  .btn-map {
    min-width: 110px;
    font-size: 1.4rem;
    padding: 3px 5px;
    margin: 5px 0 0
  }
  .btn-map:hover {
    color: #fff
  }
}

.btn-return {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  position: relative;
  display: block;
  background: #fff;
  color: #fff;
  font-size: 1.7rem;
  font-weight: 500;
  text-align: center;
  margin: auto;
  padding: .6em 20px;
  border: 1px solid #601986;
  color: #601986;
  margin: 40px auto
}

.btn-return:before {
  position: absolute;
  top: 50%;
  left: 10px;
  transform: translateY(-50%);
  font-size: 1rem
}

@media screen and (min-width:768px) {
  .btn-return {
    cursor: pointer;
    display: table;
    min-width: 350px;
    font-size: 1.8rem;
    padding: .65em 20px;
    transition: background .3s, color .3s;
    margin: 0
  }
  .btn-return:before {
    left: 20px
  }
  .btn-return:hover {
    background: #601986
  }
}

@media screen and (min-width:768px) {
  .btn-return {
    margin: 70px auto 0
  }
  .btn-return:hover {
    color: #fff
  }
}

.btn-return2 {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  position: relative;
  display: block;
  background: #fff;
  color: #fff;
  font-size: 1.7rem;
  font-weight: 500;
  text-align: center;
  margin: auto;
  padding: .6em 20px;
  border: 1px solid #601986;
  color: #601986;
  margin: 40px auto
}

.btn-return2:before {
  position: absolute;
  top: 50%;
  left: 10px;
  transform: translateY(-50%);
  font-size: 1rem
}

@media screen and (min-width:768px) {
  .btn-return2 {
    cursor: pointer;
    display: table;
    min-width: 350px;
    font-size: 1.8rem;
    padding: .65em 20px;
    transition: background .3s, color .3s;
    margin: 0
  }
  .btn-return2:before {
    left: 20px
  }
  .btn-return2:hover {
    background: #601986
  }
}

@media screen and (min-width:768px) {
  .btn-return2 {
    min-width: 450px;
    margin: 70px auto 0
  }
  .btn-return2:hover {
    color: #fff
  }
}

.h-large, .h-information {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  text-align: center;
  font-size: 1.7rem;
  margin: 30px 0 20px
}

.h-large span, .h-information span {
  font-family: Bellefair, serif;
  font-weight: 400;
  letter-spacing: .1em;
  display: block;
  color: #601986;
  font-size: 1.5rem;
  padding-bottom: 10px
}

.h-large span:after, .h-information span:after {
  content: "";
  display: block;
  height: 1px;
  width: 35px;
  margin: auto;
  background: #601986;
  margin-top: 10px
}

@media screen and (min-width:768px) {
  .h-large, .h-information {
    font-size: 2.2rem;
    margin: 50px 0 30px
  }
  .h-large span, .h-information span {
    font-size: 2rem;
    padding-bottom: 20px
  }
  .h-large span:after, .h-information span:after {
    width: 50px;
    margin-top: 20px
  }
}

.h-middle {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  border-left: solid 3px #fff;
  font-size: 2.4rem;
  letter-spacing: .025em;
  padding-left: 8px;
  padding-bottom: 4px;
  position: relative;
  margin: 40px 0 25px;
  line-height: 1.3
}

.h-middle:after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  left: -3px;
  bottom: -5px;
  right: 0
}

.h-middle.women {
  border-color: #faafbe
}

.h-middle.women:after {
  background-color: #faafbe
}

.h-middle.women2 {
  border-color: #faafbe;
  margin: 20px 0 25px
}

.h-middle.women2:after {
  background-color: #faafbe
}

.h-middle.men {
  border-color: #34648f
}

.h-middle.men:after {
  background-color: #34648f
}

@media screen and (min-width:768px) {
  .h-middle {
    font-size: 3.6rem;
    border-width: 5px;
    padding-left: 16px;
    margin: 80px 0 35px
  }
  .h-middle:after {
    bottom: -10px;
    left: -5px
  }
  .h-middle.women2 {
    border-color: #faafbe;
    margin: 0 0 35px
  }
  .h-middle.women2:after {
    background-color: #faafbe
  }
}

.h-small {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  letter-spacing: .025em;
  font-size: 1.8rem;
  margin-bottom: 10px
}

.h-small.circle {
  position: relative;
  padding-left: 1.25em
}

.h-small.circle:before {
  position: absolute;
  content: "●";
  left: 0
}

.h-small.women:before {
  color: #faafbe
}

.h-small.men:before {
  color: #34648f
}

@media screen and (min-width:768px) {
  .h-small {
    font-size: 2.6rem;
    margin-bottom: 20px
  }
}

.contents-area .h-large, .contents-area .h-information {
  margin-top: 40px
}

@media screen and (min-width:768px) {
  .contents-area .h-large, .contents-area .h-information {
    margin-top: 60px
  }
}

.h-index-pickup {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  text-align: center;
  font-size: 2rem;
  padding: 10px 0 16px;
  color: #fff;
  background: url("../img/index/pickup-bg.webp");
  z-index: 2;
  position: relative
}

@media screen and (min-width:768px) {
  .h-index-pickup {
    font-size: 2.4rem;
    padding: 20px 0
  }
}

.h-index-pickup.rent03 {
  background-color: #91a7d5
}

.h-index-pickup.rent01 {
  background-color: #e3a52e
}

.h-index-pickup.rent02 {
  background-color: #de6791
}

.h-index-about {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  font-size: 1.8rem;
  text-align: center;
  margin: 30px 0 16px
}

@media screen and (min-width:768px) {
  .h-index-about {
    font-size: 3rem;
    text-align: left;
    margin: 0 0 30px
  }
}

@media screen and (max-width:320px) {
  .h-index-about {
    font-size: 1.7rem
  }
}

.h-index-lineup, .h-pege-title, .h-pege-title--buy {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  font-size: 2.5rem;
  color: #264530
}

.h-index-lineup:after, .h-pege-title:after, .h-pege-title--buy:after {
  content: "";
  display: block;
  height: 1px;
  background: #264530;
  width: 35px;
  margin-top: 10px
}

@media screen and (min-width:768px) {
  .h-index-lineup, .h-pege-title, .h-pege-title--buy {
    font-size: 3.6rem
  }
}

.h-index-lineup.rent, .h-pege-title, .rent.h-pege-title--buy {
  color: #601986
}

.h-index-lineup.rent:after, .h-pege-title:after, .rent.h-pege-title--buy:after {
  background: #601986
}

.h-index-lineup--small, .h-pege-title--small {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  margin: 20px 0 16px;
  font-size: 1.8rem
}

@media screen and (max-width:320px) {
  .h-index-lineup--small, .h-pege-title--small {
    font-size: 1.7rem
  }
}

@media screen and (min-width:768px) {
  .h-index-lineup--small, .h-pege-title--small {
    font-size: 2.6rem
  }
}

.h-index-buy, .h-index-rent, .h-rent, .h-buy {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  text-align: center;
  font-size: 1.5rem;
  padding: 0 5px;
  height: 50px;
  color: #fff;
  background: url("../img/index/pickup-bg.webp");
  z-index: 2;
  position: relative;
  background-color: #928755;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1.3
}

@media screen and (max-width:320px) {
  .h-index-buy, .h-index-rent, .h-rent, .h-buy {
    font-size: 1.3rem
  }
}

@media screen and (min-width:768px) {
  .h-index-buy, .h-index-rent, .h-rent, .h-buy {
    height: 70px;
    font-size: 1.8rem
  }
}

.h-index-rent, .h-rent {
  background-color: #844e85
}

.h-buy {
  font-size: 2.4rem;
  height: 60px
}

@media screen and (max-width:320px) {
  .h-buy {
    font-size: 2.1rem
  }
}

@media screen and (min-width:768px) {
  .h-buy {
    height: 80px
  }
}

.h-rent {
  font-size: 2.4rem;
  min-height: 60px;
  height: auto;
  padding: 10px 0 15px
}

@media screen and (max-width:320px) {
  .h-rent {
    font-size: 2.1rem
  }
}

@media screen and (min-width:768px) {
  .h-rent {
    height: 100px;
    padding: 0
  }
}

.h-price {
  text-align: center;
  color: #601986;
  font-size: 1.4rem;
  padding: 10px 16px;
  margin: 20px 0 0
}

.h-price .tax {
  font-size: 1.1rem
}

.h-price.women {
  background: #fee0e6
}

.h-price.rental02 {
  background: #601986;
  color: #fff
}

.h-price.rental03 {
  background: #61cbf4;
  color: #fff
}

.h-price.men {
  background: #b8d0e5
}

@media screen and (min-width:768px) {
  .h-price {
    font-size: 2rem;
    margin: 30px 0 10px
  }
  .h-price .tax {
    font-size: 1.4rem
  }
  .h-price.rental02 {
    font-size: 1.4rem;
    margin: 0 0 10px
  }
}

.h-footer-shop {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  text-align: center;
  color: #601986;
  font-size: 2.5rem;
  margin-bottom: 20px
}

@media screen and (min-width:768px) {
  .h-footer-shop {
    text-align: left;
    font-size: 3.6rem
  }
}

.h-footer-shop--small {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  text-align: center;
  font-size: 1.8rem;
  margin-bottom: 16px
}

@media screen and (min-width:768px) {
  .h-footer-shop--small {
    text-align: left;
    font-size: 2.2rem
  }
}

.footer-shop {
  background: url("../img/common/bg-pale.webp");
  margin-top: 50px
}

@media screen and (min-width:768px) {
  .footer-shop {
    position: relative;
    min-width: 1120px;
    margin-top: 80px;
    padding: 50px 0;
    z-index: -3
  }
}

.footer-shop-data {
  padding: 30px 16px 40px!important
}

@media screen and (max-width:768px) {
  .footer-shop-data {
    background-size: 130px;
    background-position: 15px 10px
  }
}

@media screen and (min-width:768px) {
  .footer-shop-data {
    order: 2;
    padding: 0 130px 0 0!important
  }
  .footer-shop-data>div {
    position: relative;
    max-width: 760px;
    width: calc(100% + 60px);
    margin: 40px -60px 0 auto;
    padding: 60px 90px;
    background: url("../img/common/bg-pale.webp")
  }
  .footer-shop-data>div:after {
    content: "";
    display: block;
    position: absolute;
    background: url("../img/index/pickup-bg.webp") #c1bccf;
    width: 100%;
    left: 160px;
    bottom: -20px;
    top: 100px;
    z-index: -2
  }
  .footer-shop-data>div:before {
    content: "";
    display: block;
    position: absolute;
    background-size: 100%;
    width: 200px;
    height: 200px;
    left: 20px;
    top: -65px;
    z-index: 0
  }
  .footer-shop-data>div h3, .footer-shop-data>div h4, .footer-shop-data>div p, .footer-shop-data>div a {
    position: relative;
    z-index: 2
  }
}

@media screen and (min-width:768px) {
  .footer-shop-img {
    order: 1
  }
  .footer-shop-img img {
    object-fit: cover;
    width: 100%;
    height: 100%;
    max-height: 520px;
    object-position: 50% 50%;
    position: relative;
    z-index: -1
  }
}

@media print, screen and (min-width:768px) and (max-width:1302px) {
  .footer-shop-img img {
    min-height: 577px
  }
}

@media print, screen and (min-width:1302px) and (max-width:1391px) {
  .footer-shop-img img {
    min-height: 546px
  }
}

@media print, screen and (min-width:1391px) and (max-width:1570px) {
  .footer-shop-img img {
    min-height: 520px
  }
}

.h-about {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  font-size: 2rem;
  text-align: center;
  margin-bottom: 10px
}

.h-about+p {
  line-height: 2
}

@media screen and (min-width:768px) {
  .h-about {
    font-size: 3rem;
    margin-bottom: 30px
  }
}

.h-history {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  color: #601986;
  font-size: 2.4rem;
  background: #fff;
  padding: 20px 0;
  width: 240px;
  text-align: center;
  position: relative
}

.h-history:before {
  content: "";
  display: block;
  background: #601986;
  left: 15px;
  right: -15px;
  bottom: -10px;
  top: 10px;
  position: absolute;
  z-index: -1
}

.h-history span {
  font-family: Bellefair, serif;
  font-weight: 400;
  letter-spacing: .1em;
  display: block;
  font-size: 1.5rem;
  position: relative
}

.h-history span:after {
  content: "";
  width: 30px;
  height: 1px;
  background: #601986;
  display: block;
  margin: 10px auto 5px
}

@media screen and (min-width:768px) {
  .h-history {
    width: 320px;
    padding: 35px;
    font-size: 3rem
  }
  .h-history:before {
    left: 20px;
    right: -20px
  }
  .h-history span {
    font-size: 2rem
  }
  .h-history span:after {
    width: 50px;
    margin-bottom: 10px
  }
}

.h-history--middle {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  color: #601986;
  text-align: center;
  font-size: 2rem;
  margin-bottom: 16px
}

@media screen and (min-width:768px) {
  .h-history--middle {
    text-align: left;
    font-size: 2.6rem;
    margin-bottom: 20px;
    max-width: 545px
  }
}

.h-information {
  color: #601986;
  font-size: 2rem
}

@media screen and (min-width:768px) {
  .h-information {
    font-size: 3rem;
    margin-bottom: 10px
  }
}

.h-shop {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  color: #601986;
  font-size: 2rem;
  text-align: center;
  margin-bottom: 10px
}

@media screen and (min-width:768px) {
  .h-shop {
    font-size: 3rem;
    text-align: left;
    margin-bottom: 20px
  }
}

.h-access {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  text-align: center;
  font-size: 2rem;
  margin: 20px 0 10px
}

@media screen and (min-width:768px) {
  .h-access {
    font-size: 2.6rem;
    margin: 30px 0 20px
  }
}

.h-access-small {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  color: #601986;
  text-align: center;
  font-size: 1.8rem;
  margin: 30px 0 10px
}

@media screen and (min-width:768px) {
  .h-access-small {
    font-size: 2.6rem;
    margin: 30px 0 20px
  }
}

.h-policy {
  font-size: 1.5rem;
  margin: 20px 0 5px;
  counter-increment: policy;
  position: relative;
  padding-left: 35px
}

.h-policy:before {
  position: absolute;
  left: -5px;
  content: "（" counter(policy) "）"
}

@media screen and (min-width:768px) {
  .h-policy {
    font-size: 1.8rem;
    margin-top: 30px
  }
  .h-policy:before {
    left: -10px
  }
}

.page-header {
  background: url("../img/common/bg-pale.webp");
  overflow: hidden;
  position: relative;
  z-index: -1
}

.page-header:after {
  content: "";
  background: url("../img/common/footer-bg.webp");
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 45%;
  z-index: -1;
  transform: rotate(25deg);
  transform-origin: left bottom
}

@media screen and (min-width:768px) {
  .page-header {
    object-fit: cover;
    max-height: 500px;
    min-height: 500px
  }
  .page-header img {
    width: 68%;
    min-height: 500px;
    min-width: 1090px;
    margin-left: auto;
    -webkit-mask-image: url("../img/common/mask.svg");
    mask-image: url("../img/common/mask.svg");
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: top right;
    mask-position: top right;
    -webkit-mask-size: 100%;
    mask-size: 100%;
    z-index: 3
  }
  .page-header:after {
    content: "";
    width: 1000px;
    height: 800px;
    left: 52%;
    transform: rotate(45deg);
    transform-origin: left top
  }
}

.page-header.buy {
  background: url("../img/buy/buy-bg.webp")
}

.page-header.buy:after {
  background: url("../img/buy/buy-bg2.webp")
}

@media screen and (min-width:768px) {
  .page-header.about {
    max-height: 300px;
    min-height: 300px
  }
  .page-header.about img {
    object-position: center left;
    object-fit: cover;
    max-height: 300px;
    min-height: 300px
  }
}

.page-hader-data {
  padding: 30px 16px 60px
}

@media screen and (min-width:768px) {
  .page-hader-data {
    padding: 0;
    width: 350px;
    position: absolute;
    left: calc(50% - 560px);
    top: 50%;
    transform: translateY(-50%)
  }
}

.h-pege-title--noimage {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  font-size: 2rem
}

.h-pege-title--noimage span {
  display: block;
  font-size: 1.3rem;
  margin-bottom: 2px
}

@media screen and (min-width:768px) {
  .h-pege-title--noimage {
    font-size: 3rem
  }
  .h-pege-title--noimage span {
    display: inline;
    font-size: 2rem;
    margin-bottom: 0
  }
}

.page-hader-txt {
  font-size: 1.2rem
}

@media screen and (min-width:768px) {
  .page-hader-txt {
    font-size: 1.4rem
  }
}

.page-header--noimage {
  background: url("../img/common/title-bg_sp.webp") no-repeat;
  background-size: cover;
  background-position: center center;
  padding-top: 25px;
  height: 125px;
  display: flex
}

.page-header--noimage.buy {
  background-image: url("../img/common/title-bg--buy_sp.webp")
}

@media screen and (min-width:768px) {
  .page-header--noimage {
    background: url("../img/common/title-bg.webp") no-repeat center center;
    background-size: auto;
    height: 180px;
    padding-top: 60px
  }
  .page-header--noimage.buy {
    background-image: url("../img/common/title-bg--buy.webp")
  }
}

@media screen and (min-width:768px) {
  .sidemenu-row {
    display: flex
  }
}

.sidemenu-item {
  padding: 0 16px
}

@media screen and (min-width:768px) {
  .sidemenu-item {
    display: block;
    flex: 0 0 280px;
    max-width: 280px;
    margin-right: 40px;
    padding: 0;
    order: 1
  }
}

.sidemenu {
  list-style-type: none;
  border: solid 1px #dddfde;
  border-bottom: none
}

@media screen and (min-width:768px) {
  .sidemenu {
    width: 280px
  }
}

.sidemenu--rental {
  border-top: none
}

.sidemenu-list:not(.title) a {
  font-size: 1.2rem;
  color: #3178b0;
  display: flex;
  align-items: center;
  height: 61px;
  position: relative;
  padding: 0 10px 0 76px;
  border-bottom: 1px solid #dddfde
}

@media screen and (max-width:320px) {
  .sidemenu-list:not(.title) a {
    padding-right: 5px
  }
}

.sidemenu-list:not(.title) span {
  width: 60px;
  height: 60px;
  display: block;
  position: absolute;
  top: 0;
  left: 0
}

.sidemenu-list:not(.title).menu-active {
  background: #ecebef
}

.sidemenu-list:not(.title).menu-active a {
  color: #222
}

@media screen and (min-width:768px) {
  .sidemenu-list:not(.title) a {
    font-size: 1.4rem;
    padding: 0 16px 0 76px
  }
}

.sidemenu-list a[href*=buy01] span {
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
  background-image: url("../img/buy/buy01.webp");
  background-size: 100%;
  background-repeat: no-repeat
}

.sidemenu-list a[href*=buy02] span {
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
  background-image: url("../img/buy/buy02.webp");
  background-size: 100%;
  background-repeat: no-repeat
}

.sidemenu-list a[href*=buy03] span {
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
  background-image: url("../img/buy/buy03.webp");
  background-size: 100%;
  background-repeat: no-repeat
}

.sidemenu-list a[href*=buy04] span {
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
  background-image: url("../img/buy/buy04.webp");
  background-size: 100%;
  background-repeat: no-repeat
}

.sidemenu-list a[href*=buy05] span {
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
  background-image: url("../img/buy/buy05.webp");
  background-size: 100%;
  background-repeat: no-repeat
}

.sidemenu-list a[href*=rental01] span {
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
  background-image: url("../img/rental/rental01.webp");
  background-size: 100%;
  background-repeat: no-repeat
}

.sidemenu-list a[href*=rental02] span {
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
  background-image: url("../img/rental/rental02.webp");
  background-size: 100%;
  background-repeat: no-repeat
}

.sidemenu-list a[href*=rental03] span {
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
  background-image: url("../img/rental/rental03.webp");
  background-size: 100%;
  background-repeat: no-repeat
}

.sidemenu-list a[href*=rental04] span {
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
  background-image: url("../img/rental/rental04.webp");
  background-size: 100%;
  background-repeat: no-repeat
}

.sidemenu-list a[href*=rental05] span {
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
  background-image: url("../img/rental/rental05.webp");
  background-size: 100%;
  background-repeat: no-repeat
}

.sidemenu-list a[href*=rental06] span {
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
  background-image: url("../img/rental/rental06.webp");
  background-size: 100%;
  background-repeat: no-repeat
}

.sidemenu-list.title a {
  display: block;
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  color: #fff;
  text-align: center;
  font-size: 1.8rem;
  line-height: 1.2;
  letter-spacing: 0;
  padding: 16px 20px;
  background: url("../img/index/pickup-bg.webp")
}

@media screen and (max-width:320px) {
  .sidemenu-list.title a {
    padding: 10px 5px;
    font-size: 1.7rem
  }
}

.sidemenu-list.buy {
  background-color: #928755
}

.sidemenu-list.rent {
  background-color: #844e85
}

.main-column {
  padding: 0 16px
}

@media screen and (min-width:768px) {
  .main-column {
    flex: 0 0 800px;
    max-width: 800px;
    padding: 0;
    order: 2
  }
}

.page-mv {
  margin: 0 -16px
}

.page-mv img {
  width: 100%;
  height: auto
}

@media screen and (min-width:768px) {
  .page-mv {
    margin: 0
  }
}

@media screen and (max-width:768px) {
  .sidemenu-item2 {
    display: block
  }
  .sidemenu-item2 .sidemenu {
    border: 1px solid #dddfde;
    border-bottom: none
  }
  .sidemenu-item2 .sidemenu-list:not(.title) a {
    height: 61px;
    padding-left: 76px
  }
  .sidemenu-item2 .sidemenu-list:not(.title) span {
    width: 60px;
    height: 60px
  }
}

.banner-center {
  margin: auto
}

.gallery, .slick-gallery {
  margin-top: 20px;
  position: relative;
  will-change: transform
}

@media screen and (min-width:768px) {
  .gallery, .slick-gallery {
    width: 600px;
    margin: 30px auto 0;
    cursor: pointer
  }
  .gallery.buy, .slick-gallery.buy {
    width: 700px
  }
}

.gallery-cap {
  text-align: center;
  font-size: 1.1rem
}

@media screen and (min-width:768px) {
  .gallery-cap {
    font-size: 1.2rem;
    margin: 5px 0 50px
  }
  .gallery-cap+p {
    margin-top: -30px;
    margin-bottom: 50px
  }
}

.slick-gallery-nav {
  padding: 10px 0
}

.slick-gallery-nav .slick-track {
  transform: unset!important;
  width: 210px!important
}

.slick-gallery-nav .slick-list {
  padding-top: 2px!important;
  padding-bottom: 2px!important
}

.slick-gallery-nav .slick-slide {
  width: 65px!important;
  margin: 0 2.5px
}

.slick-gallery-nav .slick-slide.slick-current {
  outline: 2px solid #222
}

@media screen and (min-width:768px) {
  .slick-gallery-nav .slick-track {
    width: 411px!important
  }
  .slick-gallery-nav .slick-slide {
    width: 126px!important;
    margin: 0 5px
  }
  .slick-gallery-nav .slick-slide img {
    transition: opacity .3s;
    width: 100%
  }
  .slick-gallery-nav .slick-slide:hover img {
    cursor: pointer
  }
}

.slick-gallery-nav.rental .slick-track {
  width: 165px!important
}

.slick-gallery-nav.rental .slick-slide {
  width: 50px!important
}

@media screen and (min-width:768px) {
  .slick-gallery-nav.rental .slick-track {
    width: 330px!important
  }
  .slick-gallery-nav.rental .slick-slide {
    width: 100px!important
  }
}

.slick-gallery-nav.rental04 .slick-track, .slick-gallery-nav.rental05 .slick-track {
  width: 120px!important
}

.slick-gallery-nav.rental04 .slick-slide, .slick-gallery-nav.rental05 .slick-slide {
  width: 55px!important
}

@media screen and (min-width:768px) {
  .slick-gallery-nav.rental04 .slick-track, .slick-gallery-nav.rental05 .slick-track {
    width: 240px!important
  }
  .slick-gallery-nav.rental04 .slick-slide, .slick-gallery-nav.rental05 .slick-slide {
    width: 110px!important
  }
}

.slick-gallery-nav.rental05 .slick-track {
  width: 180px!important
}

@media screen and (min-width:768px) {
  .slick-gallery-nav.rental05 .slick-track {
    width: 360px!important
  }
}

.slick-next, .slick-prev {
  text-indent: 100%;
  overflow: hidden;
  display: block;
  width: 36px;
  height: 36px;
  z-index: 2
}

@media screen and (min-width:768px) {
  .slick-next, .slick-prev {
    width: 50px;
    height: 50px;
    opacity: 0;
    transition: opacity .3s
  }
  .slick-gallery:hover .slick-next, .slick-gallery:hover .slick-prev {
    opacity: 1
  }
}

.slick-next {
  right: 0;
  background: url("../img/common/owl-next.webp")!important;
  background-size: 36px!important
}

@media screen and (min-width:768px) {
  .slick-next {
    background-size: 50px!important;
    right: -50px
  }
}

.slick-prev {
  left: 0;
  background: url("../img/common/owl-prev.webp")!important;
  background-size: 36px!important
}

@media screen and (min-width:768px) {
  .slick-prev {
    background-size: 50px!important;
    left: -50px
  }
}

.buy-rent-image {
  margin-top: 20px
}

@media screen and (min-width:768px) {
  .buy-rent-image {
    margin: 30px auto 0
  }
}

.rent-txt {
  text-align: center;
  margin-top: 10px;
  word-break: break-all
}

@media screen and (min-width:768px) {
  .rent-txt {
    margin-top: 16px;
    margin-bottom: 30px
  }
}

@media screen and (min-width:768px) {
  .set-cap {
    font-size: 1.4rem
  }
}

@media screen and (min-width:768px) {
  .desc-txt {
    text-align: center
  }
}

.flow-area {
  background: url("../img/flow/flow_bg.webp");
  background-size: 100%;
  padding: 20px 20px 10px;
  margin-top: 20px
}

@media screen and (min-width:768px) {
  .flow-area {
    padding: 40px;
    margin-top: 30px
  }
}

.flow-title {
  position: relative;
  background-size: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  height: calc((100vw - 72px)*.45);
  margin-bottom: 20px
}

.flow-title:before {
  content: "";
  display: block;
  background: url("../img/flow/flow_label.webp") no-repeat;
  background-size: 100%;
  filter: drop-shadow(2px 4px 2px rgba(0, 0, 0, .1));
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: -1
}

.flow-title p {
  text-align: center;
  font-size: 1.2rem
}

@media screen and (max-width:360px) {
  .flow-title p {
    font-size: 1.1rem
  }
}

@media screen and (min-width:768px) {
  .flow-title {
    height: 220px;
    margin: -40px -40px 30px
  }
  .flow-title:before {
    width: 400px;
    top: 40px;
    left: calc(50% - 200px)
  }
  .flow-title p {
    font-size: 1.4rem
  }
}

@media screen and (min-width:768px) {
  .flow-title.rental01 {
    background-image: url("../img/rental01/rental01_flow_bg.webp");
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: top left;
    z-index: -2
  }
}

@media screen and (min-width:768px) {
  .flow-title.rental02 {
    background-image: url("../img/rental02/rental02_flow_bg.webp");
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: top left;
    z-index: -2
  }
}

@media screen and (min-width:768px) {
  .flow-title.rental03 {
    background-image: url("../img/rental03/rental03_flow_bg.webp");
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: top left;
    z-index: -2
  }
}

@media screen and (min-width:768px) {
  .flow-title.rental04 {
    background-image: url("../img/rental04/rental04_flow_bg.webp");
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: top left;
    z-index: -2
  }
}

.h-flow-title {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  font-size: 3rem;
  text-align: center;
  color: #f35b2a;
  line-height: 1;
  margin-bottom: 10px
}

@media screen and (max-width:360px) {
  .h-flow-title {
    font-size: 8vmin
  }
}

.h-flow-title span {
  font-family: Bellefair, serif;
  font-weight: 400;
  letter-spacing: .1em;
  color: #ecb360;
  display: block;
  font-size: 1.5rem
}

@media screen and (min-width:768px) {
  .h-flow-title {
    font-size: 4rem;
    margin: 40px 0 10px
  }
  .h-flow-title span {
    font-size: 2rem
  }
}

@media screen and (min-width:768px) {
  .flow-row>div {
    display: flex
  }
}

.flow-item {
  background: #fff;
  box-shadow: 2px 4px 4px rgba(0, 0, 0, .1);
  padding: 20px 16px 25px;
  margin-bottom: 20px;
  position: relative
}

@media screen and (max-width:768px) {
  .flow-item:after {
    content: "";
    font-size: 0;
    border: 12.5px solid transparent;
    border-top-color: #ecb360;
    border-top-width: 12px;
    bottom: -24.5px;
    position: absolute;
    left: 50%;
    margin-left: -12.5px
  }
}

.flow-item.last:after {
  display: none
}

.flow-item img {
  width: auto;
  height: 186px;
  margin: 10px auto 13px
}

.flow-item p {
  font-size: 1.2rem
}

@media screen and (min-width:768px) {
  .flow-item {
    padding: 20px 20px 30px;
    flex: 0 0 100%
  }
  .flow-item:after {
    content: "";
    font-size: 0;
    border: 15px solid transparent;
    border-left-color: #ecb360;
    border-left-width: 16px;
    right: -31px;
    position: absolute;
    top: 50%;
    margin-top: -15px
  }
  .flow-item.last:after {
    display: none
  }
  .flow-item img {
    width: auto;
    height: 220px;
    margin: 16px auto 20px
  }
  .flow-item p {
    font-size: 1.4rem
  }
}

.h-flow {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  font-size: 2rem;
  position: relative;
  padding-left: 42px;
  height: 34px;
  align-items: center;
  display: flex
}

@media screen and (min-width:768px) {
  .h-flow {
    height: 40px;
    padding-left: 48px;
    font-size: 2.2rem
  }
}

.flow-no1:before {
  display: block;
  content: "";
  background: url("../img/flow/flow_no1.webp");
  background-size: 100%;
  width: 34px;
  height: 34px;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%)
}

@media screen and (min-width:768px) {
  .flow-no1:before {
    width: 40px;
    height: 40px
  }
}

.flow-no2:before {
  display: block;
  content: "";
  background: url("../img/flow/flow_no2.webp");
  background-size: 100%;
  width: 34px;
  height: 34px;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%)
}

@media screen and (min-width:768px) {
  .flow-no2:before {
    width: 40px;
    height: 40px
  }
}

.flow-no3:before {
  display: block;
  content: "";
  background: url("../img/flow/flow_no3.webp");
  background-size: 100%;
  width: 34px;
  height: 34px;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%)
}

@media screen and (min-width:768px) {
  .flow-no3:before {
    width: 40px;
    height: 40px
  }
}

.flow-no4:before {
  display: block;
  content: "";
  background: url("../img/flow/flow_no4.webp");
  background-size: 100%;
  width: 34px;
  height: 34px;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%)
}

@media screen and (min-width:768px) {
  .flow-no4:before {
    width: 40px;
    height: 40px
  }
}

.flow-no5:before {
  display: block;
  content: "";
  background: url("../img/flow/flow_no5.webp");
  background-size: 100%;
  width: 34px;
  height: 34px;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%)
}

@media screen and (min-width:768px) {
  .flow-no5:before {
    width: 40px;
    height: 40px
  }
}

.flow-no6:before {
  display: block;
  content: "";
  background: url("../img/flow/flow_no6.webp");
  background-size: 100%;
  width: 34px;
  height: 34px;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%)
}

@media screen and (min-width:768px) {
  .flow-no6:before {
    width: 40px;
    height: 40px
  }
}

.flow-no7:before {
  display: block;
  content: "";
  background: url("../img/flow/flow_no7.webp");
  background-size: 100%;
  width: 34px;
  height: 34px;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%)
}

@media screen and (min-width:768px) {
  .flow-no7:before {
    width: 40px;
    height: 40px
  }
}

@media screen and (min-width:768px) {
  .flow-2col {
    display: flex;
    align-items: center
  }
  .flow-2col img {
    flex: 0 0 220px;
    margin-left: 40px;
    margin-right: 40px
  }
}

.index-mv {
  width: 100%
}

.index-mv img {
  width: 100%
}

@media screen and (min-width:768px) {
  .index-mv {
    min-width: 1120px
  }
}

.index-pickup-item {
  overflow: hidden
}

@media screen and (max-width:768px) {
  .index-pickup-item {
    margin-top: 10px
  }
  .index-pickup-item:first-of-type {
    margin-top: 0
  }
}

.index-pickup-item img {
  width: 100%
}

.index-about {
  margin-top: 40px
}

@media screen and (min-width:768px) {
  .index-about {
    margin-top: 60px
  }
}

@media screen and (min-width:768px) {
  .index-about-row {
    min-width: 1120px
  }
}

@media screen and (min-width:768px) {
  .index-about-img {
    max-height: 500px;
    order: 2
  }
  .index-about-img img {
    object-fit: cover;
    object-position: center center;
    width: 100%;
    height: 100%
  }
}

.index-about-data {
  background: url("../img/common/bg-pale.webp");
  padding-bottom: 35px
}

.index-about-data>div {
  margin: 0 30px
}

@media screen and (max-width:320px) {
  .index-about-data>div {
    margin: 0 18px
  }
}

@media screen and (min-width:768px) {
  .index-about-data {
    background-image: url("../img/common/bg-pale.webp");
    background-repeat: repeat;
    background-size: auto;
    background-position: left top;
    padding: 100px 0;
    order: 2
  }
  .index-about-data>div {
    max-width: 560px;
    margin: 0 auto 0 0;
    padding-left: 80px
  }
}

.index-about-txt {
  margin-bottom: 20px
}

@media screen and (min-width:768px) {
  .index-about-txt {
    padding-right: 80px;
    margin-bottom: 40px
  }
}

.inex-lineup {
  margin-top: 40px
}

@media screen and (min-width:768px) {
  .inex-lineup {
    margin-top: 60px
  }
}

@media screen and (min-width:768px) {
  .index-lineup-row {
    max-width: 1600px;
    min-width: 1120px;
    margin: auto;
    max-height: 600px;
    min-height: 480px;
    height: calc(50vw*.75);
    position: relative
  }
}

.index-lineup-data {
  padding: 50px 30px 40px!important;
  background-image: url("../img/index/top_buy_pattern@2x.webp"), url("../img/index/lineup-bg--asa.webp"), url("../img/index/lineup-bg.webp");
  background-size: 100px, 50px, auto;
  background-repeat: no-repeat, repeat, repeat;
  background-position: right 16px top 10px, left top, left top;
  position: relative
}

@media screen and (max-width:768px) {
  .index-lineup-data {
    margin: -16px 16px 0;
    max-width: calc(100% - 32px)
  }
}

.index-lineup-data:after {
  content: "";
  display: block;
  position: absolute;
  background: url("../img/index/pickup-bg.webp") #d5ceb7;
  right: -16px;
  bottom: -16px;
  top: 16px;
  left: 16px;
  z-index: -1
}

@media screen and (min-width:768px) {
  .index-lineup-data {
    max-width: 740px!important;
    margin: 60px 0 0;
    padding: 80px!important;
    background-size: 140px, 75px, auto;
    background-position: right 110px top 20px, left top, left top;
    position: absolute;
    left: calc(50% - 40px);
    width: calc(50% + 40px)
  }
  .index-lineup-data:after {
    right: -9999px;
    bottom: -20px;
    top: 280px;
    left: 16px;
    z-index: -1
  }
}

@media screen and (min-width:768px) {
  .index-lineup-img img {
    object-fit: cover;
    object-position: center center;
    width: 100%;
    height: calc(50vw*.75);
    min-height: 420px;
    max-height: 600px;
    object-position: 50% 50%
  }
}

@media screen and (min-width:768px) {
  .index-lineup-txt {
    max-width: 510px
  }
}

.index-buy-item, .index-rent-item {
  overflow: hidden;
  margin:5%;
}

@media screen and (max-width:768px) {
  .index-buy-item, .index-rent-item {
    margin-top: 16px
  }
}

@media screen and (min-width:768px) {
  .index-rent-item {
    margin-top: 30px
  }
}

p.index-buy-txt, p.buy-txt {
  line-height: 1.5;
  font-weight: 400;
  margin-top: 10px;
  font-size: 1.2rem;
  padding: 0 3px
}

@media screen and (min-width:768px) {
  p.index-buy-txt, p.buy-txt {
    font-size: 1.4rem
  }
}

a.index-infomation-bnr {
  display: block;
  margin: 25px 0 0
}

@media screen and (min-width:768px) {
  a.index-infomation-bnr {
    margin: 50px 0 -10px
  }
}

.index-lineup-data.rent {
  background-image: url("../img/index/top_rental_pattern@2x.webp"), url("../img/index/rental-bg--asa.webp"), url("../img/index/rental-bg.webp")
}

.index-lineup-data.rent:after {
  z-index: -3;
  background-color: #d2cae8;
  right: 16px;
  left: -16px
}

@media screen and (min-width:768px) {
  .index-lineup-data.rent {
    min-width: 560px;
    order: 1;
    position: absolute;
    left: auto;
    right: calc(50% - 40px);
    margin-left: 50%
  }
  .index-lineup-data.rent:after {
    right: 0;
    left: -9999px
  }
}

@media print, screen and (min-width:768px) and (max-width:1120px) {
  .index-lineup-data.rent {
    padding: 75px 70px!important
  }
}

@media screen and (min-width:768px) {
  .index-lineup-img.rent {
    order: 1;
    z-index: -1;
    margin: 0;
    position: absolute;
    right: 0
  }
}

p.buy-txt {
  line-height: 1.7;
  font-size: 1.3rem
}

@media screen and (min-width:768px) {
  p.buy-txt {
    font-size: 1.4rem
  }
}

.buy-item, .rent-item {
  margin-top: 20px;
  overflow: hidden
}

@media screen and (min-width:768px) {
  .buy-item, .rent-item {
    margin-top: 0
  }
}

.rental-men-item {
  margin-top: 16px
}

@media screen and (min-width:768px) {
  .rental-men-item {
    margin-top: 20px
  }
}

@media screen and (max-width:768px) {
  .rent-03w-set {
    width: 75%;
    margin: 10px auto 0
  }
}

.set-item {
  background: url("../img/common/footer-bg.webp");
  padding: 10px;
  margin-top: 25px
}

.set-item.men {
  background: url("../img/rental01/set-m-bg.webp")
}

.set-item>div {
  background: #fff;
  padding: 16px
}

.set-item img {
  margin: 16px auto 0
}

@media screen and (min-width:768px) {
  .set-item {
    padding: 20px;
    margin-top: 50px
  }
  .set-item>div {
    padding: 30px
  }
  .set-item img {
    margin: 20px auto 0
  }
  .set-item.min {
    width: 550px;
    margin-left: auto;
    margin-right: auto
  }
}

.h-set {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  color: #601986;
  font-size: 1.8rem;
  text-align: center;
  margin-bottom: 10px
}
.news-article-area{
  width: 90%;
  margin: 1% auto 2% auto;
  padding: 1% 2%;
  text-align: left;
  box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.1);
}

@media screen and (min-width:768px) {
  .h-set {
    font-size: 2.6rem
  }
  .news-article-area{
    width: 60%;
    border: 2px solid #f5f5f5;
    margin: 1% auto 2% auto;
    padding: 2% 4%;
    text-align: left;
  }
}

.h-set02 {
  font-family: Noto Serif JP, serif;
  letter-spacing: .1em;
  color: #555;
  font-size: 1.4rem;
  margin-bottom: 10px;
  background-size: 6px 2px;
  background-image: linear-gradient(to right, #f1f1f1 3px, transparent 3px);
  background-repeat: repeat-x;
  background-position: left bottom;
  padding-bottom: 8px;
}
.h-set02 a:hover {
  color: #601986;
}

@media screen and (min-width:768px) {
  .h-set02 {
    font-size: 1.8rem;
    margin-bottom: 30px;
  }
}



.set-txt {
  font-size: 1.2rem;
  text-align: center
}

@media screen and (min-width:768px) {
  .set-txt {
    font-size: 1.4rem
  }
}

.set-txt-min {
  font-size: 1rem
}

@media screen and (min-width:768px) {
  .set-txt-min {
    font-size: 1.2rem
  }
}

.set-flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap
}

.set-flex .h-set {
  text-align: left
}

.set-flex>div {
  flex: 0 0 50%;
  display: flex;
  flex-direction: column;
  justify-content: center
}

.set-flex .set-txt {
  flex: 0 0 50%;
  text-align: left
}

.set-flex img {
  flex: 0 0 50%;
  flex-basis: calc(50% - 10px);
  margin: 0;
  max-width: calc(50% - 10px)
}

@media screen and (min-width:768px) {
  .set-flex {
    align-items: flex-start
  }
  .set-item .set-flex {
    padding: 40px
  }
  .set-flex .h-set {
    margin: 20px 0
  }
  .set-flex>div {
    flex: 0 0 auto;
    max-width: 405px
  }
  .set-flex img {
    flex-basis: auto
  }
}

.set-flex--buy04 img {
  width: 210px;
  margin: 10px auto 0
}

@media screen and (min-width:768px) {
  .set-flex--buy04 {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap
  }
  .set-flex--buy04 .h-set {
    text-align: left;
    margin: 20px 0
  }
  .set-flex--buy04 .set-txt {
    text-align: left
  }
  .set-item .set-flex--buy04 {
    padding: 40px
  }
  .set-flex--buy04 img {
    width: auto;
    margin: 0
  }
}

.about-image {
  margin: 20px -16px 40px
}

@media screen and (min-width:768px) {
  .about-image {
    width: 960px;
    margin: 50px auto 60px
  }
}

.history-title {
  background: url("../img/about/history-bg_sp.webp") no-repeat;
  background-size: cover;
  height: 100vw;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: -2
}

@media screen and (min-width:768px) {
  .history-title {
    background-image: url("../img/about/history-bg_pc.webp");
    height: 450px
  }
}

.history-txt {
  margin-bottom: 10px
}

@media screen and (min-width:768px) {
  .history-txt {
    max-width: 540px;
    margin-bottom: 10px
  }
}

.history-name {
  text-align: right;
  margin-top: 16px
}

@media screen and (min-width:768px) {
  .history-name {
    max-width: 530px;
    margin-top: 20px
  }
}

.history-cap {
  text-align: center;
  font-size: 1.2rem;
  margin-top: 10px
}

@media screen and (min-width:768px) {
  .history-cap {
    font-size: 1.4rem;
    margin-top: 8px
  }
}

.history-item {
  margin-top: 16px
}

@media screen and (max-width:768px) {
  .history-item:nth-of-type(1) {
    order: 1
  }
  .history-item:nth-of-type(2) {
    order: 3
  }
  .history-item:nth-of-type(3) {
    order: 4
  }
  .history-item:nth-of-type(4) {
    order: 2
  }
}

@media screen and (min-width:768px) {
  .history-item {
    margin-top: 40px
  }
  .history-item:nth-of-type(1) p, .history-item:nth-of-type(1) h3 {
    margin-left: auto
  }
}

.shop-info, .access {
  background: url("../img/common/bg-pale.webp");
  margin: 30px 0 0;
  padding: 1px 0 30px
}

.info-dl {
  position: relative
}

.info-dl dt {
  position: absolute;
  margin-bottom: 8px
}

.info-dl dt:before {
  content: "■";
  color: #dbd9e0;
  margin-right: 2px
}

.info-dl dd {
  padding-left: 7em;
  margin-bottom: 8px
}

@media screen and (min-width:768px) {
  .info-dl dt, .info-dl dd {
    margin-bottom: 16px
  }
}

.info-dl .txt-link {
  font-size: 1.4rem
}

.info-row {
  border-bottom: 1px dotted #c4c4c4;
  padding-bottom: 5px;
  margin-bottom: 16px
}

.info-row:last-of-type {
  margin-bottom: 0;
  border-bottom: none
}

@media screen and (min-width:768px) {
  .info-row {
    display: flex;
    justify-content: space-between;
    padding: 30px 10px;
    padding-right: 0
  }
}

.info-img {
  margin: 16px 0
}

@media screen and (min-width:768px) {
  .info-img {
    flex: 0 0 400px;
    max-width: 400px;
    margin: 0;
    align-self: flex-start
  }
}

@media screen and (max-width:768px) {
  .shop-mv {
    margin: 20px -16px 0;
    max-width: calc(100% + 32px)
  }
}

@media screen and (min-width:768px) {
  .shop-mv {
    margin-top: 30px
  }
}

.shop-row {
  margin-top: 20px
}

@media screen and (max-width:768px) {
  .shop-row img {
    width: 225px;
    margin: 25px auto 30px
  }
}

@media screen and (min-width:768px) {
  .shop-row {
    display: flex;
    justify-content: space-between;
    margin: 30px auto 60px
  }
  .shop-row img {
    flex: 0 0 450px;
    width: 450px
  }
}

.shop-address {
  text-align: center;
  margin-bottom: 20px
}

@media screen and (min-width:768px) {
  .shop-address {
    text-align: left
  }
}

.access-img {
  padding: 0 16px
}

.access-img img {
  margin-top: 16px
}

@media screen and (min-width:768px) {
  .access-img {
    padding: 0;
    display: flex;
    margin-top: 20px
  }
  .access-img img {
    flex: 0 0 50%
  }
}

@media screen and (min-width:768px) {
  .map {
    width: 700px;
    margin: auto
  }
}

.access-data {
  background: #fff;
  padding: 5px 16px 20px
}

.access-data h4 {
  color: #601986;
  font-size: 1.5rem;
  margin: 16px 0 5px
}

.access-data .parking {
  padding-left: 23px;
  position: relative
}

.access-data .parking:before {
  content: "P";
  color: #fff;
  background: #601986;
  padding: 0 6px;
  border-radius: 50%;
  font-size: .9em;
  position: absolute;
  left: 0
}

.access-data ul {
  list-style-type: none
}

.access-data li {
  position: relative;
  padding-left: 40px
}

.access-data li:before {
  content: "・";
  position: absolute;
  left: 23px
}

.access-data p {
  font-size: 1.2rem;
  line-height: 1.7
}

@media screen and (min-width:768px) {
  .access-data {
    width: 700px;
    margin: 40px auto 30px;
    padding: 10px 30px 30px
  }
  .access-data h4 {
    font-size: 1.8rem
  }
  .access-data .parking {
    padding-left: 28px
  }
  .access-data .parking:before {
    padding: 0 7px
  }
  .access-data li {
    padding-left: 45px
  }
  .access-data li:before {
    left: 28px
  }
  .access-data p {
    font-size: 1.4rem
  }
}

@media screen and (min-width:768px) {
  .p-list-row {
    display: flex;
    margin-top: 5px
  }
}

p.p-note {
  color: #666;
  font-size: 1rem;
  padding-left: 23px;
  margin-top: 3px
}

@media screen and (min-width:768px) {
  p.p-note {
    padding-left: 28px;
    margin-top: 5px;
    font-size: 1.2rem
  }
}

@media screen and (min-width:768px) {
  .access-data-flex {
    display: flex
  }
  .access-data-flex div {
    margin-right: 40px
  }
}

.policy-txt {
  padding-left: 35px
}

@media screen and (max-width:768px) {
  .u-vw65 {
    width: 65vw
  }
}

@media screen and (max-width:768px) {
  .u-vw80 {
    width: 80vw
  }
}

.u-space {
  width: 1em;
  display: inline-block
}

.u-lh15 {
  line-height: 1.5
}

.u-lh2 {
  line-height: 2
}

.u-center {
  display: table;
  margin-left: auto;
  margin-right: auto
}

.u-txt-c {
  text-align: center
}

.u-txt-r {
  text-align: right
}

.u-txt-l {
  text-align: left
}

.u-comments {
  position: relative;
  padding-left: 1.3em
}

.u-comments:before {
  content: "※";
  display: inline;
  position: absolute;
  left: 0
}

.u-fff {
  background-color: #fff
}

.u-bn {
  border: none
}

.u-ib {
  display: inline-block
}

.u-txt-em {
  color: red;
  line-height: 1.5!important
}

.u-red {
  color: red
}

.u-pr {
  position: relative
}

.em {
  font-style: normal;
  font-weight: 700
}

.u-txt-big {
  font-size: 1.5em!important
}

@media screen and (min-width:768px) {
  .u-txt-s {
    font-size: 1.4rem
  }
}

.u-lh15 {
  line-height: 1.5
}

.u-lh1 {
  line-height: 1
}

.u-must {
  color: red;
  font-weight: 700
}

.u-break {
  word-wrap: break-word
}

.u-radius10 {
  border-radius: 10px
}

.u-flex {
  display: flex
}

.u-fullw {
  width: 100%
}

.u-imgfull {
  max-width: 100%
}

.ip5only {
  display: none
}

@media screen and (max-width:320px) {
  .ip5only {
    display: inline
  }
}

.u-blankimg:after {
  display: none!important
}

@media screen and (max-width:1200px) {
  .outside-none {
    display: none
  }
}

@media screen and (max-width:768px) {
  .u-col-height {
    display: flex;
    flex-wrap: wrap
  }
  .sp-none {
    display: none
  }
  .u-mt0-sp {
    margin-top: 0!important
  }
  .u-mb0-sp {
    margin-bottom: 0!important
  }
  .u-ml0-sp {
    margin-left: 0!important
  }
  .u-mr0-sp {
    margin-right: 0!important
  }
  .u-pt0-sp {
    padding-top: 0!important
  }
  .u-pb0-sp {
    padding-bottom: 0!important
  }
  .u-pl0-sp {
    padding-left: 0!important
  }
  .u-pr0-sp {
    padding-right: 0!important
  }
  .u-mt5-sp {
    margin-top: 5px!important
  }
  .u-mb5-sp {
    margin-bottom: 5px!important
  }
  .u-ml5-sp {
    margin-left: 5px!important
  }
  .u-mr5-sp {
    margin-right: 5px!important
  }
  .u-pt5-sp {
    padding-top: 5px!important
  }
  .u-pb5-sp {
    padding-bottom: 5px!important
  }
  .u-pl5-sp {
    padding-left: 5px!important
  }
  .u-pr5-sp {
    padding-right: 5px!important
  }
  .u-mt10-sp {
    margin-top: 10px!important
  }
  .u-mb10-sp {
    margin-bottom: 10px!important
  }
  .u-ml10-sp {
    margin-left: 10px!important
  }
  .u-mr10-sp {
    margin-right: 10px!important
  }
  .u-pt10-sp {
    padding-top: 10px!important
  }
  .u-pb10-sp {
    padding-bottom: 10px!important
  }
  .u-pl10-sp {
    padding-left: 10px!important
  }
  .u-pr10-sp {
    padding-right: 10px!important
  }
  .u-mt15-sp {
    margin-top: 15px!important
  }
  .u-mb15-sp {
    margin-bottom: 15px!important
  }
  .u-ml15-sp {
    margin-left: 15px!important
  }
  .u-mr15-sp {
    margin-right: 15px!important
  }
  .u-pt15-sp {
    padding-top: 15px!important
  }
  .u-pb15-sp {
    padding-bottom: 15px!important
  }
  .u-pl15-sp {
    padding-left: 15px!important
  }
  .u-pr15-sp {
    padding-right: 15px!important
  }
  .u-mt20-sp {
    margin-top: 20px!important
  }
  .u-mb20-sp {
    margin-bottom: 20px!important
  }
  .u-ml20-sp {
    margin-left: 20px!important
  }
  .u-mr20-sp {
    margin-right: 20px!important
  }
  .u-pt20-sp {
    padding-top: 20px!important
  }
  .u-pb20-sp {
    padding-bottom: 20px!important
  }
  .u-pl20-sp {
    padding-left: 20px!important
  }
  .u-pr20-sp {
    padding-right: 20px!important
  }
  .u-mt25-sp {
    margin-top: 25px!important
  }
  .u-mb25-sp {
    margin-bottom: 25px!important
  }
  .u-ml25-sp {
    margin-left: 25px!important
  }
  .u-mr25-sp {
    margin-right: 25px!important
  }
  .u-pt25-sp {
    padding-top: 25px!important
  }
  .u-pb25-sp {
    padding-bottom: 25px!important
  }
  .u-pl25-sp {
    padding-left: 25px!important
  }
  .u-pr25-sp {
    padding-right: 25px!important
  }
  .u-mt30-sp {
    margin-top: 30px!important
  }
  .u-mb30-sp {
    margin-bottom: 30px!important
  }
  .u-ml30-sp {
    margin-left: 30px!important
  }
  .u-mr30-sp {
    margin-right: 30px!important
  }
  .u-pt30-sp {
    padding-top: 30px!important
  }
  .u-pb30-sp {
    padding-bottom: 30px!important
  }
  .u-pl30-sp {
    padding-left: 30px!important
  }
  .u-pr30-sp {
    padding-right: 30px!important
  }
  .u-mt35-sp {
    margin-top: 35px!important
  }
  .u-mb35-sp {
    margin-bottom: 35px!important
  }
  .u-ml35-sp {
    margin-left: 35px!important
  }
  .u-mr35-sp {
    margin-right: 35px!important
  }
  .u-pt35-sp {
    padding-top: 35px!important
  }
  .u-pb35-sp {
    padding-bottom: 35px!important
  }
  .u-pl35-sp {
    padding-left: 35px!important
  }
  .u-pr35-sp {
    padding-right: 35px!important
  }
  .u-mt40-sp {
    margin-top: 40px!important
  }
  .u-mb40-sp {
    margin-bottom: 40px!important
  }
  .u-ml40-sp {
    margin-left: 40px!important
  }
  .u-mr40-sp {
    margin-right: 40px!important
  }
  .u-pt40-sp {
    padding-top: 40px!important
  }
  .u-pb40-sp {
    padding-bottom: 40px!important
  }
  .u-pl40-sp {
    padding-left: 40px!important
  }
  .u-pr40-sp {
    padding-right: 40px!important
  }
  .u-mt45-sp {
    margin-top: 45px!important
  }
  .u-mb45-sp {
    margin-bottom: 45px!important
  }
  .u-ml45-sp {
    margin-left: 45px!important
  }
  .u-mr45-sp {
    margin-right: 45px!important
  }
  .u-pt45-sp {
    padding-top: 45px!important
  }
  .u-pb45-sp {
    padding-bottom: 45px!important
  }
  .u-pl45-sp {
    padding-left: 45px!important
  }
  .u-pr45-sp {
    padding-right: 45px!important
  }
  .u-mt50-sp {
    margin-top: 50px!important
  }
  .u-mb50-sp {
    margin-bottom: 50px!important
  }
  .u-ml50-sp {
    margin-left: 50px!important
  }
  .u-mr50-sp {
    margin-right: 50px!important
  }
  .u-pt50-sp {
    padding-top: 50px!important
  }
  .u-pb50-sp {
    padding-bottom: 50px!important
  }
  .u-pl50-sp {
    padding-left: 50px!important
  }
  .u-pr50-sp {
    padding-right: 50px!important
  }
  .u-mt55-sp {
    margin-top: 55px!important
  }
  .u-mb55-sp {
    margin-bottom: 55px!important
  }
  .u-ml55-sp {
    margin-left: 55px!important
  }
  .u-mr55-sp {
    margin-right: 55px!important
  }
  .u-pt55-sp {
    padding-top: 55px!important
  }
  .u-pb55-sp {
    padding-bottom: 55px!important
  }
  .u-pl55-sp {
    padding-left: 55px!important
  }
  .u-pr55-sp {
    padding-right: 55px!important
  }
  .u-mt60-sp {
    margin-top: 60px!important
  }
  .u-mb60-sp {
    margin-bottom: 60px!important
  }
  .u-ml60-sp {
    margin-left: 60px!important
  }
  .u-mr60-sp {
    margin-right: 60px!important
  }
  .u-pt60-sp {
    padding-top: 60px!important
  }
  .u-pb60-sp {
    padding-bottom: 60px!important
  }
  .u-pl60-sp {
    padding-left: 60px!important
  }
  .u-pr60-sp {
    padding-right: 60px!important
  }
  .u-mt65-sp {
    margin-top: 65px!important
  }
  .u-mb65-sp {
    margin-bottom: 65px!important
  }
  .u-ml65-sp {
    margin-left: 65px!important
  }
  .u-mr65-sp {
    margin-right: 65px!important
  }
  .u-pt65-sp {
    padding-top: 65px!important
  }
  .u-pb65-sp {
    padding-bottom: 65px!important
  }
  .u-pl65-sp {
    padding-left: 65px!important
  }
  .u-pr65-sp {
    padding-right: 65px!important
  }
  .u-mt70-sp {
    margin-top: 70px!important
  }
  .u-mb70-sp {
    margin-bottom: 70px!important
  }
  .u-ml70-sp {
    margin-left: 70px!important
  }
  .u-mr70-sp {
    margin-right: 70px!important
  }
  .u-pt70-sp {
    padding-top: 70px!important
  }
  .u-pb70-sp {
    padding-bottom: 70px!important
  }
  .u-pl70-sp {
    padding-left: 70px!important
  }
  .u-pr70-sp {
    padding-right: 70px!important
  }
  .u-mt75-sp {
    margin-top: 75px!important
  }
  .u-mb75-sp {
    margin-bottom: 75px!important
  }
  .u-ml75-sp {
    margin-left: 75px!important
  }
  .u-mr75-sp {
    margin-right: 75px!important
  }
  .u-pt75-sp {
    padding-top: 75px!important
  }
  .u-pb75-sp {
    padding-bottom: 75px!important
  }
  .u-pl75-sp {
    padding-left: 75px!important
  }
  .u-pr75-sp {
    padding-right: 75px!important
  }
  .u-mt80-sp {
    margin-top: 80px!important
  }
  .u-mb80-sp {
    margin-bottom: 80px!important
  }
  .u-ml80-sp {
    margin-left: 80px!important
  }
  .u-mr80-sp {
    margin-right: 80px!important
  }
  .u-pt80-sp {
    padding-top: 80px!important
  }
  .u-pb80-sp {
    padding-bottom: 80px!important
  }
  .u-pl80-sp {
    padding-left: 80px!important
  }
  .u-pr80-sp {
    padding-right: 80px!important
  }
  .u-mt85-sp {
    margin-top: 85px!important
  }
  .u-mb85-sp {
    margin-bottom: 85px!important
  }
  .u-ml85-sp {
    margin-left: 85px!important
  }
  .u-mr85-sp {
    margin-right: 85px!important
  }
  .u-pt85-sp {
    padding-top: 85px!important
  }
  .u-pb85-sp {
    padding-bottom: 85px!important
  }
  .u-pl85-sp {
    padding-left: 85px!important
  }
  .u-pr85-sp {
    padding-right: 85px!important
  }
  .u-mt90-sp {
    margin-top: 90px!important
  }
  .u-mb90-sp {
    margin-bottom: 90px!important
  }
  .u-ml90-sp {
    margin-left: 90px!important
  }
  .u-mr90-sp {
    margin-right: 90px!important
  }
  .u-pt90-sp {
    padding-top: 90px!important
  }
  .u-pb90-sp {
    padding-bottom: 90px!important
  }
  .u-pl90-sp {
    padding-left: 90px!important
  }
  .u-pr90-sp {
    padding-right: 90px!important
  }
  .u-mt95-sp {
    margin-top: 95px!important
  }
  .u-mb95-sp {
    margin-bottom: 95px!important
  }
  .u-ml95-sp {
    margin-left: 95px!important
  }
  .u-mr95-sp {
    margin-right: 95px!important
  }
  .u-pt95-sp {
    padding-top: 95px!important
  }
  .u-pb95-sp {
    padding-bottom: 95px!important
  }
  .u-pl95-sp {
    padding-left: 95px!important
  }
  .u-pr95-sp {
    padding-right: 95px!important
  }
  .u-mt100-sp {
    margin-top: 100px!important
  }
  .u-mb100-sp {
    margin-bottom: 100px!important
  }
  .u-ml100-sp {
    margin-left: 100px!important
  }
  .u-mr100-sp {
    margin-right: 100px!important
  }
  .u-pt100-sp {
    padding-top: 100px!important
  }
  .u-pb100-sp {
    padding-bottom: 100px!important
  }
  .u-pl100-sp {
    padding-left: 100px!important
  }
  .u-pr100-sp {
    padding-right: 100px!important
  }
}

@media screen and (min-width:768px) {
  .pc-none {
    display: none
  }
  .u-mt0 {
    margin-top: 0!important
  }
  .u-mb0 {
    margin-bottom: 0!important
  }
  .u-ml0 {
    margin-left: 0!important
  }
  .u-mr0 {
    margin-right: 0!important
  }
  .u-pt0 {
    padding-top: 0!important
  }
  .u-pb0 {
    padding-bottom: 0!important
  }
  .u-pl0 {
    padding-left: 0!important
  }
  .u-pr0 {
    padding-right: 0!important
  }
  .u-mt5 {
    margin-top: 5px!important
  }
  .u-mb5 {
    margin-bottom: 5px!important
  }
  .u-ml5 {
    margin-left: 5px!important
  }
  .u-mr5 {
    margin-right: 5px!important
  }
  .u-pt5 {
    padding-top: 5px!important
  }
  .u-pb5 {
    padding-bottom: 5px!important
  }
  .u-pl5 {
    padding-left: 5px!important
  }
  .u-pr5 {
    padding-right: 5px!important
  }
  .u-mt10 {
    margin-top: 10px!important
  }
  .u-mb10 {
    margin-bottom: 10px!important
  }
  .u-ml10 {
    margin-left: 10px!important
  }
  .u-mr10 {
    margin-right: 10px!important
  }
  .u-pt10 {
    padding-top: 10px!important
  }
  .u-pb10 {
    padding-bottom: 10px!important
  }
  .u-pl10 {
    padding-left: 10px!important
  }
  .u-pr10 {
    padding-right: 10px!important
  }
  .u-mt15 {
    margin-top: 15px!important
  }
  .u-mb15 {
    margin-bottom: 15px!important
  }
  .u-ml15 {
    margin-left: 15px!important
  }
  .u-mr15 {
    margin-right: 15px!important
  }
  .u-pt15 {
    padding-top: 15px!important
  }
  .u-pb15 {
    padding-bottom: 15px!important
  }
  .u-pl15 {
    padding-left: 15px!important
  }
  .u-pr15 {
    padding-right: 15px!important
  }
  .u-mt20 {
    margin-top: 20px!important
  }
  .u-mb20 {
    margin-bottom: 20px!important
  }
  .u-ml20 {
    margin-left: 20px!important
  }
  .u-mr20 {
    margin-right: 20px!important
  }
  .u-pt20 {
    padding-top: 20px!important
  }
  .u-pb20 {
    padding-bottom: 20px!important
  }
  .u-pl20 {
    padding-left: 20px!important
  }
  .u-pr20 {
    padding-right: 20px!important
  }
  .u-mt25 {
    margin-top: 25px!important
  }
  .u-mb25 {
    margin-bottom: 25px!important
  }
  .u-ml25 {
    margin-left: 25px!important
  }
  .u-mr25 {
    margin-right: 25px!important
  }
  .u-pt25 {
    padding-top: 25px!important
  }
  .u-pb25 {
    padding-bottom: 25px!important
  }
  .u-pl25 {
    padding-left: 25px!important
  }
  .u-pr25 {
    padding-right: 25px!important
  }
  .u-mt30 {
    margin-top: 30px!important
  }
  .u-mb30 {
    margin-bottom: 30px!important
  }
  .u-ml30 {
    margin-left: 30px!important
  }
  .u-mr30 {
    margin-right: 30px!important
  }
  .u-pt30 {
    padding-top: 30px!important
  }
  .u-pb30 {
    padding-bottom: 30px!important
  }
  .u-pl30 {
    padding-left: 30px!important
  }
  .u-pr30 {
    padding-right: 30px!important
  }
  .u-mt35 {
    margin-top: 35px!important
  }
  .u-mb35 {
    margin-bottom: 35px!important
  }
  .u-ml35 {
    margin-left: 35px!important
  }
  .u-mr35 {
    margin-right: 35px!important
  }
  .u-pt35 {
    padding-top: 35px!important
  }
  .u-pb35 {
    padding-bottom: 35px!important
  }
  .u-pl35 {
    padding-left: 35px!important
  }
  .u-pr35 {
    padding-right: 35px!important
  }
  .u-mt40 {
    margin-top: 40px!important
  }
  .u-mb40 {
    margin-bottom: 40px!important
  }
  .u-ml40 {
    margin-left: 40px!important
  }
  .u-mr40 {
    margin-right: 40px!important
  }
  .u-pt40 {
    padding-top: 40px!important
  }
  .u-pb40 {
    padding-bottom: 40px!important
  }
  .u-pl40 {
    padding-left: 40px!important
  }
  .u-pr40 {
    padding-right: 40px!important
  }
  .u-mt45 {
    margin-top: 45px!important
  }
  .u-mb45 {
    margin-bottom: 45px!important
  }
  .u-ml45 {
    margin-left: 45px!important
  }
  .u-mr45 {
    margin-right: 45px!important
  }
  .u-pt45 {
    padding-top: 45px!important
  }
  .u-pb45 {
    padding-bottom: 45px!important
  }
  .u-pl45 {
    padding-left: 45px!important
  }
  .u-pr45 {
    padding-right: 45px!important
  }
  .u-mt50 {
    margin-top: 50px!important
  }
  .u-mb50 {
    margin-bottom: 50px!important
  }
  .u-ml50 {
    margin-left: 50px!important
  }
  .u-mr50 {
    margin-right: 50px!important
  }
  .u-pt50 {
    padding-top: 50px!important
  }
  .u-pb50 {
    padding-bottom: 50px!important
  }
  .u-pl50 {
    padding-left: 50px!important
  }
  .u-pr50 {
    padding-right: 50px!important
  }
  .u-mt55 {
    margin-top: 55px!important
  }
  .u-mb55 {
    margin-bottom: 55px!important
  }
  .u-ml55 {
    margin-left: 55px!important
  }
  .u-mr55 {
    margin-right: 55px!important
  }
  .u-pt55 {
    padding-top: 55px!important
  }
  .u-pb55 {
    padding-bottom: 55px!important
  }
  .u-pl55 {
    padding-left: 55px!important
  }
  .u-pr55 {
    padding-right: 55px!important
  }
  .u-mt60 {
    margin-top: 60px!important
  }
  .u-mb60 {
    margin-bottom: 60px!important
  }
  .u-ml60 {
    margin-left: 60px!important
  }
  .u-mr60 {
    margin-right: 60px!important
  }
  .u-pt60 {
    padding-top: 60px!important
  }
  .u-pb60 {
    padding-bottom: 60px!important
  }
  .u-pl60 {
    padding-left: 60px!important
  }
  .u-pr60 {
    padding-right: 60px!important
  }
  .u-mt65 {
    margin-top: 65px!important
  }
  .u-mb65 {
    margin-bottom: 65px!important
  }
  .u-ml65 {
    margin-left: 65px!important
  }
  .u-mr65 {
    margin-right: 65px!important
  }
  .u-pt65 {
    padding-top: 65px!important
  }
  .u-pb65 {
    padding-bottom: 65px!important
  }
  .u-pl65 {
    padding-left: 65px!important
  }
  .u-pr65 {
    padding-right: 65px!important
  }
  .u-mt70 {
    margin-top: 70px!important
  }
  .u-mb70 {
    margin-bottom: 70px!important
  }
  .u-ml70 {
    margin-left: 70px!important
  }
  .u-mr70 {
    margin-right: 70px!important
  }
  .u-pt70 {
    padding-top: 70px!important
  }
  .u-pb70 {
    padding-bottom: 70px!important
  }
  .u-pl70 {
    padding-left: 70px!important
  }
  .u-pr70 {
    padding-right: 70px!important
  }
  .u-mt75 {
    margin-top: 75px!important
  }
  .u-mb75 {
    margin-bottom: 75px!important
  }
  .u-ml75 {
    margin-left: 75px!important
  }
  .u-mr75 {
    margin-right: 75px!important
  }
  .u-pt75 {
    padding-top: 75px!important
  }
  .u-pb75 {
    padding-bottom: 75px!important
  }
  .u-pl75 {
    padding-left: 75px!important
  }
  .u-pr75 {
    padding-right: 75px!important
  }
  .u-mt80 {
    margin-top: 80px!important
  }
  .u-mb80 {
    margin-bottom: 80px!important
  }
  .u-ml80 {
    margin-left: 80px!important
  }
  .u-mr80 {
    margin-right: 80px!important
  }
  .u-pt80 {
    padding-top: 80px!important
  }
  .u-pb80 {
    padding-bottom: 80px!important
  }
  .u-pl80 {
    padding-left: 80px!important
  }
  .u-pr80 {
    padding-right: 80px!important
  }
  .u-mt85 {
    margin-top: 85px!important
  }
  .u-mb85 {
    margin-bottom: 85px!important
  }
  .u-ml85 {
    margin-left: 85px!important
  }
  .u-mr85 {
    margin-right: 85px!important
  }
  .u-pt85 {
    padding-top: 85px!important
  }
  .u-pb85 {
    padding-bottom: 85px!important
  }
  .u-pl85 {
    padding-left: 85px!important
  }
  .u-pr85 {
    padding-right: 85px!important
  }
  .u-mt90 {
    margin-top: 90px!important
  }
  .u-mb90 {
    margin-bottom: 90px!important
  }
  .u-ml90 {
    margin-left: 90px!important
  }
  .u-mr90 {
    margin-right: 90px!important
  }
  .u-pt90 {
    padding-top: 90px!important
  }
  .u-pb90 {
    padding-bottom: 90px!important
  }
  .u-pl90 {
    padding-left: 90px!important
  }
  .u-pr90 {
    padding-right: 90px!important
  }
  .u-mt95 {
    margin-top: 95px!important
  }
  .u-mb95 {
    margin-bottom: 95px!important
  }
  .u-ml95 {
    margin-left: 95px!important
  }
  .u-mr95 {
    margin-right: 95px!important
  }
  .u-pt95 {
    padding-top: 95px!important
  }
  .u-pb95 {
    padding-bottom: 95px!important
  }
  .u-pl95 {
    padding-left: 95px!important
  }
  .u-pr95 {
    padding-right: 95px!important
  }
  .u-mt100 {
    margin-top: 100px!important
  }
  .u-mb100 {
    margin-bottom: 100px!important
  }
  .u-ml100 {
    margin-left: 100px!important
  }
  .u-mr100 {
    margin-right: 100px!important
  }
  .u-pt100 {
    padding-top: 100px!important
  }
  .u-pb100 {
    padding-bottom: 100px!important
  }
  .u-pl100 {
    padding-left: 100px!important
  }
  .u-pr100 {
    padding-right: 100px!important
  }
}

@media screen and (min-width:768px) {
  .anime-opa {
    transition: opacity .5s
  }
  .anime-opa:hover {
    opacity: .8
  }
  .anime-opaimg {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transition: opacity .5s cubic-bezier(0, 0, .1, 1)
  }
  .anime-opaimg img, .anime-opaimg video {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transition: opacity .5s cubic-bezier(0, 0, .1, 1), transform .5s cubic-bezier(0, 0, .1, 1)
  }
  .anime-opaimg:hover {
    opacity: .8!important
  }
  .anime-opaimg:hover img, .anime-opaimg:hover video {
    opacity: .8!important;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: scale(1.05)
  }
  .anime-img {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
  }
  .anime-img img, .anime-img video {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transition: transform .5s cubic-bezier(0, 0, .1, 1)
  }
  .anime-img:hover img, .anime-img:hover video {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: scale(1.05)
  }
  .js_opaimg {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    position: relative
  }
  .js_opaimg img, .js_opaimg video {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: scale(1.05)
  }
  .anime-ponpon {
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
  }
  .anime-ponpon:hover, .anime-ponpon:focus, .anime-ponpon:active {
    animation: anime-ponpon .85s ease-in-out 1
  }
}

@keyframes anime-ponpon {
  16.65% {
    transform: translateY(4px)
  }
  33.3% {
    transform: translateY(-3px)
  }
  49.95% {
    transform: translateY(1px)
  }
  66.6% {
    transform: translateY(-2px)
  }
  83.25% {
    transform: translateY(1px)
  }
  100% {
    transform: translateY(0)
  }
}

@keyframes anime-ponpon-scale {
  16.65% {
    transform: scale(1.02)
  }
  33.3% {
    transform: scale(.97)
  }
  49.95% {
    transform: scale(1.01)
  }
  66.6% {
    transform: scale(.99)
  }
  83.25% {
    transform: scale(1.01)
  }
  100% {
    transform: scale(1)
  }
}

@keyframes anime-hang {
  50% {
    transform: translateY(5px)
  }
  100% {
    transform: translateY(0)
  }
}

@keyframes fadeIn20 {
  0% {
    opacity: .2
  }
  100% {
    opacity: 1
  }
}

@keyframes fadeIn {
  0% {
    opacity: 0
  }
  100% {
    opacity: 1
  }
}

@keyframes fadeOut {
  0% {
    opacity: 1
  }
  100% {
    opacity: 0
  }
}

.anime-boundin {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
  will-change: animation;
  animation: boundIn .8s ease 1 forwards;
  opacity: 1;
  perspective: 1000
}

@keyframes boundIn {
  from, 20%, 40%, 60%, 80%, to {
    animation-timing-function: cubic-bezier(.215, .61, .355, 1)
  }
  0% {
    opacity: 0;
    transform: scale3d(.8, .8, .8) rotate(0deg)
  }
  20% {
    transform: scale3d(1.1, 1.1, 1.1)
  }
  40% {
    transform: scale3d(.95, .95, .95) rotate(0deg)
  }
  60% {
    opacity: 1;
    transform: scale3d(1.01, 1.01, 1.01)
  }
  80% {
    transform: scale3d(.99, .99, .99)
  }
  to {
    opacity: 1;
    transform: scale3d(1, 1, 1)
  }
}

@keyframes load5 {
  0%, 100% {
    box-shadow: 0 -2.6em 0 0 #601986, 1.8em -1.8em 0 0 rgba(64, 50, 118, .2), 2.5em 0 0 0 rgba(64, 50, 118, .2), 1.75em 1.75em 0 0 rgba(64, 50, 118, .2), 0 2.5em 0 0 rgba(64, 50, 118, .2), -1.8em 1.8em 0 0 rgba(64, 50, 118, .2), -2.6em 0 0 0 rgba(64, 50, 118, .5), -1.8em -1.8em 0 0 rgba(64, 50, 118, .7)
  }
  12.5% {
    box-shadow: 0 -2.6em 0 0 rgba(64, 50, 118, .7), 1.8em -1.8em 0 0 #601986, 2.5em 0 0 0 rgba(64, 50, 118, .2), 1.75em 1.75em 0 0 rgba(64, 50, 118, .2), 0 2.5em 0 0 rgba(64, 50, 118, .2), -1.8em 1.8em 0 0 rgba(64, 50, 118, .2), -2.6em 0 0 0 rgba(64, 50, 118, .2), -1.8em -1.8em 0 0 rgba(64, 50, 118, .5)
  }
  25% {
    box-shadow: 0 -2.6em 0 0 rgba(64, 50, 118, .5), 1.8em -1.8em 0 0 rgba(64, 50, 118, .7), 2.5em 0 0 0 #601986, 1.75em 1.75em 0 0 rgba(64, 50, 118, .2), 0 2.5em 0 0 rgba(64, 50, 118, .2), -1.8em 1.8em 0 0 rgba(64, 50, 118, .2), -2.6em 0 0 0 rgba(64, 50, 118, .2), -1.8em -1.8em 0 0 rgba(64, 50, 118, .2)
  }
  37.5% {
    box-shadow: 0 -2.6em 0 0 rgba(64, 50, 118, .2), 1.8em -1.8em 0 0 rgba(64, 50, 118, .5), 2.5em 0 0 0 rgba(64, 50, 118, .7), 1.75em 1.75em 0 0 #601986, 0 2.5em 0 0 rgba(64, 50, 118, .2), -1.8em 1.8em 0 0 rgba(64, 50, 118, .2), -2.6em 0 0 0 rgba(64, 50, 118, .2), -1.8em -1.8em 0 0 rgba(64, 50, 118, .2)
  }
  50% {
    box-shadow: 0 -2.6em 0 0 rgba(64, 50, 118, .2), 1.8em -1.8em 0 0 rgba(64, 50, 118, .2), 2.5em 0 0 0 rgba(64, 50, 118, .5), 1.75em 1.75em 0 0 rgba(64, 50, 118, .7), 0 2.5em 0 0 #601986, -1.8em 1.8em 0 0 rgba(64, 50, 118, .2), -2.6em 0 0 0 rgba(64, 50, 118, .2), -1.8em -1.8em 0 0 rgba(64, 50, 118, .2)
  }
  62.5% {
    box-shadow: 0 -2.6em 0 0 rgba(64, 50, 118, .2), 1.8em -1.8em 0 0 rgba(64, 50, 118, .2), 2.5em 0 0 0 rgba(64, 50, 118, .2), 1.75em 1.75em 0 0 rgba(64, 50, 118, .5), 0 2.5em 0 0 rgba(64, 50, 118, .7), -1.8em 1.8em 0 0 #601986, -2.6em 0 0 0 rgba(64, 50, 118, .2), -1.8em -1.8em 0 0 rgba(64, 50, 118, .2)
  }
  75% {
    box-shadow: 0 -2.6em 0 0 rgba(64, 50, 118, .2), 1.8em -1.8em 0 0 rgba(64, 50, 118, .2), 2.5em 0 0 0 rgba(64, 50, 118, .2), 1.75em 1.75em 0 0 rgba(64, 50, 118, .2), 0 2.5em 0 0 rgba(64, 50, 118, .5), -1.8em 1.8em 0 0 rgba(64, 50, 118, .7), -2.6em 0 0 0 #601986, -1.8em -1.8em 0 0 rgba(64, 50, 118, .2)
  }
  87.5% {
    box-shadow: 0 -2.6em 0 0 rgba(64, 50, 118, .2), 1.8em -1.8em 0 0 rgba(64, 50, 118, .2), 2.5em 0 0 0 rgba(64, 50, 118, .2), 1.75em 1.75em 0 0 rgba(64, 50, 118, .2), 0 2.5em 0 0 rgba(64, 50, 118, .2), -1.8em 1.8em 0 0 rgba(64, 50, 118, .5), -2.6em 0 0 0 rgba(64, 50, 118, .7), -1.8em -1.8em 0 0 #601986
  }
}

.js_hight {
  height: 100vh;
  overflow: hidden
}

.js_hide {
  display: none
}

.js_select {
  display: block
}

.js_fixed {
  overflow: hidden
}

.js_fixnav {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 9999;
  padding-top: 20px;
  padding-bottom: 10px
}

.js_print {
  display: none
}

.js_index-service-txt {
  color: #fff
}

.js_index-service-txt span {
  color: #fff
}

.js_index-service-txt span:after {
  background: #fff
}

.js_index-service-txt:after {
  transform: translateX(0)
}