@charset "UTF-8";
/* =========================================================
 * reset　　　    /*リセット
========================================================= */
@import url("https://fonts.googleapis.com/css2?family=Barlow+Condensed:ital,wght@0,100;0,300;0,400;0,500;1,100;1,400;1,500&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;500;600;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Sawarabi+Gothic&display=swap");
blockquote, body, div, dl, dt, dd, fieldset, form, h1, h2, h3, h4, h5, h6, input, li, ol, p, pre, select, span, textarea, td, th, ul, figure, figcaption {
  margin: 0px;
  padding: 0px; }

fieldset, img {
  border: 0; }

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal; }

ol {
  list-style-type: none; }

ul {
  list-style-type: none; }
  ul li {
    list-style-type: none; }

img {
  border: none;
  vertical-align: bottom; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

caption, th {
  text-align: left; }

iframe {
  border: none; }

a:focus {
  outline: none; }

address, caption, cite, code, dfn, em, strong, th, var {
  font-style: normal;
  font-weight: normal; }

li img {
  line-height: 0;
  font-size: 0;
  vertical-align: top; }

/* IE */
* html ul li dl, * html ol li dl {
  display: inline; }
*:first-child + html ul li dl, *:first-child + html ol li dl {
  display: inline; }

/* =========================================================
 * default settings      　   /*デフォルトセッティング
========================================================= */
html {
  font-size: 62.5%; }

* {
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  word-break: break-all; }

p {
  line-break: strict; }

a {
  color: #333;
  text-decoration: none;
  -webkit-transition: opacity 0.3s ease-out;
  -moz-transition: opacity 0.3s ease-out;
  -ms-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out; }
  a:hover {
    opacity: 0.7;
    -webkit-opacity: .7;
    -moz-opacity: .7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)"; }

body {
  font-size: 1.4rem;
  font: inherit;
  font-family: 'Sawarabi Gothic', 'Noto Sans Japanese', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-weight: 500;
        font-size: 16px;
  line-height: 1.4;
  background: #fff;
  -webkit-text-size-adjust: 100%;
  color: #333; }

#wrapper {
  width: 100%; }

.pc {
  display: block; }

.sp {
  display: none; }

.hide, .hidden {
  visibility: hidden; }

img {
  max-width: 100%; }

article {
  display: block; }

@media screen and (max-width: 767px) {
  a {
    -webkit-transition: none;
    -moz-transition: none;
    -ms-transition: none;
    transition: none; }
    a:hover {
      opacity: 1;
      -webkit-opacity: 1;
      -moz-opacity: 1;
      filter: alpha(opacity=100);
      /* IE lt 8 */
      -ms-filter: "alpha(opacity=100)";
      /* IE 8 */ }

  body {
    -webkit-text-size-adjust: 100%;
    background: #fff;
    min-width: 100%;
    font-family: 'Sawarabi Gothic', 'Noto Sans Japanese', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
    font-family: sans-serif;
    font-weight: 500; }

  img {
    width: 100%; }

  .pc {
    display: none; }

  .sp {
    display: block; }

  input[type="submit"] {
    -webkit-appearance: none; } }
/* =========================================================
 * font
========================================================= */
.font-barlow {
  font-family: 'Barlow Condensed',serif; }

.font-noto {
  font-family: 'Noto Sans Japanese', sans-serif; }

.font-serif {
  font-family: 'Noto Serif JP', serif; }

.font-sawarabi {
  font-family: 'Noto Serif JP', serif; }

/* =========================================================
 * clearfix　　   /*クリアフィックス
========================================================= */
.clearfix {
  zoom: 1; }
  .clearfix:before {
    content: "";
    display: table; }
  .clearfix:after {
    content: "";
    display: table;
    clear: both; }

body.pc {
  display: block; }

header {
  position: fixed;
  top: 0;
  height: auto;
  width: 100%;
  margin: 0 auto;
  z-index: 999;
  display: none;
  justify-content: space-between;
  align-items: center;
  /*　ハンバーガーボタン　*/
  /* ナビ開いてる時のボタン */ }
  header.backnone {
    background: none; }
  header a {
    text-decoration: none; }
  header .logo_area a h1 {
    width: 320px;
    margin: 30px 10px 0;
    padding: 0 10px;
    align-items: center; }
  header .hamburger {
    position: fixed;
    z-index: 3;
    right: 15px;
    top: 15px;
    width: 75px;
    height: 75px;
    cursor: pointer;
    text-align: center;
    background: #003894;
    color: #fff; }
  header .hamburger span {
    display: block;
    position: absolute;
    width: 30px;
    height: 2px;
    left: 22.5px;
    background: #fff;
    -webkit-transition: 0.5s ease-in-out;
    -moz-transition: 0.5s ease-in-out;
    transition: 0.5s ease-in-out; }
  header .hamburger span:nth-child(1) {
    top: 20px; }
  header .hamburger span:nth-child(2) {
    top: 30px; }
  header .hamburger span:nth-child(3) {
    top: 40px; }
  header .hamburger p {
    position: absolute;
    bottom: 5px;
    width: 100%;
    text-align: center;
    font-size: 15px; }
  header .hamburger.active span:nth-child(1) {
    top: 30px;
    left: 22.5px;
    -webkit-transform: rotate(315deg);
    -moz-transform: rotate(315deg);
    transform: rotate(315deg); }
  header .hamburger.active span:nth-child(2),
  header .hamburger.active span:nth-child(3) {
    top: 30px;
    -webkit-transform: rotate(-315deg);
    -moz-transform: rotate(-315deg);
    transform: rotate(-315deg); }
  header .navicont {
    width: calc(100% - 310px); }
    header .navicont .nav_head_or {
      position: absolute;
      top: 15px;
      right: 480px;
      width: 110px;
      height: 75px;
      background: #fff; }
      header .navicont .nav_head_or a {
        display: block;
        padding: 13px 0;
        text-align: center; }
        header .navicont .nav_head_or a img {
          width: 85px; }
    header .navicont .nav_head_pr {
      position: absolute;
      top: 15px;
      right: 355px;
      width: 110px;
      height: 75px;
      background: #fff; }
      header .navicont .nav_head_pr a {
        display: block;
        padding: 13px 0;
        text-align: center; }
        header .navicont .nav_head_pr a img {
          width: 85px; }
    header .navicont .reserve {
          position: fixed;
    top: 15px;
    right: 105px;
    background: #fff;
    height: 75px;
    width: 235px;
    z-index: 3;
    box-sizing: border-box;
    border: 2px solid red;}
      header .navicont .reserve a {
        display: block;
        text-align: center;
        padding: 18px 0; }
        header .navicont .reserve a img {
          width: 200px; }
    header .navicont .naviinnercont {
      display: none;
      position: absolute;
      background: #003894;
      top: 15px;
      right: 15px; }
      header .navicont .naviinnercont ul {
        width: 325px;
        padding-top: 90px;
        padding-bottom: 50px; }
        header .navicont .naviinnercont ul li {
          font-size: 16px;
          letter-spacing: 0.1em;
          padding: 0px 0px 0px 15px; }
          header .navicont .naviinnercont ul li a {
            display: block;
            color: #fff;
            text-decoration: none;
            position: relative;
            border-bottom: 1px solid #fff;
            padding: 15px 0; }
            header .navicont .naviinnercont ul li a:after {
              position: absolute;
              content: "";
              height: 10px;
              width: 10px;
              border-top: 1px solid #fff;
              border-right: 1px solid #fff;
              right: 20px;
              top: 50%;
              margin-top: -4px;
              transform: rotate(45deg); }
  header.HeightMin {
    height: 75px;
    background: #fff; }
    header.HeightMin .logo_area h1 {
      margin: 0px 10px 0; }
    header.HeightMin .hamburger {
      right: 0px;
      top: 0px; }
    header.HeightMin .navicont .nav_head_or {
      top: 0px;
      right: 420px; }
    header.HeightMin .navicont .nav_head_pr {
      position: absolute;
      top: 0px;
      right: 310px; }
    header.HeightMin .navicont .reserve {
      position: fixed;
      top: 0px;
      right: 75px; }
    header.HeightMin .navicont .naviinnercont {
      top: 0px;
      right: 0px;
      width: 310px; }

.page {
  display: none;
position: relative;}

footer {
  width: 100%;
  position: relative; }
  footer .linkinner {
    background: #e60014;
    width: 100%;
    display: flex;
    justify-content: center;
    padding-bottom: 120px;
    position: relative; }
    footer .linkinner:before {
      position: absolute;
      content: "";
      width: 100%;
      height: 78px;
      margin-top: -75px;
      background: url("../../imgs/common/obi_r.svg") repeat-x bottom center; }
    footer .linkinner li {
      width: 210px;
      margin: 0 10px;
      padding-top: 20px;
      position: relative;
      z-index: 5; }
  footer .under {
    width: 100%;
    background: #003894;
    position: relative;
    color: #fff; }
    footer .under:before {
      position: absolute;
      content: "";
      width: 100%;
      height: 78px;
      margin-top: -75px;
      left: 0;
      background: url("../../imgs/common/obi_w.svg") repeat-x bottom center; }
    footer .under div {
      text-align: center; }
      footer .under div .logo {
        width: 310px;
        margin: 0 auto; }
      footer .under div .address {
        text-align: center;
        font-size: 14px;
        margin-top: 20px; }
      footer .under div ul {
        display: flex;
        justify-content: center;
        flex-wrap: wrap; }
        footer .under div ul li {
          font-size: 14px;
          margin: 5px 12px; }
          footer .under div ul li a {
            display: block;
            color: #fff;
            position: relative; }
            footer .under div ul li a:before {
              position: absolute;
              content: "";
              height: 15px;
              border-right: 1px solid #fff;
              right: -11px;
              top: 3px; }
          footer .under div ul li:last-child a:before {
            content: none; }
    footer .under address {
      text-align: center;
      font-size: 12px;
      letter-spacing: 0.06em;
      padding: 35px 0 50px; }
  footer .pagetop {
    position: absolute;
    bottom: 45px;
    width: 46px;
    right: 66px; }
  footer .footernavi {
    display: none; }

#reserve {
  top: 90px;
  right: 105px;
  overflow: hidden;
  height: 0;
  -moz-transition: height 0.4s;
  -o-transition: height 0.4s;
  -webkit-transition: height 0.4s;
  transition: height 0.4s;
  transform: none !important; }

#reserve #reserve_wrap::before {
  content: "";
  display: block;
  background-color: #0070bd;
  width: 100%;
  height: 5px;
  position: absolute;
  left: 0;
  top: 0px; }

#reserve #reserve_wrap::after {
  content: "";
  display: block;
  width: 0px;
  height: 0px;
  border: solid 8px #0070bd;
  border-left: solid 5px transparent;
  border-right: solid 5px transparent;
  border-bottom: solid 0px transparent;
  position: absolute;
  left: calc(50% - 5px);
  top: 5px;
  opacity: 1;
  z-index: 1; }

#reserve[data-edit=on].on {
  height: auto; }

#reserve #reserve_wrap {
  position: relative;
  width: 235px;
  padding: 15px 10px 10px;
  box-sizing: border-box;
  background-color: #FFF;
  border: solid 1px #EEE;
  border-top: none; }

#reserve #reserve_wrap form fieldset {
  overflow: hidden; }

#reserve #reserve_wrap form fieldset > * {
  float: left;
  display: inline-block; }

#reserve #reserve_wrap form > * {
  padding: 10px 0 0; }

fieldset, img {
  border: 0; }

#reserve #reserve_wrap form fieldset legend {
  font-size: 14px;
  line-height: 18px;
  padding: 0.4em 3px 0.4em 0; }

#reserve #reserve_wrap form fieldset #start_port_select_wrap, #reserve #reserve_wrap form fieldset #date_input_select_wrap, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap {
  position: relative;
  width: 160px; }

#reserve #reserve_wrap form #reserve_submit {
  width: 100%; }

#reserve #reserve_wrap form > * {
  padding: 10px 0 0; }

.pc #reserve #reserve_wrap form #reserve_submit > a {
  -moz-transition: background 0.4s;
  -o-transition: background 0.4s;
  -webkit-transition: background 0.4s;
  transition: background 0.4s; }

#reserve #reserve_wrap form #reserve_submit > a, #reserve #reserve_wrap form #reserve_submit > a:visited, #reserve #reserve_form_wrap form #reserve_submit > a, #reserve #reserve_form_wrap form #reserve_submit > a:visited, #reserve_cont #reserve_wrap form #reserve_submit > a, #reserve_cont #reserve_wrap form #reserve_submit > a:visited, #reserve_cont #reserve_form_wrap form #reserve_submit > a, #reserve_cont #reserve_form_wrap form #reserve_submit > a:visited {
  color: #FFF; }

#reserve #reserve_wrap form #reserve_submit > a {
  box-sizing: border-box;
  width: 100%; }

#reserve #reserve_wrap form #reserve_submit > a, #reserve #reserve_wrap form #reserve_submit > a:hover, #reserve #reserve_form_wrap form #reserve_submit > a, #reserve #reserve_form_wrap form #reserve_submit > a:hover, #reserve_cont #reserve_wrap form #reserve_submit > a, #reserve_cont #reserve_wrap form #reserve_submit > a:hover, #reserve_cont #reserve_form_wrap form #reserve_submit > a, #reserve_cont #reserve_form_wrap form #reserve_submit > a:hover {
  text-decoration: none; }

#reserve #reserve_wrap form #reserve_submit > a, #reserve #reserve_form_wrap form #reserve_submit > a, #reserve_cont #reserve_wrap form #reserve_submit > a, #reserve_cont #reserve_form_wrap form #reserve_submit > a {
  display: block;
  padding: 0.4em 0.8em;
  font-size: 14px;
  line-height: 18px;
  background-color: #FF8000;
  text-align: center;
  border-radius: 4px;
  box-sizing: border-box; }

.spbr {
  display: none; }

#reserve #reserve_wrap form #reserve_edit {
  width: 100%; }

#reserve #reserve_wrap form > * {
  padding: 10px 0 0; }

.pc #reserve #reserve_wrap form #reserve_edit > a {
  -moz-transition: background 0.4s;
  -o-transition: background 0.4s;
  -webkit-transition: background 0.4s;
  transition: background 0.4s; }

#reserve #reserve_wrap form #reserve_edit > a {
  box-sizing: border-box;
  width: 100%; }

#reserve #reserve_wrap form #reserve_edit > a, #reserve #reserve_form_wrap form #reserve_edit > a, #reserve_cont #reserve_wrap form #reserve_edit > a, #reserve_cont #reserve_form_wrap form #reserve_edit > a {
  display: block;
  padding: 0.46666em 0.2em;
  font-size: 12px;
  line-height: 18px;
  background-color: #333b90;
  text-align: center;
  border-radius: 4px;
  box-sizing: border-box; }

#reserve #reserve_wrap form #reserve_member {
  width: 100%; }

#reserve #reserve_wrap form > * {
  padding: 10px 0 0; }

#reserve #reserve_wrap form #reserve_member > a {
  box-sizing: border-box;
  width: 100%; }

#reserve #reserve_wrap form fieldset #start_port_select_wrap::before, #reserve #reserve_wrap form fieldset #start_port_select_wrap::after, #reserve #reserve_wrap form fieldset #start_port_select_wrap #start_port, #reserve #reserve_wrap form fieldset #start_port_select_wrap #date_input, #reserve #reserve_wrap form fieldset #date_input_select_wrap::before, #reserve #reserve_wrap form fieldset #date_input_select_wrap::after, #reserve #reserve_wrap form fieldset #date_input_select_wrap #start_port, #reserve #reserve_wrap form fieldset #date_input_select_wrap #date_input, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap::before, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap::after, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap #start_port, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap #date_input, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap::before, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap::after, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap #start_port, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap #date_input, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap::before, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap::after, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap #start_port, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap #date_input, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap::before, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap::after, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap #start_port, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap #date_input, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap::before, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap::after, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap #start_port, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap #date_input, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap::before, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap::after, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap #start_port, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap #date_input {
  font-size: 14px;
  line-height: 18px; }

#reserve #reserve_wrap form fieldset #start_port_select_wrap::after, #reserve #reserve_wrap form fieldset #start_port_select_form_wrap::after, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap::after, #reserve #reserve_form_wrap form fieldset #start_port_select_form_wrap::after, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap::after, #reserve_cont #reserve_wrap form fieldset #start_port_select_form_wrap::after, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap::after, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_form_wrap::after {
  font-family: 'FontAwesome';
  content: "\f107";
  display: inline-block;  
  color: #0070bd;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding-top: 0.2em;
  position: absolute;
  top: 0.4em;
  right: 8px;
  z-index: 1; }

#reserve #reserve_wrap form fieldset #date_input_select_wrap::before, #reserve #reserve_wrap form fieldset #date_input_select_form_wrap::before, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap::before, #reserve #reserve_form_wrap form fieldset #date_input_select_form_wrap::before, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap::before, #reserve_cont #reserve_wrap form fieldset #date_input_select_form_wrap::before, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap::before, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_form_wrap::before {
font-family: 'FontAwesome';
  content: "\f073";
  display: inline-block;  
  color: #0070bd;
  background-color: #FFF;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  position: absolute;
  top: 0.4em;
  left: 8px;
  z-index: 1; }

#window_body #time_table header {
  position: inherit;
  top: auto;
  height: auto;
  width: 100%;
  margin: 0 auto;
  z-index: 999;
  background: none;
  display: block; }

#window_body #time_table {
  display: block;
  font-size: 13px; }

#time_table {
  overflow: scroll; }

#time_table #popClose {
  z-index: 99999; }

#time_table #popClose > .pop_close_btn {
  background: url("../../imgs/common/close_btn.jpg") center center/cover; }

/*#reserve{
    width: 235px;
    top: 90px;
    right: 105px;
    overflow: hidden;
    height: auto;
    transition: height 0.4s;
    transform: none;
}

#reserve[data-edit=on].on {
    height: 232px;
    position: fixed;
}

#reserve #reserve_wrap {
    position: relative;
    width: 235px;
    padding: 15px 10px 10px;
    box-sizing: border-box;
    background-color: #FFF;
    border: solid 1px #EEE;
    border-top: none;
}

#reserve #reserve_wrap form fieldset legend {
    padding: 0.4em 10px 0.4em 0;
}

#reserve #reserve_wrap form fieldset #start_port_select_wrap,
#reserve #reserve_wrap form fieldset #date_input_select_wrap,{
    position: relative;
    width: 160px;
}
*/
.fade,
.fadein,
.fadein-top,
.fadein-left,
.fadein-right,
.opening {
  opacity: 0;
  transition: all 0.875s ease-in-out; }

.fade {
  transform: translate(0, 0); }

.fadein {
  transform: translate(0, 50px); }

.fadein-top {
  transform: translate(0, -50px); }

.fadein-left {
  transform: translate(-50px, 0); }

.fadein-right {
  transform: translate(50px, 0); }

.fade.scrollin,
.fadein.scrollin,
.fadein-top.scrollin,
.fadein-left.scrollin,
.fadein-right.scrollin,
.opening.active {
  opacity: 1;
  transform: translate(0, 0); }

p.comment {
  font-size: 3.4vw;
  margin: 40px 0 10px; }

