.newsArea .newsDots li:before, .newsArea .newsDots li button:before, .roomArea .roomDots li:before, .roomArea .roomDots li button:before, .diningArea .diningDotBox li:before, .diningArea .diningDotBox li button:before {
  -webkit-transition: all .5s;
  -o-transition: all .5s;
  transition: all .5s; }

.loadArea {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 999;
  -webkit-transition: all .8s;
  -o-transition: all .8s;
  transition: all .8s;
  background-color: #FFF; }
  .loadArea.hide {
    pointer-events: none;
    opacity: 0; }
  .loadArea .iconstart {
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -100%) scaleX(-1) scaleY(1);
    -ms-transform: translate(-50%, -100%) scaleX(-1) scaleY(1);
    transform: translate(-50%, -100%) scaleX(-1) scaleY(1);
    -webkit-animation-name: headeroneshow;
    animation-name: headeroneshow;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
    -webkit-animation-duration: 5s;
    animation-duration: 5s;
    opacity: 0; }
    .loadArea .iconstart2 {
      position: absolute;
      left: 50%;
      top: 50%;
      -webkit-transform: translate(-50%, -150%);
      -ms-transform: translate(-50%, -150%);
      transform: translate(-50%, -150%);
      -webkit-animation-name: headeroneshow2;
      animation-name: headeroneshow2;
      -webkit-animation-fill-mode: forwards;
      animation-fill-mode: forwards;
      -webkit-animation-duration: 5s;
      animation-duration: 5s;
      opacity: 0; }

@-webkit-keyframes headeroneshow {
  0% {
    -webkit-transform: translate(-50%, -100%) scaleX(-1) scaleY(1);
    transform: translate(-50%, -100%) scaleX(-1) scaleY(1);
    opacity: 0; }
  40% {
    -webkit-transform: translate(-50%, -100%) scaleX(1) scaleY(1);
    transform: translate(-50%, -100%) scaleX(1) scaleY(1);
    opacity: 1; }
  80% {
    -webkit-transform: translate(-50%, -100%) scaleX(1) scaleY(1);
    transform: translate(-50%, -100%) scaleX(1) scaleY(1);
    opacity: 1; }
  100% {
    -webkit-transform: translate(-50%, -160%) scaleX(1) scaleY(1);
    transform: translate(-50%, -160%) scaleX(1) scaleY(1);
    opacity: 0; } }

@keyframes headeroneshow {
  0% {
    -webkit-transform: translate(-50%, -100%) scaleX(-1) scaleY(1);
    transform: translate(-50%, -100%) scaleX(-1) scaleY(1);
    opacity: 0; }
  40% {
    -webkit-transform: translate(-50%, -100%) scaleX(1) scaleY(1);
    transform: translate(-50%, -100%) scaleX(1) scaleY(1);
    opacity: 1; }
  80% {
    -webkit-transform: translate(-50%, -100%) scaleX(1) scaleY(1);
    transform: translate(-50%, -100%) scaleX(1) scaleY(1);
    opacity: 1; }
  100% {
    -webkit-transform: translate(-50%, -160%) scaleX(1) scaleY(1);
    transform: translate(-50%, -160%) scaleX(1) scaleY(1);
    opacity: 0; } }

@-webkit-keyframes headeroneshow2 {
  0% {
    -webkit-transform: translate(-50%, -150%);
    transform: translate(-50%, -150%);
    opacity: 0; }
  40% {
    -webkit-transform: translate(-50%, -150%);
    transform: translate(-50%, -150%);
    opacity: 0; }
  80% {
    -webkit-transform: translate(-50%, -100%);
    transform: translate(-50%, -100%);
    opacity: 1; }
  100% {
    -webkit-transform: translate(-50%, -160%);
    transform: translate(-50%, -160%);
    opacity: 0; } }

@keyframes headeroneshow2 {
  0% {
    -webkit-transform: translate(-50%, -150%);
    transform: translate(-50%, -150%);
    opacity: 0; }
  40% {
    -webkit-transform: translate(-50%, -150%);
    transform: translate(-50%, -150%);
    opacity: 0; }
  80% {
    -webkit-transform: translate(-50%, -100%);
    transform: translate(-50%, -100%);
    opacity: 1; }
  100% {
    -webkit-transform: translate(-50%, -160%);
    transform: translate(-50%, -160%);
    opacity: 0; } }

.changePageArea {
  -webkit-transition-duration: 1s;
  -o-transition-duration: 1s;
  transition-duration: 1s; }

.bannerArea .wrap {
  max-width: 100%; }

