@charset "UTF-8";
/* top layout */
/* 全体の設定
---------------------------------------------------------------------------*/
/* 基本設定
---------------------------------------------------------------------------*/
/* responsive */
/* サイズ */
/* flexbox */
/* フォント */
/* 色 */
/* グラデ背景色 */
/* 中央揃え */
/* objectfit */
/* ホバーアクション */
/* 角丸 */
/* ボタン */
/* ボタンの中のspan */
/* フォントサイズ */
/* padding margin */
/* 縦書き */
/* 内径 */
/* 文字 */
/* panel
---------------------------------------------------------------------------*/
@media screen and (max-width: 480px) {
  body.scroll .glnv.scroll_fadein,
  .glnv.scroll_fadein {
    opacity: 1 !important;
    visibility: visible !important; }

  .glnv {
    position: absolute;
    top: 100vh;
    top: calc(var(--vh, 1vh) * 100); } }
/* mv
---------------------------------------------------------------------------*/
.mv {
  position: relative;
  width: 100%;
  height: 100vh;
  height: calc(var(--vh, 1vh) * 100);
  overflow: hidden; }
  @media screen and (max-width: 480px) {
    .mv {
      margin-bottom: 77vw; } }
  .mv #topSlider {
    width: 100%;
    height: 100vh;
    height: calc(var(--vh, 1vh) * 100); }
    .mv #topSlider .swiper-slide {
      position: relative;
      width: 100%;
      height: 100%; }
      .mv #topSlider .swiper-slide img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
        font-family: "object-fit: cover; object-position: center;"; }
      .mv #topSlider .swiper-slide.zoomIn img {
        animation: zoomIn 14s linear; }
    .mv #topSlider video {
      object-fit: cover;
      object-position: center;
      width: 100%;
      height: 100vh;
      height: calc(var(--vh, 1vh) * 100);
      font-family: "object-fit: cover; object-position: center;"; }
  .mv-catch {
    position: absolute;
    z-index: 100;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 260px;
    z-index: 100;
    color: #ffffff; }
    @media screen and (max-width: 1500px) {
      .mv-catch {
        width: 17.3333333333vw; } }
    @media screen and (max-width: 480px) {
      .mv-catch {
        width: 29.3333333333vw;
        padding-top: 2em; } }
    .mv-catch h1, .mv-catch p {
      -webkit-writing-mode: vertical-rl;
      -moz-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
      -o-writing-mode: vertical-rl;
      writing-mode: vertical-rl;
      font-weight: 500;
      text-shadow: 0px 0px 2px rgba(0, 0, 0, 0.2), 0px 0px 2px rgba(0, 0, 0, 0.2), 0px 0px 4px rgba(0, 0, 0, 0.2), 0px 0px 4px rgba(0, 0, 0, 0.2), 0px 0px 6px rgba(0, 0, 0, 0.2), 0px 0px 6px rgba(0, 0, 0, 0.2), 0px 0px 8px rgba(0, 0, 0, 0.2), 0px 0px 8px rgba(0, 0, 0, 0.2); }
    .mv-catch h1 {
      font-size: 40px;
      width: 2em;
      margin-left: 0.5em; }
      @media screen and (max-width: 1500px) {
        .mv-catch h1 {
          font-size: 2.6666666667vw; } }
      @media screen and (max-width: 480px) {
        .mv-catch h1 {
          font-size: 9.3333333333vw; } }
      @media screen and (max-width: 480px) {
        .mv-catch h1 {
          font-size: 8vw; } }
    .mv-catch p {
      padding-top: 1em;
      width: auto;
      font-size: 26px; }
      @media screen and (max-width: 1500px) {
        .mv-catch p {
          font-size: 1.7333333333vw; } }
      @media screen and (max-width: 480px) {
        .mv-catch p {
          font-size: 6.0666666667vw; } }
      @media screen and (max-width: 480px) {
        .mv-catch p {
          font-size: 5.5vw; } }
  .mv-scrl {
    position: absolute;
    width: 26px;
    left: calc(50% + 574px);
    bottom: 37px;
    z-index: 100; }
    @media screen and (max-width: 1500px) {
      .mv-scrl {
        width: 1.7333333333vw;
        left: calc(50% + 44.15384vw);
        bottom: 2.4666666667vw; } }
    @media screen and (max-width: 480px) {
      .mv-scrl {
        width: 6.9333333333vw;
        left: auto;
        right: 5.3333333333vw;
        bottom: 5.3333333333vw; } }

.mv-bana {
    position: absolute;
    right: 40px;
    z-index: 100;
    width: 300px;
    bottom: 210px; }
    @media screen and (max-width: 1500px) {
      .mv-bana {
        right: 2.6666666667vw;
        width: 20vw;
        bottom: 14vw; } }
    @media screen and (max-width: 480px) {
      .mv-bana {
        right: auto;
        left: 5vw;
        width: 37vw;
        bottom: 5vw; } }

@keyframes zoomIn {
  0% {
    transform: scale(1); }
  100% {
    transform: scale(1.1); } }
/* tp-tomaru
---------------------------------------------------------------------------*/
.tp-tomaru {
  position: relative;
  width: 100%;
  height: 964px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../img/top/tp-tomaru.jpg); }
  @media screen and (max-width: 1500px) {
    .tp-tomaru {
      height: 64.2666666667vw; } }
  @media screen and (max-width: 480px) {
    .tp-tomaru {
      height: auto; } }
  .tp-tomaru-tx {
    position: absolute;
    width: 430px;
    top: 50%;
    transform: translateY(-50%);
    left: calc(50% - 695px); }
    @media screen and (max-width: 1500px) {
      .tp-tomaru-tx {
        width: 28.6666666667vw;
        left: calc(50% - 46.33vw); } }
    @media screen and (max-width: 480px) {
      .tp-tomaru-tx {
        position: relative;
        left: auto;
        top: auto;
        transform: translateY(0);
        width: 100%;
        padding: 16vw 5.3333333333vw; } }
  .tp-tomaru-catch {
    margin-bottom: 50px; }
    @media screen and (max-width: 1500px) {
      .tp-tomaru-catch {
        margin-bottom: 3.3333333333vw; } }
    @media screen and (max-width: 480px) {
      .tp-tomaru-catch {
        margin-bottom: 13.3333333333vw; } }
  .tp-tomaru-img {
    position: absolute;
    width: 1044px;
    left: calc(50% - 170px);
    top: 50%;
    transform: translateY(-50%); }
    @media screen and (max-width: 1500px) {
      .tp-tomaru-img {
        width: 69.6vw;
        left: calc(50% - 11.33vw); } }
    @media screen and (max-width: 480px) {
      .tp-tomaru-img {
        position: relative;
        left: auto;
        top: auto;
        transform: translateY(0);
        width: 100%; } }