.pages article {
  padding-bottom: 125px; }
  .pages article .main--inner {
    width: 100%;
    height: 650px;
    padding-top: 140px; }
    .pages article .main--inner--title {
      text-align: center;
      color: #fff; }
      .pages article .main--inner--title h1 {
        font-size: 2.4rem;
        font-family: "Noto Serif JP", serif;
        font-weight: 600;
        line-height: 1;
        letter-spacing: .1em; }
        .pages article .main--inner--title h1 span {
          display: block;
          font-size: 5.9rem;
          font-family: "Barlow Condensed", "Noto Sans Japanese", serif;
          letter-spacing: .01em;
          margin-bottom: 20px; }
      .pages article .main--inner--title p {
        font-size: 1.3rem;
        line-height: 2;
        letter-spacing: .08em;
        margin-top: 40px; }

@media screen and (min-width: 768px) and (max-width: 1023px) {
    header .navicont .reserve {
    display: none;
}
    header .navicont .nav_head_pr {
    right: 95px;
}
    header .navicont .nav_head_or {
    right: 215px;
}
    .slick-dots {
    bottom: -20px !important;
    z-index: 3;
}
    .contents main .contentsinner--box{
        padding: 0 10px;
}
    .contents main .contentsinner {
    max-width: 100%;
        padding: 0 10px;
}
    .contents main .contentshead .route_box {
        padding: 0 10px;
    }
    .contents main .contentsinner--box--cont--box .flex figure {
    height:100% !important;
}
    .contents main .contentsinner--box--cont--guide .ttl dt {
    width: 50px !important;
}
    .contents main .contentsinner--box--cont--ships figure {
    width: 46% !important;
}
    .contents main .contentsinner--flex p {
    width: 48% !important;
}
    .contents main .content_tabinner .tabs {
        top: 430px !important;
    }
    .contents main .content_tabinner .tabs li {
    font-size: 14px;
}
    .contents main .contentsinner--box--cont--photo--area .flex .flexbox {
    width: 48% !important;
}
    .contents main .contentsinner--box--cont--photo--area .flex.wid_2 .flexbox{
        width: 32% !important;
    }
    
    .contents main .contentsinner--box--cont--photo--area .flex_all .flexbox {
 width: 32% !important;
    }
    .contents main .contentsinner--box--cont--photo--area .flex_all .flexbox .wids {
    width: 100%;
    margin-right: 0;
}
    .contents main .contentsinner--box--cont--photo--area .flex.wid_3 {
    width:64% !important;
}
     .contents main .contentsinner--box--cont--photo--area .flex.wid_4 {
    width:64% !important;
}
    .contents main .contentsinner--box--cont--photo--area .flex.wid_3 .flexbox{
        width:48% !important;
}
    .contents main .contentsinner--box--cont--photo--area .flex.wid_4 .flexbox{
        width:48% !important;
}
.contents main .contentsinner--box--cont--foodb--flex figure {
    width: 40% !important;
    margin-right: -50px !important;
    margin-top: 0px !important;
}
.contents main .contentsinner--box--cont--foodb--flex .border_flex figure {
    margin: 0 !important;
    width: 40% !important;
}
.contents main .contentshead .anchor.wid_1{
        max-width: 100%;
        padding: 0 10px;
    }
.contents main .contentshead .anchor.wid_1 li{
        font-size: 14px;
    }
.contents main .contentshead p {
    max-width: 96% !important;
}

    
 #reserve {
    position: fixed;
    top: auto;
    right: auto;
    height: auto;
    left: 0;
    bottom: 0;
    z-index: 20;
    width: 100%;
    background-color: #FFF;
    padding: 0;
    box-sizing: border-box;
    border-bottom: 1px solid #f2f2f2; }

  #reserve #reserve_wrap::before {
    content: none; }

  #reserve #reserve_wrap::after {
    content: none; }

  #reserve[data-edit=on].on {
    height: auto; }

  #reserve #reserve_wrap {
    position: relative;
    width: 100%;
    padding: 5px;
    box-sizing: border-box;
    background-color: #FFF;
    border: none;
    border-top: none;
    height: auto; }

  #reserve #reserve_wrap form fieldset {
    overflow: hidden;
    padding: 6px 0 0px;
    flex: 1 1 60%;}

  #reserve #reserve_wrap form fieldset > * {
    float: left;
    display: inline-block; }

  #reserve #reserve_wrap form {
    display: flex;
    justify-content: space-between; }

  #reserve #reserve_wrap form > * {
    padding: 0px 0 0; }

  #reserve #reserve_wrap form fieldset legend {
    font-size: 16px;
    line-height: 16px;
    padding: 0 0 0.4em; }

  #reserve #reserve_wrap form fieldset #start_port_select_wrap, #reserve #reserve_wrap form fieldset #date_input_select_wrap, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap {
    position: relative;
    width: 90%; }

  #reserve #reserve_wrap form #reserve_submit {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 80px;
    -moz-box-flex: 0;
    -moz-flex: 0 0 80px;
    -ms-flex: 0 0 80px;
    flex: 0 0 80px;
    padding: 0 0px;
    box-sizing: border-box; }

  #reserve #reserve_wrap form > * {
    padding: 10px 0 0; }

  .pc #reserve #reserve_wrap form #reserve_submit > a {
    -moz-transition: background 0.4s;
    -o-transition: background 0.4s;
    -webkit-transition: background 0.4s;
    transition: background 0.4s; }

  #reserve #reserve_wrap form #reserve_submit > a, #reserve #reserve_wrap form #reserve_submit > a:visited, #reserve #reserve_form_wrap form #reserve_submit > a, #reserve #reserve_form_wrap form #reserve_submit > a:visited, #reserve_cont #reserve_wrap form #reserve_submit > a, #reserve_cont #reserve_wrap form #reserve_submit > a:visited, #reserve_cont #reserve_form_wrap form #reserve_submit > a, #reserve_cont #reserve_form_wrap form #reserve_submit > a:visited {
    color: #FFF; }

  #reserve #reserve_wrap form #reserve_submit > a {
    box-sizing: border-box;
    width: 100%; }

  #reserve #reserve_wrap form #reserve_submit > a, #reserve #reserve_wrap form #reserve_submit > a:hover, #reserve #reserve_form_wrap form #reserve_submit > a, #reserve #reserve_form_wrap form #reserve_submit > a:hover, #reserve_cont #reserve_wrap form #reserve_submit > a, #reserve_cont #reserve_wrap form #reserve_submit > a:hover, #reserve_cont #reserve_form_wrap form #reserve_submit > a, #reserve_cont #reserve_form_wrap form #reserve_submit > a:hover {
    text-decoration: none; }

  #reserve #reserve_wrap form #reserve_submit > a, #reserve #reserve_form_wrap form #reserve_submit > a, #reserve_cont #reserve_wrap form #reserve_submit > a, #reserve_cont #reserve_form_wrap form #reserve_submit > a {
    display: block;
    padding: 0.4em 0.8em;
    font-size: 16px;
    line-height: 18px;
    background-color: #FF8000;
    text-align: center;
    border-radius: 4px;
    box-sizing: border-box; }

  #reserve #reserve_wrap form > * {
    padding: 10px 0 0; }

  #reserve #reserve_wrap form #reserve_edit > a, #reserve #reserve_form_wrap form #reserve_edit > a, #reserve_cont #reserve_wrap form #reserve_edit > a, #reserve_cont #reserve_form_wrap form #reserve_edit > a {
    display: block;
    padding: 0.46666em 0.2em;
    font-size: 16px;
    line-height: 16px; }

  #reserve #reserve_wrap form #reserve_member {
    width: 100%; }

  #reserve #reserve_wrap form > * {
    padding: 10px 0 0; }

  #reserve #reserve_wrap form #reserve_member > a {
    box-sizing: border-box;
    width: 100%; }

  #reserve #reserve_wrap form #reserve_submit > a, #reserve #reserve_form_wrap form #reserve_submit > a, #reserve_cont #reserve_wrap form #reserve_submit > a, #reserve_cont #reserve_form_wrap form #reserve_submit > a {
    font-size: 16px;
    line-height: 16px;
    padding: 0.4em 0.2em; }

  #reserve #reserve_wrap form fieldset #start_port_select_wrap::before, #reserve #reserve_wrap form fieldset #start_port_select_wrap::after, #reserve #reserve_wrap form fieldset #start_port_select_wrap #start_port, #reserve #reserve_wrap form fieldset #start_port_select_wrap #date_input, #reserve #reserve_wrap form fieldset #date_input_select_wrap::before, #reserve #reserve_wrap form fieldset #date_input_select_wrap::after, #reserve #reserve_wrap form fieldset #date_input_select_wrap #start_port, #reserve #reserve_wrap form fieldset #date_input_select_wrap #date_input, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap::before, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap::after, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap #start_port, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap #date_input, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap::before, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap::after, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap #start_port, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap #date_input, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap::before, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap::after, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap #start_port, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap #date_input, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap::before, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap::after, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap #start_port, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap #date_input, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap::before, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap::after, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap #start_port, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap #date_input, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap::before, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap::after, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap #start_port, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap #date_input {
    font-size: 16px;
    line-height: 16px; }

  #reserve #reserve_wrap form fieldset #date_input_select_wrap::before, #reserve #reserve_wrap form fieldset #date_input_select_form_wrap::before, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap::before, #reserve #reserve_form_wrap form fieldset #date_input_select_form_wrap::before, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap::before, #reserve_cont #reserve_wrap form fieldset #date_input_select_form_wrap::before, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap::before, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_form_wrap::before {
    top: 1.1em; }

  #window_body #time_table {
    display: block;
    font-size: 15px; }

  #window_body #time_table header {
    position: inherit;
    top: auto;
    height: auto;
    width: 100%;
    margin: 0 auto;
    z-index: 999;
    background: none;
    display: block; }

  #time_table > header > h1 {
    font-size: 16px; }

  #time_table > header > h1 > i {
    font-size: 22px; }

  #time_table > header > h1 > span {
    display: block;
    font-size: 16px;
    margin-left: 16px; }

  #time_table article {
    padding: 10px 0 0; }

  #time_table article > p {
    padding: 10px 0 0; }

  #time_table article #time_table_wrap {
    margin-top: 10px; } 
footer {
    padding: 0 0 60px;
}
footer .pagetop {
    right: 15px;
    bottom: 90px;
}
#reserve #reserve_wrap form #reserve_submit > a{
    font-size: 16px;
    line-height: 16px;
    padding: 0.7em 0em;
    background-color: red;
    color: #fff !important;
}
#reserve #reserve_wrap form #reserve_edit > a{
    display: block;
    padding: 0.7em 0em;
    font-size: 16px;
    line-height: 16px;
}
    #reserve #reserve_wrap form fieldset legend {
    font-size: 16px;
    line-height: 16px;
    padding: 0 0 0.4em;
    margin-bottom: -3px;
}
    #reserve #reserve_wrap form #reserve_edit {
    width: 30%;
    display: block !important;
    padding: 0;
    margin-left: 10px;
    border-left: 1px solid #000;
    padding-left: 7px;
    font-size: 12px;
}
    
    #reserve #reserve_wrap form #reserve_edit a{
        background-color: #333b90;
}
     #reserve #reserve_wrap form #reserve_edit a i{
         display: none;
}
    #reserve #reserve_wrap form #reserve_member {
    width: 100%;
    display: none;
    }
}}

