@charset "UTF-8";
/* CSS Document */
/* -----------------------------------------------------------
global
----------------------------------------------------------- */
body, html {
  height: 100%;
}

body {
  margin: 0;
  padding: 0;
  font-size: 16px;
  line-height: 160%;
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  vertical-align: top;
  background-color: #fff;
}

* {
  box-sizing: border-box;
}

img {
  line-height: 1;
}

a, a:hover {
  text-decoration: none;
  color: #fff;
}

.font_small {
  font-size: 16px;
  font-weight: normal;
}

.wrapper {
  width: 1880px;
  margin: 0 auto;
  height: 100%;
  min-height: 100%;
}

.contents {
  width: 1780px;
  margin: 0 auto;
}

/* -----------------------------------------------------------
レストランワイヤー
----------------------------------------------------------- */
.dinner .contents {
  padding: 50px 0;
  color: #4c91b8;
}

.rest-head {
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}

.rest-head-left {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}
.rest-head-left h1 {
  font-size: 38px;
  padding-right: 20px;
}

.rest-top-lead {
  font-weight: bold;
}

.rest-head-right {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  font-size: 14px;
  text-align: right;
}

/* -----------------------------------------------------------
レストランiframe
----------------------------------------------------------- */
.restraunt {
  color: #4c91b8;
  font-feature-settings: "palt" 1;
}
.restraunt .contents {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 1780px;
}
.restraunt .contents .column {
  width: 32%;
}
.restraunt h2 {
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  background: #4c91b8;
  padding: 10px;
  color: #fff;
  font-size: 24px;
}
.restraunt h2 .h2-left {
  font-size: 20px;
}
.restraunt h2 .h2-right {
  font-size: 15px;
}
.restraunt ul {
  font-size: 26px;
}
.restraunt ul li {
  width: 100%;
  position: relative;
  border-bottom: 1px solid #4c91b8;
  padding: 15px 0;
  line-height: 90%;
}
.restraunt ul li:last-child {
  border: none;
}
.restraunt ul li div {
  width: 100%;
}
.restraunt ul li div span {
  display: block;
  transform-origin: top left;
}
.restraunt ul li div span:first-child {
  margin-bottom: 5px;
}
.restraunt ul li p {
  width: 200px;
  position: absolute;
  right: 0;
  top: 15px;
}
.restraunt ul li .cho-60 {
  transform: scale(0.6, 1);
}
.restraunt ul li .cho-65 {
  transform: scale(0.65, 1);
}
.restraunt ul li .cho-70 {
  transform: scale(0.7, 1);
}
.restraunt ul li .cho-75 {
  transform: scale(0.75, 1);
}
.restraunt ul li .cho-80 {
  transform: scale(0.8, 1);
}
.restraunt ul li .cho-85 {
  transform: scale(0.85, 1);
}
.restraunt ul li .cho-90 {
  transform: scale(0.9, 1);
}
.restraunt ul li .cho-95 {
  transform: scale(0.95, 1);
}