#banner .bannerTxt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  color: #ffffff;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  pointer-events: none; }
  @media (min-width: 1601px) {
    #banner .bannerTxt {
      padding-left: calc((100% - 1366px) / 2); } }
  @media (min-width: 1181px) {
    #banner .bannerTxt {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; } }
  @media (max-width: 1600px) {
    #banner .bannerTxt {
      padding-left: 140px; } }
  @media (max-width: 1180px) {
    #banner .bannerTxt {
      position: relative;
      color: #111;
      z-index: 1;
      margin-top: -60px;
      padding-left: 60px;
      padding-right: 60px; } }
  @media (max-width: 740px) {
    #banner .bannerTxt {
      margin-top: -80px;
      padding-left: 20px;
      padding-right: 20px;
      padding-bottom: 30px; } }
  #banner .bannerTxt .titlebox {
    position: relative; }
    @media (min-width: 1181px) {
      #banner .bannerTxt .titlebox {
        margin-top: -100px; } }
  #banner .bannerTxt .title01 {
    font-size: 90px;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1; }
    @media (max-width: 1180px) {
      #banner .bannerTxt .title01 {
        font-size: 56px; } }
    @media (max-width: 480px) {
      #banner .bannerTxt .title01 {
        font-size: 40px;
        line-height: 1; } }
    #banner .bannerTxt .title01 .spc {
      letter-spacing: 0; }
  #banner .bannerTxt .title02 {
    margin-top: 15px;
    font-size: 22px;
    font-weight: 300;
    letter-spacing: 0.02em; }
    #banner .bannerTxt .title02 .spc {
      letter-spacing: 0.02em; }
  #banner .bannerTxt .exp {
    margin-top: 20px;
    font-size: 15px;
    font-weight: 100;
    letter-spacing: 0.05em;
    line-height: 24px; }
    @media (max-width: 740px) {
      #banner .bannerTxt .exp br {
        display: none; } }
    #banner .bannerTxt .exp .spc {
      letter-spacing: .075em; }
  #banner .bannerTxt .spc {
    position: relative;
    display: inline-block;
    -webkit-transform: translateY(10px);
    -ms-transform: translateY(10px);
    transform: translateY(10px);
    -webkit-transition: all .5s ease-in-out;
    -o-transition: all .5s ease-in-out;
    transition: all .5s ease-in-out;
    opacity: 0; }
  #banner .bannerTxt .space {
    width: 15px;
    height: 5px; }

#banner .Img {
  position: relative; }
  #banner .Img:before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 194px;
    background-image: url(../images/bannerCover.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    z-index: 1; }

@media (max-width: 1181px) {
  #banner img {
    min-height: 300px;
    -o-object-fit: cover;
    object-fit: cover; } }

#banner .moreBtn {
  margin-top: 30px;
  position: relative; }
  @media (max-width: 1180px) {
    #banner .moreBtn {
      display: none; } }
  #banner .moreBtn a {
    position: relative;
    display: inline-block;
    font-size: 15px;
    font-weight: 100;
    letter-spacing: 0.1em;
    outline: none;
    color: #FFF;
    pointer-events: auto; }
    #banner .moreBtn a:before {
      content: '';
      margin-right: 25px;
      display: inline-block;
      width: 54px;
      height: 54px;
      border-radius: 50%;
      -webkit-box-shadow: 0 0 0 6px rgba(255, 255, 255, 0.3);
      box-shadow: 0 0 0 6px rgba(255, 255, 255, 0.3);
      background-color: #FFF;
      background-image: url(../images/down.png);
      background-repeat: no-repeat;
      background-position: center;
      vertical-align: middle; }

@media (min-width: 1181px) {
  .bookingArea {
    margin-top: -100px; } }

@media (max-width: 1180px) {
  .bookingArea {
    margin-top: 0; } }

@media (max-width: 1180px) {
  .bookingArea .wrap {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    padding-left: 60px; } }

.mainArea {
  padding: 0;
  background-color: #f5f5f5;
  background-image: url(../images/bgHome2.png);
  background-repeat: no-repeat;
  background-position: center -1020px; }