.contents main {
  display: block;
  margin-top: 0px;
  font-size: 16px; }
  .contents main.mt {
    margin-top: 0px; }
  .contents main .topicback {
    background: linear-gradient(to bottom, #fff 0%, #0071a6 100%); }
  .contents main .back_b2 {
    background: #2992c9;
    margin-top: 0px;
    position: relative;
    padding-bottom: 150px; }
    .contents main .back_b2:before {
      position: absolute;
      content: "";
      width: 100%;
      height: 78px;
      bottom: 0;
      left: 0;
      background: url("../../imgs/common/obi_b.svg") repeat-x bottom center; }
  .contents main .back_b3 {
    background: #0071a2;
    margin-top: 0px;
    position: relative;
    padding-bottom: 150px; }
    .contents main .back_b3:before {
      position: absolute;
      content: "";
      width: 100%;
      height: 78px;
      bottom: 0;
      left: 0;
      background: url("../../imgs/common/obi_b.svg") repeat-x bottom center; }
  .contents main .back_p {
    background: #fbe6ef;
    margin-top: 0px;
    position: relative;
    padding-bottom: 150px;
    padding-top: 110px; }
    .contents main .back_p:before {
      position: absolute;
      content: "";
      width: 100%;
      height: 78px;
      bottom: 0;
      left: 0;
      background: url("../../imgs/common/obi_b.svg") repeat-x bottom center; }
    .contents main .back_p:after {
      position: absolute;
      content: "";
      width: 100%;
      height: 78px;
      bottom: 0;
      left: 0;
      background: url("../../imgs/common/obi_w2.svg") repeat-x bottom center; }
  .contents main .back_w2 {
    background: #e4f4fd;
    margin-top: 0px;
    position: relative;
    padding-top: 30px; }
  .contents main .contentshead {
    position: relative; }
    .contents main .contentshead h2 {
      font-size: 30px;
      text-align: center;
      position: relative;
      padding-bottom: 15px;
      letter-spacing: 0.12em;
      margin-top: 150px;
      margin-bottom: 20px;
      color: #2985bc; }
      .contents main .contentshead h2.mt {
        margin-top: 100px; }
    .contents main .contentshead h3 {
      text-align: center;
      padding-bottom: 20px;
      font-size: 20px; }
    .contents main .contentshead p {
      max-width: 900px;
      margin: 0 auto 30px;
      font-size: 14px;
      line-height: 2.2; }
      .contents main .contentshead p.center {
        text-align: center; }
    .contents main .contentshead .anchor {
      max-width: 900px;
      margin: 40px auto 40px;
      display: flex;
      justify-content: space-between; }
      .contents main .contentshead .anchor li {
        font-size: 18px;
        border: 1px solid #2991c8;
        text-align: center; }
        .contents main .contentshead .anchor li a {
          display: block;
          color: #2991c8;
          padding: 10px 25px 25px;
          position: relative; }
          .contents main .contentshead .anchor li a:after {
            position: absolute;
            content: "";
            width: 10px;
            height: 10px;
            border-top: 1px solid #2993ca;
            border-right: 1px solid #2993ca;
            left: 50%;
            margin-left: -6px;
            bottom: 10px;
            transform: rotate(135deg); }
          .contents main .contentshead .anchor li a span {
            display: block;
            font-size: 14px; }
        .contents main .contentshead .anchor li.close {
          border: 1px solid #ccc; }
          .contents main .contentshead .anchor li.close a {
            pointer-events: none;
            color: #ccc; }
            .contents main .contentshead .anchor li.close a:after {
              border-top: 1px solid #ccc;
              border-right: 1px solid #ccc; }
      .contents main .contentshead .anchor.wid_2 {
        justify-content: center;
        margin-bottom: 80px; }
        .contents main .contentshead .anchor.wid_2 li {
          width: 340px;
          margin: 0 30px; }
      .contents main .contentshead .anchor.wid_3 {
        justify-content: center;
        margin-bottom: 80px; }
        .contents main .contentshead .anchor.wid_3 li {
          width: 340px;
          margin: 0 30px;
          position: relative; }
          .contents main .contentshead .anchor.wid_3 li.pt {
            padding-top: 10px; }
          .contents main .contentshead .anchor.wid_3 li span {
            font-size: 14px;
            line-height: 1; }
            .contents main .contentshead .anchor.wid_3 li span.mark {
              position: absolute;
              width: 80px;
              right: -20px;
              top: -25px;
              z-index: 4; }
    .contents main .contentshead.under_b {
      padding-bottom: 60px; }
      .contents main .contentshead.under_b:before {
        position: absolute;
        content: "";
        width: 100%;
        height: 78px;
        bottom: 0;
        left: 0;
        background: url("../../imgs/common/obi_b2.svg") repeat-x bottom center; }
    .contents main .contentshead.under_p {
      padding-bottom: 60px; }
      .contents main .contentshead.under_p:before {
        position: absolute;
        content: "";
        width: 100%;
        height: 78px;
        bottom: 0;
        left: 0;
        background: url("../../imgs/common/obi_p.svg") repeat-x bottom center; }
    .contents main .contentshead .route_box {
      max-width: 900px;
      margin: 50px auto 0; }
      .contents main .contentshead .route_box .txt_cap {
        text-align: right;
        margin-top: 4px; }
      .contents main .contentshead .route_box--inner {
        border-top: 3px solid #2985bc;
        border-bottom: 3px solid #2985bc;
        padding: 3px 0; }
        .contents main .contentshead .route_box--inner--box {
          display: flex;
          justify-content: space-between;
          align-items: center;
          border-top: 1px solid #2985bc; }
          .contents main .contentshead .route_box--inner--box:last-child {
            border-bottom: 1px solid #2985bc; }
          .contents main .contentshead .route_box--inner--box p {
            width: 65px;
            margin: 0 15px; }
          .contents main .contentshead .route_box--inner--box dl {
            padding: 30px 0;
            width: calc(100% - 95px); }
            .contents main .contentshead .route_box--inner--box dl dt {
              font-size: 22px;
              border-bottom: 1px dashed #2985bc;
              padding-bottom: 5px;
              margin-bottom: 5px;
              color: #666; }
            .contents main .contentshead .route_box--inner--box dl dd {
              font-size: 31px;
              color: #2985bc; }
              .contents main .contentshead .route_box--inner--box dl dd sup {
                font-size: 12px;
                position: relative;
                top: -5px; }
              .contents main .contentshead .route_box--inner--box dl dd span {
                font-size: 36px;
                color: #003894;
                position: relative;
                margin-left: 5px; }
                .contents main .contentshead .route_box--inner--box dl dd span:after {
                  position: absolute;
                  content: "";
                  background: #ffda37;
                  height: 50%;
                  width: 105%;
                  bottom: 0;
                  left: -2.5%; }
              .contents main .contentshead .route_box--inner--box dl dd i {
                font-style: normal;
                position: relative;
                z-index: 3; }
  .contents main .content_tabinner {
    max-width: 900px;
    margin: 20px auto 0;
    position: relative; }
    .contents main .content_tabinner .tabs {
      display: flex;
      justify-content: space-between;
      position: absolute;
      z-index: 2;
      width: 100%;
      top: 510px; }
      .contents main .content_tabinner .tabs li {
        width: 19.8%;
        color: #808080;
        background: #c0c0c0;
        text-align: center;
        padding: 8px 0;
        cursor: pointer; }
        .contents main .content_tabinner .tabs li span {
          display: block;
          font-family: 'Barlow Condensed',serif;
          font-weight: 300; }
        .contents main .content_tabinner .tabs li.active {
          background: #ffbb37;
          color: #000; }
    .contents main .content_tabinner .tabinnermap {
      display: none; }
      .contents main .content_tabinner .tabinnermap.show {
        display: block; }
      .contents main .content_tabinner .tabinnermap .mapkv {
        margin-bottom: 80px; }
      .contents main .content_tabinner .tabinnermap .tabinnermapcont, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 {
        display: none; }
        .contents main .content_tabinner .tabinnermap .tabinnermapcont.show, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2.show, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3.show, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4.show, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5.show {
          display: block; }
        .contents main .content_tabinner .tabinnermap .tabinnermapcont .tabinnermapcontflex, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2 .tabinnermapcontflex, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3 .tabinnermapcontflex, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4 .tabinnermapcontflex, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 .tabinnermapcontflex {
          display: flex;
          justify-content: space-between; }
          .contents main .content_tabinner .tabinnermap .tabinnermapcont .tabinnermapcontflex p, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2 .tabinnermapcontflex p, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3 .tabinnermapcontflex p, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4 .tabinnermapcontflex p, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 .tabinnermapcontflex p {
            width: 220px; }
            .contents main .content_tabinner .tabinnermap .tabinnermapcont .tabinnermapcontflex p.wids, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2 .tabinnermapcontflex p.wids, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3 .tabinnermapcontflex p.wids, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4 .tabinnermapcontflex p.wids, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 .tabinnermapcontflex p.wids {
              width: 310px; }
          .contents main .content_tabinner .tabinnermap .tabinnermapcont .tabinnermapcontflex div, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2 .tabinnermapcontflex div, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3 .tabinnermapcontflex div, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4 .tabinnermapcontflex div, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 .tabinnermapcontflex div {
            width: 660px; }
            .contents main .content_tabinner .tabinnermap .tabinnermapcont .tabinnermapcontflex div.widd, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2 .tabinnermapcontflex div.widd, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3 .tabinnermapcontflex div.widd, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4 .tabinnermapcontflex div.widd, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 .tabinnermapcontflex div.widd {
              width: 570px; }
            .contents main .content_tabinner .tabinnermap .tabinnermapcont .tabinnermapcontflex div figcaption, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2 .tabinnermapcontflex div figcaption, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3 .tabinnermapcontflex div figcaption, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4 .tabinnermapcontflex div figcaption, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 .tabinnermapcontflex div figcaption {
              font-size: 11px;
              padding-top: 5px; }
      .contents main .content_tabinner .tabinnermap .innertabs, .contents main .content_tabinner .tabinnermap .innertabs_2, .contents main .content_tabinner .tabinnermap .innertabs_3, .contents main .content_tabinner .tabinnermap .innertabs_4, .contents main .content_tabinner .tabinnermap .innertabs_5 {
        display: flex;
        justify-content: space-between;
        z-index: 2;
        margin-top: 20px; }
        .contents main .content_tabinner .tabinnermap .innertabs li, .contents main .content_tabinner .tabinnermap .innertabs_2 li, .contents main .content_tabinner .tabinnermap .innertabs_3 li, .contents main .content_tabinner .tabinnermap .innertabs_4 li, .contents main .content_tabinner .tabinnermap .innertabs_5 li {
          width: 24.9%;
          color: #fff;
          background: #c0c0c0;
          text-align: center;
          padding: 10px 0;
          cursor: pointer; }
          .contents main .content_tabinner .tabinnermap .innertabs li span, .contents main .content_tabinner .tabinnermap .innertabs_2 li span, .contents main .content_tabinner .tabinnermap .innertabs_3 li span, .contents main .content_tabinner .tabinnermap .innertabs_4 li span, .contents main .content_tabinner .tabinnermap .innertabs_5 li span {
            display: block;
            font-family: 'Barlow Condensed',serif;
            font-weight: 300; }
          .contents main .content_tabinner .tabinnermap .innertabs li.active, .contents main .content_tabinner .tabinnermap .innertabs_2 li.active, .contents main .content_tabinner .tabinnermap .innertabs_3 li.active, .contents main .content_tabinner .tabinnermap .innertabs_4 li.active, .contents main .content_tabinner .tabinnermap .innertabs_5 li.active {
            background: #0071aa; }
  .contents main .contentsinner {
    max-width: 1024px;
    margin: 0 auto;
    padding-bottom: 170px; }
    .contents main .contentsinner .morebtn {
      max-width: 250px;
      margin: 60px auto 0;
      background: #2986bd;
      color: #fff;
      text-align: center;
      font-size: 17px;
      padding: 15px 0 18px;
      position: relative;
      cursor: pointer;
      letter-spacing: 0.1em; }
      .contents main .contentsinner .morebtn:after {
        position: absolute;
        content: "";
        border-bottom: 1px solid #fff;
        border-right: 1px solid #fff;
        width: 10px;
        height: 10px;
        transform: rotate(45deg);
        bottom: 8px;
        left: 50%;
        margin-left: -5px; }
    .contents main .contentsinner .topicks .icon {
      font-size: 25px;
      text-align: center;
      color: #fff;
      position: relative; }
      .contents main .contentsinner .topicks .icon span {
        width: 70px;
        margin: 0 auto 10px;
        display: block; }
      .contents main .contentsinner .topicks .icon.cl_1 {
        color: #2992c9; }
    .contents main .contentsinner .topicks--inner {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; }
      .contents main .contentsinner .topicks--inner--box {
        width: 24%;
        margin-top: 30px;
        background: #fff;
        padding-left: 20px;
        position: relative; }
        .contents main .contentsinner .topicks--inner--box:after {
          position: absolute;
          content: url("../../imgs/top/top_kazari_1.svg");
          width: 30px;
          height: 30px;
          bottom: 0;
          right: 0; }
        .contents main .contentsinner .topicks--inner--box figure {
          position: relative; }
          .contents main .contentsinner .topicks--inner--box figure:before {
            position: absolute;
            content: url("../../imgs/top/top_kazari_2.svg");
            width: 48px;
            height: 48px;
            top: 0;
            right: 0; }
          .contents main .contentsinner .topicks--inner--box figure:after {
            position: absolute;
            content: url("../../imgs/top/top_kazari_3.svg");
            width: 48px;
            height: 48px;
            bottom: 0;
            left: 0; }
        .contents main .contentsinner .topicks--inner--box dl {
          padding: 15px 0 35px; }
    .contents main .contentsinner.mb {
      padding-bottom: 0; }
    .contents main .contentsinner--box {
      max-width: 900px;
      margin: 0 auto; }
      .contents main .contentsinner--box .topco {
        display: none; }
      .contents main .contentsinner--box.wid {
        max-width: 100%;
        position: relative;
        z-index: 2; }
      .contents main .contentsinner--box--cont {
        padding-bottom: 40px;
        position: relative; }
        .contents main .contentsinner--box--cont.none {
          display: none; }
        .contents main .contentsinner--box--cont.border_r {
          border: 2px solid #b91023;
          border-radius: 20px;
          padding: 0 40px 40px; }
        .contents main .contentsinner--box--cont.border_w {
          border: 2px dotted #298dc4;
          border-radius: 20px;
          padding: 0 40px 40px; }
        .contents main .contentsinner--box--cont .leadobj {
          max-width: 750px;
          margin: 0 auto;
          background: #fbe6ef;
          position: relative;
          top: -100px;
          margin-bottom: -80px; }
        .contents main .contentsinner--box--cont .lead {
          font-size: 25px;
          border-bottom: 2px solid #d8d8d8;
          margin-bottom: 15px;
          padding-bottom: 10px;
          position: relative; }
          .contents main .contentsinner--box--cont .lead:before {
            position: absolute;
            content: "";
            width: 40%;
            border-bottom: 2px solid #2991c8;
            bottom: -3px; }
          .contents main .contentsinner--box--cont .lead.center {
            text-align: center; }
          .contents main .contentsinner--box--cont .lead.blue {
            color: #0071a2; }
          .contents main .contentsinner--box--cont .lead span {
            font-size: 18px; }
          .contents main .contentsinner--box--cont .lead.pts {
            padding-top: 60px; }
          .contents main .contentsinner--box--cont .lead .captionl {
            position: absolute;
            right: 0;
            bottom: 10px;
            text-align: right;
            color: #000;
            font-size: 14px; }
        .contents main .contentsinner--box--cont .icon {
          font-size: 25px;
          text-align: center;
          color: #fff;
          position: relative; }
          .contents main .contentsinner--box--cont .icon span {
            width: 70px;
            margin: 0 auto 10px;
            display: block; }
            .contents main .contentsinner--box--cont .icon span.smalls {
              width: 100%;
              font-size: 15px; }
            .contents main .contentsinner--box--cont .icon span.a_mark {
              position: absolute;
              width: 100px;
              right: 50%;
              top: 0;
              margin-right: -200px; }
          .contents main .contentsinner--box--cont .icon.cl_1 {
            color: #2992c9; }
        .contents main .contentsinner--box--cont .lead_txt {
          text-align: center;
          font-size: 18px;
          line-height: 2;
          margin: 30px 0; }
        .contents main .contentsinner--box--cont .txts {
          font-size: 14px;
          margin-bottom: 10px;
          line-height: 2; }
          .contents main .contentsinner--box--cont .txts a {
            text-decoration: underline; }
        .contents main .contentsinner--box--cont ul li {
          font-size: 14px;
          list-style: disc;
          padding-left: 0px;
          margin-left: 25px;
          line-height: 2; }
        .contents main .contentsinner--box--cont ul.num li {
          list-style: decimal; }
        .contents main .contentsinner--box--cont .right {
          text-align: right;
          font-size: 14px;
          line-height: 2; }
        .contents main .contentsinner--box--cont .policy {
          color: #2986bd; }
          .contents main .contentsinner--box--cont .policy li {
            font-size: 23px;
            list-style: none;
            margin-left: 0;
            letter-spacing: 0.06em; }
        .contents main .contentsinner--box--cont .backimgs {
          background: url("../../imgs/top/top_5.svg") no-repeat top center; }
        .contents main .contentsinner--box--cont--move {
          max-width: 900px;
          margin: 0 auto;
          border-top: 2px solid #0071a6;
          border-bottom: 2px solid #0071a6;
          margin-top: 20px;
          padding: 10px 0;
          margin-bottom: 100px; }
          .contents main .contentsinner--box--cont--move .movetp {
            background: #0071a6;
            color: #fff;
            display: flex;
            align-items: center;
            padding: 20px 5px;
            margin-bottom: 5px; }
            .contents main .contentsinner--box--cont--move .movetp dt {
              width: 270px;
              font-size: 21px;
              text-align: center;
              border-right: 1px solid #fff; }
            .contents main .contentsinner--box--cont--move .movetp dd {
              margin-left: 15px;
              font-size: 20px; }
              .contents main .contentsinner--box--cont--move .movetp dd span {
                font-size: 25px;
                color: #0071a6;
                background: #fff;
                padding: 5px 10px;
                margin-right: 15px; }
          .contents main .contentsinner--box--cont--move--inner {
            height: 150px;
            overflow: scroll; }
            .contents main .contentsinner--box--cont--move--inner .moveinner {
              display: flex;
              justify-content: space-between;
              font-size: 18px;
              padding: 10px 0;
              border-top: 1px dashed #b6b6b6; }
              .contents main .contentsinner--box--cont--move--inner .moveinner .date {
                width: 135px; }
              .contents main .contentsinner--box--cont--move--inner .moveinner .txtinner {
                width: calc(100% - 135px); }
                .contents main .contentsinner--box--cont--move--inner .moveinner .txtinner .ttl {
                  color: #0071a6; }
                .contents main .contentsinner--box--cont--move--inner .moveinner .txtinner .txt {
                  font-size: 16px;
                  padding: 10px 0; }
                .contents main .contentsinner--box--cont--move--inner .moveinner .txtinner .btns {
                  max-width: 250px;
                  margin: 0px auto 0 0;
                  background: #0071a6;
                  color: #fff;
                  text-align: center;
                  font-size: 15px;
                  padding: 8px 0 8px;
                  position: relative; }
                  .contents main .contentsinner--box--cont--move--inner .moveinner .txtinner .btns a {
                    display: block;
                    color: #fff;
                    position: relative; }
                    .contents main .contentsinner--box--cont--move--inner .moveinner .txtinner .btns a:after {
                      position: absolute;
                      content: "";
                      width: 8px;
                      height: 8px;
                      border-top: 1px solid #fff;
                      border-right: 1px solid #fff;
                      transform: rotate(45deg);
                      right: 10px;
                      top: 50%;
                      margin-top: -5px; }
        .contents main .contentsinner--box--cont--news {
          max-width: 900px;
          margin: 0 auto;
          border-top: 2px solid #0071a6;
          border-bottom: 2px solid #0071a6;
          margin-top: 20px;
          padding: 10px 0;
          margin-bottom: 100px; }
          .contents main .contentsinner--box--cont--news--inner {
            height: 250px;
            overflow: scroll; }
            .contents main .contentsinner--box--cont--news--inner .moveinner {
              display: flex;
              justify-content: space-between;
              font-size: 18px;
              padding: 10px 0;
              border-bottom: 1px dashed #b6b6b6; }
              .contents main .contentsinner--box--cont--news--inner .moveinner:last-child {
                border-bottom: none; }
              .contents main .contentsinner--box--cont--news--inner .moveinner .date {
                width: 135px; }
              .contents main .contentsinner--box--cont--news--inner .moveinner .txtinner {
                width: calc(100% - 135px); }
                .contents main .contentsinner--box--cont--news--inner .moveinner .txtinner .ttl {
                  color: #0071a6; }
                .contents main .contentsinner--box--cont--news--inner .moveinner .txtinner .txt {
                  font-size: 16px;
                  padding: 10px 0; }
                .contents main .contentsinner--box--cont--news--inner .moveinner .txtinner .btns {
                  max-width: 250px;
                  margin: 0px auto 0 0;
                  background: #0071a6;
                  color: #fff;
                  text-align: center;
                  font-size: 15px;
                  padding: 8px 0 8px;
                  position: relative; }
                  .contents main .contentsinner--box--cont--news--inner .moveinner .txtinner .btns a {
                    display: block;
                    color: #fff;
                    position: relative; }
                    .contents main .contentsinner--box--cont--news--inner .moveinner .txtinner .btns a:after {
                      position: absolute;
                      content: "";
                      width: 8px;
                      height: 8px;
                      border-top: 1px solid #fff;
                      border-right: 1px solid #fff;
                      transform: rotate(45deg);
                      right: 10px;
                      top: 50%;
                      margin-top: -5px; }
        .contents main .contentsinner--box--cont--flex {
          display: flex;
          justify-content: space-between;
          flex-wrap: wrap; }
          .contents main .contentsinner--box--cont--flex dl {
            width: 448px;
            margin-top: 25px;
            letter-spacing: 0.02em; }
            .contents main .contentsinner--box--cont--flex dl dt {
              font-size: 17px;
              color: #2986bd;
              padding-bottom: 10px; }
            .contents main .contentsinner--box--cont--flex dl dd {
              font-size: 13px;
              line-height: 1.8; }
        .contents main .contentsinner--box--cont--safe dl {
          display: flex;
          padding: 25px 0;
            font-size: 16px;
            line-height: 1.8;
          border-bottom: 2px dashed #d9d9d9; }
          .contents main .contentsinner--box--cont--safe dl dt {
            width: 115px; }
          .contents main .contentsinner--box--cont--safe dl dd {
            text-align: left; }
            .contents main .contentsinner--box--cont--safe dl dd a {
              text-decoration: underline;
              color: #2986bd; }
        .contents main .contentsinner--box--cont--qa {
          padding: 0 15px; }
          .contents main .contentsinner--box--cont--qa dl {
            margin-top: 40px; }
            .contents main .contentsinner--box--cont--qa dl dt {
              font-size: 16px;
              padding: 0px 0 15px;
              padding-left: 55px;
              border-bottom: 2px solid #d9d9d9;
              position: relative; }
              .contents main .contentsinner--box--cont--qa dl dt:before {
                position: absolute;
                content: url("../../imgs/qa/qa_1.svg");
                width: 33px;
                height: 33px;
                left: 0;
                top: -5px; }
              .contents main .contentsinner--box--cont--qa dl dt:after {
                position: absolute;
                content: "";
                width: 10px;
                height: 10px;
                border-top: 1px solid #2993ca;
                border-right: 1px solid #2993ca;
                right: 10px;
                top: 6px;
                transform: rotate(135deg); }
              .contents main .contentsinner--box--cont--qa dl dt.active:after {
                transform: rotate(-45deg);
                margin-top: -0px; }
            .contents main .contentsinner--box--cont--qa dl dd {
              display: none;
              padding: 15px 0 0 55px;
              text-align: justify;
              font-size: 14px;
              line-height: 1.8; }
              .contents main .contentsinner--box--cont--qa dl dd a {
                text-decoration: underline;
                color: #2993ca; }
              .contents main .contentsinner--box--cont--qa dl dd .caution {
                color: red; }
              .contents main .contentsinner--box--cont--qa dl dd .red {
                color: red;
                -webkit-text-stroke: 0.8px red; }
        .contents main .contentsinner--box--cont--box .flex {
          display: flex;
          justify-content: space-between;
          flex-wrap: wrap;
          margin-top: 10px; }
          .contents main .contentsinner--box--cont--box .flex figure {
            height: 245px; }
            .contents main .contentsinner--box--cont--box .flex figure img {
              height: 100%;
              width: auto; }
          .contents main .contentsinner--box--cont--box .flex dl {
            width: 100%;
            display: flex;
            justify-content: space-between;
            align-items: center;
            font-size: 18px;
            margin: 15px 0 0; }
            .contents main .contentsinner--box--cont--box .flex dl dd {
              background: #ffcd37;
              border-radius: 8px; }
              .contents main .contentsinner--box--cont--box .flex dl dd a {
                display: block;
                padding: 8px 30px;
                position: relative; }
                .contents main .contentsinner--box--cont--box .flex dl dd a:after {
                  position: absolute;
                  content: "";
                  width: 8px;
                  height: 8px;
                  border-top: 1px solid #000;
                  border-right: 1px solid #000;
                  transform: rotate(45deg);
                  right: 8px;
                  top: 50%;
                  margin-top: -5px; }
        .contents main .contentsinner--box--cont--box .lead_toggle {
          font-size: 21px;
          color: #0071a2;
          border: 1px solid #0071a2;
          padding: 10px 20px;
          margin-top: 40px;
          position: relative;
          cursor: pointer; }
          .contents main .contentsinner--box--cont--box .lead_toggle:after {
            position: absolute;
            content: "";
            width: 12px;
            height: 12px;
            border-top: 1px solid #0071a2;
            border-right: 1px solid #0071a2;
            transform: rotate(135deg);
            right: 30px;
            top: 50%;
            margin-top: -8px; }
          .contents main .contentsinner--box--cont--box .lead_toggle.active:after {
            transform: rotate(-45deg);
            margin-top: -2px; }
        .contents main .contentsinner--box--cont--box .togglearea {
          display: none; }
          .contents main .contentsinner--box--cont--box .togglearea figure {
            margin-top: 30px; }
          .contents main .contentsinner--box--cont--box .togglearea--box {
            padding: 0 25px; }
            .contents main .contentsinner--box--cont--box .togglearea--box .lead_t {
              font-size: 18px;
              margin-top: 40px;
              position: relative; }
              .contents main .contentsinner--box--cont--box .togglearea--box .lead_t:after {
                position: absolute;
                content: "";
                width: calc(100% - 70px);
                border-top: 1px solid #000;
                right: 0;
                top: 50%; }
            .contents main .contentsinner--box--cont--box .togglearea--box figure {
              margin-top: 10px; }
        .contents main .contentsinner--box--cont--box .g_maps {
          width: 100%;
          height: 400px;
          margin-top: 50px; }
          .contents main .contentsinner--box--cont--box .g_maps iframe {
            width: 100%;
            height: 100%; }
        .contents main .contentsinner--box--cont--guide {
          margin-top: 30px;
          color: #fff; }
          .contents main .contentsinner--box--cont--guide .ttl {
            border: 1px solid #fff;
            display: flex;
            align-items: center;
            padding: 8px 0; }
            .contents main .contentsinner--box--cont--guide .ttl dt {
              font-family: 'Barlow Condensed',serif;
              font-weight: 300;
              font-size: 40px;
              margin: 0 25px; }
            .contents main .contentsinner--box--cont--guide .ttl dd {
              font-size: 23px; }
              .contents main .contentsinner--box--cont--guide .ttl dd span {
                display: block;
                font-size: 19px;
                color: #ffff92; }
          .contents main .contentsinner--box--cont--guide .flex {
            display: flex;
            justify-content: space-between;
            margin-top: 40px; }
            .contents main .contentsinner--box--cont--guide .flex dl {
              width: 50%;
              text-align: center; }
              .contents main .contentsinner--box--cont--guide .flex dl:last-child {
                border-left: 1px solid #fff; }
              .contents main .contentsinner--box--cont--guide .flex dl dt {
                font-size: 24px; }
                .contents main .contentsinner--box--cont--guide .flex dl dt span {
                  display: block;
                  width: 92px;
                  margin: 0 auto 20px; }
              .contents main .contentsinner--box--cont--guide .flex dl dd {
                color: #ffff92;
                font-size: 22px; }
                .contents main .contentsinner--box--cont--guide .flex dl dd.pt_1 {
                  padding-top: 20px; }
                .contents main .contentsinner--box--cont--guide .flex dl dd.pt_2 {
                  padding-top: 35px; }
        .contents main .contentsinner--box--cont--flow {
          margin-top: 85px; }
          .contents main .contentsinner--box--cont--flow--box {
            display: flex;
            justify-content: space-between;
            position: relative;
            padding-bottom: 85px; }
            .contents main .contentsinner--box--cont--flow--box:before {
              position: absolute;
              content: "";
              width: 15px;
              left: 48px;
              height: calc(100% - 130px);
              top: 115px;
              background: #d9d9d9; }
            .contents main .contentsinner--box--cont--flow--box:after {
              position: absolute;
              content: url("../../imgs/guide/tri.svg");
              width: 40px;
              left: 36px;
              bottom: 0px; }
            .contents main .contentsinner--box--cont--flow--box:last-child:before, .contents main .contentsinner--box--cont--flow--box:last-child:after {
              content: none; }
            .contents main .contentsinner--box--cont--flow--box .steps {
              width: 110px;
              height: 110px;
              background: #fff;
              border: 1px solid #2992c9;
              font-family: 'Barlow Condensed',serif;
              font-weight: 300;
              color: #2992c9;
              text-align: center; }
              .contents main .contentsinner--box--cont--flow--box .steps dt {
                font-size: 28px;
                line-height: 1;
                padding-top: 15px; }
              .contents main .contentsinner--box--cont--flow--box .steps dd {
                font-size: 60px;
                line-height: 0.6; }
            .contents main .contentsinner--box--cont--flow--box--txt {
              width: calc(100% - 110px); }
              .contents main .contentsinner--box--cont--flow--box--txt .lead_f {
                font-size: 19px;
                border-bottom: 1px solid #2992c9;
                padding-bottom: 10px;
                padding-left: 35px;
                margin-bottom: 10px;
                color: #2992c9; }
              .contents main .contentsinner--box--cont--flow--box--txt .txts {
                padding-left: 35px; }
              .contents main .contentsinner--box--cont--flow--box--txt .links {
                display: flex;
                align-items: center;
                padding-left: 35px; }
                .contents main .contentsinner--box--cont--flow--box--txt .links dt {
                  margin-right: 30px; }
                  .contents main .contentsinner--box--cont--flow--box--txt .links dt span {
                    display: inline-block;
                    width: 260px;
                    position: relative;
                    top: 6px;
                    margin-right: 20px; }
                .contents main .contentsinner--box--cont--flow--box--txt .links dd {
                  width: 170px;
                  background: #bf0828;
                  border-radius: 8px;
                  margin-top: 12px;
                  padding: 10px 0px; }
                  .contents main .contentsinner--box--cont--flow--box--txt .links dd a {
                    display: block;
                    position: relative;
                    color: #fff;
                    padding-left: 20px; }
                    .contents main .contentsinner--box--cont--flow--box--txt .links dd a:after {
                      position: absolute;
                      content: "";
                      width: 8px;
                      height: 8px;
                      border-top: 1px solid #fff;
                      border-right: 1px solid #fff;
                      transform: rotate(45deg);
                      right: 15px;
                      top: 50%;
                      margin-top: -5px; }
              .contents main .contentsinner--box--cont--flow--box--txt--box {
                margin-left: 35px;
                margin-top: 25px;
                border: 1px solid #2992c9;
                padding: 20px 30px; }
                .contents main .contentsinner--box--cont--flow--box--txt--box .tog_lead {
                  width: 100%;
                  color: #2992c9;
                  font-size: 20px;
                  position: relative; }
                  .contents main .contentsinner--box--cont--flow--box--txt--box .tog_lead.plt {
                    padding-left: 75px; }
                  .contents main .contentsinner--box--cont--flow--box--txt--box .tog_lead i {
                    position: absolute;
                    width: 120px;
                    left: -50px;
                    top: -40px; }
                  .contents main .contentsinner--box--cont--flow--box--txt--box .tog_lead:after {
                    position: absolute;
                    content: "";
                    width: 10px;
                    height: 10px;
                    border-top: 1px solid #2993ca;
                    border-right: 1px solid #2993ca;
                    right: 0;
                    bottom: 10px;
                    transform: rotate(135deg); }
                  .contents main .contentsinner--box--cont--flow--box--txt--box .tog_lead.active:after {
                    transform: rotate(-45deg);
                    margin-top: -2px; }
                .contents main .contentsinner--box--cont--flow--box--txt--box--inner {
                  display: none; }
                  .contents main .contentsinner--box--cont--flow--box--txt--box--inner .leadinner {
                    font-size: 18px;
                    margin: 30px 0 15px; }
                    .contents main .contentsinner--box--cont--flow--box--txt--box--inner .leadinner span {
                      color: #2992c9; }
                  .contents main .contentsinner--box--cont--flow--box--txt--box--inner .txtinner {
                    font-size: 15px; }
                  .contents main .contentsinner--box--cont--flow--box--txt--box--inner ul li {
                    margin-left: 0;
                    list-style: none;
                    padding-left: 1em;
                    text-indent: -1em; }
                    .contents main .contentsinner--box--cont--flow--box--txt--box--inner ul li i {
                      font-style: normal; }
                  .contents main .contentsinner--box--cont--flow--box--txt--box--inner .innerflex {
                    display: flex;
                    justify-content: space-between;
                    align-items: center;
                    border-bottom: 1px solid #ccc;
                    padding-bottom: 30px;
                    margin-bottom: 30px; }
                    .contents main .contentsinner--box--cont--flow--box--txt--box--inner .innerflex:last-child {
                      margin-bottom: 0;
                      border-bottom: none; }
                    .contents main .contentsinner--box--cont--flow--box--txt--box--inner .innerflex p {
                      width: 390px;
                      padding-left: 1em;
                      text-indent: -1em; }
                      .contents main .contentsinner--box--cont--flow--box--txt--box--inner .innerflex p i {
                        font-style: normal; }
                    .contents main .contentsinner--box--cont--flow--box--txt--box--inner .innerflex figure {
                      width: 300px; }
        .contents main .contentsinner--box--cont--ships {
          display: flex;
          justify-content: space-between;
          margin-top: 40px; }
          .contents main .contentsinner--box--cont--ships figure {
            width: 470px; }
          .contents main .contentsinner--box--cont--ships--txt {
            width: 386px; }
            .contents main .contentsinner--box--cont--ships--txt dl {
              display: flex;
              flex-wrap: wrap; }
              .contents main .contentsinner--box--cont--ships--txt dl dt {
                width: 50%;
                border-bottom: 1px solid #d9d9d9;
                padding: 5px 0; }
              .contents main .contentsinner--box--cont--ships--txt dl dd {
                width: 50%;
                border-bottom: 1px solid #d9d9d9;
                padding: 5px 0; }
            .contents main .contentsinner--box--cont--ships--txt .point {
              font-size: 15px;
              margin-top: 20px;
              text-align: justify;
              line-height: 1.8; }
              .contents main .contentsinner--box--cont--ships--txt .point span {
                color: #0071a2; }
                .contents main .contentsinner--box--cont--ships--txt .point span a {
                  color: #0071a2;
                  text-decoration: underline; }
        .contents main .contentsinner--box--cont--photo {
          margin-top: 30px; }
          .contents main .contentsinner--box--cont--photo .tog_l {
            font-size: 22px;
            color: #0071a2;
            border: 1px solid #0071a2;
            padding: 8px 20px;
            cursor: pointer;
            position: relative;
            height: 100%; }
          .contents main .contentsinner--box--cont--photo--area {
            margin-top: 30px;
            color: #fff; }
            .contents main .contentsinner--box--cont--photo--area .back_1 {
              background: #003894;
              border-top-left-radius: 30px;
              display: flex;
              flex-wrap: wrap;
              justify-content: space-between;
              padding: 25px 20px;
              padding-bottom: 50px; }
              .contents main .contentsinner--box--cont--photo--area .back_1 p:first-child {
                font-size: 25px;
                line-height: 1.2;
                width: 40px; }
            .contents main .contentsinner--box--cont--photo--area .back_2 {
              background: #2992c9;
              border-top-left-radius: 30px;
              display: flex;
              flex-wrap: wrap;
              justify-content: space-between;
              padding: 25px 20px;
              padding-bottom: 50px;
              margin-top: -30px; }
              .contents main .contentsinner--box--cont--photo--area .back_2 p:first-child {
                font-size: 25px;
                line-height: 1.2;
                width: 40px; }
            .contents main .contentsinner--box--cont--photo--area .flex {
              display: flex;
              justify-content: space-between;
              flex-wrap: wrap; }
              .contents main .contentsinner--box--cont--photo--area .flex .flexbox {
                width: 400px; }
                .contents main .contentsinner--box--cont--photo--area .flex .flexbox.all {
                  width: 100%; }
              .contents main .contentsinner--box--cont--photo--area .flex figcaption {
                padding: 5px 0 10px; }
              .contents main .contentsinner--box--cont--photo--area .flex.wid_2 {
                width: 100%; }
                .contents main .contentsinner--box--cont--photo--area .flex.wid_2 .flexbox {
                  width: 260px; }
              .contents main .contentsinner--box--cont--photo--area .flex.wid_3 {
                width: 540px; }
                .contents main .contentsinner--box--cont--photo--area .flex.wid_3 .flexbox {
                  width: 260px; }
              .contents main .contentsinner--box--cont--photo--area .flex.wid_4 {
                width: 540px; }
                .contents main .contentsinner--box--cont--photo--area .flex.wid_4 .flexbox {
                  width: 260px; }
            .contents main .contentsinner--box--cont--photo--area .flexare {
              width: calc(100% - 40px); }
            .contents main .contentsinner--box--cont--photo--area .flex_all {
              width: calc(100% - 40px);
              display: flex;
              flex-wrap: wrap;
              justify-content: space-between; }
              .contents main .contentsinner--box--cont--photo--area .flex_all .wids {
                width: 260px;
                margin-right: 20px; }
        .contents main .contentsinner--box--cont--price {
          padding-bottom: 80px; }
          .contents main .contentsinner--box--cont--price .captionlead {
            margin-top: 25px;
            padding: 15px 20px;
            border: red 1px solid;
            color: red;
            line-height: 1.8; }
          .contents main .contentsinner--box--cont--price .tb_1 {
            margin-top: 30px;
            color: #333; }
            .contents main .contentsinner--box--cont--price .tb_1 th {
              background: #2999d0;
              color: #fff;
              text-align: center;
              padding: 10px 0;
              border-right: 1px solid #fff;
              border-left: 1px solid #2999d0; }
              .contents main .contentsinner--box--cont--price .tb_1 th.wid_n {
                width: 45.5%; }
              .contents main .contentsinner--box--cont--price .tb_1 th.wid_b {
                width: 60%; }
              .contents main .contentsinner--box--cont--price .tb_1 th:last-child {
                border-right: none; }
            .contents main .contentsinner--box--cont--price .tb_1 td {
              text-align: center;
              border: 1px solid #2999d0;
              padding: 10px 0;
              -webkit-text-stroke: 0.7px #333; }
              .contents main .contentsinner--box--cont--price .tb_1 td span {
                display: block;
                font-size: 11px; }
            .contents main .contentsinner--box--cont--price .tb_1 .vert_1 {
              background: #e4ffff;
              width: 8%;
              -ms-writing-mode: tb-rl;
    -webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl; }
            .contents main .contentsinner--box--cont--price .tb_1 .b_c1 {
              background: #e4ffff; }
            .contents main .contentsinner--box--cont--price .tb_1 .b_c2 {
              background: #f1f1f1;
              padding: 30px 0; }
            .contents main .contentsinner--box--cont--price .tb_1 .b_c3 {
              background: #f1f1f1; }
            .contents main .contentsinner--box--cont--price .tb_1 .wid_u_1 {
              width: 40%; }
            .contents main .contentsinner--box--cont--price .tb_1 .wid_u_2 {
              width: 20%; }
          .contents main .contentsinner--box--cont--price .pointcaps {
            margin-top: 30px; }
            .contents main .contentsinner--box--cont--price .pointcaps li {
              font-size: 13px;
              list-style: none;
              position: relative;
              padding-left: 20px;
              margin-left: 0; }
              .contents main .contentsinner--box--cont--price .pointcaps li:before {
                position: absolute;
                content: "※";
                color: #db1c24;
                left: 0; }
          .contents main .contentsinner--box--cont--price--flex {
            display: flex;
            justify-content: space-between;
            flex-wrap: wrap; }
            .contents main .contentsinner--box--cont--price--flex .tb_1 {
              width: 50%; }
            .contents main .contentsinner--box--cont--price--flex .allarea {
              width: 54%; }
              .contents main .contentsinner--box--cont--price--flex .allarea .tb_1 {
                width: 100%; }
                .contents main .contentsinner--box--cont--price--flex .allarea .tb_1:last-child {
                  margin-top: 0; }
                  .contents main .contentsinner--box--cont--price--flex .allarea .tb_1:last-child td {
                    border-top: none; }
            .contents main .contentsinner--box--cont--price--flex .tablecap {
              width: 50%;
              margin-top: 30px;
              border: 1px solid #2999d0;
              border-left: none; }
              .contents main .contentsinner--box--cont--price--flex .tablecap.allarea {
                width: 46%; }
              .contents main .contentsinner--box--cont--price--flex .tablecap p {
                background: #2999d0;
                color: #fff;
                text-align: center;
                padding: 10px 0;
                border-left: 1px solid #fff; }
              .contents main .contentsinner--box--cont--price--flex .tablecap--inner {
                height: calc(100% - 45px);
                display: flex;
                justify-content: center;
                align-items: center;
                align-content: center;
                flex-wrap: wrap; }
                .contents main .contentsinner--box--cont--price--flex .tablecap--inner dl {
                  width: 100%;
                  padding: 0 60px; }
                  .contents main .contentsinner--box--cont--price--flex .tablecap--inner dl dt {
                    color: #2999d0;
                    position: relative;
                    padding-left: 25px; }
                    .contents main .contentsinner--box--cont--price--flex .tablecap--inner dl dt:before {
                      position: absolute;
                      content: "■";
                      color: #2999d0;
                      left: 0; }
                  .contents main .contentsinner--box--cont--price--flex .tablecap--inner dl dd {
                    font-size: 14px;
                    padding-left: 25px;
                    position: relative; }
                    .contents main .contentsinner--box--cont--price--flex .tablecap--inner dl dd:before {
                      position: absolute;
                      content: "■";
                      color: #2999d0;
                      left: 0; }
                    .contents main .contentsinner--box--cont--price--flex .tablecap--inner dl dd.caution:before {
                      content: none; }
                .contents main .contentsinner--box--cont--price--flex .tablecap--inner.wid dl {
                  padding: 0 30px; }
          .contents main .contentsinner--box--cont--price .point_area {
            position: relative;
            margin-top: 40px;
            background: #def1fb;
            padding: 30px 70px;
            display: flex;
            justify-content: space-between; }
            .contents main .contentsinner--box--cont--price .point_area:after {
              position: absolute;
              content: "";
              height: calc(100% - 60px);
              top: 30px;
              left: 50%;
              border-left: 1px dashed #2999d0; }
            .contents main .contentsinner--box--cont--price .point_area .obj {
              position: absolute;
              width: 80px;
              left: -25px;
              top: -15px; }
            .contents main .contentsinner--box--cont--price .point_area--box {
              width: 340px; }
              .contents main .contentsinner--box--cont--price .point_area--box p:first-child {
                font-size: 22px;
                color: #333;
                padding-bottom: 10px; }
              .contents main .contentsinner--box--cont--price .point_area--box dl {
                margin-top: 10px; }
                .contents main .contentsinner--box--cont--price .point_area--box dl dt {
                  background: #2999d0;
                  color: #fff;
                  text-align: center;
                  padding: 5px;
                  border-radius: 20px; }
                .contents main .contentsinner--box--cont--price .point_area--box dl dd {
                  font-size: 14px;
                  text-align: justify;
                  margin-top: 10px; }
          .contents main .contentsinner--box--cont--price .cautionbos {
            margin-top: 40px;
            border: 1px solid #e5811e;
            padding: 30px; }
            .contents main .contentsinner--box--cont--price .cautionbos .leadc {
              text-align: center;
              color: #e5811e;
              font-size: 22px;
              padding-bottom: 10px; }
            .contents main .contentsinner--box--cont--price .cautionbos .txtc {
              text-align: justify;
              font-size: 15px;
              line-height: 2; }
            .contents main .contentsinner--box--cont--price .cautionbos li {
              font-size: 14px;
              list-style: none;
              position: relative;
              padding-left: 20px;
              margin-left: 0;
              line-height: 1.6;
              margin-bottom: 10px; }
              .contents main .contentsinner--box--cont--price .cautionbos li:before {
                position: absolute;
                content: "※";
                color: #db1c24;
                left: 0; }
          .contents main .contentsinner--box--cont--price .btns {
            max-width: 340px;
            margin: 60px auto 0;
            background: #2999d0;
            color: #fff;
            text-align: center;
            font-size: 17px;
            padding: 15px 0 18px;
            position: relative; }
            .contents main .contentsinner--box--cont--price .btns a {
              display: block;
              color: #fff;
              position: relative; }
              .contents main .contentsinner--box--cont--price .btns a:after {
                position: absolute;
                content: "";
                width: 8px;
                height: 8px;
                border-top: 1px solid #fff;
                border-right: 1px solid #fff;
                transform: rotate(45deg);
                right: 8px;
                top: 50%;
                margin-top: -5px; }
          .contents main .contentsinner--box--cont--price .imgs {
            margin-top: 30px; }
          .contents main .contentsinner--box--cont--price--camp {
            margin-top: 50px;
            background: #def1fb;
            padding: 40px;
            border-radius: 20px;
            display: flex;
            justify-content: space-between;
            flex-direction: row-reverse; }
            .contents main .contentsinner--box--cont--price--camp .left {
              width: 420px; }
              .contents main .contentsinner--box--cont--price--camp .left .txt_camp {
                margin-top: 40px;
                padding-right: 20px;
                padding-left: 1em;
                text-indent: -1em; }
                .contents main .contentsinner--box--cont--price--camp .left .txt_camp i {
                  font-style: normal;
                  color: #2991c8; }
              .contents main .contentsinner--box--cont--price--camp .left .btns {
                margin-top: 20px; }
            .contents main .contentsinner--box--cont--price--camp figure {
              width: 390px; }
        .contents main .contentsinner--box--cont--oper {
          display: flex;
          justify-content: space-around; }
          .contents main .contentsinner--box--cont--oper--box {
            width: 340px; }
            .contents main .contentsinner--box--cont--oper--box p {
              background: #2999d0;
              color: #fff;
              font-size: 20px;
              text-align: center;
              line-height: 1.4;
              padding-top: 8px; }
              .contents main .contentsinner--box--cont--oper--box p .img {
                display: inline-block;
                width: 62px;
                position: relative;
                margin: 0 10px;
                top: -8px; }
              .contents main .contentsinner--box--cont--oper--box p .txt {
                font-size: 14px;
                line-height: 1;
                position: relative;
                top: -5px; }
            .contents main .contentsinner--box--cont--oper--box dl {
              display: flex;
              border: 1px solid #2999d0;
              border-bottom: none;
              justify-content: center;
              align-items: center;
              flex-wrap: wrap;
              text-align: center; }
              .contents main .contentsinner--box--cont--oper--box dl dt {
                width: 50%;
                height: 40px;
                font-size: 22px;
                border-bottom: 1px solid #2999d0;
                padding: 4.5px 0;
                position: relative;
                -webkit-text-stroke: 0.5px #000; }
                .contents main .contentsinner--box--cont--oper--box dl dt:after {
                  position: absolute;
                  content: url("../../imgs/operation/operation_4.svg");
                  width: 40px;
                  right: -20px;
                  top: 0px; }
                .contents main .contentsinner--box--cont--oper--box dl dt.reg:before {
                  position: absolute;
                  content: "臨時";
                  left: 10px;
                  top: 8px;
                  font-size: 16px; }
              .contents main .contentsinner--box--cont--oper--box dl dd {
                width: 50%;
                height: 40px;
                font-size: 18px;
                padding: 8px 0;
                color: #333;
                border-bottom: 1px solid #2999d0; }
        .contents main .contentsinner--box--cont--food .txt {
          margin: 20px 0;
          text-align: justify;
          line-height: 1.8; }
        .contents main .contentsinner--box--cont--food dl {
          display: flex;
          font-size: 14px; }
          .contents main .contentsinner--box--cont--food dl span {
            background: #b91023;
            color: #fff;
            padding: 0 8px;
            margin-right: 10px; }
          .contents main .contentsinner--box--cont--food dl dt {
            margin-right: 15px; }
        .contents main .contentsinner--box--cont--food .flex {
          display: flex;
          justify-content: space-between;
          flex-wrap: wrap; }
          .contents main .contentsinner--box--cont--food .flex dl {
            margin-top: 15px;
            display: block;
            width: 32%;
            text-align: center; }
            .contents main .contentsinner--box--cont--food .flex dl dt {
              margin-right: 0; }
            .contents main .contentsinner--box--cont--food .flex dl dd {
              padding-top: 5px; }
        .contents main .contentsinner--box--cont--food .btns.red {
          max-width: 340px;
          margin: 60px auto 0;
          background: #b91023;
          color: #fff;
          text-align: center;
          font-size: 17px;
          padding: 15px 0 18px;
          position: relative; }
          .contents main .contentsinner--box--cont--food .btns.red a {
            display: block;
            color: #fff;
            position: relative; }
            .contents main .contentsinner--box--cont--food .btns.red a:after {
              position: absolute;
              content: "";
              width: 8px;
              height: 8px;
              border-top: 1px solid #fff;
              border-right: 1px solid #fff;
              transform: rotate(45deg);
              right: 8px;
              top: 50%;
              margin-top: -5px; }
        .contents main .contentsinner--box--cont--foodb {
          border: 2px dotted #298dc4;
          border-radius: 20px;
          padding: 15px;
          margin-top: 40px; }
          .contents main .contentsinner--box--cont--foodb .lead_f {
            font-size: 30px;
            padding: 25px 25px 10px 25px;
            color: #298dc4; }
          .contents main .contentsinner--box--cont--foodb .txt_f {
            padding: 0 25px;
            line-height: 1.8;
            text-align: justify;
            margin-bottom: 20px; }
          .contents main .contentsinner--box--cont--foodb--flex {
            background: #fff;
            border-radius: 20px;
            display: flex;
            justify-content: space-between;
            flex-wrap: wrap; }
            .contents main .contentsinner--box--cont--foodb--flex .left {
              width: 450px; }
              .contents main .contentsinner--box--cont--foodb--flex .left ul {
                display: flex;
                justify-content: space-between; }
                .contents main .contentsinner--box--cont--foodb--flex .left ul li {
                  width: 48%;
                  list-style: none; }
              .contents main .contentsinner--box--cont--foodb--flex .left.all {
                width: 100%; }
                .contents main .contentsinner--box--cont--foodb--flex .left.all ul {
                  padding-top: 15px;
                  padding-right: 25px; }
                  .contents main .contentsinner--box--cont--foodb--flex .left.all ul li {
                    width: 32%; }
            .contents main .contentsinner--box--cont--foodb--flex figure {
              width: 420px;
              margin-right: -80px;
              margin-top: -80px; }
            .contents main .contentsinner--box--cont--foodb--flex dl {
              display: flex;
              font-size: 14px;
              margin-left: 25px; }
              .contents main .contentsinner--box--cont--foodb--flex dl span {
                background: #b91023;
                color: #fff;
                padding: 0 8px;
                margin-right: 10px; }
              .contents main .contentsinner--box--cont--foodb--flex dl dt {
                margin-right: 15px; }
            .contents main .contentsinner--box--cont--foodb--flex .border_flex {
              width: 100%;
              margin: 25px;
              padding: 20px;
              border: 1px solid #298dc4;
              border-radius: 20px;
              display: flex;
              justify-content: space-between; }
              .contents main .contentsinner--box--cont--foodb--flex .border_flex figure {
                margin: 0;
                width: 390px; }
              .contents main .contentsinner--box--cont--foodb--flex .border_flex dl {
                display: block;
                margin: 0;
                width: 375px;
                padding-left: 25px; }
                .contents main .contentsinner--box--cont--foodb--flex .border_flex dl dd {
                  font-size: 16px;
                  line-height: 2;
                  margin-top: 20px; }
        .contents main .contentsinner--box--cont .btns {
          max-width: 340px;
          margin: 60px auto 0;
          background: #2999d0;
          color: #fff;
          text-align: center;
          font-size: 17px;
          padding: 15px 0 18px;
          position: relative; }
          .contents main .contentsinner--box--cont .btns a {
            display: block;
            color: #fff;
            position: relative; }
            .contents main .contentsinner--box--cont .btns a:after {
              position: absolute;
              content: "";
              width: 8px;
              height: 8px;
              border-top: 1px solid #fff;
              border-right: 1px solid #fff;
              transform: rotate(45deg);
              right: 8px;
              top: 50%;
              margin-top: -5px; }
      .contents main .contentsinner--box .btnsroute {
        max-width: 340px;
        margin: 60px auto 0;
        background: #2999d0;
        color: #fff;
        text-align: center;
        font-size: 17px;
        padding: 15px 0 18px;
        position: relative; }
        .contents main .contentsinner--box .btnsroute a {
          display: block;
          color: #fff;
          position: relative; }
          .contents main .contentsinner--box .btnsroute a:after {
            position: absolute;
            content: "";
            width: 8px;
            height: 8px;
            border-top: 1px solid #fff;
            border-right: 1px solid #fff;
            transform: rotate(45deg);
            right: 8px;
            top: 50%;
            margin-top: -5px; }
      .contents main .contentsinner--box--route {
        margin-top: 60px; }
        .contents main .contentsinner--box--route .mores {
          text-align: center;
          font-size: 33px;
          color: #0071aa;
          position: relative;
          margin-bottom: 80px; }
          .contents main .contentsinner--box--route .mores:after {
            position: absolute;
            content: "";
            width: 0;
            height: 0;
            border-style: solid;
            border-width: 50px 32.5px 0 32.5px;
            border-color: #0071aa transparent transparent transparent;
            bottom: -50px;
            left: 50%;
            margin-left: -32.5px; }
        .contents main .contentsinner--box--route--camp {
          background: #ddf0fa;
          border-radius: 20px;
          padding: 40px 0; }
          .contents main .contentsinner--box--route--camp figure {
            width: 680px;
            margin: 0 auto; }
          .contents main .contentsinner--box--route--camp p {
            width: 680px;
            margin: 20px auto 0; }
            .contents main .contentsinner--box--route--camp p.txt_camp {
              padding-left: 1em;
              text-indent: -1em; }
              .contents main .contentsinner--box--route--camp p.txt_camp i {
                font-style: normal;
                color: #2991c8; }
            .contents main .contentsinner--box--route--camp p.btns {
              max-width: 340px;
              margin: 20px auto 0;
              background: #ffcd37;
              color: #333;
              text-align: center;
              font-size: 17px;
              padding: 15px 0 18px;
              position: relative; }
              .contents main .contentsinner--box--route--camp p.btns a {
                display: block;
                color: #333;
                position: relative; }
                .contents main .contentsinner--box--route--camp p.btns a:after {
                  position: absolute;
                  content: "";
                  width: 8px;
                  height: 8px;
                  border-top: 1px solid #333;
                  border-right: 1px solid #333;
                  transform: rotate(45deg);
                  right: 8px;
                  top: 50%;
                  margin-top: -5px; }
      .contents main .contentsinner--box .btn_o {
        max-width: 290px;
        background: #ffcd37;
        border-radius: 8px;
        font-size: 18px;
        text-align: center;
        margin: 30px auto 15px; }
        .contents main .contentsinner--box .btn_o a {
          display: block;
          padding: 8px 0px;
          position: relative; }
          .contents main .contentsinner--box .btn_o a:after {
            position: absolute;
            content: "";
            width: 8px;
            height: 8px;
            border-top: 1px solid #000;
            border-right: 1px solid #000;
            transform: rotate(45deg);
            right: 15px;
            top: 50%;
            margin-top: -5px; }
      .contents main .contentsinner--box--comp {
        max-width: 730px;
        margin: 0 auto; }
        .contents main .contentsinner--box--comp dl {
          display: flex;
          padding: 15px 35px;
          border-bottom: 2px solid #d9d9d9;
            font-size: 16px;}
          .contents main .contentsinner--box--comp dl dt {
            width: 150px; }
          .contents main .contentsinner--box--comp dl:last-child {
            border-bottom: none; }
      .contents main .contentsinner--box--compacc {
        width: 320px; }
        .contents main .contentsinner--box--compacc dt {
          color: #2986bd;
          font-size: 17px;
          margin-bottom: 10px; }
        .contents main .contentsinner--box--compacc dd {
          font-size: 16px;
          line-height: 2; }
        .contents main .contentsinner--box--compacc dl:last-child {
          margin-top: 30px; }
        .contents main .contentsinner--box--compacc.all {
          width: 100%;
          text-align: center; }
          .contents main .contentsinner--box--compacc.all dt {
            font-size: 22px;
            line-height: 1.8; }
      .contents main .contentsinner--box.flex {
        max-width: 730px;
        display: flex;
        justify-content: space-between; }
        .contents main .contentsinner--box.flex .contentsinner--box--comp {
          max-width: 350px;
          margin: 0 auto 0 0; }
      .contents main .contentsinner--box.flex2 {
        max-width: 730px;
        display: flex;
        justify-content: center; }
        .contents main .contentsinner--box.flex2 .contentsinner--box--compacc {
          max-width: 200px;
          margin: 0 60px; }
          .contents main .contentsinner--box.flex2 .contentsinner--box--compacc span {
            color: #2986bd; }
      .contents main .contentsinner--box--caution {
        max-width: 900px;
        margin: 0 auto;
        background: #fff; }
        .contents main .contentsinner--box--caution dl {
          display: flex;
          align-items: center;
          padding: 15px 0; }
          .contents main .contentsinner--box--caution dl dt {
            width: 280px;
            padding: 10px 60px;
            border-right: 2px solid #2992c9; }
          .contents main .contentsinner--box--caution dl dd {
            font-size: 17px;
            line-height: 2;
            margin-left: 30px; }
    .contents main .contentsinner--flex {
      max-width: 900px;
      margin: 0 auto;
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; }
      .contents main .contentsinner--flex p {
        width: 430px;
        height: 150px;
        border: 2px solid #cdcdcd;
        border-radius: 15px;
        margin-top: 30px; }
        .contents main .contentsinner--flex p a {
          height: 100%;
          display: flex;
          align-items: center;
          justify-content: center; }
        .contents main .contentsinner--flex p:first-child img {
          width: 230px; }
        .contents main .contentsinner--flex p:nth-child(2) img {
          width: 330px; }
        .contents main .contentsinner--flex p:nth-child(3) img {
          width: 360px; }
        .contents main .contentsinner--flex p:nth-child(4) img {
          width: 200px; }
        .contents main .contentsinner--flex p:nth-child(5) img {
          width: 300px; }
      .contents main .contentsinner--flex.txtlink {
        max-width: 650px; }
        .contents main .contentsinner--flex.txtlink .txtlink_box {
          width: 300px;    }
        .contents main .contentsinner--flex.txtlink p {
          width: 100%;
          height: auto;
          text-align: center;
            font-size: 14px;
          border: 1px solid #0071a2;
          margin-top: 20px;}
          .contents main .contentsinner--flex.txtlink p a {
            display: block;
            color: #0071a2;
            padding: 10px 0; }
  .contents main .kv {
    width: 100%;
    height: 650px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative; }
    .contents main .kv h2 {
      width: 1024px;
      text-align: center;
      margin: 0 auto;
      font-size: 48px;
      letter-spacing: 0.06em;
      font-weight: 500;
      color: #fff;
      padding: 0px;
      position: relative;
      text-shadow: #000 1px 0 10px;
      -webkit-text-stroke: 0.2px #fff;
      padding-bottom: 80px; }
      .contents main .kv h2.imgs {
        width: 900px; }
    .contents main .kv.access {
      background: url("../../imgs/access/kv.jpg") no-repeat center center/cover; }
    .contents main .kv.guide {
      background: url("../../imgs/guide/kv.jpg") no-repeat center center/cover; }
    .contents main .kv.ship {
      background: url("../../imgs/senpaku/kv.jpg") no-repeat center center/cover; }
    .contents main .kv.price {
      background: url("../../imgs/price/kv.jpg") no-repeat center center/cover; }
    .contents main .kv.operation {
      background: url("../../imgs/operation/kv.jpg") no-repeat center center/cover; }
    .contents main .kv.food {
      background: url("../../imgs/food/kv.jpg") no-repeat center center/cover; }
    .contents main .kv.caseindex {
      background: url("../images/case/index/img_1.png") no-repeat center center/cover; }
    .contents main .kv:before {
      position: absolute;
      content: "";
      width: 100%;
      height: 78px;
      bottom: 0;
      left: 0;
      background: url("../../imgs/common/obi_b.svg") repeat-x bottom center; }
    .contents main .kv.ship {
      background: url("../../imgs/senpaku/kv.jpg") no-repeat center center/cover; }
    .contents main .kv.route {
      background: rgba(41, 133, 188, 0.12); }
      .contents main .kv.route:before {
        background: url("../../imgs/common/obi_w3.svg") repeat-x bottom center; }
    .contents main .kv.top {
      display: block;
      position: relative;
      margin-bottom: -5px; }
      .contents main .kv.top .slide {
        position: absolute;
        width: 100%;
        height: 650px;
        left: 0;
        top: 0; }
        .contents main .kv.top .slide .topback_1 {
          background: url("../../imgs/top/slide_1.jpg") no-repeat center center;
          height: 650px; }
        .contents main .kv.top .slide .topback_2 {
          background: url("../../imgs/top/slide_2.jpg") no-repeat center center;
          height: 650px; }
        .contents main .kv.top .slide .topback_3 {
          background: url("../../imgs/top/slide_3.jpg") no-repeat center center;
          height: 650px; }
        .contents main .kv.top .slide .topback_4 {
          background: rgba(41, 133, 188, 0.12);
          height: 650px; }
      .contents main .kv.top .toplead {
        max-width: 1260px;
        padding: 0 20px;
        margin: 0 auto; }
        .contents main .kv.top .toplead .tops {
          width: 300px;
          text-align: left;
          padding-bottom: 20px;
          padding-top: 180px;
          margin: 0 auto 0 0; }
        .contents main .kv.top .toplead .objs {
          width: 270px; }
        .contents main .kv.top .toplead figure {
          max-width: 880px;
          margin: 0 auto;
          padding-top: 160px; }
      .contents main .kv.top:before {
        background: url("../../imgs/common/obi_top.svg") repeat-x bottom center;
        position: absolute;
        z-index: 2; }
  .contents main .numberingOL {
    list-style-type: none;
    counter-reset: number;
    /* カウンターを初期化 */ }
    .contents main .numberingOL li {
      position: relative;
      padding-left: 25px; }
      .contents main .numberingOL li:before {
        content: counter(number);
        counter-increment: number;
        padding: 0.1em 0 0.1em 0.35em;
        left: 0;
        position: absolute;
        transform: translateY(-6%); }
      .contents main .numberingOL li:after {
        content: '';
        position: absolute;
        display: block;
        top: 50%;
        left: 0;
        transform: translateY(-50%);
        /* ○を作る */
        width: 1em;
        height: 1em;
        border: 1px solid #000;
        border-radius: 50%; }
  .contents main .warn_dl {
    border: 1px solid red;
    margin-top: 10px;
    border-radius: 10px;
    padding: 20px 40px; }
    .contents main .warn_dl p:first-child {
      font-size: 18px;
      color: red;
      text-align: center;
      -webkit-text-stroke: 0.3px red;
      margin-bottom: 10px; }
  .contents main .btn_style {
    max-width: 340px;
    margin: 30px auto 0;
    background: #2999d0;
    color: #fff;
    text-align: center;
    font-size: 17px;
    padding: 15px 0 18px;
    position: relative; }
    .contents main .btn_style a {
      display: block;
      color: #fff !important;
      text-decoration: none !important;
      position: relative; }
      .contents main .btn_style a:after {
        position: absolute;
        content: "";
        width: 8px;
        height: 8px;
        border-top: 1px solid #fff;
        border-right: 1px solid #fff;
        transform: rotate(45deg);
        right: 8px;
        top: 50%;
        margin-top: -5px; }

@media all and (-ms-high-contrast: none) {
  .contents main .kv:before {
    width: 530px; } }
@media screen and (max-width: 767px) {
  .contents main {
    display: block;
    margin-top: 60px;
    font-size: 16px; }
    .contents main .contents {
      position: relative;
      top: -2px;
      z-index: 3; }
    .contents main.mt {
      margin-top: 60px; }
    .contents main.mt.mtnone {
      margin-top: 0px; }
    .contents main .back_b2 {
      margin-top: 0px;
      padding-bottom: 50px; }
      .contents main .back_b2:before {
        width: 100%;
        height: 78px;
        background: url("../../imgs/common/obi_b.svg") repeat-x bottom center; }
    .contents main .back_b3 {
      margin-top: 0px;
      padding-bottom: 50px; }
      .contents main .back_b3:before {
        width: 100%;
        height: 78px;
        background: url("../../imgs/common/obi_b.svg") repeat-x bottom center; }
    .contents main .back_p {
      margin-top: 0px;
      padding-bottom: 80px;
      padding-top: 60px; }
      .contents main .back_p:before {
        position: absolute;
        content: "";
        width: 100%;
        height: 78px;
        bottom: 0;
        left: 0;
        background: url("../../imgs/common/obi_b.svg") repeat-x bottom center; }
      .contents main .back_p:after {
        position: absolute;
        content: "";
        width: 100%;
        height: 78px;
        bottom: 0;
        left: 0;
        background: url("../../imgs/common/obi_w2.svg") repeat-x bottom center; }
    .contents main .back_w2 {
      background: #e4f4fd;
      margin-top: 0px;
      position: relative;
      padding-top: 20px; }
    .contents main .contentshead h2 {
      font-size: 24px;
      margin-top: 100px;
      margin-bottom: 20px;
      color: #2985bc; }
      .contents main .contentshead h2.mt {
        margin-top: 50px; }
    .contents main .contentshead p {
      max-width: 90%; }
    .contents main .contentshead .anchor {
      max-width: 100%;
      margin: 40px auto 40px;
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between; }
      .contents main .contentshead .anchor li {
        font-size: 16px;
        border: 1px solid #2991c8;
        text-align: center; }
        .contents main .contentshead .anchor li a {
          display: block;
          color: #2991c8;
          padding: 10px 0px 25px;
          position: relative; }
          .contents main .contentshead .anchor li a:after {
            position: absolute;
            content: "";
            width: 10px;
            height: 10px;
            border-top: 1px solid #2993ca;
            border-right: 1px solid #2993ca;
            left: 50%;
            margin-left: -6px;
            bottom: 10px;
            transform: rotate(135deg); }
          .contents main .contentshead .anchor li a span {
            display: block;
            font-size: 14px; }
        .contents main .contentshead .anchor li.close {
          border: 1px solid #ccc; }
          .contents main .contentshead .anchor li.close a {
            pointer-events: none;
            color: #ccc; }
            .contents main .contentshead .anchor li.close a:after {
              border-top: 1px solid #ccc;
              border-right: 1px solid #ccc; }
      .contents main .contentshead .anchor.wid_1 {
        justify-content: center;
        margin-bottom: 60px; }
        .contents main .contentshead .anchor.wid_1 li {
          width: 100%;
          margin: 2% 2% 0; }
      .contents main .contentshead .anchor.wid_2 {
        justify-content: center;
        margin-bottom: 60px; }
        .contents main .contentshead .anchor.wid_2 li {
          width: 46%;
          margin: 0 2%; }
      .contents main .contentshead .anchor.wid_3 {
        justify-content: center;
        margin-bottom: 60px; }
        .contents main .contentshead .anchor.wid_3 li {
          width: 46%;
          margin: 0 2%;
          position: relative; }
          .contents main .contentshead .anchor.wid_3 li:last-child {
            margin-top: 2%; }
          .contents main .contentshead .anchor.wid_3 li.pt {
            padding-top: 10px; }
          .contents main .contentshead .anchor.wid_3 li span.mark {
            width: 50px;
            right: -10px;
            top: -10px; }
    .contents main .contentshead.under_b {
      padding-bottom: 20px; }
      .contents main .contentshead.under_b:before {
        width: 100%;
        height: 78px;
        background: url("../../imgs/common/obi_b2.svg") repeat-x bottom center; }
    .contents main .contentshead.under_p {
      padding-bottom: 20px; }
      .contents main .contentshead.under_p:before {
        width: 100%;
        height: 78px;
        background: url("../../imgs/common/obi_p.svg") repeat-x bottom center; }
    .contents main .contentshead .route_box {
      max-width: 90%;
      margin: 50px auto 0; }
      .contents main .contentshead .route_box .txt_cap {
        max-width: 100%;
        font-size: 11px;
        text-align: right;
        margin-top: 4px; }
      .contents main .contentshead .route_box--inner {
        border-top: 3px solid #2985bc;
        border-bottom: 3px solid #2985bc;
        padding: 3px 0; }
        .contents main .contentshead .route_box--inner--box {
          display: flex;
          justify-content: space-between;
          align-items: center;
          border-top: 1px solid #2985bc;
          position: relative; }
          .contents main .contentshead .route_box--inner--box:last-child {
            border-bottom: 1px solid #2985bc; }
          .contents main .contentshead .route_box--inner--box p {
            width: 40px;
            margin: 0;
            position: absolute;
            left: 0;
            top: 10px; }
          .contents main .contentshead .route_box--inner--box dl {
            padding: 30px 0 10px;
            width: 100%; }
            .contents main .contentshead .route_box--inner--box dl dt {
              font-size: 16px;
              text-align: center; }
            .contents main .contentshead .route_box--inner--box dl dd {
              display: flex;
              align-items: center;
              font-size: 24px;
              color: #2985bc; }
              .contents main .contentshead .route_box--inner--box dl dd sub {
                line-height: 1.4; }
              .contents main .contentshead .route_box--inner--box dl dd span {
                font-size: 32px;
                color: #003894;
                position: relative;
                margin-left: 5px; }
                .contents main .contentshead .route_box--inner--box dl dd span:after {
                  position: absolute;
                  content: "";
                  background: #ffda37;
                  height: 50%;
                  width: 105%;
                  bottom: 0;
                  left: -2.5%; }
              .contents main .contentshead .route_box--inner--box dl dd i {
                font-style: normal;
                position: relative;
                z-index: 3; }
    .contents main .content_tabinner {
      max-width: 900px;
      margin: 20px auto 0;
      position: relative; }
      .contents main .content_tabinner .tabs {
        display: flex;
        justify-content: space-between;
        position: absolute;
        flex-wrap: wrap;
        z-index: 2;
        width: 100%;
        top: 260px; }
        .contents main .content_tabinner .tabs li {
          width: 90%;
          margin: 1% auto 0;
          padding: 8px 0;
          cursor: pointer; }
          .contents main .content_tabinner .tabs li span {
            display: inline-block;
            font-family: 'Barlow Condensed',serif;
            font-weight: 300;
            margin-right: 15px; }
          .contents main .content_tabinner .tabs li.active {
            background: #ffbb37;
            color: #000; }
      .contents main .content_tabinner .tabinnermap {
        display: none; }
        .contents main .content_tabinner .tabinnermap.show {
          display: block; }
        .contents main .content_tabinner .tabinnermap .mapkv {
          max-width: 375px;
          margin: 0 auto;
          margin-bottom: 240px; }
        .contents main .content_tabinner .tabinnermap .tabinnermapcont, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 {
          display: none; }
          .contents main .content_tabinner .tabinnermap .tabinnermapcont.show, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2.show, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3.show, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4.show, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5.show {
            display: block; }
          .contents main .content_tabinner .tabinnermap .tabinnermapcont .tabinnermapcontflex, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2 .tabinnermapcontflex, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3 .tabinnermapcontflex, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4 .tabinnermapcontflex, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 .tabinnermapcontflex {
            width: 90%;
            margin: 0 auto;
            display: block;
            justify-content: space-between; }
            .contents main .content_tabinner .tabinnermap .tabinnermapcont .tabinnermapcontflex p, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2 .tabinnermapcontflex p, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3 .tabinnermapcontflex p, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4 .tabinnermapcontflex p, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 .tabinnermapcontflex p {
              width: 100%; }
              .contents main .content_tabinner .tabinnermap .tabinnermapcont .tabinnermapcontflex p.wids, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2 .tabinnermapcontflex p.wids, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3 .tabinnermapcontflex p.wids, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4 .tabinnermapcontflex p.wids, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 .tabinnermapcontflex p.wids {
                width: 100%; }
            .contents main .content_tabinner .tabinnermap .tabinnermapcont .tabinnermapcontflex div, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2 .tabinnermapcontflex div, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3 .tabinnermapcontflex div, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4 .tabinnermapcontflex div, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 .tabinnermapcontflex div {
              width: 100%;
              margin-top: 20px; }
              .contents main .content_tabinner .tabinnermap .tabinnermapcont .tabinnermapcontflex div.widd, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2 .tabinnermapcontflex div.widd, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3 .tabinnermapcontflex div.widd, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4 .tabinnermapcontflex div.widd, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 .tabinnermapcontflex div.widd {
                width: 100%; }
              .contents main .content_tabinner .tabinnermap .tabinnermapcont .tabinnermapcontflex div figcaption, .contents main .content_tabinner .tabinnermap .tabinnermapcont_2 .tabinnermapcontflex div figcaption, .contents main .content_tabinner .tabinnermap .tabinnermapcont_3 .tabinnermapcontflex div figcaption, .contents main .content_tabinner .tabinnermap .tabinnermapcont_4 .tabinnermapcontflex div figcaption, .contents main .content_tabinner .tabinnermap .tabinnermapcont_5 .tabinnermapcontflex div figcaption {
                font-size: 11px;
                padding-top: 5px; }
        .contents main .content_tabinner .tabinnermap .innertabs, .contents main .content_tabinner .tabinnermap .innertabs_2, .contents main .content_tabinner .tabinnermap .innertabs_3, .contents main .content_tabinner .tabinnermap .innertabs_4, .contents main .content_tabinner .tabinnermap .innertabs_5 {
          display: flex;
          justify-content: space-between;
          flex-wrap: wrap;
          z-index: 2;
          margin-top: 20px; }
          .contents main .content_tabinner .tabinnermap .innertabs li, .contents main .content_tabinner .tabinnermap .innertabs_2 li, .contents main .content_tabinner .tabinnermap .innertabs_3 li, .contents main .content_tabinner .tabinnermap .innertabs_4 li, .contents main .content_tabinner .tabinnermap .innertabs_5 li {
            width: 90%;
            margin: 1% auto 0;
            cursor: pointer; }
            .contents main .content_tabinner .tabinnermap .innertabs li span, .contents main .content_tabinner .tabinnermap .innertabs_2 li span, .contents main .content_tabinner .tabinnermap .innertabs_3 li span, .contents main .content_tabinner .tabinnermap .innertabs_4 li span, .contents main .content_tabinner .tabinnermap .innertabs_5 li span {
              display: block;
              font-family: 'Barlow Condensed',serif;
              font-weight: 300; }
            .contents main .content_tabinner .tabinnermap .innertabs li.active, .contents main .content_tabinner .tabinnermap .innertabs_2 li.active, .contents main .content_tabinner .tabinnermap .innertabs_3 li.active, .contents main .content_tabinner .tabinnermap .innertabs_4 li.active, .contents main .content_tabinner .tabinnermap .innertabs_5 li.active {
              background: #0071aa; }
    .contents main .contentsinner {
      max-width: 100%;
      margin: 0 auto;
      padding-bottom: 70px; }
      .contents main .contentsinner.reserve {
        max-width: 90%; }
      .contents main .contentsinner .morebtn {
        max-width: 250px;
        margin: 60px auto 0;
        background: #2986bd;
        color: #fff;
        text-align: center;
        font-size: 17px;
        padding: 15px 0 18px;
        position: relative;
        cursor: pointer;
        letter-spacing: 0.1em; }
        .contents main .contentsinner .morebtn:after {
          position: absolute;
          content: "";
          border-bottom: 1px solid #fff;
          border-right: 1px solid #fff;
          width: 10px;
          height: 10px;
          transform: rotate(45deg);
          bottom: 8px;
          left: 50%;
          margin-left: -5px; }
      .contents main .contentsinner .topicks .icon {
        font-size: 25px;
        text-align: center;
        color: #fff;
        position: relative; }
        .contents main .contentsinner .topicks .icon.cl_1 {
          color: #2992c9; }
      .contents main .contentsinner .topicks--inner {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        max-width: 90%;
        margin: 0 auto; }
        .contents main .contentsinner .topicks--inner--box {
          width: 48%;
          margin-top: 30px;
          background: #fff;
          padding-left: 20px;
          position: relative; }
          .contents main .contentsinner .topicks--inner--box figure {
            position: relative; }
          .contents main .contentsinner .topicks--inner--box dl {
            padding: 15px 0 35px; }
      .contents main .contentsinner.mb {
        padding-bottom: 0; }
      .contents main .contentsinner--box {
        max-width: 90%;
        margin: 0 auto; }
        .contents main .contentsinner--box .topco {
          display: block;
          width: 95%;
          margin: 0 auto;
          padding-top: 15px; }
          .contents main .contentsinner--box .topco .objs {
            width: 70%;
            margin: 25px auto; }
        .contents main .contentsinner--box--cont {
          padding-bottom: 40px; }
          .contents main .contentsinner--box--cont.none {
            display: none; }
          .contents main .contentsinner--box--cont.border_r {
            border-radius: 10px;
            padding: 0 20px 20px; }
          .contents main .contentsinner--box--cont.border_w {
            border-radius: 10px;
            padding: 0 20px 20px; }
          .contents main .contentsinner--box--cont .leadobj {
            max-width: 90%;
            margin: 0 auto;
            background: #fbe6ef;
            position: relative;
            top: -35px;
            margin-bottom: -30px; }
          .contents main .contentsinner--box--cont .lead {
            font-size: 19px; }
            .contents main .contentsinner--box--cont .lead:before {
              width: 60%; }
            .contents main .contentsinner--box--cont .lead.center {
              text-align: center; }
            .contents main .contentsinner--box--cont .lead.blue {
              color: #0071a2; }
            .contents main .contentsinner--box--cont .lead span {
              font-size: 18px; }
            .contents main .contentsinner--box--cont .lead.pts {
              padding-top: 60px; }
            .contents main .contentsinner--box--cont .lead .captionl {
              position: inherit;
              display: block;
              right: 0;
              bottom: 0px;
              text-align: left;
              font-size: 12px;
              margin-top: 3px; }
          .contents main .contentsinner--box--cont .icon {
            font-size: 22px;
            text-align: center;
            color: #fff;
            position: relative; }
            .contents main .contentsinner--box--cont .icon span {
              width: 50px; }
              .contents main .contentsinner--box--cont .icon span.smalls {
                width: 100%;
                font-size: 15px; }
              .contents main .contentsinner--box--cont .icon span.a_mark {
                position: absolute;
                width: 80px;
                right: 5%;
                top: 0;
                margin-right: 0px; }
            .contents main .contentsinner--box--cont .icon.cl_1 {
              color: #2992c9; }
          .contents main .contentsinner--box--cont .lead_txt {
            font-size: 16px; }
          .contents main .contentsinner--box--cont .txts {
            font-size: 14px;
            margin-bottom: 10px;
            line-height: 2; }
            .contents main .contentsinner--box--cont .txts a {
              text-decoration: underline; }
          .contents main .contentsinner--box--cont ul li {
            font-size: 14px;
            list-style: disc;
            padding-left: 0px;
            margin-left: 25px;
            line-height: 2; }
          .contents main .contentsinner--box--cont ul.num li {
            list-style: decimal; }
          .contents main .contentsinner--box--cont .right {
            text-align: right;
            font-size: 14px;
            line-height: 2; }
          .contents main .contentsinner--box--cont .backimgs {
            background: url("../../imgs/top/top_5.svg") no-repeat top center/160%; }
          .contents main .contentsinner--box--cont--move {
            max-width: 90%;
            margin: 0 auto;
            border-top: 2px solid #0071a6;
            border-bottom: 2px solid #0071a6;
            margin-top: 20px;
            padding: 10px 0;
            margin-bottom: 60px; }
            .contents main .contentsinner--box--cont--move .movetp {
              background: #0071a6;
              color: #fff;
              display: block;
              align-items: center;
              padding: 10px 10px;
              margin-bottom: 5px; }
              .contents main .contentsinner--box--cont--move .movetp dt {
                width: 100%;
                font-size: 21px;
                text-align: center;
                border-right: none;
                border-bottom: 1px solid #fff;
                padding-bottom: 8px; }
              .contents main .contentsinner--box--cont--move .movetp dd {
                margin-left: 15px;
                margin: 0 0px;
                font-size: 15px; }
                .contents main .contentsinner--box--cont--move .movetp dd span {
                  text-align: center;
                  display: block;
                  font-size: 25px;
                  color: #0071a6;
                  background: #fff;
                  padding: 5px 10px;
                  margin-right: 0px;
                  margin-top: 10px;
                  margin-bottom: 8px; }
            .contents main .contentsinner--box--cont--move--inner .moveinner {
              display: block;
              font-size: 15px;
              padding: 20px 10px; }
              .contents main .contentsinner--box--cont--move--inner .moveinner .date {
                width: 100%;
                margin-bottom: 10px; }
              .contents main .contentsinner--box--cont--move--inner .moveinner .txtinner {
                width: 100%; }
                .contents main .contentsinner--box--cont--move--inner .moveinner .txtinner .txt {
                  font-size: 14px;
                  padding: 10px 0; }
                .contents main .contentsinner--box--cont--move--inner .moveinner .txtinner .btns {
                  font-size: 14px; }
          .contents main .contentsinner--box--cont--news {
            max-width: 90%;
            margin: 0 auto;
            border-top: 2px solid #0071a6;
            border-bottom: 2px solid #0071a6;
            margin-top: 20px;
            padding: 10px 0;
            margin-bottom: 60px; }
            .contents main .contentsinner--box--cont--news--inner .moveinner {
              display: block;
              font-size: 15px;
              padding: 20px 10px; }
              .contents main .contentsinner--box--cont--news--inner .moveinner .date {
                width: 100%;
                margin-bottom: 10px; }
              .contents main .contentsinner--box--cont--news--inner .moveinner .txtinner {
                width: 100%; }
                .contents main .contentsinner--box--cont--news--inner .moveinner .txtinner .txt {
                  font-size: 14px;
                  padding: 10px 0; }
                .contents main .contentsinner--box--cont--news--inner .moveinner .txtinner .btns {
                  font-size: 14px; }
          .contents main .contentsinner--box--cont .policy {
            color: #2986bd; }
            .contents main .contentsinner--box--cont .policy li {
              font-size: 16px;
              list-style: none;
              margin-left: 0;
              letter-spacing: 0.06em; }
          .contents main .contentsinner--box--cont--flex {
            display: flex;
            justify-content: space-between;
            flex-wrap: wrap; }
            .contents main .contentsinner--box--cont--flex dl {
              width: 448px;
              margin-top: 25px;
              letter-spacing: 0.02em; }
              .contents main .contentsinner--box--cont--flex dl dt {
                font-size: 17px;
                color: #2986bd;
                padding-bottom: 10px; }
              .contents main .contentsinner--box--cont--flex dl dd {
                font-size: 12px; }
          .contents main .contentsinner--box--cont--safe dl dt {
            width: 130px; }
          .contents main .contentsinner--box--cont--safe dl dd {
            width: calc(100% - 130px); }
          .contents main .contentsinner--box--cont--qa {
            padding: 0 0px; }
            .contents main .contentsinner--box--cont--qa dl {
              margin-top: 40px; }
              .contents main .contentsinner--box--cont--qa dl dt {
                font-size: 15px;
                padding-right: 40px; }
              .contents main .contentsinner--box--cont--qa dl dd {
                display: none;
                padding: 15px 0 0 0px;
                text-align: justify;
                font-size: 14px;
                line-height: 1.8; }
                .contents main .contentsinner--box--cont--qa dl dd a {
                  text-decoration: underline;
                  color: #2993ca; }
                .contents main .contentsinner--box--cont--qa dl dd .caution {
                  color: red; }
          .contents main .contentsinner--box--cont--box .flex {
            display: flex;
            justify-content: space-between;
            flex-wrap: wrap;
            margin-top: 10px; }
            .contents main .contentsinner--box--cont--box .flex figure {
              height: auto; }
              .contents main .contentsinner--box--cont--box .flex figure img {
                height: auto;
                width: 100%; }
            .contents main .contentsinner--box--cont--box .flex dl {
              width: 100%;
              display: block;
              font-size: 16px;
              margin: 15px 0 0; }
              .contents main .contentsinner--box--cont--box .flex dl dd {
                text-align: center;
                margin-top: 10px; }
                .contents main .contentsinner--box--cont--box .flex dl dd a {
                  display: block;
                  padding: 10px 0px;
                  position: relative; }
                  .contents main .contentsinner--box--cont--box .flex dl dd a:after {
                    right: 15px; }
          .contents main .contentsinner--box--cont--box .lead_toggle {
            font-size: 17px; }
            .contents main .contentsinner--box--cont--box .lead_toggle:after {
              right: 20px; }
          .contents main .contentsinner--box--cont--box .togglearea figure {
            margin-top: 30px; }
          .contents main .contentsinner--box--cont--box .togglearea--box {
            padding: 0 0px; }
            .contents main .contentsinner--box--cont--box .togglearea--box .lead_t {
              font-size: 16px; }
          .contents main .contentsinner--box--cont--box .g_maps {
            width: 100%;
            height: 250px; }
            .contents main .contentsinner--box--cont--box .g_maps iframe {
              width: 100%;
              height: 100%; }
          .contents main .contentsinner--box--cont--guide {
            margin-top: 30px;
            color: #fff; }
            .contents main .contentsinner--box--cont--guide .ttl {
              padding: 5px 10px 5px 0; }
              .contents main .contentsinner--box--cont--guide .ttl dt {
                width: 60px;
                margin: 0 0px;
                text-align: center; }
              .contents main .contentsinner--box--cont--guide .ttl dd {
                width: calc(100% - 60px);
                font-size: 19px; }
                .contents main .contentsinner--box--cont--guide .ttl dd span {
                  display: block;
                  font-size: 14px;
                  color: #ffff92; }
            .contents main .contentsinner--box--cont--guide .flex {
              flex-wrap: wrap;
              margin-top: 40px; }
              .contents main .contentsinner--box--cont--guide .flex dl {
                width: 100%;
                text-align: center; }
                .contents main .contentsinner--box--cont--guide .flex dl:last-child {
                  border-left: none;
                  border-top: 1px solid #fff;
                  margin-top: 20px;
                  padding-top: 20px; }
                .contents main .contentsinner--box--cont--guide .flex dl dt {
                  font-size: 24px; }
                .contents main .contentsinner--box--cont--guide .flex dl dd {
                  color: #ffff92;
                  font-size: 18px;
                  padding-top: 15px; }
                  .contents main .contentsinner--box--cont--guide .flex dl dd.pt_1 {
                    padding-top: 15px; }
                  .contents main .contentsinner--box--cont--guide .flex dl dd.pt_2 {
                    padding-top: 15px; }
          .contents main .contentsinner--box--cont--flow {
            margin-top: 60px; }
            .contents main .contentsinner--box--cont--flow--box {
              display: block;
              justify-content: space-between;
              padding-bottom: 60px; }
              .contents main .contentsinner--box--cont--flow--box:before {
                content: none; }
              .contents main .contentsinner--box--cont--flow--box:after {
                position: absolute;
                content: url("../../imgs/guide/tri.svg");
                width: 60px;
                left: 50%;
                margin-left: -30px;
                bottom: 15px; }
              .contents main .contentsinner--box--cont--flow--box .steps {
                width: 60px;
                height: 60px;
                margin: 0 auto; }
                .contents main .contentsinner--box--cont--flow--box .steps dt {
                  font-size: 20px;
                  line-height: 1;
                  padding-top: 2px; }
                .contents main .contentsinner--box--cont--flow--box .steps dd {
                  font-size: 40px;
                  line-height: 0.8; }
              .contents main .contentsinner--box--cont--flow--box--txt {
                width: 100%; }
                .contents main .contentsinner--box--cont--flow--box--txt .lead_f {
                  margin-top: 20px;
                  text-align: center;
                  font-size: 19px;
                  padding-bottom: 15px;
                  padding-left: 0px;
                  margin-bottom: 15px; }
                .contents main .contentsinner--box--cont--flow--box--txt .txts {
                  padding-left: 0px; }
                .contents main .contentsinner--box--cont--flow--box--txt .links {
                  display: block;
                  align-items: center;
                  padding-left: 0px; }
                  .contents main .contentsinner--box--cont--flow--box--txt .links dt {
                    width: 100%;
                    margin-right: 0px; }
                    .contents main .contentsinner--box--cont--flow--box--txt .links dt span {
                      display: inline-block;
                      width: 60%;
                      position: relative;
                      top: 6px;
                      margin-right: 20px; }
                  .contents main .contentsinner--box--cont--flow--box--txt .links dd {
                    width: 170px;
                    background: #bf0828;
                    border-radius: 8px;
                    margin: 0 auto;
                    margin-top: 15px;
                    padding: 10px 0px; }
                    .contents main .contentsinner--box--cont--flow--box--txt .links dd a {
                      display: block;
                      position: relative;
                      color: #fff;
                      padding-left: 20px; }
                      .contents main .contentsinner--box--cont--flow--box--txt .links dd a:after {
                        position: absolute;
                        content: "";
                        width: 8px;
                        height: 8px;
                        border-top: 1px solid #fff;
                        border-right: 1px solid #fff;
                        transform: rotate(45deg);
                        right: 15px;
                        top: 50%;
                        margin-top: -5px; }
                .contents main .contentsinner--box--cont--flow--box--txt--box {
                  margin-left: 0px;
                  margin-top: 25px;
                  border: 1px solid #2992c9;
                  padding: 20px 20px; }
                  .contents main .contentsinner--box--cont--flow--box--txt--box .tog_lead {
                    width: 100%;
                    color: #2992c9;
                    font-size: 18px; }
                    .contents main .contentsinner--box--cont--flow--box--txt--box .tog_lead i {
                      width: 90px;
                      left: -25px;
                      top: -50px; }
                    .contents main .contentsinner--box--cont--flow--box--txt--box .tog_lead.plt {
                      padding-left: 0; }
                  .contents main .contentsinner--box--cont--flow--box--txt--box--inner .leadinner {
                    font-size: 16px; }
                  .contents main .contentsinner--box--cont--flow--box--txt--box--inner .txtinner {
                    font-size: 14px; }
                  .contents main .contentsinner--box--cont--flow--box--txt--box--inner ul {
                    padding-left: 15px; }
                    .contents main .contentsinner--box--cont--flow--box--txt--box--inner ul li {
                      margin-left: 0;
                      list-style: none; }
                  .contents main .contentsinner--box--cont--flow--box--txt--box--inner .innerflex {
                    display: block;
                    padding-bottom: 30px;
                    margin-bottom: 30px; }
                    .contents main .contentsinner--box--cont--flow--box--txt--box--inner .innerflex:last-child {
                      margin-bottom: 0;
                      border-bottom: none; }
                    .contents main .contentsinner--box--cont--flow--box--txt--box--inner .innerflex p {
                      width: 100%;
                      padding-bottom: 10px;
                      font-size: 14px; }
                    .contents main .contentsinner--box--cont--flow--box--txt--box--inner .innerflex figure {
                      width: 100%; }
          .contents main .contentsinner--box--cont--ships {
            display: block;
            justify-content: space-between;
            margin-top: 40px; }
            .contents main .contentsinner--box--cont--ships figure {
              width: 100%;
              margin-bottom: 25px; }
            .contents main .contentsinner--box--cont--ships--txt {
              width: 100%; }
          .contents main .contentsinner--box--cont--photo {
            margin-top: 30px; }
            .contents main .contentsinner--box--cont--photo .tog_l {
              font-size: 18px; }
            .contents main .contentsinner--box--cont--photo--area {
              margin-top: 30px;
              color: #fff; }
              .contents main .contentsinner--box--cont--photo--area .back_1 {
                border-top-left-radius: 15px;
                display: flex;
                flex-wrap: wrap;
                justify-content: space-between;
                padding: 15px 20px;
                padding-bottom: 50px; }
                .contents main .contentsinner--box--cont--photo--area .back_1 p:first-child {
                  font-size: 20px;
                  line-height: 1.2;
                  width: 30px; }
              .contents main .contentsinner--box--cont--photo--area .back_2 {
                border-top-left-radius: 15px;
                display: flex;
                flex-wrap: wrap;
                justify-content: space-between;
                padding: 15px 20px;
                padding-bottom: 50px; }
                .contents main .contentsinner--box--cont--photo--area .back_2 p:first-child {
                  font-size: 20px;
                  line-height: 1.2;
                  width: 30px; }
              .contents main .contentsinner--box--cont--photo--area .flex {
                display: flex;
                justify-content: space-between;
                flex-wrap: wrap; }
                .contents main .contentsinner--box--cont--photo--area .flex .flexbox {
                  width: 48%; }
                  .contents main .contentsinner--box--cont--photo--area .flex .flexbox.all {
                    width: 100%; }
                .contents main .contentsinner--box--cont--photo--area .flex figcaption {
                  font-size: 12px;
                  padding: 5px 0 10px; }
                .contents main .contentsinner--box--cont--photo--area .flex.wid_2 {
                  width: 100%; }
                  .contents main .contentsinner--box--cont--photo--area .flex.wid_2 .flexbox {
                    width: 48%; }
                .contents main .contentsinner--box--cont--photo--area .flex.wid_3 {
                  width: 100%; }
                  .contents main .contentsinner--box--cont--photo--area .flex.wid_3 .flexbox {
                    width: 48%; }
                .contents main .contentsinner--box--cont--photo--area .flex.wid_4 {
                  width: 100%; }
                  .contents main .contentsinner--box--cont--photo--area .flex.wid_4 .flexbox {
                    width: 48%; }
              .contents main .contentsinner--box--cont--photo--area .flexare {
                width: calc(100% - 30px); }
              .contents main .contentsinner--box--cont--photo--area .flex_all {
                width: calc(100% - 30px);
                display: flex;
                flex-wrap: wrap;
                justify-content: space-between; }
                .contents main .contentsinner--box--cont--photo--area .flex_all .flexbox {
                  width: 100%; }
                  .contents main .contentsinner--box--cont--photo--area .flex_all .flexbox figcaption {
                    font-size: 12px;
                    padding: 5px 0 10px; }
                .contents main .contentsinner--box--cont--photo--area .flex_all .wids {
                  width: 100%;
                  margin-right: 0px; }
          .contents main .contentsinner--box--cont--price {
            padding-bottom: 60px; }
            .contents main .contentsinner--box--cont--price .tb_1 {
              margin-top: 20px; }
              .contents main .contentsinner--box--cont--price .tb_1 th:last-child {
                border-right: none; }
              .contents main .contentsinner--box--cont--price .tb_1 td span {
                display: block;
                font-size: 10px;
                padding: 0 5px; }
            .contents main .contentsinner--box--cont--price .pointcaps li {
              font-size: 13px; }
            .contents main .contentsinner--box--cont--price--flex .tb_1 {
              width: 100%; }
            .contents main .contentsinner--box--cont--price--flex .allarea {
              width: 100%; }
              .contents main .contentsinner--box--cont--price--flex .allarea .tb_1 {
                width: 100%; }
                .contents main .contentsinner--box--cont--price--flex .allarea .tb_1:last-child {
                  margin-top: 0; }
                  .contents main .contentsinner--box--cont--price--flex .allarea .tb_1:last-child td {
                    border-top: none; }
            .contents main .contentsinner--box--cont--price--flex .tablecap {
              width: 100%;
              margin-top: 0px;
              padding: 0px 0;
              border-left: 1px solid #2999d0; }
              .contents main .contentsinner--box--cont--price--flex .tablecap p {
                text-align: center;
                padding: 10px 0;
                border-left: none; }
              .contents main .contentsinner--box--cont--price--flex .tablecap--inner {
                height: auto;
                padding: 20px 0;
                flex-wrap: wrap; }
                .contents main .contentsinner--box--cont--price--flex .tablecap--inner dl {
                  width: 100%;
                  padding: 0 20px; }
                .contents main .contentsinner--box--cont--price--flex .tablecap--inner.wid dl {
                  padding: 0 20px; }
              .contents main .contentsinner--box--cont--price--flex .tablecap.allarea {
                width: 100%; }
            .contents main .contentsinner--box--cont--price .point_area {
              margin-top: 30px;
              padding: 30px 10px;
              flex-wrap: wrap; }
              .contents main .contentsinner--box--cont--price .point_area:after {
                content: none; }
              .contents main .contentsinner--box--cont--price .point_area .obj {
                position: absolute;
                width: 60px;
                left: auto;
                right: -5%;
                top: -15px; }
              .contents main .contentsinner--box--cont--price .point_area--box {
                width: 100%; }
                .contents main .contentsinner--box--cont--price .point_area--box:last-child {
                  padding-top: 15px;
                  border-top: 1px solid #2999d0;
                  margin-top: 15px; }
                .contents main .contentsinner--box--cont--price .point_area--box p:first-child {
                  font-size: 18px; }
            .contents main .contentsinner--box--cont--price--camp {
              margin-top: 50px;
              background: #def1fb;
              padding: 20px;
              border-radius: 20px;
              display: flex;
              justify-content: space-between;
              flex-direction: row-reverse;
              flex-wrap: wrap; }
              .contents main .contentsinner--box--cont--price--camp .left {
                width: 100%; }
                .contents main .contentsinner--box--cont--price--camp .left .txt_camp {
                  margin-top: 20px;
                  padding-right: 0px;
                  padding-left: 1em;
                  text-indent: -1em; }
                  .contents main .contentsinner--box--cont--price--camp .left .txt_camp i {
                    font-style: normal;
                    color: #2991c8; }
                .contents main .contentsinner--box--cont--price--camp .left .btns {
                  margin-top: 20px; }
              .contents main .contentsinner--box--cont--price--camp figure {
                width: 100%;
                margin-top: 20px; }
          .contents main .contentsinner--box--cont--oper {
            flex-wrap: wrap; }
            .contents main .contentsinner--box--cont--oper--box {
              width: 100%; }
              .contents main .contentsinner--box--cont--oper--box:last-child {
                margin-top: 20px; }
          .contents main .contentsinner--box--cont--food .txt {
            margin: 20px 0; }
          .contents main .contentsinner--box--cont--food dl {
            width: 100%;
            display: block;
            font-size: 14px; }
            .contents main .contentsinner--box--cont--food dl span {
              display: block;
              padding: 2px 8px;
              margin-right: 0px;
              margin-bottom: 10px;
              text-align: center; }
            .contents main .contentsinner--box--cont--food dl dt {
              text-align: center;
              margin-right: 0px;
              margin-bottom: 10px; }
          .contents main .contentsinner--box--cont--food .flex {
            display: flex;
            justify-content: space-between;
            flex-wrap: wrap; }
            .contents main .contentsinner--box--cont--food .flex dl {
              margin-top: 15px;
              display: block;
              width: 49%;
              text-align: center; }
              .contents main .contentsinner--box--cont--food .flex dl dt {
                margin-right: 0; }
              .contents main .contentsinner--box--cont--food .flex dl dd {
                padding-top: 0px; }
          .contents main .contentsinner--box--cont--food .btns.red {
            margin: 30px auto 0; }
          .contents main .contentsinner--box--cont--foodb {
            border-radius: 20px;
            padding: 10px;
            margin-top: 40px; }
            .contents main .contentsinner--box--cont--foodb .lead_f {
              font-size: 22px;
              padding: 25px 25px 10px 25px;
              color: #298dc4; }
            .contents main .contentsinner--box--cont--foodb .txt_f {
              padding: 0 25px;
              line-height: 1.8;
              text-align: justify;
              margin-bottom: 20px; }
            .contents main .contentsinner--box--cont--foodb--flex {
              background: #fff;
              border-radius: 20px;
              display: flex;
              justify-content: space-between;
              flex-wrap: wrap; }
              .contents main .contentsinner--box--cont--foodb--flex .left {
                width: 90%; }
                .contents main .contentsinner--box--cont--foodb--flex .left ul {
                  display: flex;
                  justify-content: space-between; }
                  .contents main .contentsinner--box--cont--foodb--flex .left ul li {
                    width: 48%;
                    list-style: none; }
                .contents main .contentsinner--box--cont--foodb--flex .left.all {
                  width: 100%;
                  margin: 0 auto; }
                  .contents main .contentsinner--box--cont--foodb--flex .left.all ul {
                    width: 90%;
                    padding-top: 15px;
                    padding-right: 0;
                    margin: 0 auto; }
                    .contents main .contentsinner--box--cont--foodb--flex .left.all ul li {
                      width: 33%;
                      margin-left: 0; }
              .contents main .contentsinner--box--cont--foodb--flex figure {
                width: 100%;
                margin-right: 0px;
                margin-top: 0px;
                padding-left: 5%; }
              .contents main .contentsinner--box--cont--foodb--flex dl {
                width: 90%;
                margin: 0 auto; }
                .contents main .contentsinner--box--cont--foodb--flex dl span {
                  display: block;
                  text-align: center;
                  background: #b91023;
                  color: #fff;
                  padding: 4 8px;
                  margin-right: 0px;
                  margin-bottom: 5px; }
                .contents main .contentsinner--box--cont--foodb--flex dl dt {
                  margin-top: 5px;
                  margin-right: 0px; }
              .contents main .contentsinner--box--cont--foodb--flex .border_flex {
                width: 90%;
                margin: 5%;
                padding: 20px 10px;
                border: 1px solid #298dc4;
                border-radius: 20px;
                display: flex;
                justify-content: space-between;
                flex-wrap: wrap; }
                .contents main .contentsinner--box--cont--foodb--flex .border_flex figure {
                  margin: 0;
                  width: 100%;
                  margin: 15px 0; }
                .contents main .contentsinner--box--cont--foodb--flex .border_flex dl {
                  display: block;
                  margin: 0;
                  width: 100%;
                  padding-left: 0px; }
                  .contents main .contentsinner--box--cont--foodb--flex .border_flex dl dd {
                    font-size: 14px;
                    line-height: 2;
                    margin-top: 20px; }
          .contents main .contentsinner--box--cont .btns {
            max-width: 340px;
            margin: 60px auto 0;
            background: #2999d0;
            color: #fff;
            text-align: center;
            font-size: 17px;
            padding: 15px 0 18px;
            position: relative; }
            .contents main .contentsinner--box--cont .btns a {
              display: block;
              color: #fff;
              position: relative; }
              .contents main .contentsinner--box--cont .btns a:after {
                position: absolute;
                content: "";
                width: 8px;
                height: 8px;
                border-top: 1px solid #fff;
                border-right: 1px solid #fff;
                transform: rotate(45deg);
                right: 8px;
                top: 50%;
                margin-top: -5px; }
        .contents main .contentsinner--box .btnsroute {
          max-width: 340px;
          margin: 60px auto 0;
          font-size: 17px;
          padding: 15px 0 18px; }
        .contents main .contentsinner--box--route {
          margin-top: 60px; }
          .contents main .contentsinner--box--route .mores {
            font-size: 25px;
            margin-bottom: 80px; }
            .contents main .contentsinner--box--route .mores:after {
              border-width: 30px 20px 0 20px;
              bottom: -35px;
              left: 50%;
              margin-left: -20px; }
          .contents main .contentsinner--box--route--camp figure {
            width: 90%;
            margin: 0 auto; }
          .contents main .contentsinner--box--route--camp p {
            width: 90%;
            margin: 20px auto 0; }
            .contents main .contentsinner--box--route--camp p.btns {
              max-width: 100%; }
        .contents main .contentsinner--box .btn_o {
          margin: 30px auto 15px; }
        .contents main .contentsinner--box--comp {
          max-width: 100%; }
          .contents main .contentsinner--box--comp dl {
            width: 100%;
            display: flex;
            flex-wrap: wrap;
            font-size: 15px;
            padding: 15px 0px; }
            .contents main .contentsinner--box--comp dl dt {
              width: 100%;
              font-size: 16px; }
            .contents main .contentsinner--box--comp dl dd {
              width: 100%;
              margin-top: 5px; }
        .contents main .contentsinner--box--compacc {
          width: 100%;
          text-align: center;
          margin-top: 20px; }
          .contents main .contentsinner--box--compacc dt {
            font-size: 16px; }
          .contents main .contentsinner--box--compacc dd {
            font-size: 14px; }
          .contents main .contentsinner--box--compacc dl:last-child {
            margin-top: 30px; }
          .contents main .contentsinner--box--compacc.all {
            width: 100%;
            text-align: center; }
            .contents main .contentsinner--box--compacc.all dt {
              font-size: 18px;
              line-height: 1.8; }
        .contents main .contentsinner--box.flex {
          max-width: 90%;
          margin: 0 auto;
          display: flex;
          flex-wrap: wrap; }
          .contents main .contentsinner--box.flex .contentsinner--box--comp {
            max-width: 40%;
            margin: 0 auto; }
            .contents main .contentsinner--box.flex .contentsinner--box--comp dl {
              width: 100%;
              font-size: 14px;
              flex-wrap: wrap;
              padding: 10px 0;
              text-align: center; }
              .contents main .contentsinner--box.flex .contentsinner--box--comp dl dt {
                width: 100%;
                font-size: 16px; }
              .contents main .contentsinner--box.flex .contentsinner--box--comp dl dd {
                width: 100%;
                margin-top: 5px; }
          .contents main .contentsinner--box.flex .contentsinner--box--compacc {
            max-width: 54%; }
        .contents main .contentsinner--box.flex2 {
          max-width: 90%;
          margin: 0 auto;
          display: flex;
          flex-wrap: wrap; }
          .contents main .contentsinner--box.flex2 .contentsinner--box--compacc {
            max-width: 100%;
            justify-content: space-between;
            margin: 0;
            text-align: center; }
            .contents main .contentsinner--box.flex2 .contentsinner--box--compacc span {
              color: #2986bd; }
            .contents main .contentsinner--box.flex2 .contentsinner--box--compacc dl:last-child {
              margin-top: 30px; }
            .contents main .contentsinner--box.flex2 .contentsinner--box--compacc:first-child dl:last-child {
              margin-top: 0px; }
        .contents main .contentsinner--box--caution {
          max-width: 90%; }
          .contents main .contentsinner--box--caution dl {
            display: block;
            align-items: center;
            padding: 15px 0; }
            .contents main .contentsinner--box--caution dl dt {
              width: 200px;
              margin: 0 auto;
              padding: 10px 0px;
              border-right: none; }
            .contents main .contentsinner--box--caution dl dd {
              font-size: 14px;
              line-height: 2;
              padding: 0 5%;
              text-align: justify;
              margin-left: 0; }
              .contents main .contentsinner--box--caution dl dd br {
                display: none; }
      .contents main .contentsinner--flex {
        max-width: 90%;
        margin: 0 auto;
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap; }
        .contents main .contentsinner--flex p {
          width: 100%;
          height: auto;
          padding: 30px 0;
          margin-top: 20px; }
          .contents main .contentsinner--flex p a {
            height: 100%;
            display: flex;
            align-items: center;
            justify-content: center; }
          .contents main .contentsinner--flex p:first-child img {
            width: 180px; }
          .contents main .contentsinner--flex p:nth-child(2) img {
            width: 280px; }
          .contents main .contentsinner--flex p:nth-child(3) img {
            width: 280px; }
          .contents main .contentsinner--flex p:nth-child(4) img {
            width: 150px; }
          .contents main .contentsinner--flex p:nth-child(5) img {
            width: 150px; }
        .contents main .contentsinner--flex.txtlink {
          max-width: 90%; }
          .contents main .contentsinner--flex.txtlink .txtlink_box {
            width: 48%; }
          .contents main .contentsinner--flex.txtlink p {
            font-size: 14px;
            width: 100%;
            height: auto;
            border: none;
            text-align: center;
            border: 1px solid #0071a2;
            margin-top: 20px;
            padding: 10px; }
            .contents main .contentsinner--flex.txtlink p a {
              display: block;
              color: #0071a2;
              padding: 0px 0; }
    .contents main .kv {
      width: 100%;
      height: 300px; }
      .contents main .kv h2 {
        width: 90%;
        font-size: 32px; }
        .contents main .kv h2.imgs {
          width: 90%;
          padding: 0 0 50px; }
      .contents main .kv:before {
        bottom: -2px;
        background: url("../../imgs/common/obi_b.svg") repeat-x bottom center; }
      .contents main .kv.ship {
        background: url("../../imgs/senpaku/kv.jpg") no-repeat center center/cover; }
      .contents main .kv.route:before {
        background: url("../../imgs/common/obi_w3.svg") repeat-x bottom center; }
      .contents main .kv.top {
        display: block;
        position: relative; }
        .contents main .kv.top .slide {
          position: absolute;
          width: 100%;
          height: 300px;
          left: 0;
          top: 0;
          z-index: -1; }
          .contents main .kv.top .slide .topback_1 {
            background: #fff url("../../imgs/top/img_1.jpg") no-repeat center center/cover;
            height: 300px; }
          .contents main .kv.top .slide .topback_2 {
            background: #fff url("../../imgs/top/img_2.jpg") no-repeat center center/cover;
            height: 300px; }
          .contents main .kv.top .slide .topback_3 {
            background: #fff url("../../imgs/top/img_3.jpg") no-repeat center center/cover;
            height: 300px; }
          .contents main .kv.top .slide .topback_4 {
            height: 300px; }
        .contents main .kv.top .toplead {
          max-width: 90%;
          padding: 0px;
          margin: 0 auto; }
          .contents main .kv.top .toplead .tops {
            display: none; }
          .contents main .kv.top .toplead .objs {
            display: none; }
          .contents main .kv.top .toplead figure {
            max-width: 100%;
            margin: 0 auto;
            padding-top: 60px; }
        .contents main .kv.top:before {
          background: url("../../imgs/common/obi_top.svg") repeat-x bottom center; }
    .contents main .numberingOL li:before {
      padding: 0.2em 0 0.1em 0.4em; }
    .contents main .numberingOL li:after {
      top: 12px;
      left: 1.5px;
      width: 1.1em;
      height: 1.1em; }
    .contents main .warn_dl {
      padding: 20px 20px; }
      .contents main .warn_dl p:first-child {
        font-size: 16px; } }
.contact main {
  display: block;
  margin-top: 90px; }
  .contact main .contents--box {
    max-width: 880px;
    margin: 0 auto;
    padding-bottom: 170px;
    position: relative;
    border-top: 2px solid #d8d8d8; }
    .contact main .contents--box:before {
      position: absolute;
      content: "";
      width: 40%;
      border-top: 2px solid #2991c8;
      top: -3px; }
    .contact main .contents--box .formbox {
      padding-top: 20px; }
      .contact main .contents--box .formbox dl {
        display: flex;
        align-items: stretch;
        align-content: center;
        justify-content: space-between;
          font-size: 16px;
        border-top: 1px dashed #9ea8b6; }
        .contact main .contents--box .formbox dl.nb {
          border-top: none; }
        .contact main .contents--box .formbox dl dt {
          width: 280px;
          font-weight: 700;
          padding: 20px 35px;
          padding-top: 28px; }
          .contact main .contents--box .formbox dl dt span {
            margin-left: 10px;
            padding: 0 5px;
            background: #D30003;
            color: #fff; }
            .contact main .contents--box .formbox dl dt span.required {
              display: none; }
            .contact main .contents--box .formbox dl dt span.optional {
              display: none; }
          .contact main .contents--box .formbox dl dt.paddingr {
            padding-right: 70px; }
        .contact main .contents--box .formbox dl dd {
          width: calc(100% - 260px);
          padding: 20px 35px;
          font-weight: 700; }
          .contact main .contents--box .formbox dl dd span {
            font-size: 12px;
            font-weight: 500; }
            .contact main .contents--box .formbox dl dd span.fb {
              font-size: 14px;
              font-weight: 700;
              margin-bottom: 15px; }
          .contact main .contents--box .formbox dl dd .error_blank {
            display: block;
            font-weight: 400;
            color: red; }
          .contact main .contents--box .formbox dl dd input {
            font: 15px/24px sans-serif;
            box-sizing: border-box;
            width: 100%;
            padding: 0.3em;
            transition: 0.3s;
            letter-spacing: 1px;
            border: 1px solid #ccc; }
            .contact main .contents--box .formbox dl dd input.wid01 {
              width: 40%; }
          .contact main .contents--box .formbox dl dd input[type="radio"] {
            font: 15px/24px sans-serif;
            box-sizing: border-box;
            width: 40px;
            transition: 0.3s;
            letter-spacing: 1px;
            border: 1px solid #ccc; }
          .contact main .contents--box .formbox dl dd textarea {
            resize: none;
            font: 15px/24px sans-serif;
            box-sizing: border-box;
            width: 100%;
            height: 165px;
            padding: 0.3em;
            transition: 0.3s;
            letter-spacing: 1px;
            border: 1px solid #ccc;
            appearance: none;
            -webkit-appearance: none;
            -moz-appearance: none; }
          .contact main .contents--box .formbox dl dd p:nth-child(2) {
            margin: 8px 0; }
          .contact main .contents--box .formbox dl dd select {
            width: 50%;
            outline: none;
            height: 40px;
            padding: 5px;
            border: 1px solid #ccc;
            background-color: #fff; }
          .contact main .contents--box .formbox dl dd label {
            width: 50%; }
            .contact main .contents--box .formbox dl dd label span {
              display: inline-block;
              position: relative;
              top: -2px;
              left: -5px; }
          .contact main .contents--box .formbox dl dd ul {
            display: flex;
            align-items: center;
            margin-top: 8px; }
            .contact main .contents--box .formbox dl dd ul li:nth-child(odd) {
              width: 20px; }
            .contact main .contents--box .formbox dl dd ul li:nth-child(2) {
              margin-right: 15px; }
            .contact main .contents--box .formbox dl dd ul li.wid01 {
              width: 100%; }
            .contact main .contents--box .formbox dl dd ul li.wid {
              width: 35px; }
            .contact main .contents--box .formbox dl dd ul.rd li:first-child {
              width: 100px; }
            .contact main .contents--box .formbox dl dd ul.rd li:last-child {
              width: 100px; }
            .contact main .contents--box .formbox dl dd ul.rd input {
              width: 30px; }
            .contact main .contents--box .formbox dl dd ul.rd02 li:first-child {
              width: 250px; }
            .contact main .contents--box .formbox dl dd ul.rd02 li:last-child {
              width: 250px; }
            .contact main .contents--box .formbox dl dd ul.pst {
              display: block; }
              .contact main .contents--box .formbox dl dd ul.pst li span {
                display: inline-block;
                position: relative;
                top: 2px;
                left: -5px; }
              .contact main .contents--box .formbox dl dd ul.pst li:first-child {
                width: 150px;
                display: flex; }
              .contact main .contents--box .formbox dl dd ul.pst li:nth-child(2) {
                width: 100%;
                margin: 15px 0; }
            .contact main .contents--box .formbox dl dd ul.check {
              display: block; }
              .contact main .contents--box .formbox dl dd ul.check li {
                width: 100%;
                display: flex; }
                .contact main .contents--box .formbox dl dd ul.check li label {
                  display: inline-block;
                  width: 100%; }
                  .contact main .contents--box .formbox dl dd ul.check li label input {
                    width: 25px; }
    .contact main .contents--box .under_text {
      background: #f2f2f2;
      padding: 40px;
      margin: 25px 0 50px; }
      .contact main .contents--box .under_text dt {
        color: red;
        margin-bottom: 10px; }
      .contact main .contents--box .under_text dd {
        font-size: 15px; }
    .contact main .contents--box .submitarea {
      width: 300px;
      margin: 0px auto 15px;
      position: relative; }
      .contact main .contents--box .submitarea:before, .contact main .contents--box .submitarea:after {
        position: absolute;
        content: ""; }
      .contact main .contents--box .submitarea:before {
        width: 30px;
        right: 20px;
        border-bottom: 1px solid #fff;
        top: 50%;
        margin-top: 2px; }
      .contact main .contents--box .submitarea:after {
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 5px 0 0 10px;
        border-color: transparent transparent transparent #fff;
        right: 19px;
        top: 50%;
        margin-top: -2px; }
    .contact main .contents--box .entrybtns {
      cursor: pointer;
      width: 100%;
      text-align: center;
      font-weight: 700;
      font-size: 24px;
      background: #2985bc;
      letter-spacing: 0.1em;
      display: block;
      color: #fff;
      text-decoration: none;
      padding: 20px 0;
      border: none; }
      .contact main .contents--box .entrybtns:focus {
        outline: none; }

@media screen and (max-width: 767px) {
  .contact main {
    margin-top: 50px; }
    .contact main .contents {
      padding: 0 0 90px; }
      .contact main .contents--box {
        max-width: 90%;
        margin: 0 auto;
        padding-top: 20px;
        padding-bottom: 0; }
        .contact main .contents--box .h2 {
          font-size: 16px;
          padding-top: 40px; }
        .contact main .contents--box--inner .txtstop {
          padding: 50px 0 0; }
          .contact main .contents--box--inner .txtstop.ed {
            padding-bottom: 50px; }
        .contact main .contents--box--inner .capbox {
          padding: 30px 0; }
        .contact main .contents--box .formbox dl {
          display: block;
          border-top: none; }
          .contact main .contents--box .formbox dl.nb {
            border-top: none; }
          .contact main .contents--box .formbox dl dt {
            width: 100%;
            padding: 10px 0px 0;
            padding-left: 0px; }
            .contact main .contents--box .formbox dl dt span {
              padding: 5px; }
            .contact main .contents--box .formbox dl dt.paddingr {
              padding-right: 0px; }
          .contact main .contents--box .formbox dl dd {
            width: 100%;
            padding: 20px 0px; }
            .contact main .contents--box .formbox dl dd span {
              font-size: 12px;
              font-weight: 500; }
              .contact main .contents--box .formbox dl dd span.fb {
                font-size: 14px;
                font-weight: 700;
                margin-bottom: 15px; }
            .contact main .contents--box .formbox dl dd .error_blank {
              display: block;
              font-weight: 400;
              color: red; }
            .contact main .contents--box .formbox dl dd p:nth-child(2) {
              margin: 8px 0; }
            .contact main .contents--box .formbox dl dd select {
              width: 100%;
              outline: none;
              height: 40px;
              padding: 5px;
              border: 1px solid #ccc;
              background-color: #fff; }
            .contact main .contents--box .formbox dl dd label {
              width: 50%; }
              .contact main .contents--box .formbox dl dd label span {
                display: inline-block;
                position: relative;
                top: -2px;
                left: -5px; }
            .contact main .contents--box .formbox dl dd ul {
              display: flex;
              align-items: center; }
              .contact main .contents--box .formbox dl dd ul li:nth-child(odd) {
                width: 20px; }
              .contact main .contents--box .formbox dl dd ul li:nth-child(2) {
                margin-right: 15px; }
              .contact main .contents--box .formbox dl dd ul li.wid01 {
                width: 100%; }
              .contact main .contents--box .formbox dl dd ul.rd li:first-child {
                width: 100px; }
              .contact main .contents--box .formbox dl dd ul.rd li:last-child {
                width: 100px; }
              .contact main .contents--box .formbox dl dd ul.rd input {
                width: 30px; }
              .contact main .contents--box .formbox dl dd ul.rd02 li:first-child {
                width: 250px; }
              .contact main .contents--box .formbox dl dd ul.rd02 li:last-child {
                width: 250px; }
              .contact main .contents--box .formbox dl dd ul.pst {
                display: block; }
                .contact main .contents--box .formbox dl dd ul.pst li span {
                  display: inline-block;
                  position: relative;
                  top: 2px;
                  left: -5px; }
                .contact main .contents--box .formbox dl dd ul.pst li:first-child {
                  width: 150px;
                  display: flex; }
                .contact main .contents--box .formbox dl dd ul.pst li:nth-child(2) {
                  width: 100%;
                  margin: 15px 0; }
              .contact main .contents--box .formbox dl dd ul.check {
                display: block; }
                .contact main .contents--box .formbox dl dd ul.check li {
                  width: 100%;
                  display: flex; }
                  .contact main .contents--box .formbox dl dd ul.check li label {
                    display: inline-block;
                    width: 100%; }
                    .contact main .contents--box .formbox dl dd ul.check li label input {
                      width: 25px; }
        .contact main .contents--box .under_text {
          text-align: left;
          padding: 20px; }
        .contact main .contents--box .submitarea {
          width: 100%; }
        .contact main .contents--box .entrybtns {
          font-size: 16px;
          padding: 10px 0;
          border: none;
          -webkit-appearance: none; }
          .contact main .contents--box .entrybtns:focus {
            outline: none; } }

@media screen and (max-width: 767px) {
  body.pc {
    display: block; }

  header {
    position: fixed;
    top: 0;
      left: 0;
    height: 60px;
    width: 100%;
    margin: 0 auto;
    z-index: 999;
    background: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
      -webkit-backface-visibility:hidden;
backface-visibility:hidden;
    /*　ハンバーガーボタン　*/
    /* ナビ開いてる時のボタン */ }
    header.backnone {
      background: #fff; }
    header a {
      text-decoration: none; }
    header .logo_area a h1 {
      width: 210px;
    margin: 15px 0px 0;
    padding: 0 5px; }
    header .hamburger {
      position: fixed;
      z-index: 3;
      right: 0px;
      top: 0px;
      width: 60px;
      height: 60px;
      cursor: pointer;
      text-align: center;
      background: #003894;
      color: #fff; }
    header .hamburger span {
      display: block;
      position: absolute;
      width: 30px;
      height: 2px;
      left: 15px;
      background: #fff;
      -webkit-transition: 0.5s ease-in-out;
      -moz-transition: 0.5s ease-in-out;
      transition: 0.5s ease-in-out; }
    header .hamburger span:nth-child(1) {
      top: 10px; }
    header .hamburger span:nth-child(2) {
      top: 20px; }
    header .hamburger span:nth-child(3) {
      top: 30px; }
    header .hamburger p {
      position: absolute;
      bottom: 5px;
      width: 100%;
      text-align: center;
      font-size: 12px; }
    header .hamburger.active span:nth-child(1) {
      top: 20px;
      left: 15px;
      -webkit-transform: rotate(315deg);
      -moz-transform: rotate(315deg);
      transform: rotate(315deg); }
    header .hamburger.active span:nth-child(2),
    header .hamburger.active span:nth-child(3) {
      top: 20px;
      -webkit-transform: rotate(-315deg);
      -moz-transform: rotate(-315deg);
      transform: rotate(-315deg); }
    header .navicont {
      width: calc(100% - 310px); }
      header .navicont .nav_head_or {
        position: absolute;
    top: 0;
    right: 124px;
    width: 41px;
    height: 60px; }
    header .navicont .nav_head_or a{
        padding: 0; }
      header .navicont .nav_head_pr {
        dposition: absolute;
    top: 0;
    right: 62px;
    width: 55px;
    height: 60px; }
    header .navicont .nav_head_pr a{
        padding: 0; }
      header .navicont .reserve {
        display: none; }
      header .navicont .naviinnercont {
        display: none;
        position: absolute;
        background: #003894;
        top: 0px;
        right: 0px; }
        header .navicont .naviinnercont ul {
          width: 300px;
          padding-top: 90px;
          padding-bottom: 100%; }
          header .navicont .naviinnercont ul li {
            font-size: 16px;
            letter-spacing: 0.1em;
            padding: 0px 15px 0px 15px; }
            header .navicont .naviinnercont ul li a {
              display: block;
              color: #fff;
              text-decoration: none;
              position: relative;
              border-bottom: 1px solid #fff;
              padding: 15px 0; }
              header .navicont .naviinnercont ul li a:after {
                position: absolute;
                content: "";
                height: 10px;
                width: 10px;
                border-top: 1px solid #fff;
                border-right: 1px solid #fff;
                right: 20px;
                top: 50%;
                margin-top: -4px;
                transform: rotate(45deg); }
    header.HeightMin {
      height: 60px;
      background: #fff; }
      header.HeightMin .hamburger {
        right: 0px;
        top: 0px; }
      header.HeightMin .navicont .nav_head_or {
        top: 0px;
        right: 405px; }
      header.HeightMin .navicont .nav_head_pr {
        position: absolute;
        top: 0px;
        right: 310px; }
      header.HeightMin .navicont .reserve {
        position: fixed;
        top: 0px;
        right: 75px; }
      header.HeightMin .navicont .naviinnercont {
        top: 0px;
        right: 0px;
        width: 310px; }

  footer {
    width: 100%;
    position: relative;
    z-index: 3; }
    footer .linkinner {
      width: 100%;
      padding-bottom: 50px;
      flex-wrap: wrap; }
      footer .linkinner:before {
        background: url("../../imgs/common/obi_r.svg") repeat-x bottom center; }
      footer .linkinner li {
        width: 43%;
        margin: 2% 1% 0;
        padding-top: 0; }
    footer .under {
      width: 100%; }
      footer .under:before {
        background: url("../../imgs/common/obi_w.svg") repeat-x bottom center; }
      footer .under div {
        text-align: center; }
        footer .under div .logo {
          width: 90%;
          margin: 0 auto;
          padding-top: 20px; }
        footer .under div .address {
          margin-top: 20px;
          margin-bottom: 20px; }
        footer .under div ul {
          width: 80%;
          margin: 0 auto; }
      footer .under address {
        font-size: 11px;
        padding: 20px 0 120px;
        text-align: left;
        width: 90%;
        margin: 0 auto; }
    footer .pagetop {
      position: absolute;
      bottom: 130px;
      width: 40px;
      right: 3%; }
    footer .footernavi {
      display:none;
      position: fixed;
      bottom: 0;
      width: 100%;
      left: 0;
      z-index: 10; }
      footer .footernavi .reserve {
        width: 60.5%; }
      footer .footernavi .nav_head_or, footer .footernavi .nav_head_pr {
        width: 19.8%; }

  #reserve {
    position: fixed;
    top: auto;
    right: auto;
    height: auto;
    left: 0;
    bottom: 0;
    z-index: 20;
    width: 100%;
    background-color: #FFF;
    padding: 0;
    box-sizing: border-box;
    border-bottom: 1px solid #f2f2f2;
    -webkit-backface-visibility:hidden;
backface-visibility:hidden;
      display:block;
}

  #reserve #reserve_wrap::before {
    content: none; }

  #reserve #reserve_wrap::after {
    content: none; }

  #reserve[data-edit=on].on {
    height: auto; }

  #reserve #reserve_wrap {
    position: relative;
    width: 100%;
    padding: 5px;
    box-sizing: border-box;
    background-color: #FFF;
    border: none;
    border-top: none;
    height: auto; }

  #reserve #reserve_wrap form fieldset {
    overflow: hidden;
    padding: 6px 0 0px; }

  #reserve #reserve_wrap form fieldset > * {
    float: left;
    display: inline-block; }

  #reserve #reserve_wrap form {
    display: flex;
    justify-content: space-between; }

  #reserve #reserve_wrap form > * {
    padding: 0px 0 0; }

  #reserve #reserve_wrap form fieldset legend {
    font-size: 16px;
    line-height: 16px;
    padding: 0 0 0.4em; }

  #reserve #reserve_wrap form fieldset #start_port_select_wrap, #reserve #reserve_wrap form fieldset #date_input_select_wrap, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap {
    position: relative;
    width: 90%; }

  #reserve #reserve_wrap form #reserve_submit {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 80px;
    -moz-box-flex: 0;
    -moz-flex: 0 0 80px;
    -ms-flex: 0 0 80px;
    flex: 0 0 80px;
    padding: 0 0px;
    box-sizing: border-box; }

  #reserve #reserve_wrap form > * {
    padding: 10px 0 0; }

  .pc #reserve #reserve_wrap form #reserve_submit > a {
    -moz-transition: background 0.4s;
    -o-transition: background 0.4s;
    -webkit-transition: background 0.4s;
    transition: background 0.4s; }

  #reserve #reserve_wrap form #reserve_submit > a, #reserve #reserve_wrap form #reserve_submit > a:visited, #reserve #reserve_form_wrap form #reserve_submit > a, #reserve #reserve_form_wrap form #reserve_submit > a:visited, #reserve_cont #reserve_wrap form #reserve_submit > a, #reserve_cont #reserve_wrap form #reserve_submit > a:visited, #reserve_cont #reserve_form_wrap form #reserve_submit > a, #reserve_cont #reserve_form_wrap form #reserve_submit > a:visited {
    color: #FFF; }

  #reserve #reserve_wrap form #reserve_submit > a {
    box-sizing: border-box;
    width: 100%; }

  #reserve #reserve_wrap form #reserve_submit > a, #reserve #reserve_wrap form #reserve_submit > a:hover, #reserve #reserve_form_wrap form #reserve_submit > a, #reserve #reserve_form_wrap form #reserve_submit > a:hover, #reserve_cont #reserve_wrap form #reserve_submit > a, #reserve_cont #reserve_wrap form #reserve_submit > a:hover, #reserve_cont #reserve_form_wrap form #reserve_submit > a, #reserve_cont #reserve_form_wrap form #reserve_submit > a:hover {
    text-decoration: none; }

  #reserve #reserve_wrap form #reserve_submit > a, #reserve #reserve_form_wrap form #reserve_submit > a, #reserve_cont #reserve_wrap form #reserve_submit > a, #reserve_cont #reserve_form_wrap form #reserve_submit > a {
    display: block;
    padding: 0.4em 0.8em;
    font-size: 16px;
    line-height: 18px;
    background-color: #FF8000;
    text-align: center;
    border-radius: 4px;
    box-sizing: border-box; }

  #reserve #reserve_wrap form > * {
    padding: 10px 0 0; }

  #reserve #reserve_wrap form #reserve_edit > a, #reserve #reserve_form_wrap form #reserve_edit > a, #reserve_cont #reserve_wrap form #reserve_edit > a, #reserve_cont #reserve_form_wrap form #reserve_edit > a {
    display: block;
    padding: 0.46666em 0.2em;
    font-size: 16px;
    line-height: 16px; }

  #reserve #reserve_wrap form #reserve_member {
    width: 100%; }

  #reserve #reserve_wrap form > * {
    padding: 10px 0 0; }

  #reserve #reserve_wrap form #reserve_member > a {
    box-sizing: border-box;
    width: 100%; }

  #reserve #reserve_wrap form #reserve_submit > a, #reserve #reserve_form_wrap form #reserve_submit > a, #reserve_cont #reserve_wrap form #reserve_submit > a, #reserve_cont #reserve_form_wrap form #reserve_submit > a {
    font-size: 16px;
    line-height: 16px;
    padding: 0.4em 0.2em; }

  #reserve #reserve_wrap form fieldset #start_port_select_wrap::before, #reserve #reserve_wrap form fieldset #start_port_select_wrap::after, #reserve #reserve_wrap form fieldset #start_port_select_wrap #start_port, #reserve #reserve_wrap form fieldset #start_port_select_wrap #date_input, #reserve #reserve_wrap form fieldset #date_input_select_wrap::before, #reserve #reserve_wrap form fieldset #date_input_select_wrap::after, #reserve #reserve_wrap form fieldset #date_input_select_wrap #start_port, #reserve #reserve_wrap form fieldset #date_input_select_wrap #date_input, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap::before, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap::after, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap #start_port, #reserve #reserve_form_wrap form fieldset #start_port_select_wrap #date_input, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap::before, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap::after, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap #start_port, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap #date_input, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap::before, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap::after, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap #start_port, #reserve_cont #reserve_wrap form fieldset #start_port_select_wrap #date_input, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap::before, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap::after, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap #start_port, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap #date_input, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap::before, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap::after, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap #start_port, #reserve_cont #reserve_form_wrap form fieldset #start_port_select_wrap #date_input, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap::before, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap::after, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap #start_port, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap #date_input {
    font-size: 16px;
    line-height: 16px; }

  #reserve #reserve_wrap form fieldset #date_input_select_wrap::before, #reserve #reserve_wrap form fieldset #date_input_select_form_wrap::before, #reserve #reserve_form_wrap form fieldset #date_input_select_wrap::before, #reserve #reserve_form_wrap form fieldset #date_input_select_form_wrap::before, #reserve_cont #reserve_wrap form fieldset #date_input_select_wrap::before, #reserve_cont #reserve_wrap form fieldset #date_input_select_form_wrap::before, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_wrap::before, #reserve_cont #reserve_form_wrap form fieldset #date_input_select_form_wrap::before {
    top: 1em; }

  #window_body #time_table {
    display: block;
    font-size: 15px; }

  #window_body #time_table header {
    position: inherit;
    top: auto;
    height: auto;
    width: 100%;
    margin: 0 auto;
    z-index: 999;
    background: none;
    display: block; }

  #time_table > header > h1 {
    font-size: 16px; }

  #time_table > header > h1 > i {
    font-size: 22px; }

  #time_table > header > h1 > span {
    display: block;
    font-size: 16px;
    margin-left: 16px; }

  #time_table article {
    padding: 10px 0 0; }

  #time_table article > p {
    padding: 10px 0 0; }

  #time_table article #time_table_wrap {
    margin-top: 10px; } }

@media screen and (max-width: 767px) {
    #reserve #reserve_wrap form fieldset #date_input_select_wrap::before{
        color: #666;
    }
    #reserve #reserve_wrap form fieldset #start_port_select_wrap::after{
        color: #666;
        top: 0.3em;
        right: 4px;
    }
#reserve #reserve_wrap form #reserve_submit > a{
    font-size: 16px;
    line-height: 16px;
    padding: 0.7em 0em;
    background-color: red;
    color: #fff !important;
}
#reserve #reserve_wrap form #reserve_edit > a{
       display: block;
    padding: 0.7em 0.2em;
    font-size: 14px;
    line-height: 16px;
}
    #reserve #reserve_wrap form fieldset legend {
    font-size: 16px;
    line-height: 16px;
    padding: 0 0 0.4em;
    margin-bottom: -3px;
}
    #reserve #reserve_wrap form #reserve_edit {
        width: 60%;
    display: block !important;
    padding: 0;
    margin-left: 7px;
    border-left: 1px solid #000;
    padding-left: 7px;
    font-size: 12px;
}
    
     #reserve #reserve_wrap form #reserve_edit a i{
         display: none;
}
    #reserve #reserve_wrap form #reserve_member {
    width: 100%;
    display: none;
    }
}

.contents main .contentsinner--box--cont--qa dl dd .btn_style {
    padding: 0 !important;
}

.contents main .contentsinner--box--cont--qa dl dd .btn_style a{
    text-align: center;
    font-size: 14px;
    line-height: 1.8;
    background-color:#2999d0;
    padding: 12px 0;
}

#reserve #reserve_wrap .lastnav{
	text-align: center;
	width: 100%;
	margin: 5px auto;
	font-size: 13px;
	border:1px solid rgba(0,156,255,1.00);
	border-radius: 20px;
}
#reserve #reserve_wrap .lastnav a{
	color: rgba(0,156,255,1.00);
	display: block;
	padding: 5px 0;
}
@media screen and (max-width: 767px) {
.fixedF{
    position: fixed;
    bottom: 0;
    left: 0;
}
    
.contents main .contentsinner--box--cont--price .tb_1 .vert_1 {
    -ms-writing-mode: horizontal-tb;
    writing-mode: horizontal-tb;
}
#reserve #reserve_wrap .lastnav{
	text-align: center;
	width: 100%;
	margin: 3px auto 0;
	font-size: 14px;
	border:1px solid rgba(0,156,255,1.00);
	border-radius: 20px;
}
#reserve #reserve_wrap .lastnav a{
	color: rgba(0,156,255,1.00);
	display: block;
	padding: 5px 0;
}
}

.topicks--inner--box img{
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;   /* ここが特に重要 */
}