/* tp-car
---------------------------------------------------------------------------*/
.tp-car .swiper-wrapper {
  transition-timing-function: linear; }
.tp-car .swiper-slide {
  width: 450px; }
  @media screen and (max-width: 1500px) {
    .tp-car .swiper-slide {
      width: 30vw; } }
  @media screen and (max-width: 480px) {
    .tp-car .swiper-slide {
      width: 60vw; } }

/* tp-rooms
---------------------------------------------------------------------------*/
.tp-rooms {
  padding: 60px 0 86px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../img/top/tp-rooms-bg.jpg); }
  @media screen and (max-width: 1500px) {
    .tp-rooms {
      padding: 4vw 0 5.7333333333vw; } }
  @media screen and (max-width: 480px) {
    .tp-rooms {
      padding: 16vw 0 22.9333333333vw; } }
  .tp-rooms-ttl {
    margin-bottom: 70px; }
    @media screen and (max-width: 1500px) {
      .tp-rooms-ttl {
        margin-bottom: 4.6666666667vw; } }
    @media screen and (max-width: 480px) {
      .tp-rooms-ttl {
        margin-bottom: 18.6666666667vw; } }
  .tp-rooms-img {
    position: relative;
    width: 100%;
    height: 550px;
    margin-bottom: 40px; }
    @media screen and (max-width: 1500px) {
      .tp-rooms-img {
        height: 36.6666666667vw;
        margin-bottom: 2.6666666667vw; } }
    @media screen and (max-width: 480px) {
      .tp-rooms-img {
        height: 47vw;
        margin-bottom: 10.6666666667vw; } }
    .tp-rooms-img > div {
      position: absolute;
      width: calc(50% + 722px);
      right: calc(50% - 722px);
      top: 0; }
      @media screen and (max-width: 1500px) {
        .tp-rooms-img > div {
          width: calc(50% + 55.53vw);
          right: calc(50% - 55.53vw); } }
      @media screen and (max-width: 480px) {
        .tp-rooms-img > div {
          width: 94vw;
          right: auto;
          left: 0; } }
    .tp-rooms-img img {
      width: 100%;
      height: 550px;
      object-fit: cover;
      object-position: right;
      font-family: "object-fit: cover; object-position: center;"; }
      @media screen and (max-width: 1500px) {
        .tp-rooms-img img {
          height: 36.6666666667vw; } }
      @media screen and (max-width: 480px) {
        .tp-rooms-img img {
          height: 47vw; } }
  .tp-rooms-tx {
    margin-bottom: 60px; }
    @media screen and (max-width: 1500px) {
      .tp-rooms-tx {
        margin-bottom: 4vw; } }
    @media screen and (max-width: 480px) {
      .tp-rooms-tx {
        margin-bottom: 16vw; } }
    .tp-rooms-tx .tx-hdl {
      letter-spacing: .12em; }
  .tp-rooms-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 1445px;
    margin: 0 auto 70px; }
    @media screen and (max-width: 1500px) {
      .tp-rooms-list {
        width: 100vw;
        margin-bottom: 4.6666666667vw; } }
    @media screen and (max-width: 480px) {
      .tp-rooms-list {
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        padding: 0 5.3333333333vw;
        margin-bottom: 18.6666666667vw; } }
    .tp-rooms-list li {
      width: 18.34%;
      margin-right: 2%; }
      @media screen and (max-width: 480px) {
        .tp-rooms-list li {
          width: 48%;
          margin-right: 0; } }
      .tp-rooms-list li:nth-of-type(5n), .tp-rooms-list li:last-of-type {
        margin-right: 0; }
      .tp-rooms-list li:nth-of-type(n + 6) {
        margin-top: 30px; }
        @media screen and (max-width: 1500px) {
          .tp-rooms-list li:nth-of-type(n + 6) {
            margin-top: 2vw; } }
        @media screen and (max-width: 480px) {
          .tp-rooms-list li:nth-of-type(n + 6) {
            margin-top: 8vw; } }
      @media screen and (max-width: 480px) {
        .tp-rooms-list li:nth-of-type(n + 3) {
          margin-top: 8vw; } }
      .tp-rooms-list li a {
        display: block;
        position: relative; }
    .tp-rooms-list-tx {
      position: absolute;
      left: 0;
      bottom: 0;
      width: 100%;
      height: 32px;
      z-index: 1;
      background-color: rgba(85, 22, 45, 0.9);
      line-height: 32px; }
      @media screen and (max-width: 1500px) {
        .tp-rooms-list-tx {
          height: 2.1333333333vw;
          line-height: 2.1333333333vw; } }
      @media screen and (max-width: 480px) {
        .tp-rooms-list-tx {
          height: 8.5333333333vw;
          line-height: 8.5333333333vw; } }
  .tp-rooms-btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; }

