#mainContent .mainContentInner {
  padding: 35px 0 110px; }

.top h1 {
  position: relative;
  padding-bottom: 45px;
  font-size: 32px;
  font-weight: bold;
  text-align: center; }
  .top h1:before {
    content: "";
    position: absolute;
    width: 100px;
    height: 3px;
    left: 50%;
    bottom: 0;
    background: #d2961e;
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%); }
  @media only screen and (min-width: 1px) and (max-width: 750px) {
    .top h1 {
      font-size: 48px; }
      .top h1:before {
        height: 6px; } }
  .top h1 + .companyWrap {
    margin-top: 45px; }
    @media only screen and (min-width: 1px) and (max-width: 750px) {
      .top h1 + .companyWrap {
        margin-top: 40px; } }
.top .companyWrap {
  margin-top: 95px; }
  @media only screen and (min-width: 1px) and (max-width: 750px) {
    .top .companyWrap {
      margin-top: 84px; } }
  .top .companyWrap h2 {
    text-align: center; }
    .top .companyWrap h2 .jp {
      margin-top: 5px; }
      @media only screen and (min-width: 1px) and (max-width: 750px) {
        .top .companyWrap h2 .jp {
          margin-top: 10px; } }
@media only screen and (min-width: 751px), print {
  .top .contentList {
    display: flex;
    margin-top: 24px;
    flex-wrap: wrap;
    justify-content: center; } }
@media only screen and (min-width: 751px), print {
  .top .contentList .contentBox {
    width: 390px;
    margin-left: 10px; }
    .top .contentList .contentBox:nth-child(3n+1) {
      margin-left: 0; }
    .top .contentList .contentBox:nth-child(n+4) {
      margin-top: 44px; } }
@media only screen and (min-width: 1px) and (max-width: 750px) {
  .top .contentList .contentBox {
    margin-top: 40px; } }
.top .contentList .contentBox a {
  position: relative;
  color: #000; }
  @media only screen and (min-width: 751px), print {
    .top .contentList .contentBox a:before, .top .contentList .contentBox a:after {
      content: "";
      position: absolute; }
    .top .contentList .contentBox a:before {
      width: 100%;
      height: 100%;
      top: 0;
      left: 0;
      opacity: 0;
      -webkit-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -ms-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -o-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      -ms-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
      transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
    .top .contentList .contentBox a:after {
      width: 24px;
      height: 24px;
      right: 0;
      bottom: 0;
      background: url(../img/arw_content.png) no-repeat; }
    .top .contentList .contentBox a:hover {
      text-decoration: none; }
      .top .contentList .contentBox a:hover:before {
        opacity: 1;
        -moz-box-shadow: 0 0 0 5px #004389 inset;
        -webkit-box-shadow: 0 0 0 5px #004389 inset;
        box-shadow: 0 0 0 5px #004389 inset; } }
.top .contentList .contentBox .title {
  height: calc(100% - 196px);
  padding: 10px 40px 15px;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  border: 1px solid #ccc;
  border-top: 0;
  background: #fff; }
  @media only screen and (min-width: 1px) and (max-width: 750px) {
    .top .contentList .contentBox .title {
      position: relative;
      padding: 18px 50px;
      padding-left: 30px;
      font-size: 32px;
      text-align: left;
      border-width: 2px; }
      .top .contentList .contentBox .title:before {
        content: "";
        position: absolute;
        width: 44px;
        height: 44px;
        right: 22px;
        bottom: 50%;
        background: url(../img/arw_content_sp.png) no-repeat;
        -moz-transform: translateY(50%);
        -ms-transform: translateY(50%);
        -webkit-transform: translateY(50%);
        transform: translateY(50%); } }

.detail #mainImageWrap {
  position: relative;
  height: 560px; }
  @media only screen and (min-width: 1px) and (max-width: 750px) {
    .detail #mainImageWrap {
      height: 620px; } }
  .detail #mainImageWrap .bg {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-size: cover !important;
    background-position: center center !important; }
  .detail #mainImageWrap h1 {
    display: flex;
    position: absolute;
    width: 100%;
    height: 120px;
    left: 0;
    bottom: 0;
    color: #fff;
    text-align: center;
    justify-content: center;
    align-items: center;
    background: rgba(0, 0, 0, 0.5);
    text-shadow: 4px 4px 4px rgba(0, 0, 0, 0.4); }
    .detail #mainImageWrap h1 .shipName {
      display: inline-block; }
    .detail #mainImageWrap h1 .jp {
      font-size: 50px;
      font-weight: bold;
      line-height: 60px; }
    .detail #mainImageWrap h1 .en {
      font-size: 20px; }
    @media only screen and (min-width: 1px) and (max-width: 750px) {
      .detail #mainImageWrap h1 {
        height: 160px; }
        .detail #mainImageWrap h1 .jp {
          font-size: 56px; }
        .detail #mainImageWrap h1 .en {
          font-size: 26px; } }
  .detail #mainImageWrap .floatLink {
    position: absolute;
    top: 30px;
    left: 30px; }
    @media only screen and (min-width: 1px) and (max-width: 750px) {
      .detail #mainImageWrap .floatLink {
        top: 20px;
        left: 20px; } }