.newsArea {
  padding-top: 150px; }
  @media screen and (min-width: 741px) and (max-width: 980px) {
    .newsArea {
      padding-top: 120px; } }
  @media (max-width: 740px) {
    .newsArea {
      padding-top: 60px; } }
  .newsArea.active .titleBox,
  .newsArea.active .newsList,
  .newsArea.active .newsBottom {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0); }
  .newsArea .wrap {
    position: relative;
    max-width: 1366px; }
    @media (min-width: 1681px) {
      .newsArea .wrap {
        padding-left: 40px;
        padding-right: 40px; } }
    @media screen and (min-width: 741px) and (max-width: 1680px) {
      .newsArea .wrap {
        padding-left: 60px;
        padding-right: 60px; } }
    @media (max-width: 740px) {
      .newsArea .wrap {
        padding-left: 20px;
        padding-right: 20px; } }
  .newsArea .titleBox {
    margin-bottom: 35px;
    opacity: 0;
    -webkit-transition: all .8s;
    -o-transition: all .8s;
    transition: all .8s;
    -webkit-transform: translateY(30px);
    -ms-transform: translateY(30px);
    transform: translateY(30px); }
  .newsArea .newsBottom {
    position: relative;
    text-align: center;
    opacity: 0;
    -webkit-transition: all .8s .8s;
    -o-transition: all .8s .8s;
    transition: all .8s .8s;
    -webkit-transform: translateY(30px);
    -ms-transform: translateY(30px);
    transform: translateY(30px); }
    @media (max-width: 740px) {
      .newsArea .newsBottom {
        margin-top: 10px; } }
  .newsArea .newsDots {
    position: relative;
    display: inline-block;
    height: 24px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none; }
    @media (max-width: 740px) {
      .newsArea .newsDots {
        height: 30px; } }
    .newsArea .newsDots .slick-dots {
      position: relative;
      bottom: auto;
      width: auto; }
      @media (min-width: 741px) {
        .newsArea .newsDots .slick-dots {
          display: inline-block !important; } }
    .newsArea .newsDots li {
      display: inline-block;
      margin-left: 3px;
      margin-right: 3px; }
      .newsArea .newsDots li:before {
        content: '';
        position: absolute;
        top: 1px;
        left: 1px;
        width: 16px;
        height: 16px;
        border-radius: 50%;
        border: solid 1px #FFF;
        opacity: 0; }
      .newsArea .newsDots li.slick-active:before {
        opacity: 1;
        border-color: #adb1b3; }
      .newsArea .newsDots li.slick-active button:before {
        background-color: #111;
        opacity: 1; }
      .newsArea .newsDots li button {
        position: relative; }
        .newsArea .newsDots li button:before {
          content: '';
          position: absolute;
          left: 50%;
          top: 50%;
          -webkit-transform: translate(-50%, -50%);
          -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
          width: 5px;
          height: 5px;
          border-radius: 50%;
          background-color: #111;
          opacity: 1; }
    .newsArea .newsDots .prevArrow {
      width: 38px;
      height: 24px;
      background-image: url(../images/prevArrow.png);
      background-repeat: no-repeat;
      background-position: center;
      cursor: pointer; }
      @media (min-width: 741px) {
        .newsArea .newsDots .prevArrow {
          position: absolute;
          right: calc(100% + 15px);
          top: 0; } }
      @media (max-width: 740px) {
        .newsArea .newsDots .prevArrow {
          position: relative;
          display: inline-block !important;
          height: 30px; } }
    .newsArea .newsDots .icon {
      display: inline-block;
      width: 34px;
      height: 30px;
      background-image: url(../images/icon03.svg);
      background-repeat: no-repeat;
      background-position: center;
      margin-left: 10px;
      margin-right: 10px; }
      @media (min-width: 741px) {
        .newsArea .newsDots .icon {
          display: none; } }
    .newsArea .newsDots .nextArrow {
      width: 38px;
      height: 24px;
      background-image: url(../images/nextArrow.png);
      background-repeat: no-repeat;
      background-position: center;
      cursor: pointer; }
      @media (min-width: 741px) {
        .newsArea .newsDots .nextArrow {
          position: absolute;
          left: calc(100% + 15px); } }
      @media (max-width: 740px) {
        .newsArea .newsDots .nextArrow {
          position: relative;
          display: inline-block !important;
          height: 30px; } }

.newsList {
  margin-bottom: 0 !important;
  opacity: 0;
  -webkit-transition: all .8s .4s;
  -o-transition: all .8s .4s;
  transition: all .8s .4s;
  -webkit-transform: translateY(30px);
  -ms-transform: translateY(30px);
  transform: translateY(30px); }
  @media (min-width: 1681px) {
    .newsList {
      margin-left: -20px;
      margin-right: -20px; } }
  @media (min-width: 641px) {
    .newsList .slick-list {
      padding-top: 60px !important; } }
  @media screen and (min-width: 641px) and (max-width: 740px) {
    .newsList .slick-list {
      padding-left: 100px !important;
      padding-right: 100px !important; } }
  @media (min-width: 641px) {
    .newsList .slick-center,
    .newsList .active {
      -webkit-transform: translateY(-60px);
      -ms-transform: translateY(-60px);
      transform: translateY(-60px); } }
  .newsList li {
    -webkit-transition: all .8s;
    -o-transition: all .8s;
    transition: all .8s; }
    @media (max-width: 1366px) {
      .newsList li {
        margin-left: 5px;
        margin-right: 5px; } }
  .newsList .item {
    max-width: 400px;
    margin-left: auto;
    margin-right: auto; }
    .newsList .item:hover img {
      -webkit-transform: scale(1.05);
      -ms-transform: scale(1.05);
      transform: scale(1.05); }
  .newsList .Img {
    overflow: hidden; }
  .newsList img {
    -webkit-transition: all 1.6s;
    -o-transition: all 1.6s;
    transition: all 1.6s; }
    @media (max-width: 1366px) {
      .newsList img {
        display: block;
        width: 100%; } }
  .newsList .Txt {
    padding: 20px; }
  .newsList .date {
    margin-bottom: 5px;
    display: inline-block;
    font-family: "Montserrat", sans-serif;
    color: #A32135; }
    .newsList .date .day {
      display: inline-block;
      font-size: 38px;
      font-weight: 500;
      letter-spacing: -0.025em; }
    .newsList .date .month {
      display: inline-block;
      font-size: 13px;
      font-weight: 400;
      letter-spacing: 0.05em; }
  .newsList .newClass {
    display: inline-block;
    font-size: 13px;
    font-weight: 300;
    letter-spacing: 0.05em;
    color: #777; }
    .newsList .newClass:before {
      content: '';
      display: inline-block;
      width: 30px;
      height: 1px;
      background-color: #A32135;
      vertical-align: middle;
      margin-left: 10px;
      margin-right: 10px; }
  .newsList h3 a {
    display: block;
    font-size: 19px;
    font-weight: 400;
    letter-spacing: .05em;
    color: #111;
    white-space: nowrap;
    overflow: hidden;
    -o-text-overflow: ellipsis;
    text-overflow: ellipsis; }
    .newsList h3 a:hover {
      color: #A32135; }
  .newsList .ellipsis {
    margin-top: 8px;
    height: 50px;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 25px;
    color: #454545; }

.roomArea {
  padding-top: 150px; }
  @media screen and (min-width: 741px) and (max-width: 980px) {
    .roomArea {
      padding-top: 120px; } }
  @media (max-width: 740px) {
    .roomArea {
      padding-top: 60px; } }
  .roomArea.active .leftBox,
  .roomArea.active .rightBox {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0); }
  .roomArea > .wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    max-width: 100%; }
  .roomArea .leftBox,
  .roomArea .rightBox {
    width: 50%;
    overflow: hidden;
    -webkit-box-sizing: border-box;
    box-sizing: border-box; }
  .roomArea .leftBox {
    position: relative;
    padding-right: 2px;
    opacity: 0;
    -webkit-transition: all .8s;
    -o-transition: all .8s;
    transition: all .8s;
    -webkit-transform: translateY(30px);
    -ms-transform: translateY(30px);
    transform: translateY(30px); }
    @media (min-width: 1681px) {
      .roomArea .leftBox {
        padding-left: calc(50% - 792px); } }
    @media screen and (min-width: 741px) and (max-width: 1680px) {
      .roomArea .leftBox {
        padding-left: 60px; } }
    @media (max-width: 1180px) {
      .roomArea .leftBox {
        width: 100%; } }
    .roomArea .leftBox img {
      display: block;
      width: 100%;
      max-height: 510px;
      -o-object-fit: cover;
      object-fit: cover; }
      @media (min-width: 1181px) {
        .roomArea .leftBox img {
          height: 510px; } }
    .roomArea .leftBox a {
      outline: none; }
  .roomArea .rightBox {
    padding-left: 2px;
    font-size: 0;
    opacity: 0;
    -webkit-transition: all .8s .4s;
    -o-transition: all .8s .4s;
    transition: all .8s .4s;
    -webkit-transform: translateY(30px);
    -ms-transform: translateY(30px);
    transform: translateY(30px); }
    @media (max-width: 1180px) {
      .roomArea .rightBox {
        display: none; } }
  .roomArea .roomBottom {
    text-align: center; }
    @media (min-width: 1181px) {
      .roomArea .roomBottom {
        position: absolute;
        left: 50%;
        bottom: 530px;
        margin-left: -52px; } }
  .roomArea .roomDots {
    position: relative;
    display: inline-block;
    height: 24px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none; }
    @media (max-width: 740px) {
      .roomArea .roomDots {
        height: 30px; } }
    .roomArea .roomDots .slick-dots {
      position: relative;
      bottom: auto;
      width: auto; }
      @media (min-width: 741px) {
        .roomArea .roomDots .slick-dots {
          display: inline-block !important; } }
    .roomArea .roomDots li {
      display: inline-block;
      margin-left: 3px;
      margin-right: 3px; }
      .roomArea .roomDots li:before {
        content: '';
        position: absolute;
        top: 1px;
        left: 1px;
        width: 16px;
        height: 16px;
        border-radius: 50%;
        border: solid 1px #FFF;
        opacity: 0; }
      .roomArea .roomDots li.slick-active:before {
        opacity: 1;
        border-color: #adb1b3; }
      .roomArea .roomDots li.slick-active button:before {
        background-color: #111;
        opacity: 1; }
      .roomArea .roomDots li button {
        position: relative; }
        .roomArea .roomDots li button:before {
          content: '';
          position: absolute;
          left: 50%;
          top: 50%;
          -webkit-transform: translate(-50%, -50%);
          -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
          width: 5px;
          height: 5px;
          border-radius: 50%;
          background-color: #111;
          opacity: 1; }
    .roomArea .roomDots .prevArrow {
      width: 38px;
      height: 24px;
      background-image: url(../images/prevArrow.png);
      background-repeat: no-repeat;
      background-position: center;
      cursor: pointer; }
      @media (min-width: 741px) {
        .roomArea .roomDots .prevArrow {
          position: absolute;
          right: calc(100% + 15px);
          top: 0; } }
      @media (max-width: 740px) {
        .roomArea .roomDots .prevArrow {
          position: relative;
          display: inline-block !important;
          height: 30px; } }
    .roomArea .roomDots .icon {
      display: inline-block;
      width: 34px;
      height: 30px;
      background-image: url(../images/icon03.svg);
      background-repeat: no-repeat;
      background-position: center;
      margin-left: 10px;
      margin-right: 10px; }
      @media (min-width: 741px) {
        .roomArea .roomDots .icon {
          display: none; } }
    .roomArea .roomDots .nextArrow {
      width: 38px;
      height: 24px;
      background-image: url(../images/nextArrow.png);
      background-repeat: no-repeat;
      background-position: center;
      cursor: pointer; }
      @media (min-width: 741px) {
        .roomArea .roomDots .nextArrow {
          position: absolute;
          left: calc(100% + 15px); } }
      @media (max-width: 740px) {
        .roomArea .roomDots .nextArrow {
          position: relative;
          display: inline-block !important;
          height: 30px; } }

.roomList {
  margin-bottom: 0 !important; }
  .roomList .titleBox {
    margin-bottom: 25px; }
    .roomList .titleBox .en {
      line-height: 1; }
    .roomList .titleBox .tw {
      line-height: 30px; }
    .roomList .titleBox a {
      display: inline-block;
      white-space: nowrap;
      overflow: hidden;
      -o-text-overflow: ellipsis;
      text-overflow: ellipsis; }
  .roomList .ellipsis {
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 25px;
    color: #454545; }
  @media (max-width: 1180px) {
    .roomList .item {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: reverse;
      -ms-flex-flow: column-reverse;
      flex-flow: column-reverse; } }
  .roomList .item:hover img {
    -webkit-transform: scale(1.05);
    -ms-transform: scale(1.05);
    transform: scale(1.05); }
  .roomList .Img {
    overflow: hidden; }
  .roomList img {
    -webkit-transition: all 1.6s;
    -o-transition: all 1.6s;
    transition: all 1.6s; }
  .roomList .Txt {
    margin-left: auto;
    margin-right: auto;
    padding-top: 30px;
    padding-bottom: 30px; }
    @media (min-width: 1181px) {
      .roomList .Txt {
        padding-bottom: 80px; } }
    @media (min-width: 741px) {
      .roomList .Txt {
        max-width: 430px; } }
    @media (max-width: 740px) {
      .roomList .Txt {
        max-width: 590px;
        padding-left: 20px;
        padding-right: 20px; } }
  .roomList .ellipsis {
    height: 120px; }
  .roomList .moreBtn {
    margin-top: 8px;
    position: relative;
    display: inline-block;
    font-family: "Montserrat", sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.05em;
    color: #111;
    z-index: 1; }
    .roomList .moreBtn:hover {
      color: #A32135; }
      .roomList .moreBtn:hover:after {
        background-color: #A32135; }
    .roomList .moreBtn:before {
      content: '';
      position: absolute;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      width: 150%;
      height: 200%;
      -webkit-transition: all .5s;
      -o-transition: all .5s;
      transition: all .5s;
      z-index: -1; }
    .roomList .moreBtn:after {
      content: '';
      position: absolute;
      bottom: -5px;
      left: 0;
      width: 100%;
      height: 1px;
      background-color: #111;
      -webkit-transition: all .5s;
      -o-transition: all .5s;
      transition: all .5s; }

.diningArea {
  padding-top: 150px; }
  @media screen and (min-width: 741px) and (max-width: 980px) {
    .diningArea {
      padding-top: 120px; } }
  @media (max-width: 740px) {
    .diningArea {
      padding-top: 60px; } }
  .diningArea.active .leftBox,
  .diningArea.active .rightBox {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0); }
  .diningArea > .wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    max-width: 100%; }
    @media (min-width: 1181px) {
      .diningArea > .wrap {
        padding-left: calc(((100% - 1180px) / 2) + 100px); } }
    @media screen and (min-width: 741px) and (max-width: 1180px) {
      .diningArea > .wrap {
        padding-left: 60px; } }
    @media (max-width: 980px) {
      .diningArea > .wrap {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-flow: column;
        flex-flow: column; } }
  @media (min-width: 981px) {
    .diningArea .leftBox,
    .diningArea .rightBox {
      width: 50%;
      max-width: 590px; } }
  @media (max-width: 980px) {
    .diningArea .leftBox,
    .diningArea .rightBox {
      width: 100%; } }
  .diningArea .leftBox {
    position: relative;
    z-index: 1;
    opacity: 0;
    -webkit-transition: all .8s;
    -o-transition: all .8s;
    transition: all .8s;
    -webkit-transform: translateY(30px);
    -ms-transform: translateY(30px);
    transform: translateY(30px); }
    @media (min-width: 981px) {
      .diningArea .leftBox {
        -webkit-box-shadow: 0px 10px 28.5px 1.5px rgba(0, 0, 0, 0.1);
        box-shadow: 0px 10px 28.5px 1.5px rgba(0, 0, 0, 0.1); } }
  .diningArea .rightBox {
    padding-top: 40px;
    opacity: 0;
    -webkit-transition: all .8s .4s;
    -o-transition: all .8s .4s;
    transition: all .8s .4s;
    -webkit-transform: translateY(30px);
    -ms-transform: translateY(30px);
    transform: translateY(30px); }
    @media (min-width: 741px) {
      .diningArea .rightBox {
        padding-left: 75px;
        padding-right: 75px; } }
    @media (max-width: 740px) {
      .diningArea .rightBox {
        max-width: 590px;
        margin-left: auto;
        margin-right: auto;
        padding-left: 20px;
        padding-right: 20px; } }
  .diningArea .diningDotBox {
    position: relative;
    display: inline-block;
    height: 24px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none; }
    @media (max-width: 740px) {
      .diningArea .diningDotBox {
        height: 30px; } }
    .diningArea .diningDotBox .slick-dots {
      position: relative;
      bottom: auto;
      width: auto; }
      @media (min-width: 741px) {
        .diningArea .diningDotBox .slick-dots {
          display: inline-block !important; } }
    .diningArea .diningDotBox li {
      display: inline-block;
      margin-left: 3px;
      margin-right: 3px; }
      .diningArea .diningDotBox li:before {
        content: '';
        position: absolute;
        top: 1px;
        left: 1px;
        width: 16px;
        height: 16px;
        border-radius: 50%;
        border: solid 1px #FFF;
        opacity: 0; }
      .diningArea .diningDotBox li.slick-active:before {
        opacity: 1;
        border-color: #adb1b3; }
      .diningArea .diningDotBox li.slick-active button:before {
        background-color: #111;
        opacity: 1; }
      .diningArea .diningDotBox li button {
        position: relative; }
        .diningArea .diningDotBox li button:before {
          content: '';
          position: absolute;
          left: 50%;
          top: 50%;
          -webkit-transform: translate(-50%, -50%);
          -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
          width: 5px;
          height: 5px;
          border-radius: 50%;
          background-color: #111;
          opacity: 1; }
    .diningArea .diningDotBox .prevArrow {
      width: 38px;
      height: 24px;
      background-image: url(../images/prevArrow.png);
      background-repeat: no-repeat;
      background-position: center;
      cursor: pointer; }
      @media (min-width: 741px) {
        .diningArea .diningDotBox .prevArrow {
          position: absolute;
          right: calc(100% + 15px);
          top: 0; } }
      @media (max-width: 740px) {
        .diningArea .diningDotBox .prevArrow {
          position: relative;
          display: inline-block !important;
          height: 30px; } }
    .diningArea .diningDotBox .icon {
      display: inline-block;
      width: 34px;
      height: 30px;
      background-image: url(../images/icon03.svg);
      background-repeat: no-repeat;
      background-position: center;
      margin-left: 10px;
      margin-right: 10px; }
      @media (min-width: 741px) {
        .diningArea .diningDotBox .icon {
          display: none; } }
    .diningArea .diningDotBox .nextArrow {
      width: 38px;
      height: 24px;
      background-image: url(../images/nextArrow.png);
      background-repeat: no-repeat;
      background-position: center;
      cursor: pointer; }
      @media (min-width: 741px) {
        .diningArea .diningDotBox .nextArrow {
          position: absolute;
          left: calc(100% + 15px); } }
      @media (max-width: 740px) {
        .diningArea .diningDotBox .nextArrow {
          position: relative;
          display: inline-block !important;
          height: 30px; } }
    @media (min-width: 741px) {
      .diningArea .diningDotBox {
        margin-top: 50px;
        margin-left: 55px; } }
    @media (max-width: 740px) {
      .diningArea .diningDotBox {
        display: block;
        text-align: center; } }

.diningImgList .item {
  max-width: 590px;
  margin-left: auto;
  margin-right: auto; }

@media (max-width: 980px) {
  .diningImgList img {
    display: block;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover; } }

.diningTxtList {
  margin-bottom: 0 !important; }
  .diningTxtList .titleBox {
    margin-bottom: 25px; }
    .diningTxtList .titleBox .en {
      line-height: 1; }
    .diningTxtList .titleBox .tw {
      line-height: 30px; }
    .diningTxtList .titleBox a {
      display: inline-block;
      white-space: nowrap;
      overflow: hidden;
      -o-text-overflow: ellipsis;
      text-overflow: ellipsis; }
  .diningTxtList .ellipsis {
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 25px;
    color: #454545; }
  .diningTxtList .slick-list {
    padding-bottom: 20px; }
    @media (max-width: 740px) {
      .diningTxtList .slick-list {
        padding-bottom: 30px; } }
  .diningTxtList .titleBox h4 {
    line-height: 1; }
  .diningTxtList .titleBox a {
    display: inline-block; }
  .diningTxtList .ellipsis {
    margin-bottom: 15px;
    height: 75px; }
  .diningTxtList .moreBtn {
    margin-top: 8px;
    position: relative;
    display: inline-block;
    font-family: "Montserrat", sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.05em;
    color: #111;
    z-index: 1;
    margin-top: 40px; }
    .diningTxtList .moreBtn:hover {
      color: #A32135; }
      .diningTxtList .moreBtn:hover:after {
        background-color: #A32135; }
    .diningTxtList .moreBtn:before {
      content: '';
      position: absolute;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      width: 150%;
      height: 200%;
      -webkit-transition: all .5s;
      -o-transition: all .5s;
      transition: all .5s;
      z-index: -1; }
    .diningTxtList .moreBtn:after {
      content: '';
      position: absolute;
      bottom: -5px;
      left: 0;
      width: 100%;
      height: 1px;
      background-color: #111;
      -webkit-transition: all .5s;
      -o-transition: all .5s;
      transition: all .5s; }
  .diningTxtList .openTime,
  .diningTxtList .bookTel {
    font-family: "Noto Sans TC", sans-serif;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 30px;
    color: #666666;
    white-space: nowrap;
    overflow: hidden;
    -o-text-overflow: ellipsis;
    text-overflow: ellipsis; }
    .diningTxtList .openTime:before,
    .diningTxtList .bookTel:before {
      content: '';
      margin-right: 10px;
      display: inline-block;
      width: 12px;
      height: 30px;
      background-repeat: no-repeat;
      background-position: center;
      vertical-align: top; }
  .diningTxtList .openTime:before {
    background-image: url(../images/time.png); }
  .diningTxtList .bookTel:before {
    background-image: url(../images/phone.png); }

@media (min-width: 981px) {
  .linkArea {
    padding-top: 50px; } }

@media (max-width: 980px) {
  .linkArea {
    padding-top: 50px; } }

.linkArea.active .Txt {
  opacity: 1;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0); }

.linkArea > .wrap {
  position: relative;
  max-width: 100%;
  overflow: hidden; }
  @media (max-width: 740px) {
    .linkArea > .wrap {
      padding-left: 0;
      padding-right: 0; } }

.linkArea .linkList {
  position: relative; }

.linkArea .Img {
  pointer-events: none;
  font-size: 0; }

.linkArea img {
  display: block;
  width: 100%;
  min-height: 300px;
  -o-object-fit: cover;
  object-fit: cover; }
  @media (min-width: 1181px) {
    .linkArea img {
      height: 660px; } }
  @media screen and (min-width: 981px) and (max-width: 1180px) {
    .linkArea img {
      height: 500px; } }

.linkArea .Txt {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  opacity: 0;
  -webkit-transition: all .8s;
  -o-transition: all .8s;
  transition: all .8s;
  -webkit-transform: translateY(30px);
  -ms-transform: translateY(30px);
  transform: translateY(30px);
  padding-left: calc(((100% - 1180px) / 2) + 100px); }

.linkArea .wordBox {
  color: #FFF; }
  @media (min-width: 741px) {
    .linkArea .wordBox {
      margin-top: 50px; } }
  .linkArea .wordBox .left {
    margin-left: -40px;
    margin-right: -2px;
    padding-left: 20px;
    padding-right: 5px;
    padding-bottom: 45px;
    display: inline-block;
    font-size: 65px;
    font-weight: bold;
    letter-spacing: 0.025em;
    -webkit-transform: skew(-40deg);
    -ms-transform: skew(-40deg);
    transform: skew(-40deg);
    overflow: hidden; }
    @media (max-width: 740px) {
      .linkArea .wordBox .left {
        font-size: 40px;
        margin-right: 18px;
        padding-bottom: 0;
        -webkit-transform: skew(-40deg) translateY(-45px);
        -ms-transform: skew(-40deg) translateY(-45px);
        transform: skew(-40deg) translateY(-45px); } }
    @media (max-width: 480px) {
      .linkArea .wordBox .left {
        margin-left: -50px; } }
    .linkArea .wordBox .left span {
      display: block;
      -webkit-transform: skew(40deg);
      -ms-transform: skew(40deg);
      transform: skew(40deg); }
  .linkArea .wordBox .right {
    padding-top: 70px;
    padding-right: 10px;
    padding-bottom: 10px;
    display: inline-block;
    font-size: 40px;
    font-weight: 100;
    letter-spacing: 0.025em;
    -webkit-transform: skew(-40deg);
    -ms-transform: skew(-40deg);
    transform: skew(-40deg);
    overflow: hidden;
    border-left: solid 1px #FFF; }
    @media (max-width: 740px) {
      .linkArea .wordBox .right {
        font-size: 30px; } }
    @media (max-width: 350px) {
      .linkArea .wordBox .right {
        margin-right: -40px; } }
    .linkArea .wordBox .right span {
      display: block;
      -webkit-transform: skew(40deg);
      -ms-transform: skew(40deg);
      transform: skew(40deg); }

@media (max-width: 740px) {
  .linkArea h4 {
    padding-left: 20px;
    padding-right: 20px; } }

.linkArea h4 a {
  font-size: 15px;
  font-weight: 300;
  letter-spacing: 0.05em;
  line-height: 28px;
  color: #FFF; }

.facArea {
  background-color: #f5f5f5;
  background-image: url(../images/bgHome02.png);
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: cover;
  padding-top: 150px;
  opacity: 0;
  -webkit-transition: all .8s;
  -o-transition: all .8s;
  transition: all .8s;
  -webkit-transform: translateY(30px);
  -ms-transform: translateY(30px);
  transform: translateY(30px); }
  @media (min-width: 1181px) {
    .facArea {
      padding-bottom: 80px; } }
  @media screen and (min-width: 741px) and (max-width: 1366px) {
    .facArea {
      padding-left: 60px;
      padding-right: 60px; } }
  @media screen and (min-width: 741px) and (max-width: 980px) {
    .facArea {
      padding-top: 120px; } }
  @media (max-width: 740px) {
    .facArea {
      padding-top: 60px; } }
  .facArea.active {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0); }
  .facArea .wrap {
    position: relative;
    max-width: 1180px; }
    @media (max-width: 860px) {
      .facArea .wrap {
        padding-left: 20px;
        padding-right: 20px; } }
  @media (min-width: 861px) {
    .facArea .titleBox {
      position: absolute;
      top: 0;
      left: 0; } }
  @media (max-width: 860px) {
    .facArea .titleBox {
      max-width: 430px;
      margin-left: auto;
      margin-right: auto;
      margin-bottom: 60px; } }
  .facArea .titleBox .facInfo {
    margin-top: 20px;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 25px;
    color: #454545; }

.facList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-flow: row-reverse wrap;
  flex-flow: row-reverse wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }
  @media screen and (min-width: 861px) and (max-width: 1180px) {
    .facList {
      margin-left: -5px;
      margin-right: -5px; } }
  .facList .li1 img,
  .facList .li3 img,
  .facList .li4 img {
    height: 330px; }
  @media (min-width: 861px) {
    .facList .li1 .Img,
    .facList .li4 .Img {
      max-width: 590px; } }
  @media (min-width: 861px) {
    .facList .li2 .item,
    .facList .li5 .item {
      max-width: 430px; } }
  .facList .li2 .Img,
  .facList .li5 .Img {
    width: 100%; }
  .facList .li1 .Txt:before {
    background-image: url(../images/icon01.png); }
  @media (min-width: 861px) {
    .facList .li2 {
      margin-top: 230px; } }
  .facList .li2 img {
    height: 480px; }
  .facList .li2 .Txt:before {
    background-image: url(../images/icon02.png); }
  @media (min-width: 861px) {
    .facList .li3 {
      margin-top: -310px; } }
  .facList .li3 .item {
    margin-left: auto;
    margin-right: auto; }
    @media (min-width: 861px) {
      .facList .li3 .item {
        max-width: 390px; } }
  .facList .li3 .Img {
    width: 100%; }
  .facList .li3 .Txt:before {
    background-image: url(../images/icon03.png); }
  @media (min-width: 861px) {
    .facList .li4 {
      margin-top: 64px; } }
  .facList .li4 .Txt:before {
    background-image: url(../images/icon04.png); }
  @media (min-width: 861px) {
    .facList .li5 {
      margin-top: -320px; } }
  .facList .li5 .item {
    margin-left: auto; }
  .facList .li5 img {
    height: 430px; }
  .facList .li5 .Txt:before {
    background-image: url(../images/icon05.png); }
  .facList li {
    display: block;
    width: 50%; }
    @media (max-width: 860px) {
      .facList li {
        width: 100%; } }
  @media screen and (min-width: 861px) and (max-width: 1180px) {
    .facList .item {
      padding-left: 5px;
      padding-right: 5px; } }
  @media (max-width: 860px) {
    .facList .item {
      max-width: 430px;
      margin-left: auto;
      margin-right: auto; } }
  .facList .item:hover img {
    -webkit-transform: scale(1.05);
    -ms-transform: scale(1.05);
    transform: scale(1.05); }
  .facList .Img {
    overflow: hidden; }
  .facList img {
    display: block;
    -webkit-transition: all 1.6s;
    -o-transition: all 1.6s;
    transition: all 1.6s; }
    @media (max-width: 1180px) {
      .facList img {
        width: 100%;
        -o-object-fit: cover;
        object-fit: cover; } }
  .facList .Txt {
    position: relative;
    padding-top: 20px;
    padding-left: 70px;
    padding-right: 20px;
    padding-bottom: 20px; }
    .facList .Txt:before {
      content: '';
      position: absolute;
      top: 20px;
      left: 20px;
      display: block;
      width: 30px;
      height: 30px;
      background-repeat: no-repeat;
      background-position: center; }
    .facList .Txt:hover a {
      color: #A32135; }
  .facList h4 a {
    font-size: 23px;
    font-weight: 400;
    letter-spacing: 0;
    color: #111; }
  .facList h3 a {
    font-size: 16px;
    font-weight: 400;
    letter-spacing: 0.05em;
    color: #111; }

.aboutArea.active #gmapContact,
.aboutArea.active .item {
  opacity: 1;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0); }

.aboutArea .wrap {
  padding-top: 10px;
  position: relative;
  max-width: 100%; }
  @media (max-width: 1180px) {
    .aboutArea .wrap {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: reverse;
      -ms-flex-flow: column-reverse;
      flex-flow: column-reverse; } }
  .aboutArea .wrap:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 168px;
    background-image: url(../images/cover02.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    pointer-events: none;
    z-index: 1; }

.aboutArea #gmapContact {
  width: 100%;
  height: 630px;
  opacity: 0;
  -webkit-transition: all .8s;
  -o-transition: all .8s;
  transition: all .8s;
  -webkit-transform: translateY(30px);
  -ms-transform: translateY(30px);
  transform: translateY(30px); }
  @media (max-width: 740px) {
    .aboutArea #gmapContact {
      height: 60vh; } }

.aboutArea .item {
  position: relative;
  background-color: #FFF;
  z-index: 1;
  opacity: 0;
  -webkit-transition: all .8s .4s;
  -o-transition: all .8s .4s;
  transition: all .8s .4s;
  -webkit-transform: translateY(30px);
  -ms-transform: translateY(30px);
  transform: translateY(30px); }
  .aboutArea .item .titleBox {
    margin-bottom: 25px; }
    .aboutArea .item .titleBox .en {
      line-height: 1; }
    .aboutArea .item .titleBox .tw {
      line-height: 30px; }
    .aboutArea .item .titleBox a {
      display: inline-block;
      white-space: nowrap;
      overflow: hidden;
      -o-text-overflow: ellipsis;
      text-overflow: ellipsis; }
  .aboutArea .item .ellipsis {
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 25px;
    color: #454545; }
  @media (min-width: 1181px) {
    .aboutArea .item {
      position: absolute;
      top: 20px;
      left: calc((100% - 1180px) / 2);
      height: 570px;
      max-width: 465px;
      -webkit-box-shadow: 0px 10px 28.5px 1.5px rgba(0, 0, 0, 0.1);
      box-shadow: 0px 10px 28.5px 1.5px rgba(0, 0, 0, 0.1);
      padding-top: 115px;
      padding-left: 85px;
      padding-right: 85px; } }
  @media (max-width: 1180px) {
    .aboutArea .item {
      padding-top: 60px;
      padding-left: 60px;
      padding-right: 60px;
      padding-bottom: 60px; } }
  @media (max-width: 740px) {
    .aboutArea .item {
      padding-left: 20px;
      padding-right: 20px; } }

.aboutArea .btn {
  margin-top: 8px;
  position: relative;
  display: inline-block;
  font-family: "Montserrat", sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #111;
  z-index: 1;
  margin-top: 25px; }
  .aboutArea .btn:hover {
    color: #A32135; }
    .aboutArea .btn:hover:after {
      background-color: #A32135; }
  .aboutArea .btn:before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 150%;
    height: 200%;
    -webkit-transition: all .5s;
    -o-transition: all .5s;
    transition: all .5s;
    z-index: -1; }
  .aboutArea .btn:after {
    content: '';
    position: absolute;
    bottom: -5px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #111;
    -webkit-transition: all .5s;
    -o-transition: all .5s;
    transition: all .5s; }

@media (max-width: 740px) {
  .slick-dots {
    display: none !important; } }