/* tp-dish
---------------------------------------------------------------------------*/
.tp-dish {
  padding: 60px 0 95px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../img/top/tp-dish-bg.jpg); }
  @media screen and (max-width: 1500px) {
    .tp-dish {
      padding: 4vw 0 6.3333333333vw; } }
  @media screen and (max-width: 480px) {
    .tp-dish {
      padding: 16vw 5.3333333333vw 25.3333333333vw; } }
  .tp-dish-ttl {
    margin-bottom: 70px; }
    @media screen and (max-width: 1500px) {
      .tp-dish-ttl {
        margin-bottom: 4.6666666667vw; } }
    @media screen and (max-width: 480px) {
      .tp-dish-ttl {
        margin-bottom: 18.6666666667vw; } }
  .tp-dish-body {
    position: relative;
    width: 100%;
    height: 1094px;
    margin-bottom: 87px; }
    @media screen and (max-width: 1500px) {
      .tp-dish-body {
        height: 72.9333333333vw;
        margin-bottom: 5.8vw; } }
    @media screen and (max-width: 480px) {
      .tp-dish-body {
        height: auto;
        margin-bottom: 21.3333333333vw; } }
    .tp-dish-body > * {
      position: absolute; }
      @media screen and (max-width: 480px) {
        .tp-dish-body > * {
          position: relative;
          top: auto !important;
          left: auto !important;
          right: auto !important; } }
    .tp-dish-body-tx {
      width: 454px;
      top: 122px;
      left: calc(50% + 40px); }
      @media screen and (max-width: 1500px) {
        .tp-dish-body-tx {
          width: 30.2666666667vw;
          top: 8.1333333333vw;
          left: calc(50% + 2.6vw); } }
      @media screen and (max-width: 480px) {
        .tp-dish-body-tx {
          width: 100%;
          text-align: center;
          margin-bottom: 10.6666666667vw; } }
    .tp-dish-body-img01 {
      width: 700px;
      top: 0;
      right: calc(50% + 199px); }
      @media screen and (max-width: 1500px) {
        .tp-dish-body-img01 {
          width: 46.6666666667vw;
          right: calc(50% + 13.26vw); } }
      @media screen and (max-width: 480px) {
        .tp-dish-body-img01 {
          display: none; } }
    .tp-dish-body-img02 {
      width: 421px;
      top: 412px;
      right: calc(50% + 122px); }
      @media screen and (max-width: 1500px) {
        .tp-dish-body-img02 {
          width: 28.0666666667vw;
          top: 27.4666666667vw;
          right: calc(50% + 8.1333vw); } }
      @media screen and (max-width: 480px) {
        .tp-dish-body-img02 {
          display: none; } }
    .tp-dish-body-img03 {
      width: 774px;
      top: 527px;
      left: 50%; }
      @media screen and (max-width: 1500px) {
        .tp-dish-body-img03 {
          width: 51.6vw;
          top: 35.1333333333vw; } }
      @media screen and (max-width: 480px) {
        .tp-dish-body-img03 {
          display: none; } }
    .tp-dish-body-btn {
      top: 974px;
      right: calc(50% + 227px); }
      @media screen and (max-width: 1500px) {
        .tp-dish-body-btn {
          top: 64.9333333333vw;
          right: calc(50% + 15.13vw); } }
      @media screen and (max-width: 480px) {
        .tp-dish-body-btn {
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-pack: center;
          -ms-flex-pack: center;
          justify-content: center; } }
  .tp-dish-sub {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    position: relative;
    width: 1472px;
    padding: 40px 50px;
    background-color: #1F1715;
    color: #ffffff;
    margin: 0 auto; }
    @media screen and (max-width: 1500px) {
      .tp-dish-sub {
        width: 98.1333333333vw;
        padding: 2.6666666667vw 3.3333333333vw; } }
    @media screen and (max-width: 480px) {
      .tp-dish-sub {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        width: 100vw;
        margin-left: -5.3333333333vw;
        padding: 10.6666666667vw 5.3333333333vw; } }
    .tp-dish-sub::after {
      position: absolute;
      content: "";
      width: calc(100% - 20px);
      height: calc(100% - 20px);
      border: 1px solid #ffffff;
      top: 50%;
      left: 50%;
      transform: translateX(-50%) translateY(-50%); }
      @media screen and (max-width: 1500px) {
        .tp-dish-sub::after {
          width: calc(100% - 1.3vw);
          height: calc(100% - 1.3vw); } }
    .tp-dish-sub-imgs {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: justify;
      -ms-flex-pack: justify;
      justify-content: space-between;
      width: 60.3%; }
      @media screen and (max-width: 480px) {
        .tp-dish-sub-imgs {
          width: 100%;
          margin-bottom: 16vw; } }
      .tp-dish-sub-imgs li {
        width: 48.8%; }
    .tp-dish-sub-tx {
      width: 35.27%; }
      @media screen and (max-width: 480px) {
        .tp-dish-sub-tx {
          width: 100%; } }
      .tp-dish-sub-tx-btn {
        margin-top: 34px; }
        @media screen and (max-width: 1500px) {
          .tp-dish-sub-tx-btn {
            margin-top: 2.2666666667vw; } }
        @media screen and (max-width: 480px) {
          .tp-dish-sub-tx-btn {
            display: -webkit-box;
            display: -ms-flexbox;
            display: flex;
            -webkit-box-pack: center;
            -ms-flex-pack: center;
            justify-content: center;
            margin-top: 13.3333333333vw; } }
  @media screen and (max-width: 480px) {
    .tp-dish-car {
      width: 80vw;
      margin-left: auto;
      margin-right: auto;
      margin-bottom: 10.6666666667vw; }
      .tp-dish-car .swiper-wrapper {
        transition-timing-function: linear; }
      .tp-dish-car .swiper-slide {
        width: 60vw; }
        .tp-dish-car .swiper-slide img {
          width: 100%;
          height: 40vw;
          object-fit: cover;
          object-position: center;
          font-family: "object-fit: cover; object-position: center;"; } }