@media only screen and (min-width: 1px) and (max-width: 750px) {
  .detail .headBlock {
    padding: 0 20px; } }
.detail .headBlock h2 {
  color: #004389;
  font-size: 28px;
  font-weight: bold;
  text-align: center; }
  @media only screen and (min-width: 1px) and (max-width: 750px) {
    .detail .headBlock h2 {
      font-size: 44px; } }
.detail .headBlock .leadWrap {
  margin-top: 40px;
  text-align: center; }
  @media only screen and (min-width: 1px) and (max-width: 750px) {
    .detail .headBlock .leadWrap {
      font-size: 28px;
      text-align: left; } }
@media only screen and (min-width: 751px), print {
  .detail .headBlock .specWrap {
    display: flex;
    margin-top: 45px; }
    .detail .headBlock .specWrap dl {
      display: flex;
      width: 276px;
      font-size: 14px;
      flex-wrap: wrap;
      justify-content: space-between; }
      .detail .headBlock .specWrap dl:nth-child(n+2) {
        margin-left: 35px; }
      .detail .headBlock .specWrap dl dt, .detail .headBlock .specWrap dl dd {
        padding: 5px 0;
        padding-left: 8px;
        border-bottom: 1px solid #9B9B9B; }
      .detail .headBlock .specWrap dl dt {
        width: 120px;
        font-weight: bold; }
        .detail .headBlock .specWrap dl dt:first-child {
          border-top: 1px solid #9B9B9B; }
          .detail .headBlock .specWrap dl dt:first-child + dd {
            border-top: 1px solid #9B9B9B; }
      .detail .headBlock .specWrap dl dd {
        width: 145px; } }
@media only screen and (min-width: 1px) and (max-width: 750px) {
  .detail .headBlock .specWrap {
    margin-top: 50px; }
    .detail .headBlock .specWrap dl {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between; }
      .detail .headBlock .specWrap dl dt, .detail .headBlock .specWrap dl dd {
        padding: 12px 18px;
        border-top: 2px solid #9B9B9B; }
      .detail .headBlock .specWrap dl dt {
        width: 280px;
        font-weight: bold; }
      .detail .headBlock .specWrap dl dd {
        width: 350px; } }
.detail .contentBlock {
  margin-top: 55px; }
  @media only screen and (min-width: 1px) and (max-width: 750px) {
    .detail .contentBlock .contentInner {
      padding: 0 25px; } }
  .detail .contentBlock h3 {
    position: relative;
    padding-left: 65px;
    color: #fff;
    font-size: 22px;
    font-weight: bold;
    line-height: 50px;
    background: #5B9ACD; }
    .detail .contentBlock h3:before {
      content: "";
      position: absolute;
      width: 34px;
      height: 100%;
      top: 0;
      left: 20px; }
    @media only screen and (min-width: 1px) and (max-width: 750px) {
      .detail .contentBlock h3 {
        padding-left: 120px;
        font-size: 44px;
        line-height: 106px; }
        .detail .contentBlock h3:before {
          width: 68px; } }
  .detail .contentBlock .contentBody {
    margin-top: 10px;
    padding: 30px 50px 45px;
    background: #E1F1FF; }
    @media only screen and (min-width: 1px) and (max-width: 750px) {
      .detail .contentBlock .contentBody {
        margin-top: 20px;
        padding: 60px 20px; } }
.detail .content01 h3:before {
  background: url(../../ship/img/detail/icon_content01.png) no-repeat center center; }
  @media only screen and (min-width: 1px) and (max-width: 750px) {
    .detail .content01 h3:before {
      background: url(../../ship/img/detail/icon_content01_sp.png) no-repeat center center; } }
.detail .content01 .sliderWrap {
  position: relative; }
  .detail .content01 .sliderWrap .slider {
    width: 1000px;
    margin: auto;
    white-space: nowrap;
    font-size: 0;
    overflow: hidden;
    border: 1px solid #ccc;
    background: #fff; }
    @media only screen and (min-width: 1px) and (max-width: 750px) {
      .detail .content01 .sliderWrap .slider {
        width: 100%;
        border-width: 2px; } }
    .detail .content01 .sliderWrap .slider li {
      display: inline-block;
      width: 100%; }
      @media only screen and (min-width: 751px), print {
        .detail .content01 .sliderWrap .slider li {
          font-size: 16px; }
          .detail .content01 .sliderWrap .slider li .slideInner {
            display: flex;
            padding: 40px 40px 20px;
            justify-content: space-between; }
            .detail .content01 .sliderWrap .slider li .slideInner .imgWrap {
              width: 400px; }
              .detail .content01 .sliderWrap .slider li .slideInner .imgWrap .caption {
                margin-top: 10px;
                text-align: center;
                white-space: normal; }
            .detail .content01 .sliderWrap .slider li .slideInner .detailWrap {
              width: 460px; }
              .detail .content01 .sliderWrap .slider li .slideInner .detailWrap dt, .detail .content01 .sliderWrap .slider li .slideInner .detailWrap dd {
                white-space: normal; }
              .detail .content01 .sliderWrap .slider li .slideInner .detailWrap dt {
                color: #004389;
                font-size: 28px;
                font-weight: bold; }
              .detail .content01 .sliderWrap .slider li .slideInner .detailWrap dd {
                margin-top: 25px; } }
      @media only screen and (min-width: 1px) and (max-width: 750px) {
        .detail .content01 .sliderWrap .slider li .slideInner {
          padding: 8px 8px 35px; }
          .detail .content01 .sliderWrap .slider li .slideInner .imgWrap .caption {
            font-size: 24px;
            text-align: center;
            white-space: normal; }
          .detail .content01 .sliderWrap .slider li .slideInner .detailWrap {
            margin-top: 20px;
            padding: 0 20px; }
            .detail .content01 .sliderWrap .slider li .slideInner .detailWrap dt, .detail .content01 .sliderWrap .slider li .slideInner .detailWrap dd {
              white-space: normal; }
            .detail .content01 .sliderWrap .slider li .slideInner .detailWrap dt {
              color: #004389;
              font-size: 48px;
              font-weight: bold; }
            .detail .content01 .sliderWrap .slider li .slideInner .detailWrap dd {
              margin-top: 20px;
              font-size: 28px; } }
  .detail .content01 .sliderWrap .control .btn {
    position: absolute;
    width: 44px;
    height: 44px;
    top: 50%;
    margin-top: -22px;
    cursor: pointer; }
    @media only screen and (min-width: 751px), print {
      .detail .content01 .sliderWrap .control .btn {
        -webkit-transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
        -ms-transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
        -o-transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
        -ms-transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
        transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
        .detail .content01 .sliderWrap .control .btn:hover {
          opacity: 0.6; } }
    @media only screen and (min-width: 1px) and (max-width: 750px) {
      .detail .content01 .sliderWrap .control .btn {
        top: 160px;
        width: 36px;
        height: 76px;
        margin-top: 0;
        background: rgba(255, 255, 255, 0.5);
        z-index: 3; } }
    .detail .content01 .sliderWrap .control .btn:before, .detail .content01 .sliderWrap .control .btn:after {
      content: "";
      position: absolute;
      width: 100%;
      height: 3px;
      top: 0;
      left: 0;
      background: #003258; }
      @media only screen and (min-width: 1px) and (max-width: 750px) {
        .detail .content01 .sliderWrap .control .btn:before, .detail .content01 .sliderWrap .control .btn:after {
          top: 50%;
          margin-top: -1px; } }
    @media only screen and (min-width: 751px), print {
      .detail .content01 .sliderWrap .control .btn:after {
        -moz-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
        -webkit-transform: rotate(90deg);
        transform: rotate(90deg);
        -moz-transform-origin: left top;
        -ms-transform-origin: left top;
        -webkit-transform-origin: left top;
        transform-origin: left top; }
      .detail .content01 .sliderWrap .control .btn.prev {
        left: 0;
        -moz-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg); }
      .detail .content01 .sliderWrap .control .btn.next {
        right: 0;
        -moz-transform: rotate(135deg);
        -ms-transform: rotate(135deg);
        -webkit-transform: rotate(135deg);
        transform: rotate(135deg); } }
    @media only screen and (min-width: 1px) and (max-width: 750px) {
      .detail .content01 .sliderWrap .control .btn:before {
        -moz-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg); }
      .detail .content01 .sliderWrap .control .btn:after {
        -moz-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
      .detail .content01 .sliderWrap .control .btn.prev {
        left: 8px; }
        .detail .content01 .sliderWrap .control .btn.prev:before, .detail .content01 .sliderWrap .control .btn.prev:after {
          -moz-transform-origin: left center;
          -ms-transform-origin: left center;
          -webkit-transform-origin: left center;
          transform-origin: left center; }
      .detail .content01 .sliderWrap .control .btn.next {
        right: 8px; }
        .detail .content01 .sliderWrap .control .btn.next:before, .detail .content01 .sliderWrap .control .btn.next:after {
          -moz-transform-origin: right center;
          -ms-transform-origin: right center;
          -webkit-transform-origin: right center;
          transform-origin: right center; } }
  .detail .content01 .sliderWrap .navWrap {
    margin-top: 24px; }
    .detail .content01 .sliderWrap .navWrap .nav {
      text-align: center;
      font-size: 0; }
      @media only screen and (min-width: 751px), print {
        .detail .content01 .sliderWrap .navWrap .nav li {
          display: inline-block;
          position: relative;
          cursor: pointer;
          -webkit-transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
          -ms-transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
          -o-transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
          -ms-transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
          transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
          .detail .content01 .sliderWrap .navWrap .nav li:hover {
            opacity: 0.6; }
          .detail .content01 .sliderWrap .navWrap .nav li:nth-child(n+2) {
            margin-left: 4px; }
          .detail .content01 .sliderWrap .navWrap .nav li:before {
            content: "";
            position: absolute;
            width: 100%;
            height: 100%;
            top: 0;
            left: 0;
            opacity: 0;
            -webkit-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
            -ms-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
            -o-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
            -ms-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
            transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
          .detail .content01 .sliderWrap .navWrap .nav li.active:before {
            opacity: 1;
            -moz-box-shadow: 0 0 0 5px #004389 inset;
            -webkit-box-shadow: 0 0 0 5px #004389 inset;
            box-shadow: 0 0 0 5px #004389 inset; } }
      @media only screen and (min-width: 1px) and (max-width: 750px) {
        .detail .content01 .sliderWrap .navWrap .nav {
          display: flex;
          background: #aeaeae; }
          .detail .content01 .sliderWrap .navWrap .nav li {
            height: 10px;
            flex-grow: 1; }
            .detail .content01 .sliderWrap .navWrap .nav li.active {
              background: #E6E6E6; }
            .detail .content01 .sliderWrap .navWrap .nav li img {
              display: none; } }
      .detail .content01 .sliderWrap .navWrap .nav li img {
        width: 46px;
        height: 26px; }
.detail .content02 h3:before {
  background: url(../../ship/img/detail/icon_content02.png) no-repeat center center; }
  @media only screen and (min-width: 1px) and (max-width: 750px) {
    .detail .content02 h3:before {
      background: url(../../ship/img/detail/icon_content02_sp.png) no-repeat center center; } }
@media only screen and (min-width: 751px), print {
  .detail .content02 .contentList {
    display: flex;
    flex-wrap: wrap; } }
@media only screen and (min-width: 751px), print {
  .detail .content02 .contentList .contentBox {
    width: 340px;
    margin-left: 40px; }
    .detail .content02 .contentList .contentBox:nth-child(3n+1) {
      margin-left: 0; }
    .detail .content02 .contentList .contentBox:nth-child(n+4) {
      margin-top: 35px; } }
@media only screen and (min-width: 1px) and (max-width: 750px) {
  .detail .content02 .contentList .contentBox:nth-child(n+2) {
    margin-top: 45px; } }
.detail .content02 .contentList .contentBox .roomSpec {
  margin-top: 10px; }
  .detail .content02 .contentList .contentBox .roomSpec > dt {
    font-size: 20px;
    font-weight: bold; }
    @media only screen and (min-width: 1px) and (max-width: 750px) {
      .detail .content02 .contentList .contentBox .roomSpec > dt {
        font-size: 40px; } }
  .detail .content02 .contentList .contentBox .roomSpec > dd {
    margin-top: 10px;
    font-size: 14px; }
    @media only screen and (min-width: 1px) and (max-width: 750px) {
      .detail .content02 .contentList .contentBox .roomSpec > dd {
        font-size: 28px; } }
  .detail .content02 .contentList .contentBox .roomSpec .detailWrap {
    display: flex;
    flex-wrap: wrap; }
    .detail .content02 .contentList .contentBox .roomSpec .detailWrap dt, .detail .content02 .contentList .contentBox .roomSpec .detailWrap dd {
      display: flex;
      align-items: center; }
      .detail .content02 .contentList .contentBox .roomSpec .detailWrap dt.wide, .detail .content02 .contentList .contentBox .roomSpec .detailWrap dd.wide {
        margin-top: 10px; }
    .detail .content02 .contentList .contentBox .roomSpec .detailWrap dt {
      width: 108px;
      color: #fff;
      background: #004389;
      justify-content: center; }
      @media only screen and (min-width: 1px) and (max-width: 750px) {
        .detail .content02 .contentList .contentBox .roomSpec .detailWrap dt {
          width: 216px; } }
    .detail .content02 .contentList .contentBox .roomSpec .detailWrap dd {
      width: 62px;
      padding-left: 10px;
      font-size: 16px; }
      @media only screen and (min-width: 1px) and (max-width: 750px) {
        .detail .content02 .contentList .contentBox .roomSpec .detailWrap dd {
          width: 114px;
          font-size: 32px; } }
      .detail .content02 .contentList .contentBox .roomSpec .detailWrap dd.wide {
        width: 232px; }
        @media only screen and (min-width: 1px) and (max-width: 750px) {
          .detail .content02 .contentList .contentBox .roomSpec .detailWrap dd.wide {
            width: 444px; } }
.detail .content02 hr {
  margin: 2em 0; }
.detail .content02 .indentList li:nth-child(n+2) {
  margin-top: 5px; }
.detail .content03 h3:before {
  background: url(../../ship/img/detail/icon_content03.png) no-repeat center center; }
  @media only screen and (min-width: 1px) and (max-width: 750px) {
    .detail .content03 h3:before {
      background: url(../../ship/img/detail/icon_content03_sp.png) no-repeat center center; } }
.detail .content04 h3:before {
  background: url(../../ship/img/detail/icon_content04.png) no-repeat center center; }
.detail .content04 .floorList li {
  display: table;
  width: 100%;
  border: 1px solid #ccc;
  background: #fff; }
  .detail .content04 .floorList li .floorNumber, .detail .content04 .floorList li .floorImg {
    display: table-cell;
    vertical-align: middle; }
  .detail .content04 .floorList li .floorNumber {
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    border-right: 1px solid #ccc;
    background: #F2F2F2;
    width: 300px; }
  .detail .content04 .floorList li .floorImg {
    padding: 25px; }
  .detail .content04 .floorList li:nth-child(n+2) {
    margin-top: 10px; }
@media only screen and (min-width: 751px), print {
  .detail .linkBlock {
    margin-top: 50px; }
    .detail .linkBlock .btnWrap {
      display: flex;
      justify-content: center; }
    .detail .linkBlock .btnStyle {
      margin: 0; }
      .detail .linkBlock .btnStyle:nth-child(n+2) {
        margin-left: 30px; } }
@media only screen and (min-width: 1px) and (max-width: 750px) {
  .detail .linkBlock .btnWrap {
    padding: 0 25px; }
  .detail .linkBlock .btnStyle {
    width: 100%;
    margin-top: 40px; } }
