@charset "UTF-8";
/* [ Yamaha Marina Hamanako ] : safetyinfo.scss */
/* [ Yamaha Marina Hamanako ] : setting.scss */
/* +++ [ ブレイクポイント ] ++++ */
/* +++ [ 幅 ] ++++ */
/* +++ [ 余白 ] ++++ */
/* +++ [ 色 ] ++++ */
/* [ 碧系 ] */
/* [ 青系 ] */
/* [ 灰系 ] */
/* [ 黒系 ] */
/* [ 白系 ] */
/* [ 赤系 ] */
/* [ 橙系 ] */
/* [ 赤系 ] */
/* [ アイコン系 ] */
/* +++ [ レスポンシブ ] +++ */
/* +++ [ 動き ] +++ */
/* +++ [ リセット ] ++++ */
/* +++ [ フォント ] ++++ */
/*==================================================*
 *  [ Common ]
 *==================================================*/
main {
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  main {
    padding-top: 60px;
  }
}

/*==================================================*
 *  [ Main Image ]
 *==================================================*/
@media screen and (max-width: 767px) {
  #contents {
    padding: 0 10px;
  }
}

.top-main {
  position: relative;
  overflow: hidden;
}
@media print, screen and (min-width: 768px) {
  .top-main {
    height: 370px;
    margin-bottom: 50px;
  }
}
@media screen and (max-width: 767px) {
  .top-main {
    height: 140px;
  }
  .top-main h1 {
    color: #ffffff;
    font-size: 1.4rem;
    font-weight: 700;
    padding-top: 85px;
  }
}

/*==================================================*
 *  [ コンテンツ内 ]
 *==================================================*/
.ttl-sline {
  color: #003063;
  font-weight: 700;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  .ttl-sline {
    font-size: 3.0rem;
    margin-bottom: 45px;
  }
}
@media screen and (max-width: 767px) {
  .ttl-sline {
    font-size: 2.2rem;
    margin-bottom: 30px;
  }
}

p {
  font-weight: 400;
}
@media print, screen and (min-width: 768px) {
  p {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  p {
    font-size: 1.4rem;
  }
}

.ttl-mplus {
  font-weight: 700;
}
@media print, screen and (min-width: 768px) {
  .ttl-mplus {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  .ttl-mplus {
    font-size: 1.8rem;
  }
}

.btn-link {
  padding-left: 30px;
  background: url("../../shared/img/icon_arrow_wh.svg") #003063 center left no-repeat;
  background-size: 30px 16px;
}
.btn-link::before {
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 50px;
  margin: auto;
  width: 50px;
}
@media screen and (max-width: 767px) {
  .btn-link {
    width: 90%;
    font-size: 1.2rem;
  }
}

@media screen and (max-width: 767px) {
  .table-wrap {
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
  }

  .table-price {
    width: max(680px, 100%);
    border-spacing: 0;
    border-left: none;
  }
  .table-price tr th, .table-price tr td {
    white-space: nowrap;
  }
  .table-price tr th:first-child {
    position: -webkit-sticky;
    position: sticky;
    left: 0;
    border-left: none;
    border-right: none;
    z-index: +1;
  }
  .table-price tr th:first-child::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-left: 1px solid #aaa;
    border-right: 1px solid #aaa;
  }

  .table-price, th, td {
    transform: translateZ(0);
  }
}