/* tp-fun
---------------------------------------------------------------------------*/
.tp-fun {
  position: relative;
  padding: 168px 0 130px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../img/top/tp-fun-bg.jpg);
  color: #ffffff;
  margin-top: 120px; }
  @media screen and (max-width: 1500px) {
    .tp-fun {
      padding: 11.2vw 0 8.6666666667vw;
      margin-top: 8vw; } }
  @media screen and (max-width: 480px) {
    .tp-fun {
      padding: 16vw 5.3333333333vw 25.3333333333vw;
      margin-bottom: 16vw; } }
  .tp-fun-ttl {
    position: absolute;
    left: calc(50% - 775px);
    top: 80px;
    width: 2em;
    font-size: 55px;
    letter-spacing: .2em; }
    @media screen and (max-width: 1500px) {
      .tp-fun-ttl {
        font-size: 3.6666666667vw; } }
    @media screen and (max-width: 480px) {
      .tp-fun-ttl {
        font-size: 12.8333333333vw; } }
    @media screen and (max-width: 480px) {
      .tp-fun-ttl {
        position: relative;
        left: auto;
        top: auto;
        width: 100%;
        margin-bottom: 13.3333333333vw; } }
    .tp-fun-ttl span {
      -webkit-writing-mode: vertical-rl;
      -moz-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
      -o-writing-mode: vertical-rl;
      writing-mode: vertical-rl; }
      @media screen and (max-width: 480px) {
        .tp-fun-ttl span {
          -webkit-writing-mode: initial;
          -moz-writing-mode: initial;
          -ms-writing-mode: initial;
          -o-writing-mode: initial;
          writing-mode: initial; } }
  .tp-fun-body {
    width: 1200px;
    margin: 0 auto; }
    @media screen and (max-width: 1500px) {
      .tp-fun-body {
        width: 80vw; } }
    @media screen and (max-width: 480px) {
      .tp-fun-body {
        width: 100%; } }
    .tp-fun-body-tx {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: justify;
      -ms-flex-pack: justify;
      justify-content: space-between;
      margin-bottom: 238px; }
      @media screen and (max-width: 1500px) {
        .tp-fun-body-tx {
          margin-bottom: 15.8666666667vw; } }
      @media screen and (max-width: 480px) {
        .tp-fun-body-tx {
          margin-bottom: 16vw; } }
      @media screen and (max-width: 480px) {
        .tp-fun-body-tx {
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
          -ms-flex-direction: column;
          flex-direction: column; } }
      .tp-fun-body-tx-btn {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-align-items: flex-end;
        align-items: flex-end; }
        @media screen and (max-width: 480px) {
          .tp-fun-body-tx-btn {
            -webkit-box-align: start;
            -ms-flex-align: start;
            align-items: flex-start;
            -webkit-box-pack: center;
            -ms-flex-pack: center;
            justify-content: center; } }
    .tp-fun-body-imgs {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: justify;
      -ms-flex-pack: justify;
      justify-content: space-between; }
      @media screen and (max-width: 480px) {
        .tp-fun-body-imgs {
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
          -ms-flex-direction: column;
          flex-direction: column;
          margin-bottom: 16vw; } }
      .tp-fun-body-imgs li {
        width: 345px; }
        @media screen and (max-width: 1500px) {
          .tp-fun-body-imgs li {
            width: 23vw; } }
        @media screen and (max-width: 480px) {
          .tp-fun-body-imgs li {
            width: 100%; }
            .tp-fun-body-imgs li + li {
              margin-top: 10.6666666667vw; } }
        .tp-fun-body-imgs li a {
          display: block;
          position: relative; }
          .tp-fun-body-imgs li a::before {
            position: absolute;
            content: "";
            width: 100%;
            height: 100%;
            right: 10px;
            top: 10px;
            background-color: #55162D; }
            @media screen and (max-width: 1500px) {
              .tp-fun-body-imgs li a::before {
                right: 0.6666666667vw;
                top: 0.6666666667vw; } }
            @media screen and (max-width: 480px) {
              .tp-fun-body-imgs li a::before {
                right: 2.6666666667vw;
                top: 2.6666666667vw; } }
      .tp-fun-body-imgs-img {
        position: relative;
        z-index: 10; }
      .tp-fun-body-imgs-tx {
        position: absolute;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        width: 214px;
        height: 40px;
        z-index: 12;
        background-color: #ffffff;
        color: #55162D;
        right: 0;
        bottom: 0; }
        @media screen and (max-width: 1500px) {
          .tp-fun-body-imgs-tx {
            width: 14.2666666667vw;
            height: 2.6666666667vw; } }
        @media screen and (max-width: 480px) {
          .tp-fun-body-imgs-tx {
            width: 57.0666666667vw;
            height: 10.6666666667vw; } }
        .tp-fun-body-imgs-tx span {
          display: block;
          width: 100%;
          white-space: nowrap;
          text-align: center;
          font-size: 15px;
          letter-spacing: .15em; }
          @media screen and (max-width: 1500px) {
            .tp-fun-body-imgs-tx span {
              font-size: 1vw; } }
          @media screen and (max-width: 480px) {
            .tp-fun-body-imgs-tx span {
              font-size: 3.5vw; } }
        .tp-fun-body-imgs-tx::before {
          position: absolute;
          content: "";
          width: 8px;
          height: 14px;
          background-repeat: no-repeat;
          background-position: center;
          background-size: contain;
          background-image: url(../img/top/tp-fun-arw.png);
          top: 50%;
          transform: translateY(-50%);
          right: 10px; }
          @media screen and (max-width: 1500px) {
            .tp-fun-body-imgs-tx::before {
              width: 0.5333333333vw;
              height: 0.9333333333vw;
              right: 0.6666666667vw; } }
          @media screen and (max-width: 480px) {
            .tp-fun-body-imgs-tx::before {
              width: 2.1333333333vw;
              height: 3.7333333333vw;
              right: 1.3333333333vw; } }

/* tp-sightseeing
---------------------------------------------------------------------------*/
.tp-sightseeing {
  position: relative;
  padding: 120px 0 80px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../img/top/tp-sightseeing-bg.png);
  color: #ffffff;
  height: 674px; }
  @media screen and (max-width: 1500px) {
    .tp-sightseeing {
      padding: 8vw 0 5.3333333333vw;
      height: 44.9333333333vw; } }
  @media screen and (max-width: 480px) {
    .tp-sightseeing {
      padding: 16vw 5.3333333333vw;
      height: auto;
      background-size: 230vw auto;
      background-position: center top; } }
  .tp-sightseeing-body {
    width: 1200px;
    margin: 0 auto; }
    @media screen and (max-width: 1500px) {
      .tp-sightseeing-body {
        width: 80vw; } }
    @media screen and (max-width: 480px) {
      .tp-sightseeing-body {
        width: 100%;
        margin-bottom: 16vw; } }
    .tp-sightseeing-body-tx-ttl {
      margin-bottom: 170px; }
      @media screen and (max-width: 1500px) {
        .tp-sightseeing-body-tx-ttl {
          margin-bottom: 11.3333333333vw; } }
      @media screen and (max-width: 480px) {
        .tp-sightseeing-body-tx-ttl {
          margin-bottom: 16vw; } }
    .tp-sightseeing-body-tx-btn {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: end;
      -ms-flex-pack: end;
      justify-content: flex-end; }
      @media screen and (max-width: 480px) {
        .tp-sightseeing-body-tx-btn {
          -webkit-box-pack: center;
          -ms-flex-pack: center;
          justify-content: center; } }
  @media screen and (min-width: 481px) {
    .tp-sightseeing .lay-ttl {
      text-align: right;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-align-items: flex-end;
      align-items: flex-end;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      -ms-flex-direction: column;
      flex-direction: column; } }
  .tp-sightseeing .lay-ttl .lay-ttl-hd {
    color: #ffffff; }
    .tp-sightseeing .lay-ttl .lay-ttl-hd::after {
      background-image: url(../img/cmn/lay-ttl-icn-white.png); }
    @media screen and (min-width: 481px) {
      .tp-sightseeing .lay-ttl .lay-ttl-hd {
        padding-left: 38px;
        padding-bottom: 0; } }
  @media screen and (min-width: 481px) and (max-width: 1500px) {
    .tp-sightseeing .lay-ttl .lay-ttl-hd {
      padding-left: 2.5333333333vw; } }
    @media screen and (min-width: 481px) {
        .tp-sightseeing .lay-ttl .lay-ttl-hd::after {
          top: 50%;
          transform: translateY(-50%);
          left: 0; } }
  .tp-sightseeing-imgs {
    position: absolute;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 1126px;
    right: calc(50% - 406px);
    bottom: -145px;
    z-index: 10; }
    @media screen and (max-width: 1500px) {
      .tp-sightseeing-imgs {
        width: 75.0666666667vw;
        right: calc(50% - 27.06vw);
        bottom: -9.6666666667vw; } }
    @media screen and (max-width: 480px) {
      .tp-sightseeing-imgs {
        position: relative;
        width: 100%;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        right: auto;
        bottom: auto;
        margin-bottom: 16vw; } }
    .tp-sightseeing-imgs li {
      width: 345px; }
      @media screen and (max-width: 1500px) {
        .tp-sightseeing-imgs li {
          width: 23vw; } }
      @media screen and (max-width: 480px) {
        .tp-sightseeing-imgs li {
          width: 100%; }
          .tp-sightseeing-imgs li + li {
            margin-top: 10.6666666667vw; } }
    .tp-sightseeing-imgs-img {
      position: relative;
      z-index: 10;
      margin-bottom: 20px; }
      @media screen and (max-width: 1500px) {
        .tp-sightseeing-imgs-img {
          margin-bottom: 1.3333333333vw; } }
      @media screen and (max-width: 480px) {
        .tp-sightseeing-imgs-img {
          margin-bottom: 5.3333333333vw; } }
      .tp-sightseeing-imgs-img::before {
        position: absolute;
        content: "";
        width: 100%;
        height: 100%;
        right: 10px;
        top: 10px;
        background-color: rgba(85, 22, 45, 0.5);
        z-index: -1; }
        @media screen and (max-width: 1500px) {
          .tp-sightseeing-imgs-img::before {
            right: 0.6666666667vw;
            top: 0.6666666667vw; } }
        @media screen and (max-width: 480px) {
          .tp-sightseeing-imgs-img::before {
            right: 2.6666666667vw;
            top: 2.6666666667vw; } }
    .tp-sightseeing-imgs-tx {
      color: #333333;
      text-align: center;
      letter-spacing: .15em; }
      .tp-sightseeing-imgs-tx-name {
        font-size: 15px;
        border-bottom: 1px solid #AAAAAA;
        padding-bottom: 8px;
        margin-bottom: 8px; }
        @media screen and (max-width: 1500px) {
          .tp-sightseeing-imgs-tx-name {
            font-size: 1vw; } }
        @media screen and (max-width: 480px) {
          .tp-sightseeing-imgs-tx-name {
            font-size: 3.5vw; } }
        @media screen and (max-width: 1500px) {
          .tp-sightseeing-imgs-tx-name {
            padding-bottom: 0.5333333333vw;
            margin-bottom: 0.5333333333vw; } }
        @media screen and (max-width: 480px) {
          .tp-sightseeing-imgs-tx-name {
            padding-bottom: 2.1333333333vw;
            margin-bottom: 2.1333333333vw; } }
      .tp-sightseeing-imgs-tx-time {
        font-size: 13px; }
        @media screen and (max-width: 1500px) {
          .tp-sightseeing-imgs-tx-time {
            font-size: 0.8666666667vw; } }
        @media screen and (max-width: 480px) {
          .tp-sightseeing-imgs-tx-time {
            font-size: 3.0333333333vw; } }

/* tp-access
---------------------------------------------------------------------------*/
.access2news-bg {
  position: relative;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../img/top/access2news-bg.jpg); }