/* -----------------------------------------------------------
木林の湯
----------------------------------------------------------- */
.kirin-wrapper {
  width: 100vw;
  height: 100vh;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

.kirin-inner {
  width: 1600px;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}

.kirin-left {
  width: 40%;
}
.kirin-left p:first-child {
  margin-bottom: 30px;
}
.kirin-left p img {
  width: 100%;
  height: auto;
}

.kirin-right {
  width: 56%;
}

.kirin-title {
  margin-bottom: 30px;
}
.kirin-title h1 {
  display: inline;
  color: #4c91b8;
  font-size: 60px;
  line-height: 1;
}
.kirin-title span {
  color: #4c91b8;
  font-size: 40px;
  padding-left: 20px;
}

.kirin-text {
  font-size: 20px;
  line-height: 1.6;
  margin-bottom: 20px;
}
.kirin-text span {
  font-size: 16px;
}

.kirin-amenity {
  padding-left: 15px;
  border-left: 4px solid #4c91b8;
}

.kirin-mb {
  margin-bottom: 30px;
}

.kirin-status {
  border: 2px solid #4c91b8;
  text-align: center;
}

.status-date {
  font-size: 24px;
  text-align: center;
  padding: 10px 0;
  color: #4c91b8;
}

.states-box {
  background: #4c91b8;
  color: #fff;
  padding: 20px 0;
}

.status-ttl {
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 30px;
}
.status-ttl small {
  font-size: 15px;
}

.status-body {
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 30px;
}

.status-cont {
  width: 50%;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.4;
}
.status-cont b {
  font-size: 15px;
}
.status-cont:nth-child(1) {
  border-right: 1px solid #fff;
}
.status-cont span {
  font-size: 48px;
}

.status-memo {
  font-size: 18px;
}

/* -----------------------------------------------------------
スノーカート
----------------------------------------------------------- */
.cart-wrapper {
  width: 100vw;
  height: 100vh;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

.cart-inner {
  width: 1600px;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}

.cart-left {
  width: 40%;
}
.cart-left p:first-child {
  margin-bottom: 30px;
}
.cart-left p img {
  width: 100%;
  height: auto;
}

.cart-right {
  width: 56%;
}

.cart-title {
  margin-bottom: 30px;
}
.cart-title h1 {
  display: block;
  color: #4c91b8;
  font-size: 56px;
  line-height: 1.2;
  margin-bottom: 30px;
}

.cart-ttl-en {
  color: #4c91b8;
  font-size: 40px;
}

.cart-text {
  font-size: 20px;
  line-height: 1.6;
  margin-bottom: 50px;
}
.cart-text span {
  font-size: 20px;
}

.cart-status {
  border: 2px solid #4c91b8;
  text-align: center;
}

.cart-status-date {
  font-size: 24px;
  text-align: center;
  padding: 10px 0;
  color: #4c91b8;
}

.cart-states-box {
  background: #4c91b8;
  color: #fff;
  padding: 20px 0;
}

.cart-status-ttl {
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 30px;
}
.cart-status-ttl small {
  font-size: 15px;
}

.cart-status-body {
  width: 100%;
  text-align: center;
}

.cart-status-icon {
  width: 100px;
  margin: 0 auto 30px;
}

.cart-status-text {
  font-size: 30px;
  font-weight: bold;
}

/* -----------------------------------------------------------
霧氷テラス
----------------------------------------------------------- */
.muhyo-wrapper {
  width: 100vw;
  height: 100vh;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

.muhyo-inner {
  width: 1600px;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}

.muhyo-left {
  width: 64%;
}
.muhyo-left p:first-child {
  margin-bottom: 30px;
}
.muhyo-left p img {
  width: 100%;
  height: auto;
}

.muhyo-right {
  width: 32%;
}

.muhyo-title h1 {
  display: block;
  color: #4c91b8;
  font-size: 56px;
  line-height: 1.2;
  margin-bottom: 30px;
}
.muhyo-title h1 span {
  background: #4c91b8;
  color: #fff;
  padding: 4px 8px;
  font-weight: bold;
  margin-right: 15px;
}

.muhyo-ttl-en,
.muhyo-ttl-ch {
  color: #4c91b8;
  font-size: 32px;
  line-height: 1.5;
}

.muhyo-ttl-en {
  margin-bottom: 30px;
}

.muhyo-text {
  font-size: 20px;
  line-height: 1.6;
  margin-bottom: 30px;
}
.muhyo-text span {
  font-size: 20px;
}

.muhyo-status {
  width: 100%;
  border: 2px solid #4c91b8;
  text-align: center;
}

.muhyo-status-date {
  font-size: 24px;
  text-align: center;
  padding: 10px 0;
  color: #4c91b8;
}

.muhyo-states-box {
  background: #4c91b8;
  color: #fff;
  padding: 20px 0;
}

.muhyo-status-ttl {
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 30px;
}
.muhyo-status-ttl small {
  font-size: 15px;
}

.muhyo-status-body {
  width: 100%;
  text-align: center;
}

.muhyo-status-icon {
  width: 100px;
  margin: 0 auto 30px;
}

.muhyo-status-text {
  font-size: 30px;
  font-weight: bold;
}

.muhyo-img {
  margin-bottom: 30px;
}
.muhyo-img img {
  width: 100%;
  height: auto;
}

.muhyo-note {
  font-size: 16px;
  margin-bottom: 30px;
}

.muhyo-ttl {
  font-size: 24px;
  font-weight: bold;
  color: #4c91b8;
  padding-bottom: 10px;
  margin-bottom: 15px;
  border-bottom: 2px solid #4c91b8;
}

/* -----------------------------------------------------------
ゲレンデインフォメーション
----------------------------------------------------------- */
.lift-wrapper {
  width: 100vw;
  height: 100vh;
  margin: 0 auto;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

.lift-inner {
  width: 1600px;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}

.lift-head {
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 30px;
}

.lift-left {
  width: 76%;
}

.lift-right {
  width: 24%;
  background: #ececf5;
  padding: 40px;
}

.lift-title {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: flex-end;
  line-height: 1;
}
.lift-title h1 {
  display: block;
  color: #4c91b8;
  font-size: 56px;
  padding-right: 50px;
}

.lift-ttl-en {
  color: #4c91b8;
  font-size: 32px;
}

.lift-map {
  position: relative;
}

.lift-map-base {
  position: relative;
  z-index: 0;
}
.lift-map-base img {
  width: 100%;
  height: auto;
}

.lift-map-line {
  position: absolute;
  z-index: 0;
}
.lift-map-line img {
  width: 100%;
  height: auto;
}

.lift-map-line-01 {
  left: 6.28%;
  top: 28.07%;
  width: 18.18%;
}

.lift-map-line-02 {
  left: 18.06%;
  top: 8.52%;
  width: 8.44%;
}

.lift-map-line-03 {
  left: 18.59%;
  top: 3.45%;
  width: 15.03%;
}

.lift-map-line-04 {
  left: 31.53%;
  top: 46%;
  width: 29.75%;
}

.lift-map-line-05 {
  left: 62.47%;
  top: 32.69%;
  width: 9.78%;
}

.lift-map-line-06 {
  left: 64.5%;
  top: 56.32%;
  width: 13.375%;
}

.lift-map-line-hanrei {
  right: 3.125%;
  top: 4.48%;
  width: 22%;
}

.lift-status-date {
  font-size: 18px;
}

.lift-info-ttl {
  font-size: 24px;
  font-weight: bold;
  color: #4c91b8;
  padding-bottom: 10px;
  margin-bottom: 30px;
  border-bottom: 2px solid #4c91b8;
}

.lift-info-box p {
  font-size: 20px;
  margin-bottom: 20px;
  line-height: 1.7;
}
.lift-info-box p:last-child {
  margin-bottom: 0;
}
.lift-info-box p.info-jp {
  font-size: 24px;
}

/* -----------------------------------------------------------
時刻表
----------------------------------------------------------- */
.timeschedule {
  width: 1728px;
  margin: 45px auto 0 auto;
}

.ts-wrapper {
  width: 100vw;
  height: 100vh;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
.ts-wrapper p {
  width: 1728px;
}
.ts-wrapper p img {
  width: 100%;
  height: auto;
}

/* -----------------------------------------------------------
スパ
----------------------------------------------------------- */
.spa-wrapper {
  width: 100vw;
  height: 100vh;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

.spa-inner {
  width: 1600px;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}

.spa-area {
  width: 100%;
  height: 60px;
  line-height: 60px;
  padding: 0 20px;
  background: #4c91b8;
  color: #fff;
  font-size: 32px;
  font-weight: bold;
}
.spa-area span {
  font-family: Helvetica;
  font-size: 24px;
}

.spa-hotel {
  font-weight: bold;
  font-size: 20px;
  padding-top: 20px;
  line-height: 1.7;
  color: #4c91b8;
}

.spa-lead {
  font-size: 18px;
  padding-bottom: 15px;
  line-height: 1.4;
}

.spa-list {
  width: 100%;
}
.spa-list li {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 100%;
  padding: 20px 0;
  border-bottom: 2px solid #4c91b8;
}
.spa-list li:last-child {
  border: none;
}

.spa-img {
  width: 30%;
  max-height: 20vw;
  overflow: hidden;
}
.spa-img img {
  width: 100%;
  height: auto;
}

.spa-right {
  width: 26%;
  background: #4c91b8;
  flex-shrink: 0;
}

.spa-status {
  position: relative;
  border: 2px solid #4c91b8;
  text-align: center;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  height: 100%;
  line-height: 1;
}

.spa-status-date {
  width: calc(100% - 2px);
  position: absolute;
  top: 1px;
  left: 1px;
  font-size: 20px;
  text-align: center;
  padding: 10px 0;
  color: #4c91b8;
  background: #fff;
}

.spa-states-box {
  background: #4c91b8;
  color: #fff;
  padding: 40px 0 0 0;
}

.spa-status-ttl {
  font-size: 22px;
  font-weight: bold;
  margin-bottom: 20px;
}
.spa-status-ttl small {
  font-size: 15px;
}

.spa-status-body {
  width: 100%;
  text-align: center;
}

.spa-status-icon {
  margin: 0 auto 20px;
  font-size: 48px;
  font-weight: bold;
  width: 100%;
  text-align: center;
}
.spa-status-icon img {
  width: 70px;
  height: auto;
  margin: 0 auto;
}

.spa-status-icon-s {
  line-height: 1.3;
  font-size: 34px;
}
.spa-status-icon-s small {
  font-size: 24px;
}
.spa-status-icon-s br {
  display: none;
}

.spa-status-text {
  font-size: 24px;
  font-weight: bold;
}

.spa-name {
  font-size: 28px;
  font-weight: bold;
  color: #4c91b8;
  margin-bottom: 10px;
  width: 100%;
}

.spa-name-long {
  font-size: 24px;
}

.spa-eng {
  font-family: Helvetica;
  font-size: 22px;
  color: #4c91b8;
  font-weight: bold;
  margin-bottom: 10px;
  width: 100%;
}

.spa-center {
  width: 38%;
}

.spa-info {
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
}
.spa-info dl {
  width: 46%;
}
.spa-info dl.dl-long {
  width: 100%;
  margin-bottom: 30px;
}
.spa-info dl:last-child {
  margin-bottom: 0;
}
.spa-info dl dt {
  font-size: 22px;
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: 1px solid #4c91b8;
  font-weight: bold;
  color: #4c91b8;
}
.spa-info dl dt span {
  font-size: 18px;
  font-family: Helvetica;
}
.spa-info dl dd {
  font-size: 20px;
  line-height: 1.5;
}

/*# sourceMappingURL=signage.css.map */