.tp-access {
  position: relative;
  padding-top: 236px; }
  @media screen and (max-width: 1500px) {
    .tp-access {
      padding-top: 15.7333333333vw; } }
  @media screen and (max-width: 480px) {
    .tp-access {
      padding-top: 16vw; } }
  .tp-access-map {
    margin-top: 65px; }
    @media screen and (max-width: 1500px) {
      .tp-access-map {
        margin-top: 4.3333333333vw; } }
    @media screen and (max-width: 480px) {
      .tp-access-map {
        margin-top: 16vw; } }
    .tp-access-map img {
      width: 100%;
      max-width: 1920px;
      margin: 0 auto; }
  .tp-access-btn {
    position: absolute;
    width: 1200px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    bottom: 42px;
    left: 50%;
    transform: translateX(-50%); }
    @media screen and (max-width: 1500px) {
      .tp-access-btn {
        width: 80vw; } }
    @media screen and (max-width: 480px) {
      .tp-access-btn {
        position: relative;
        width: 100%;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        margin-top: 16vw;
        left: auto;
        bottom: auto;
        transform: translateX(0); } }

/* tp-news
---------------------------------------------------------------------------*/
.tp-news {
  position: relative;
  padding-top: 120px;
  padding-bottom: 120px; }
  @media screen and (max-width: 1500px) {
    .tp-news {
      padding-top: 8vw;
      padding-bottom: 8vw; } }
  @media screen and (max-width: 480px) {
    .tp-news {
      padding-top: 16vw;
      padding-bottom: 16vw; } }
  .tp-news-ttl {
    margin-bottom: 50px; }
    @media screen and (max-width: 1500px) {
      .tp-news-ttl {
        margin-bottom: 3.3333333333vw; } }
    @media screen and (max-width: 480px) {
      .tp-news-ttl {
        margin-bottom: 13.3333333333vw; } }
  .tp-news-body {
    width: 1200px;
    margin: 0 auto 80px; }
    @media screen and (max-width: 1500px) {
      .tp-news-body {
        width: 80vw;
        margin-bottom: 5.3333333333vw; } }
    @media screen and (max-width: 480px) {
      .tp-news-body {
        width: 100%;
        margin-bottom: 16vw; } }
    .tp-news-body ul {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex; }
      @media screen and (max-width: 480px) {
        .tp-news-body ul {
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
          -ms-flex-direction: column;
          flex-direction: column;
          padding-left: 5.3333333333vw;
          padding-right: 5.3333333333vw; } }
      .tp-news-body ul li {
        width: 264px;
        margin-right: 48px; }
        @media screen and (max-width: 1500px) {
          .tp-news-body ul li {
            width: 17.6vw;
            margin-right: 3.2vw; } }
        @media screen and (max-width: 480px) {
          .tp-news-body ul li {
            width: 100%;
            margin-right: 0; }
            .tp-news-body ul li + li {
              margin-top: 10.6666666667vw; } }
        .tp-news-body ul li:nth-of-type(4n), .tp-news-body ul li:last-of-type {
          margin-right: 0; }
    .tp-news-body-img {
      margin-bottom: 10px; }
      @media screen and (max-width: 1500px) {
        .tp-news-body-img {
          margin-bottom: 0.6666666667vw; } }
      @media screen and (max-width: 480px) {
        .tp-news-body-img {
          margin-bottom: 2.6666666667vw; } }
      .tp-news-body-img img {
        width: 100%;
        height: 197px;
        object-fit: cover;
        object-position: center;
        font-family: "object-fit: cover; object-position: center;"; }
        @media screen and (max-width: 1500px) {
          .tp-news-body-img img {
            height: 13.1333333333vw; } }
        @media screen and (max-width: 480px) {
          .tp-news-body-img img {
            height: 50vw; } }
    .tp-news-body-tx {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      -webkit-box-pack: justify;
      -ms-flex-pack: justify;
      justify-content: space-between; }
      .tp-news-body-tx-ttl {
        width: 100%;
        font-size: 15px;
        letter-spacing: .13em;
        border-bottom: 1px solid rgba(119, 119, 119, 0.5);
        padding-bottom: 8px;
        margin-bottom: 8px; }
        @media screen and (max-width: 1500px) {
          .tp-news-body-tx-ttl {
            font-size: 1vw; } }
        @media screen and (max-width: 480px) {
          .tp-news-body-tx-ttl {
            font-size: 3.5vw; } }
        @media screen and (max-width: 1500px) {
          .tp-news-body-tx-ttl {
            padding-bottom: 0.5333333333vw;
            margin-bottom: 0.5333333333vw; } }
        @media screen and (max-width: 480px) {
          .tp-news-body-tx-ttl {
            padding-bottom: 2.1333333333vw;
            margin-bottom: 2.1333333333vw; } }
      .tp-news-body-tx-cat {
        width: 90px;
        height: 15px;
        line-height: 15px;
        background-color: #55162D;
        font-size: 9px;
        /* regular: 400 */
        font-family: "Noto Sans JP", sans-serif;
        font-weight: 400;
        font-style: normal;
        color: #ffffff;
        letter-spacing: .011em; }
        @media screen and (max-width: 1500px) {
          .tp-news-body-tx-cat {
            font-size: 0.6vw; } }
        @media screen and (max-width: 480px) {
          .tp-news-body-tx-cat {
            font-size: 2.1vw; } }
        @media screen and (max-width: 1500px) {
          .tp-news-body-tx-cat {
            width: 6vw;
            height: 1vw;
            line-height: 1vw; } }
        @media screen and (max-width: 480px) {
          .tp-news-body-tx-cat {
            width: 24vw;
            height: 4vw;
            line-height: 4vw; } }
        .tp-news-body-tx-cat span {
          display: block;
          width: 100%;
          white-space: nowrap;
          text-align: center; }
      .tp-news-body-tx-date {
        line-height: 15px;
        font-size: 9px;
        /* regular: 400 */
        font-family: "Noto Sans JP", sans-serif;
        font-weight: 400;
        font-style: normal;
        color: #AAAAAA;
        letter-spacing: .011em; }
        @media screen and (max-width: 1500px) {
          .tp-news-body-tx-date {
            font-size: 0.6vw; } }
        @media screen and (max-width: 480px) {
          .tp-news-body-tx-date {
            font-size: 2.1vw; } }
        @media screen and (max-width: 1500px) {
          .tp-news-body-tx-date {
            line-height: 1vw; } }
        @media screen and (max-width: 480px) {
          .tp-news-body-tx-date {
            line-height: 4vw; } }
      .tp-news-body-tx-desc {
        width: 100%;
        font-size: 13px;
        line-height: 1.92;
        margin-top: 12px;
        /* regular: 400 */
        font-family: "Noto Sans JP", sans-serif;
        font-weight: 400;
        font-style: normal; }
        @media screen and (max-width: 1500px) {
          .tp-news-body-tx-desc {
            font-size: 0.8666666667vw; } }
        @media screen and (max-width: 480px) {
          .tp-news-body-tx-desc {
            font-size: 3.0333333333vw; } }
        @media screen and (max-width: 1500px) {
          .tp-news-body-tx-desc {
            margin-top: 0.8vw; } }
        @media screen and (max-width: 480px) {
          .tp-news-body-tx-desc {
            margin-top: 3.2vw; } }
  .tp-news-btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; }

/* tp-instagram
---------------------------------------------------------------------------*/
.tp-instagram {
  position: relative;
  padding: 80px 0 60px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../img/top/tp-instagram-bg.jpg);
  color: #ffffff; }
  @media screen and (max-width: 1500px) {
    .tp-instagram {
      padding: 5.3333333333vw 0 4vw; } }
  @media screen and (max-width: 480px) {
    .tp-instagram {
      padding: 21.3333333333vw 5.3333333333vw 16vw; } }
  .tp-instagram-body {
    width: 1200px;
    margin: 0 auto 80px; }
    @media screen and (max-width: 1500px) {
      .tp-instagram-body {
        width: 80vw;
        margin-bottom: 5.3333333333vw; } }
    @media screen and (max-width: 480px) {
      .tp-instagram-body {
        width: 100%;
        margin-bottom: 16vw; } }
  .tp-instagram-btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; }
    .tp-instagram-btn a {
      background-image: url(../img/top/icn-instagram.png);
      background-repeat: no-repeat;
      background-position: 36px center;
      background-size: 18px 18px; }
      @media screen and (max-width: 1500px) {
        .tp-instagram-btn a {
          background-position: 2.4vw center;
          background-size: 1.2vw 1.2vw; } }
      @media screen and (max-width: 480px) {
        .tp-instagram-btn a {
          background-position: 9.6vw center;
          background-size: 4.8vw 4.8vw; } }
