/* Minification failed. Returning unminified contents.
(120,1): run-time error CSS1019: Unexpected token, found '@charset'
(120,10): run-time error CSS1019: Unexpected token, found '"UTF-8"'
(120,17): run-time error CSS1019: Unexpected token, found ';'
(2293,1): run-time error CSS1019: Unexpected token, found '@charset'
(2293,10): run-time error CSS1019: Unexpected token, found '"UTF-8"'
(2293,17): run-time error CSS1019: Unexpected token, found ';'
(2772,1): run-time error CSS1019: Unexpected token, found '}'
(2772,3): run-time error CSS1031: Expected selector, found '/'
(2772,3): run-time error CSS1025: Expected comma or open brace, found '/'
(4013,1): run-time error CSS1019: Unexpected token, found '@charset'
(4013,10): run-time error CSS1019: Unexpected token, found '"UTF-8"'
(4013,17): run-time error CSS1019: Unexpected token, found ';'
(6437,1): run-time error CSS1019: Unexpected token, found '@charset'
(6437,10): run-time error CSS1019: Unexpected token, found '"UTF-8"'
(6437,17): run-time error CSS1019: Unexpected token, found ';'
 */
@charset "utf-8";

	.u-mt0 { margin-top:  0px; }     .u-pt0 { padding-top:  0px; }
	.u-mt05 { margin-top:  5px; }    .u-pt05 { padding-top:  5px; }
	.u-mt10 { margin-top: 10px; }    .u-pt10 { padding-top: 10px; }
	.u-mt15 { margin-top: 15px; }    .u-pt15 { padding-top: 15px; }
	.u-mt20 { margin-top: 20px; }    .u-pt20 { padding-top: 20px; }
	.u-mt25 { margin-top: 25px; }    .u-pt25 { padding-top: 25px; }
	.u-mt30 { margin-top: 30px; }    .u-pt30 { padding-top: 30px; }
	.u-mt35 { margin-top: 35px; }    .u-pt35 { padding-top: 35px; }
	.u-mt40 { margin-top: 40px; }    .u-pt40 { padding-top: 40px; }
	.u-mt45 { margin-top: 45px; }    .u-pt45 { padding-top: 45px; }
	.u-mt50 { margin-top: 50px; }    .u-pt50 { padding-top: 50px; }
	.u-mt55 { margin-top: 55px; }    .u-pt55 { padding-top: 55px; }
	.u-mt60 { margin-top: 60px; }    .u-pt60 { padding-top: 60px; }
	.u-mt65 { margin-top: 65px; }    .u-pt65 { padding-top: 65px; }
	.u-mt70 { margin-top: 70px; }    .u-pt70 { padding-top: 70px; }
	.u-mt75 { margin-top: 75px; }    .u-pt75 { padding-top: 75px; }
	.u-mt80 { margin-top: 80px; }    .u-pt80 { padding-top: 80px; }
	.u-mt85 { margin-top: 85px; }    .u-pt85 { padding-top: 85px; }
	.u-mt90 { margin-top: 90px; }    .u-pt90 { padding-top: 90px; }
	.u-mt95 { margin-top: 95px; }    .u-pt95 { padding-top: 95px; }
	.u-mt100{ margin-top:100px; }    .u-pt100{ padding-top:100px; }

	.u-mr0 { margin-right:  0px; }   .u-pr0 { padding-right:  0px; }
	.u-mr05 { margin-right:  5px; }  .u-pr05 { padding-right:  5px; }
	.u-mr10 { margin-right: 10px; }  .u-pr10 { padding-right: 10px; }
	.u-mr15 { margin-right: 15px; }  .u-pr15 { padding-right: 15px; }
	.u-mr20 { margin-right: 20px; }  .u-pr20 { padding-right: 20px; }
	.u-mr25 { margin-right: 25px; }  .u-pr25 { padding-right: 25px; }
	.u-mr30 { margin-right: 30px; }  .u-pr30 { padding-right: 30px; }
	.u-mr35 { margin-right: 35px; }  .u-pr35 { padding-right: 35px; }
	.u-mr40 { margin-right: 40px; }  .u-pr40 { padding-right: 40px; }
	.u-mr45 { margin-right: 45px; }  .u-pr45 { padding-right: 45px; }
	.u-mr50 { margin-right: 50px; }  .u-pr50 { padding-right: 50px; }
	.u-mr55 { margin-right: 55px; }  .u-pr55 { padding-right: 55px; }
	.u-mr60 { margin-right: 60px; }  .u-pr60 { padding-right: 60px; }
	.u-mr65 { margin-right: 65px; }  .u-pr65 { padding-right: 65px; }
	.u-mr70 { margin-right: 70px; }  .u-pr70 { padding-right: 70px; }
	.u-mr75 { margin-right: 75px; }  .u-pr75 { padding-right: 75px; }
	.u-mr80 { margin-right: 80px; }  .u-pr80 { padding-right: 80px; }
	.u-mr85 { margin-right: 85px; }  .u-pr85 { padding-right: 85px; }
	.u-mr90 { margin-right: 90px; }  .u-pr90 { padding-right: 90px; }
	.u-mr95 { margin-right: 95px; }  .u-pr95 { padding-right: 95px; }
	.u-mr100{ margin-right:100px; }  .u-pr100{ padding-right:100px; }

	.u-mb0 { margin-bottom:  0px; }  .u-pb0 { padding-bottom:  0px; }
	.u-mb05 { margin-bottom:  5px; } .u-pb05 { padding-bottom:  5px; }
	.u-mb10 { margin-bottom: 10px; } .u-pb10 { padding-bottom: 10px; }
	.u-mb15 { margin-bottom: 15px; } .u-pb15 { padding-bottom: 15px; }
	.u-mb20 { margin-bottom: 20px; } .u-pb20 { padding-bottom: 20px; }
	.u-mb25 { margin-bottom: 25px; } .u-pb25 { padding-bottom: 25px; }
	.u-mb30 { margin-bottom: 30px; } .u-pb30 { padding-bottom: 30px; }
	.u-mb35 { margin-bottom: 35px; } .u-pb35 { padding-bottom: 35px; }
	.u-mb40 { margin-bottom: 40px; } .u-pb40 { padding-bottom: 40px; }
	.u-mb45 { margin-bottom: 45px; } .u-pb45 { padding-bottom: 45px; }
	.u-mb50 { margin-bottom: 50px; } .u-pb50 { padding-bottom: 50px; }
	.u-mb55 { margin-bottom: 55px; } .u-pb55 { padding-bottom: 55px; }
	.u-mb60 { margin-bottom: 60px; } .u-pb60 { padding-bottom: 60px; }
	.u-mb65 { margin-bottom: 65px; } .u-pb65 { padding-bottom: 65px; }
	.u-mb70 { margin-bottom: 70px; } .u-pb70 { padding-bottom: 70px; }
	.u-mb75 { margin-bottom: 75px; } .u-pb75 { padding-bottom: 75px; }
	.u-mb80 { margin-bottom: 80px; } .u-pb80 { padding-bottom: 80px; }
	.u-mb85 { margin-bottom: 85px; } .u-pb85 { padding-bottom: 85px; }
	.u-mb90 { margin-bottom: 90px; } .u-pb90 { padding-bottom: 90px; }
	.u-mb95 { margin-bottom: 95px; } .u-pb95 { padding-bottom: 95px; }
	.u-mb100{ margin-bottom:100px; } .u-pb100{ padding-bottom:100px; }

	.u-ml0 { margin-left:  0px; }    .u-pl0 { padding-left:  0px; }
	.u-ml05 { margin-left:  5px; }   .u-pl05 { padding-left:  5px; }
	.u-ml10 { margin-left: 10px; }   .u-pl10 { padding-left: 10px; }
	.u-ml15 { margin-left: 15px; }   .u-pl15 { padding-left: 15px; }
	.u-ml20 { margin-left: 20px; }   .u-pl20 { padding-left: 20px; }
	.u-ml25 { margin-left: 25px; }   .u-pl25 { padding-left: 25px; }
	.u-ml30 { margin-left: 30px; }   .u-pl30 { padding-left: 30px; }
	.u-ml35 { margin-left: 35px; }   .u-pl35 { padding-left: 35px; }
	.u-ml40 { margin-left: 40px; }   .u-pl40 { padding-left: 40px; }
	.u-ml45 { margin-left: 45px; }   .u-pl45 { padding-left: 45px; }
	.u-ml50 { margin-left: 50px; }   .u-pl50 { padding-left: 50px; }
	.u-ml55 { margin-left: 55px; }   .u-pl55 { padding-left: 55px; }
	.u-ml60 { margin-left: 60px; }   .u-pl60 { padding-left: 60px; }
	.u-ml65 { margin-left: 65px; }   .u-pl65 { padding-left: 65px; }
	.u-ml70 { margin-left: 70px; }   .u-pl70 { padding-left: 70px; }
	.u-ml75 { margin-left: 75px; }   .u-pl75 { padding-left: 75px; }
	.u-ml80 { margin-left: 80px; }   .u-pl80 { padding-left: 80px; }
	.u-ml85 { margin-left: 85px; }   .u-pl85 { padding-left: 85px; }
	.u-ml90 { margin-left: 90px; }   .u-pl90 { padding-left: 90px; }
	.u-ml95 { margin-left: 95px; }   .u-pl95 { padding-left: 95px; }
	.u-ml100{ margin-left:100px; }   .u-pl100{ padding-left:100px; }

/* Float */
	.u-fl { float: left; }        .u-fr { float: right; }       .u-clear { clear:both; }
	.u-fc{margin:0 auto;text-align:center;}

/*text-align*/
	.u-al{text-align:left}     .u-ar{text-align:right;}      .u-ac{text-align:center}

/* Hidden */
	.u-dn { display: none; }
	.u-hd { visibility:hidden; }

/*  micro cf */
.u-cf:after {
  content: "";
  clear: both;
  display: block;
}

.u-bld{
	font-weight: bold;
}
.u-udl{
	text-decoration: underline;
}
.blk{
    display:block;
}


@charset "UTF-8";
/* import css ======================================================  */
/*　foundation  ------------------------------------------- */
html {
  font-size: 62.5%; height:100%;
  /*overflow:auto;*/
  -webkit-overflow-scrolling:touch;}

body {
  font-family: Arial,Helvetica,"Hiragino Sans","Hiragino Kaku Gothic ProN",Meiryo,"メイリオ",sans-serif;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 28px;
  line-height: 2.8rem;
  color: #000;
  background-color: #e5e8ef;
  box-sizing: border-box; 
  height:100%;
  /*overflow:auto;*/
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
}

* {
  box-sizing: border-box; }

a:link {
  color: #06175b;
  text-decoration: none; }
a:visited {
  color: #06175b;
  text-decoration: none; }
a:hover {
  opacity: 0.8;
  text-decoration: none; }
a:hover * {
  filter: alpha(opacity=80);
  -moz-opacity: 0.8;
  opacity: 0.8; }

img {
  max-width: 100%;
  height: auto;
  width: auto; }

input[type="text"] {
  -webkit-appearance: none;
  border-radius: 0;
  border: #ccc 1px solid;
  padding: 0 3px;
  font-size: 16px; }

input[type="text"]:focus {
  border: solid 1px #20b2aa; }

input[type="text"], select {
  outline: none; }

input[type="submit"], input[type="button"] {
  -webkit-appearance: none;
  border-radius: 0;
  border: #ccc 1px solid;
  padding: 0 3px;
  font-size: 16px; }

/*　layout  ------------------------------------------- */
/*　grid------------------------------------------- */
.l-grid {
  width: 100%; }

.l-grid:after {
  content: "";
  clear: both;
  display: block; }

.l-grid__box {
  box-sizing: border-box;
  float: left;
  border: 1px solid #000;
  width: 100%; }

@media (min-width: 980px) {
  .l-grid__box.l-grid__box1 {
    width: 8.3%; }

  .l-grid__box.l-grid__box2 {
    width: 16.6%; }

  .l-grid__box.l-grid__box3 {
    width: 25%; }

  .l-grid__box.l-grid__box4 {
    width: 33.3%; }

  .l-grid__box.l-grid__box5 {
    width: 41.6%; }

  .l-grid__box.l-grid__box6 {
    width: 50%; }

  .l-grid__box.l-grid__box7 {
    width: 58.3%; }

  .l-grid__box.l-grid__box8 {
    width: 66.7%; }

  .l-grid__box.l-grid__box9 {
    width: 75%; }

  .l-grid__box.l-grid__box10 {
    width: 83.4%; }

  .l-grid__box.l-grid__box11 {
    width: 91.7%; }

  .l-grid__box.l-grid__box12 {
    width: 100%; } }
/* flexbox------------------------------------------- */
.l-flex {
  display: -ms-flex;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between; }

.l-flex__box {
  flex: 1 1 auto; }

/* layout------------------------------------------- */
/*　mixin  ------------------------------------------- */
/*
@media screen and (max-width: xxxpx) {
}
@media screen and (min-width: xxxpx) {
}
*/
/*　mixin  ------------------------------------------- */
/*
@media screen and (max-width: xxxpx) {
}
@media screen and (min-width: xxxpx) {
}
*/
/* -------c-label--------------------------*/
.c-label {
    color: #000; /*add*/
  display: inline-block;
  background-color: #bbdef5;
  padding: 2px 6px;
  border-radius: 2px;
  margin: 1px 0; }

/* -------bt--------------------------*/
.bt-tt-reload:hover {
  cursor: pointer; }

/* -------c-table--------------------------*/
.c-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 3px; }
  .c-table th {
    padding: 4px;
    vertical-align: middle;
    background-color: #06175b;
    color: #fff;
    font-weight: bold;
    font-size: 1.2rem; }
  .c-table td {
    padding: 4px 15px;
    vertical-align: middle;
    background-color: #dadce8; }
  .c-table tr:nth-child(2n) td {
    background-color: #ecedf2; }
  .c-table .u-em td {
    color: #ea008a; }

/* -------ico--------------------------*/
.c-ico {
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-right: 0px;
  margin-bottom: 0px;
  position: relative;
  cursor: pointer; }

.c-ico-close:before, .c-ico-close:after {
  display: block;
  content: '';
  width: 2px;
  height: 24px;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  background-color: #fff;
  position: absolute;
  top: 0px;
  left: 10px;
  cursor: pointer; }

.c-ico-close:after {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg); }

.c-ico-plus {
  position: absolute;
  top: 8px;
  right: 20px; }

.c-ico-plus:before, .c-ico-plus:after {
  display: block;
  content: '';
  width: 3px;
  height: 24px;
  background-color: #808080;
  position: absolute;
  top: 0px;
  right: 0px;
  cursor: pointer;
  transition: 0.5s; }

.c-ico-plus::after {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg); }

.selected .c-ico-plus::before {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg); }

.c-ico_disc {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: #179e72; }

.c-ico-arrow-r::before, .c-ico-arrow-r::after {
  display: block;
  content: '';
  width: 14px;
  height: 3px;
  position: absolute;
  background-color: #ccc; }

.c-ico-arrow-r::after {
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
  top: 12px;
  left: 4px; }

.c-ico-arrow-r::before {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 4px;
  left: 4px; }

.c-ico-arrow-d {
  position: absolute;
  right: 2px; }

.c-ico-arrow-d::before, .c-ico-arrow-d::after {
  display: block;
  content: '';
  width: 14px;
  height: 2px;
  position: absolute;
  top: 0px;
  right: 0px;
  background-color: #000; }

.c-ico-arrow-d:after {
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
  top: 12px;
  left: 12px;
  transition: 0.5s; }

.c-ico-arrow-d::before {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 12px;
  left: 4px;
  transition: 0.5s; }

.selected .c-ico-arrow-d::after {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 8px;
  left: 12px; }
.selected .c-ico-arrow-d::before {
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
  top: 8px;
  left: 4px; }

/*----- hr -------*/
.c-line-dot {
  height: 8px;
  width: 100%;
  border: 0;
  background: url("../images/line-dot.jpg") 0 0 repeat-x; }

@media only screen and (max-width: 979px) {
  .u-pc {
    display: none; } }
@media screen and (min-width: 980px) {
  .u-sp {
    display: none; } }
/*　mixin  ------------------------------------------- */
/*
@media screen and (max-width: xxxpx) {
}
@media screen and (min-width: xxxpx) {
}
*/
@media (max-width: 979px) {
  /* ----header-----------------------------*/
  .c-header-bg {
    background-image: url("../images/main-bg_sp.jpg");
    background-size: 100% auto;
    background-position: center bottom;
    background-repeat: no-repeat;
    padding-bottom: 25%; } }
  @media (max-width: 979px) and (max-width: 480px) {
    .c-header-bg {
      padding-bottom: 45%; } }

@media (max-width: 979px) {
  .l-header {
    width: 100%; }
    .l-header .head-container {
      z-index: 12;
      position: fixed;
      height: auto;
      width: 100%; }
    .l-header .head-bottom {
      padding-top: 67px; }
    .l-header .u-inner {
      background: #fbfffe url("../images/head-bg_sp.jpg") repeat-x;
      background-size: 100% 67px; }
    .l-header .c-logo {
      height: 33px; }
      .l-header .c-logo img {
        height: 100%; }
    .l-header .c-head-wrap {
      display: flex;
      justify-content: space-between;
      position: relative;
      width: 100%;
      height: 67px; }
      .l-header .c-head-wrap.is-on:before {
        content: "";
        position: absolute;
        width: 100%;
        height: 100%;
        display: block;
        background-color: #333;
        opacity: 0.5;
        z-index: 1; }
    .l-header .c-head-wrap__box {
      width: 13.56%;
      flex-basis: 13.56%;
      height: 67px;
      margin: 0 0.8325%; }
      .l-header .c-head-wrap__box:first-child {
        width: 50.89%;
        flex-basis: 50.89%;
        margin-right: auto;
        margin-left: 14px;
        padding: 16px 0; }
    .l-header .c-gnav-wrap {
      display: none; }

  .header-change {
    display: none; }

  .c-spmenu {
    width: 100%;
    height: 67px;
    background-color: #fff;
    display: inline-block;
    cursor: pointer;
    position: relative; }
    .c-spmenu.selected {
      z-index: 999;
      position: relative; }
    .c-spmenu img {
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0;
      right: 0;
      margin: auto;
      max-height: 43px; }

  .c-spmenu__cont {
    display: none;
    position: absolute;
    top: 67px;
    left: 0;
    width: 100%;
    background: #fff;
    z-index: 998; }
    .c-spmenu__cont .cont_li {
      border-bottom: 1px solid #ccc;
      padding: 2px 16px; }
      .c-spmenu__cont .cont_li:last-child {
        border-bottom: 0; }
    .c-spmenu__cont .c-h2 {
      width: 100%; }
      .c-spmenu__cont .c-h2::before {
        top: 17%;
        left: 31%;
        left: calc(50% - 75px);
        background-position: 0 0px; } }
      @media (max-width: 979px) and (max-width: 480px) {
        .c-spmenu__cont .c-h2::before {
          left: calc(50% - 60px);
          background-position: 0 2px; } }

@media (max-width: 979px) {
  .c-spmenu__close:hover {
    cursor: pointer; }

  .c-overlay {
    z-index: 10;
    display: none; }

  .c-overlay.is-on {
    position: absolute;
    top: 68px;
    left: 0;
    width: 100%;
    height: calc(100% - 68px);
    display: block;
    background-color: #333;
    opacity: 0.5; }

  /* ---- alert -----------------------------*/
  .c-head-alert {
    background-color: #06175b;
    color: #fff;
    font-size: 1.3rem;
    font-weight: bold; }
    .c-head-alert .u-inner {
      background: none;
      padding: 0 10px; }
    .c-head-alert a:link, .c-head-alert a:visited {
      color: #fff; }

  .ico_alert {
    display: inline-block;
    width: 22px;
    height: 22px;
    background: url(../images/ico_alert.png) 0 0 no-repeat;
    background-size: 22px;
    position: relative;
    top: 5px;
    margin-right: 5px; }

  .c-head-txt {
    width: 86%;
    max-width: 600px;
    padding: 10px 25px;
    margin: 0 auto;
    font-size: 1.2rem;
    line-height: 1.5; } }
@media (max-width: 979px) and (max-width: 480px) {
  .c-header-bg {
    background-size: auto 100%; }

  .c-head-txt {
    width: 96%;
    padding: 10px; } }
@media (max-width: 979px) {
  /* ---- 運行情報  -----------------------------*/
  .c-transinfo-wrap {
    padding: 4px 15px; }
    .c-transinfo-wrap .u-note {
      text-align: right;
      font-size: 1.1rem; }

  .c-transinfo-ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap; }
    .c-transinfo-ul li {
      width: 49%;
      flex-basis: 49%;
      margin-bottom: 10px; }
      .c-transinfo-ul li:last-child {
        margin-bottom: 0; }

  .c-transinfo-label {
    position: relative;
    width: 100%; }
    .c-transinfo-label a {
      display: block; }

  .c-transinfo-btn {
    background: url("../images/label-bl-bg.jpg") 0 0 no-repeat;
    background-size: 100%;
    display: flex;
    align-items: center; }
    .c-transinfo-btn::before {
      content: "";
      display: block;
      padding-top: 36.7816%; }
    .c-transinfo-btn.is-alert {
      background-image: url("../images/label-pk-bg.jpg"); }
    .c-transinfo-btn .u-tit {
      font-weight: bold;
      font-size: 1.7rem;
      line-height: 1.1;
      display: table-cell;
      text-align: left;
      padding-left: 12px;
      width: 50%;
      height: auto;
      color: #fff; } }
    @media (max-width: 979px) and (max-width: 420px) {
      .c-transinfo-btn .u-tit {
        font-size: 1.5rem; } }
@media (max-width: 979px) {
    .c-transinfo-btn .u-status {
      width: 45%;
      height: 98%;
      max-height: 75px;
      position: absolute;
      top: 0%;
      bottom: 0;
      right: 0%;
      margin: auto; }
      .c-transinfo-btn .u-status img {
        width: auto;
        height: 73%;
        max-height: 55px;
        max-width: 75px;
        position: absolute;
        top: 0;
        right: 0;
        left: 0;
        margin: auto; }
      .c-transinfo-btn .u-status strong {
        position: absolute;
        bottom: 5%;
        left: 0;
        right: 0;
        margin: auto;
        font-weight: normal;
        text-align: center;
        font-size: 1.1rem;
        line-height: 1;
        display: inline-block; } }
    @media (max-width: 979px) and (max-width: 480px) {
      .c-transinfo-btn .u-status img {
        right: 2%; }
      .c-transinfo-btn .u-status strong {
        font-size: 1rem; } }
    @media (max-width: 979px) and (max-width: 380px) {
      .c-transinfo-btn .u-status strong {
        font-size: 0.9rem;
        bottom: 8%; } }
@media (max-width: 979px) {
      .c-transinfo-btn .u-status.u-ok img {
        top: 13%; }

  .c-spmenu__close {
    display: block;
    background-color: #566390;
    font-size: 1.4rem;
    font-weight: bold;
    color: #fff;
    padding: 7px 0;
    text-align: center;
    border-bottom: 1px solid #fff; }
    .c-spmenu__close:hover {
      cursor: pointer; }

  /* ---- lang menu -----------------------------*/
  .c-splang-wrap.c-spmenu__cont .cont_li {
    border-bottom: 0;
    padding-bottom: 5px; }
    .c-splang-wrap.c-spmenu__cont .cont_li a {
      display: block;
      padding: 8px 0;
      text-align: center;
      background-color: #dadce8; }
    .c-splang-wrap.c-spmenu__cont .cont_li:first-child {
      margin-top: 8px; }
    .c-splang-wrap.c-spmenu__cont .cont_li:nth-child(2n) a {
      background-color: #ecedf2; }
  .c-splang-wrap.c-spmenu__cont .c-spmenu__close {
    margin-top: 4px; }

  /* ---- sp menu -----------------------------*/
  .c-spmenulink-wrap.c-spmenu__cont li a {
    display: block;
    text-align: center;
    font-size: 1.6rem;
    padding: 5px 0;
    font-weight: bold; }
  .c-spmenulink-wrap.c-spmenu__cont .cont_li {
    border-bottom: 0;
    padding-bottom: 5px; }
    .c-spmenulink-wrap.c-spmenu__cont .cont_li a {
      padding: 8px 0;
      font-size: 1.8rem;
      background-color: #dadce8; }
    .c-spmenulink-wrap.c-spmenu__cont .cont_li:first-child {
      margin-top: 8px; }
    .c-spmenulink-wrap.c-spmenu__cont .cont_li:nth-child(2n) a {
      background-color: #ecedf2; }

  /* ----map-----------------------------*/
  .c-h2 {
    display: inline-block;
    text-align: center;
    margin: 0 auto;
    color: #06175b;
    font-weight: bold;
    font-size: 1.9rem;
    line-height: 1;
    letter-spacing: 2px;
    padding: 14px 0 20px;
    padding-left: 15px;
    position: relative; }
    .c-h2::before {
      content: '';
      display: inline-block;
      position: absolute;
      width: 35px;
      height: 33px;
      top: 15%;
      left: -26px;
      background: url("../images/ico_h2.png") 40% 0px no-repeat;
      background-size: 100%; } }
  @media (max-width: 979px) and (max-width: 480px) {
    .c-h2 {
      font-size: 1.4rem; }
      .c-h2::before {
        width: 24px;
        height: 22px;
        top: 20%;
        left: -12px; } }

@media (max-width: 979px) {
  .sec-h2 {
    background-color: #fff;
    box-shadow: 0px 6px rgba(6, 23, 91, 0.1); }

  .sec-helpmap .c-secinner {
    text-align: center;
    padding-top: 10px;
    padding-bottom: 10px;
    position: relative; }

  .c-map-ico {
    position: absolute;
    top: 15px;
    right: 12px;
    width: 25%; }
    .c-map-ico ul {
      display: flex;
      align-items: baseline;
      justify-content: flex-end; }
      .c-map-ico ul li {
        margin-left: 5px; }

  .c-map-cont-wrap img {
    width: 100%; }

  .c-map-cont {
    display: none; }

  .c-map-btn-wrap {
    padding: 0 22px;
    margin-top: 8px; } }
  @media (max-width: 979px) and (max-width: 420px) {
    .c-map-btn-wrap {
      padding: 0 10px; } }

@media (max-width: 979px) {
  .c-map-btn-ul {
    display: flex;
    justify-content: center;
    align-items: stretch;
    width: 100%; }
    .c-map-btn-ul li {
      text-align: center;
      padding: 0 2px;
      width: 33.3%;
      flex-basis: 33.3%; } }
  @media (max-width: 979px) and (max-width: 420px) {
    .c-map-btn-ul {
      width: 100%;
      flex-basis: auto;
      justify-content: space-between; }
      .c-map-btn-ul li {
        width: 30%;
        flex-basis: 30%; }
        .c-map-btn-ul li:nth-child(2) {
          width: 40%;
          flex-basis: 40%; } }

@media (max-width: 979px) {
  .c-map-btn {
    display: block;
    text-align: center;
    margin: 0 auto;
    width: 100%;
    height: 30px;
    background: url("../images/bt-map_off.jpg") 0 0 no-repeat;
    background-size: 100% 100%;
    font-size: 1.3rem;
    font-size: 14px;
    line-height: 1;
    padding: 9px 4px 14px 4px;
    color: #fff; }
    .c-map-btn::after {
      content: '';
      display: block;
      padding-bottom: 4%; }
    .c-map-btn:hover {
      cursor: pointer;
      background-image: url("../images/bt-map_on.jpg"); }
    .c-map-btn.selected {
      background-image: url("../images/bt-map_on.jpg"); } }
  @media (max-width: 979px) and (max-width: 420px) {
    .c-map-btn {
      font-size: 1.3rem;
      padding: 11px 2px 13px;
      height: 35px;
      background-size: 100% 100%; }
      .c-map-btn::after {
        padding-bottom: 0; } }

@media (max-width: 979px) {
  .c-map-btnsub-wrap {
    padding: 0 22px;
    margin-top: 6px; } }
  @media (max-width: 979px) and (max-width: 420px) {
    .c-map-btnsub-wrap {
      padding: 0 10px; } }

@media (max-width: 979px) {
  .c-map-btnsub {
    display: inline-block;
    padding: 4px 13px;
    font-size: 1.2rem;
    line-height: 1;
    font-weight: bold;
    background: url("../images/bt-port-dgy.jpg") 0 0 no-repeat;
    background-size: 100% 20px;
    border-radius: 4px; }
    .c-map-btnsub.u-lgy {
      background-image: url("../images/bt-port-lgy.jpg"); }

  a.c-map-btnsub:link, a.c-map-btnsub:visited {
    color: #000; }

  .c-map-btnsub-ul {
    text-align: left; }
    .c-map-btnsub-ul li {
      display: block;
      line-height: 1;
      margin-top: 4px;
      margin-bottom: 6px; }

  /* ---- 出発時刻表  -----------------------------*/
  .sec-timetable {
    margin-top: 22px;
    padding-bottom: 15px; }
    .sec-timetable .c-secinner {
      text-align: center;
      padding-top: 10px;
      padding-bottom: 10px;
      position: relative; }
    .sec-timetable .u-note {
      text-align: right;
      font-size: 1.2rem; }

  .c-timetable-reload-wrap {
    text-align: right; }
    .c-timetable-reload-wrap ul {
      display: flex;
      justify-content: flex-end;
      margin-right: 10px; }
    .c-timetable-reload-wrap li {
      line-height: 23px; }
    .c-timetable-reload-wrap .u-note {
      font-size: 1.2rem;
      margin-right: 6px; }

  .sec-timetableinner > .l-flex {
    display: block; }

  .sec-tt {
    margin-top: 15px; }
    .sec-tt:first-child {
      margin-top: 5px; }
    .sec-tt .c-spmenu__cont {
      display: block;
      position: relative; }
    .sec-tt .c-table {
      margin-top: 0px; }
      .sec-tt .c-table-wrap {
        padding: 0 22px; }
        .sec-tt .c-table-wrap .u-note {
          font-size: 1.0rem; }
        .sec-tt .c-table-wrap .u-tit {
          font-weight: bold;
          font-size: 1.2rem;
          text-align: left; }

  .c-table.c-table--jr th, .c-table.c-table--jr td, .c-table.c-table--nankai th, .c-table.c-table--nankai td {
    width: 16%; }
  .c-table.c-table--jr th:nth-child(1), .c-table.c-table--jr th:nth-child(2), .c-table.c-table--jr td:nth-child(1), .c-table.c-table--jr td:nth-child(2), .c-table.c-table--nankai th:nth-child(1), .c-table.c-table--nankai th:nth-child(2), .c-table.c-table--nankai td:nth-child(1), .c-table.c-table--nankai td:nth-child(2) {
    width: 42%; }
  .c-table.c-table--bus tr:nth-child(4n-1) td, .c-table.c-table--bus tr:nth-child(4n) td {
    background-color: #dadce8; }
  .c-table.c-table--bus th {
    width: 15%; }
    .c-table.c-table--bus th:nth-child(1) {
      width: 60%; }
    .c-table.c-table--bus th:nth-child(2) {
      width: 10%; }
  .c-table.c-table--bus td {
    background-color: #ecedf2;
    width: 15%; }
    .c-table.c-table--bus td:nth-child(1), .c-table.c-table--bus td:nth-child(2) {
      width: 30%; }
    .c-table.c-table--bus td:nth-child(3) {
      width: 10%; } }
  @media (max-width: 979px) and (max-width: 420px) {
    .c-table.c-table--bus td {
      padding: 8px 2px; } }
@media (max-width: 979px) {
  .c-table.c-table--bus tr:nth-child(2n) td:nth-child(2) {
    width: 10%; }
  .c-table.c-table--bus tr:nth-child(2n) td:nth-child(3) {
    width: 15%; }
  .c-table.c-table--bus .u-embg {
    background-color: #06175b !important;
    color: #fff;
    text-align: left;
    font-size: 0.9rem;
    padding: 4px; }
  .c-table.c-table--ship tr:nth-child(4n-1) td, .c-table.c-table--ship tr:nth-child(3n) td {
    background-color: #dadce8; }
  .c-table.c-table--ship th {
    width: 24%; }
    .c-table.c-table--ship th:nth-child(3) {
      width: 22%; }
    .c-table.c-table--ship th:nth-last-child(1), .c-table.c-table--ship th:nth-last-child(2) {
      width: 15%; }
  .c-table.c-table--ship td {
    background-color: #ecedf2;
    width: 24%; }
    .c-table.c-table--ship td:nth-child(3) {
      width: 22%; }
    .c-table.c-table--ship td:nth-last-child(1), .c-table.c-table--ship td:nth-last-child(2) {
      width: 15%; } }
  @media (max-width: 979px) and (max-width: 420px) {
    .c-table.c-table--ship td {
      padding: 2px; } }
@media (max-width: 979px) {
  .c-table.c-table--ship tr:nth-child(2n) td:nth-child(1) {
    width: 22%;
    /*background-color: #ffcccc;*/ }
  .c-table.c-table--ship .u-embg {
    background-color: #06175b !important;
    color: #fff;
    text-align: left;
    font-size: 0.9rem;
    padding: 4px; }

  .c-tt-tit {
    display: block;
    font-size: 2.0rem;
    font-weight: bold;
    letter-spacing: 2px;
    color: #06175b;
    text-align: left;
    line-height: 1;
    padding: 10px;
    padding-left: 50px;
    margin-bottom: 15px;
    background-color: #ecedf2;
    position: relative;
    background-position: 10px 5px;
    background-repeat: no-repeat;
    background-color: #ecedf2;
    cursor: pointer; }

  .c-tt-jr .c-tt-tit {
    background-image: url("../images/ico-train.png"); }

  .c-tt-nankai .c-tt-tit {
    background-image: url("../images/ico-train.png"); }

  .c-tt-bus .c-tt-tit {
    background-image: url("../images/ico-bus.png"); }

  .c-tt-ship .c-tt-tit {
    background-image: url("../images/ico-ship.png"); }

  .c-tt-bridge .c-tt-tit {
    background-image: url("../images/ico-bridge.png"); }

  .c-tt__cont {
    display: none;
    margin: 15px auto; }
    .c-tt__cont .c-table {
      font-size: 1.2rem;
      line-height: 1.2; }

  /* ---- のりば案内 -----------------------------*/
  .sec-portinfo > .u-inner {
    padding: 0 22px; }
  .sec-portinfo .l-flex {
    display: block;
    font-size: 1.4rem; }
  .sec-portinfo .l-flex__box {
    text-align: left;
    margin-top: 10px; }
  .sec-portinfo .c-portinfo-tit {
    font-weight: bold;
    font-size: 1.4rem;
    line-height: 1.2;
    margin-bottom: 8px; }
    .sec-portinfo .c-portinfo-tit span {
      display: inline-block;
      font-size: 1.1rem;
      font-weight: normal; }
  .sec-portinfo a.c-portinfo-pk {
    display: inline-block;
    font-size: 1.2rem;
    line-height: 1.1;
    color: #d11380;
    text-decoration: underline;
    position: relative; }
    .sec-portinfo a.c-portinfo-pk::after {
      content: '>';
      display: block;
      width: 15px;
      height: 15px;
      font-weight: bold;
      position: absolute;
      top: 2px;
      right: -22px; }
    .sec-portinfo a.c-portinfo-pk:hover {
      text-decoration: none; }
  .sec-portinfo .c-portinfo-link {
    background-color: #f4f3f8;
    padding: 10px; }
    .sec-portinfo .c-portinfo-link li {
      float: left;
      width: 50%;
      font-size: 1.4rem;
      line-height: 1.4;
      margin-bottom: 8px; }
      .sec-portinfo .c-portinfo-link li a:link, .sec-portinfo .c-portinfo-link li a:visited {
        text-decoration: underline;
        color: #000; }
      .sec-portinfo .c-portinfo-link li a:hover {
        text-decoration: none; } }
    @media (max-width: 979px) and (max-width: 560px) {
      .sec-portinfo .c-portinfo-link li {
        float: none;
        width: 100%; } }

@media (max-width: 979px) {
  /* ------- アクセスルート案内 --------------------------*/
  .sec-accroot {
    margin-top: 24px;
    background-color: #d3f4fc;
    padding-bottom: 20px; }
    .sec-accroot .c-secinner {
      padding: 0 22px;
      padding-top: 8px;
      text-align: center; }
    .sec-accroot .u-txt {
      text-align: left; }

  .c-accroot-cont {
    font-size: 1.2rem;
    line-height: 1.3; }
    .c-accroot-cont .l-flex {
      display: block; }
      .c-accroot-cont .l-flex img {
        width: 72%;
        margin: 10px auto; }

  .c-accsearch-btn-wrap {
    position: relative;
    width: 60%;
    max-width: 350px;
    margin: 0 auto;
    display: block; }
    .c-accsearch-btn-wrap::after {
      content: '';
      display: block;
      padding-bottom: 20.45%; }

  .c-accsearch-btn {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    display: block;
    text-align: center;
    background: url("../images/bt-search_off.jpg") 0 0 no-repeat;
    background-size: 100%;
    font-size: 1.8rem;
    line-height: 0;
    padding-top: 10%;
    font-weight: bold;
    color: #fff; }
    .c-accsearch-btn:hover {
      cursor: pointer;
      background-image: url("../images/bt-search_on.jpg"); }

  /* ---- 運行情報詳細 -----------------------------*/
  .sec-transinfo-det {
    margin-top: 24px;
    padding-top: 6px;
    padding-bottom: 20px; }
    .sec-transinfo-det .c-secinner {
      padding: 0;
      text-align: center; }
    .sec-transinfo-det .l-flex {
      display: block; }

  .c-transinfo-det-wrap .c-transinfo-det-wrap {
    padding: 9px 20px; }
  .c-transinfo-det-wrap .c-tt__cont {
    padding: 0 20px;
    display: none; }

  .c-transinfo-det-cont {
    text-align: left;
    font-size: 1.2rem;
    padding: 5px;
    background-color: #f4f3f8; }
    .c-transinfo-det-cont.is-alert {
      background-color: #fdf2fa; }
    .c-transinfo-det-cont .u-note {
      font-size: 1.1rem;
      text-align: right; }
    .c-transinfo-det-cont a:link, .c-transinfo-det-cont a:visited {
      color: #1facda;
      text-decoration: underline; }
    .c-transinfo-det-cont:hover {
      text-decoration: none; }
    .c-transinfo-det-cont p {
        overflow-wrap: break-word;
    }
        /* ---- おトクなチケット -----------------------------*/
        .sec-ticket {
    margin-top: 24px;
    padding-top: 6px;
    padding-bottom: 20px; }
    .sec-ticket .c-secinner {
      padding: 0 20px;
      text-align: center; }

  .c-ticket-wrap {
    border-radius: 5px;
    margin-bottom: 20px; }
    .c-ticket-wrap.u-bl {
      background-color: #d4f5fe; }
    .c-ticket-wrap.u-be {
      background-color: #feefd8; }
    .c-ticket-wrap .ticket-line {
      width: 100%; }
    .c-ticket-wrap .u-tit {
      font-size: 3.5vw;
      line-height: 1.4;
      font-weight: bold;
      text-align: left; }
    .c-ticket-wrap .u-price {
      color: #06175b;
      font-weight: bold;
      font-size: 3.3vw;
      line-height: 1.4;
      text-align: left; }
    .c-ticket-wrap .u-date {
      background-color: #06175b;
      color: #fff;
      padding: 2px;
      border-radius: 4px;
      font-size: 1.0rem;
      line-height: 1.2;
      text-align: left; }
    .c-ticket-wrap .u-txt {
      font-size: 1.3rem;
      line-height: 1.3;
      text-align: left;
      margin-bottom: 5px; }
    .c-ticket-wrap .c-ticket-head {
      padding: 8px;
      padding-bottom: 0; }
      .c-ticket-wrap .c-ticket-head .l-flex__box {
        width: 50%;
        flex-basis: 50%; }
        .c-ticket-wrap .c-ticket-head .l-flex__box:first-child {
          padding-right: 2px; }
        .c-ticket-wrap .c-ticket-head .l-flex__box:last-child {
          padding-left: 2px; }
      .c-ticket-wrap .c-ticket-head > .l-flex {
        align-items: stretch; }
    .c-ticket-wrap .c-ticket-bottom {
      padding: 8px;
      padding-top: 0; }

  .c-ticket-btn-wrap {
    position: relative;
    width: 60%;
    max-width: 250px;
    margin: 0 auto;
    display: block; }
    .c-ticket-btn-wrap::after {
      content: '';
      display: block;
      padding-bottom: 20.45%; }

  .c-ticket-btn {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    display: block;
    text-align: center;
    margin: 0 auto;
    background: url("../images/ticket-btn_off.jpg") 0 0 no-repeat;
    background-size: 100%;
    font-size: 1.4rem;
    line-height: 1;
    font-weight: bold;
    color: #fff; }
    .c-ticket-btn:hover {
      cursor: pointer;
      background-image: url("../images/ticket-btn_on.jpg"); }
    .c-ticket-btn span {
      position: absolute;
      top: 30%;
      left: 0;
      right: 0;
      margin: auto; } }
    @media (max-width: 979px) and (max-width: 380px) {
      .c-ticket-btn span {
        top: 24%; } }

@media (max-width: 979px) {
  .c-ticket-line {
    font-size: 1.1rem;
    width: 100%;
    border: 0;
    background: url("../images/line-dot.jpg") center center repeat-x; }
    .c-ticket-line span {
      font-weight: bold;
      display: inline-block;
      background-color: #fff;
      padding: 8px; }

  /* ---- バナー -----------------------------*/
  .sec-bnr {
    margin-top: 24px;
    padding-top: 6px;
    padding-bottom: 20px; }
    .sec-bnr.sec-h2 {
      background-color: transparent; }
    .sec-bnr .c-secinner {
      padding: 0 20px;
      text-align: center; }

  .c-bnr-cont .l-flex {
    flex-wrap: wrap;
    justify-content: center; }
  .c-bnr-cont .l-flex__box {
    width: calc(33.333% - 3px);
    flex-basis: calc(33.333% - 3px);
    padding: 3px; }
  .c-bnr-cont li, .c-bnr-cont a {
    line-height: 0; }

  /* ------- pagetop＆自動スクロール --------------------------*/
  .c-pagetop {
    z-index: 1001;
    right: 10px; }
    .c-pagetop a {
      width: 60px;
      text-align: center;
      display: block; }

  /* ---- footer -----------------------------*/
  .l-footer {
    width: 100%;
    padding-top: 14px;
    padding-bottom: 20px;
    background-color: #06175b;
    text-align: center; }
    .l-footer .c-foot-link {
      font-size: 1.2rem;
      font-weight: bold;
      margin-bottom: 22px; }
      .l-footer .c-foot-link li {
        display: inline-block;
        margin: 0 20px; }
    .l-footer a:link, .l-footer a:visited {
      color: #fff; }
    .l-footer .c-footlogo {
      max-width: 70%;
      margin: 0 auto; } }
/* media end */
/* ---- min-width PC -------------------------------------*/
@media (min-width: 980px) {
  .l-allcontents {
    background-image: url("../images/main-bg_pc.jpg");
    background-size: 100%;
    background-position: center top;
    background-repeat: no-repeat; } }
@media screen and (min-width: 980px) and (min-width: 1242px) {
  .l-allcontents {
    background-size: 100%;
    background-position: top bottom; } }
@media (min-width: 980px) {
  /* ----header-----------------------------*/
  .c-header-bg {
    background: none;
    padding: 0; }

  .l-header {
    height: auto; }
    .l-header .u-inner {
      max-width: 960px;
      margin: 0 auto;
      /*padding-top: 80px;*/ }
    .l-header .c-head-wrap {
      /*display: flex;*/
      height: auto;
      /*margin-bottom: 35px;*/ }
    .l-header .c-head-wrap__box {
      height: auto;
      text-align: left; }
      .l-header .c-head-wrap__box img {
        max-height: 100%; }
      .l-header .c-head-wrap__box:first-child {
        padding: 0; }
    .l-header .c-head-wrap__box:first-child {
      /*width: 30%;
      flex-basis: 30%;*/ 
      padding: 26px 0;
    }
    .l-header .c-head-wrap__box:last-child {
      width: 70%;
      flex-basis: 70%; }
    .l-header .c-logo {
      margin-top: 0px;
      /*width: 174px;*/
      height: 68px; }
    .l-header .c-spmenu-wrap {
      display: none; }
    .l-header.is-fix {
      background: rgba(255, 255, 255, 0.9);
      position: fixed;
      top: 0px;
      transition: .9s;
      width: 100%;
      height: 60px;
      z-index: 990; }
      .l-header.is-fix .u-inner {
        padding-top: 0;
        position: relative; }
      .l-header.is-fix .c-head-wrap {
        display: block;
        position: absolute;
        top: 12px;
        left: 0px;
        margin-bottom: 0; }
      .l-header.is-fix .c-logo {
        width: 80px;
        height: 36px; }
      .l-header.is-fix .c-head-txt {
        visibility: hidden; }
      .l-header.is-fix .c-head-alert {
        display: none; }

  .c-gnav-wrap {
    display: block;
    position: absolute;
    right: 0;
    top: 20px;
    background-color: #fff;
    border-radius: 4px 0 0 4px; }
    .c-gnav-wrap .c-spmenu__cont {
      display: none;
      position: absolute;
      width: auto;
      top: 24px;
      left: auto;
      right: 10px;
      border: 1px solid #ccc;
      background: #fff;
      z-index: 998; }
      .c-gnav-wrap .c-spmenu__cont .cont_li {
        border-bottom: 1px solid #ccc;
        padding: 2px 16px; }
        .c-gnav-wrap .c-spmenu__cont .cont_li:last-child {
          border-bottom: 0; }

  .c-gnav {
    font-size: 1.3rem;
    line-height: 1.4;
    font-weight: bold; }
    .c-gnav__menu {
      padding: 4px 20px;
      display: inline-block; }

  .header-change {
    top: -60px;
    background: rgba(255, 255, 255, 0.9);
    position: fixed;
    transition: .9s;
    width: 100%;
    height: 60px;
    z-index: 990; }
    .header-change .u-inner {
      max-width: 960px;
      margin: 0 auto;
      padding-top: 0;
      position: relative; }
    .header-change .c-head-wrap {
      display: block;
      position: absolute;
      top: 12px;
      left: 0px;
      margin-bottom: 0; }
    .header-change .c-logo {
      width: 238px;
      height: 38px; }
    .header-change .c-gnav-wrap {
      top: 16px;
      border-radius: 4px 0 0 4px; }
    .header-change.show {
      top: 0; }

  .c-head-txt {
    max-width: 100%;
    padding: 0;
    font-size: 1.2rem;
    line-height: 1.367;
    color: #fff; /*add*/
  }

  .c-lang {
    background: url("../../../cmn/img/ico_globe.png") 0 0 no-repeat;
    background-size: 18px;
    padding-left: 22px;
    display: inline-block; }
    .c-lang:hover {
      cursor: pointer; }

  /* ---- alert -----------------------------*/
  .c-head-alert {
    background-color: #06175b;
    color: #fff;
    font-size: 1.6rem;
    font-weight: bold; }
    .c-head-alert .u-inner {
      padding: 0 10px;
      max-width: 960px;
      margin: 0 auto; }
    .c-head-alert a:link, .c-head-alert a:visited {
      color: #fff; }

  .ico_alert {
    display: inline-block;
    width: 22px;
    height: 22px;
    background: url(../images/ico_alert.png) 0 0 no-repeat;
    background-size: 22px;
    position: relative;
    top: 5px;
    margin-right: 5px; }

  /* ----map-----------------------------*/
  .l-main > .u-inner {
    max-width: 980px;
    margin: 0 auto; }

  .c-h2 {
    display: inline-block;
    text-align: center;
    margin: 0 auto;
    color: #06175b;
    font-weight: bold;
    font-size: 2.5rem;
    letter-spacing: 2px;
    padding-left: 20px;
    padding: 1px 0;
    position: relative; }
    .c-h2::before {
      content: '';
      display: inline-block;
      position: absolute;
      width: 45px;
      height: 38px;
      top: -7px;
      left: -50px;
      background: url("../images/ico_h2.png") 45% 0px no-repeat;
      background-size: 100%; }

  .sec-h2 {
    background-color: #fff;
    box-shadow: 6px 6px rgba(6, 23, 91, 0.1); }

  .c-maptransinfo-wrap {
    display: flex;
    justify-content: space-between;
    margin-top: 16px; }

  .sec-helpmap {
    width: 71.4%;
    flex-basis: 71.4%; }
    .sec-helpmap .c-h2 {
      font-size: 1.8rem; }
      .sec-helpmap .c-h2::before {
        width: 34px;
        height: 32px;
        top: -2px;
        left: -40px; }
    .sec-helpmap .c-secinner {
      text-align: center;
      padding-top: 12px;
      padding-left: 36px;
      padding-right: 36px;
      padding-bottom: 29px;
      position: relative; }

  .c-map-ico {
    position: absolute;
    top: 2.9%;
    right: 3.3%; }
    .c-map-ico ul {
      display: flex;
      align-items: baseline; }
      .c-map-ico ul li {
        margin-left: 5px; }

  .c-map-cont-wrap {
    margin-top: 20px; }
    .c-map-cont-wrap img {
      width: 100%; }

  .c-map-cont {
    display: none; vertical-align:top; }

  .c-map-btn-wrap {
    margin-top: 5px;
    margin-bottom: 5px;
    padding: 0; }

  .c-map-btn-ul {
    text-align: left; }
    .c-map-btn-ul li {
      display: inline-block;
      width: 134px;
      padding-right: 5px; }

  .c-map-btn {
    display: block;
    text-align: center;
    width: 134px;
    height: 34px;
    background: url("../images/bt-map_off.jpg") 0 0 no-repeat;
    font-size: 1.2rem;
    line-height: 34px;
    font-weight: bold;
    color: #fff; }
    .c-map-btn:hover {
      cursor: pointer;
      background-image: url("../images/bt-map_on.jpg"); }
    .c-map-btn.selected {
      background-image: url("../images/bt-map_on.jpg"); }

  .c-map-btnsub-wrap {
    padding: 0; }

  .c-map-btnsub {
    display: inline-block;
    padding: 4px 13px;
    font-size: 1.2rem;
    line-height: 1;
    font-weight: bold;
    background: url("../images/bt-port-dgy.jpg") 0 0 no-repeat;
    background-size: 100% 20px;
    border-radius: 4px; }
    .c-map-btnsub.u-lgy {
      background-image: url("../images/bt-port-lgy.jpg"); }

  a.c-map-btnsub:link, a.c-map-btnsub:visited {
    color: #000; }

  .c-map-btnsub-ul {
    text-align: left; }
    .c-map-btnsub-ul li {
      display: inline-block; }

  /* ------- 運行情報　transinfo --------------------------*/
  .sec-transinfo {
    display: none;
    width: 26.93%;
    flex-basis: 26.93%; }
    .sec-transinfo.is-on {
      display: block; }
    .sec-transinfo .c-h2 {
      font-size: 1.8rem; }
      .sec-transinfo .c-h2::before {
        width: 34px;
        height: 32px;
        top: -2px;
        left: -50px; }
    .sec-transinfo .c-secinner {
      text-align: center;
      position: relative;
      padding-top: 18px;
      padding-left: 46px;
      padding-right: 40px; }

  .c-transinfo-wrap {
    margin-top: 15px; }
    .c-transinfo-wrap .u-note {
      text-align: right;
      font-size: 1.1rem; }

  .c-transinfo-ul li {
    margin-bottom: 10px; }
    .c-transinfo-ul li:last-child {
      margin-bottom: 0; }

  .c-transinfo-label {
    position: relative;
    width: 100%; }

  .c-transinfo-btn {
    background: url("../images/label-bl-bg.jpg") 0 0 no-repeat;
    background-size: 100%;
    display: flex;
    align-items: center; }
    .c-transinfo-btn::before {
      content: "";
      display: block;
      padding-top: 36.7816%; }
    .c-transinfo-btn.is-alert {
      background-image: url("../images/label-pk-bg.jpg"); }
    .c-transinfo-btn .u-tit {
      text-align: left;
      font-weight: bold;
      font-size: 1.7rem;
      line-height: 1.1;
      display: table-cell;
      text-align: left;
      padding-left: 12px;
      width: 70px;
      height: auto;
      color: #fff; }
    .c-transinfo-btn .u-status {
      width: 80px;
      height: 100%;
      position: absolute;
      top: 0%;
      right: 0%; }
      .c-transinfo-btn .u-status img {
        width: auto;
        height: 50px;
        position: absolute;
        top: 0;
        right: 6%; }
      .c-transinfo-btn .u-status strong {
        position: absolute;
        bottom: 5px;
        left: 0;
        right: 0;
        margin: auto;
        font-weight: normal;
        font-size: 1.1rem;
        line-height: 1;
        display: inline-block; }
      .c-transinfo-btn .u-status.u-ok img {
        top: 12%; }

  /* ------- 経路情報　rootinfo --------------------------*/
  .sec-rootinfo {
    display: none;
    width: 26.93%;
    flex-basis: 26.93%; }
    .sec-rootinfo.is-on {
      display: block; }
    .sec-rootinfo .c-h2 {
      font-size: 1.8rem; }
      .sec-rootinfo .c-h2::before {
        width: 34px;
        height: 32px;
        top: -2px;
        left: -40px; }
    .sec-rootinfo .c-secinner {
      text-align: center;
      position: relative;
      padding-top: 18px;
      padding-left: 20px;
      padding-right: 20px; }

  .c-rootinfo-wrap {
    background-color: #f3f3f7;
    font-size: 1.4rem;
    text-align: left;
    padding: 10px;
    margin-top: 15px; }
    .c-rootinfo-wrap dt {
      /*background-color: #d6dae5;*/
      display: inline-block;
      font-weight: bold;
      padding: 0 2px; }
    .c-rootinfo-wrap dd {
      margin-bottom: 8px;
      margin-left: 1.4rem;
      line-height: 1.3;
      font-weight: bold; }

  /* ---- 出発時刻表  -----------------------------*/
  .sec-timetable {
    margin-top: 22px;
    padding-bottom: 40px; }
    .sec-timetable .c-secinner {
      text-align: center;
      padding-top: 10px;
      padding-bottom: 10px;
      position: relative; }
    .sec-timetable .u-note {
      text-align: right;
      font-size: 1.2rem; }

  .sec-timetableinner {
    padding: 0 65px; }
    .sec-timetableinner .l-flex__box {
      flex: 0 0 auto;
      width: calc(50% - 18px);
      flex-basis: calc(50% - 18px); }
    .sec-timetableinner .l-flex__box:first-child {
      margin-right: 18px; }
    .sec-timetableinner .l-flex__box:last-child {
      margin-left: 18px; }

  .c-timetable-reload-wrap {
    text-align: right; }
    .c-timetable-reload-wrap ul {
      display: flex;
      justify-content: flex-end;
      margin-right: 10px; }
    .c-timetable-reload-wrap li {
      line-height: 23px; }
    .c-timetable-reload-wrap .u-note {
      font-size: 1.2rem;
      margin-right: 6px; }

  .sec-tt {
    margin-top: 15px;
    padding-bottom: 5px; }
    .sec-tt .c-spmenu__cont {
      display: block;
      position: relative; }
    .sec-tt .c-table {
      margin-top: 0px; }
      .sec-tt .c-table-wrap .u-note {
        font-size: 1.0rem; }
      .sec-tt .c-table-wrap .u-tit {
        font-weight: bold;
        font-size: 1.5rem;
        text-align: left; }

  .c-table {
    border-spacing: 2px; }
    .c-table td {
      font-size: 1.4rem;
      padding: 10px; height: 52px;}
    .c-table.c-table--jr th, .c-table.c-table--jr td, .c-table.c-table--nankai th, .c-table.c-table--nankai td {
      width: 16%; }
    .c-table.c-table--jr th:nth-child(1), .c-table.c-table--jr th:nth-child(2), .c-table.c-table--jr td:nth-child(1), .c-table.c-table--jr td:nth-child(2), .c-table.c-table--nankai th:nth-child(1), .c-table.c-table--nankai th:nth-child(2), .c-table.c-table--nankai td:nth-child(1), .c-table.c-table--nankai td:nth-child(2) {
      width: 42%; }
    .c-table.c-table--bus .u-embg {
      background-color: #06175b !important;
      color: #fff;
      text-align: left;
      font-size: 0.9rem; }
    .c-table.c-table--bus tr:first-child th {
      width: 27%; }
      .c-table.c-table--bus tr:first-child th:first-child {
        width: 46%; }
    .c-table.c-table--bus tr:nth-child(2) th {
      width: 10%; }
      .c-table.c-table--bus tr:nth-child(2) th:nth-child(1), .c-table.c-table--bus tr:nth-child(2) th:nth-child(4) {
        width: 7%; }
    .c-table.c-table--bus td {
      background-color: #ecedf2;
      width: 10%; }
      .c-table.c-table--bus td:first-child {
        width: 46%; }
      .c-table.c-table--bus td:nth-child(2), .c-table.c-table--bus td:nth-child(5) {
        width: 7%; }
    .c-table.c-table--bus tr:nth-child(2n) td {
      background-color: #dadce8; }
    .c-table.c-table--ship .u-embg {
      background-color: #06175b !important;
      color: #fff;
      text-align: left;
      font-size: 0.9rem; }
    .c-table.c-table--ship tr:first-child th {
      width: 10%; }
      .c-table.c-table--ship tr:first-child th:nth-child(1) {
        width: 31%; }
      .c-table.c-table--ship tr:first-child th:nth-child(2) {
        width: 35%; }
      .c-table.c-table--ship tr:first-child th:nth-child(3), .c-table.c-table--ship tr:first-child th:nth-child(4) {
        width: 17%; }
    .c-table.c-table--ship tr:nth-child(2) th {
      width: 10%; }
      .c-table.c-table--ship tr:nth-child(2) th:nth-child(1), .c-table.c-table--ship tr:nth-child(2) th:nth-child(3) {
        width: 7%; }
    .c-table.c-table--ship td {
      background-color: #ecedf2;
      width: 10%; }
      .c-table.c-table--ship td:nth-child(1) {
        width: 31%; }
      .c-table.c-table--ship td:nth-child(2) {
        /*width: 35%;*/  width: 10%;  }
      .c-table.c-table--ship td:nth-child(3), .c-table.c-table--ship td:nth-child(5) {
        width: 7%; }
    .c-table.c-table--ship tr:nth-child(2n) td {
      background-color: #dadce8; }

  .c-tt-tit {
    display: block;
    font-size: 2.4rem;
    font-weight: bold;
    letter-spacing: 2px;
    color: #06175b;
    text-align: left;
    line-height: 1;
    padding: 10px;
    padding-left: 50px;
    margin-bottom: 10px;
    position: relative;
    border-bottom: 3px solid #576290;
    background-position: 0px 5px;
    background-repeat: no-repeat;
    cursor: pointer; }

  .c-tt-jr .c-tt-tit {
    background-image: url("../images/ico-train.png"); }

  .c-tt-nankai .c-tt-tit {
    background-image: url("../images/ico-train.png"); }

  .c-tt-bus .c-tt-tit {
    background-image: url("../images/ico-bus.png"); }

  .c-tt-ship .c-tt-tit {
    background-image: url("../images/ico-ship.png"); }

  .c-tt-bridge .c-tt-tit {
    background-image: url("../images/ico-bridge.png"); }

  .c-ico-arrow-d:after {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    top: 8px;
    left: 12px;
    transition: 0.5s; }

  .c-ico-arrow-d::before {
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
    position: absolute;
    top: 8px;
    left: 4px;
    transition: 0.5s; }

  .selected .c-ico-arrow-d::after {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    top: 8px;
    left: 12px; }
  .selected .c-ico-arrow-d::before {
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
    top: 8px;
    left: 4px; }

  .not-selected .c-ico-arrow-d::after {
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
    top: 8px;
    left: 12px; }
  .not-selected .c-ico-arrow-d::before {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    top: 8px;
    left: 4px; }

  .c-tt__cont {
    margin-top: 15px; }
    .c-tt__cont .c-table {
      font-size: 1.2rem;
      line-height: 1.2; }

  /* ---- のりば案内 -----------------------------*/
  .sec-portinfo .l-flex {
    font-size: 1.4rem;
    align-items: stretch; }
  .sec-portinfo .l-flex__box {
    text-align: left;
    margin-top: 10px;
    background-color: #f4f3f8; }
  .sec-portinfo .c-portinfo-tit {
    font-weight: bold;
    font-size: 1.6rem;
    background-color: #fff; }
    .sec-portinfo .c-portinfo-tit span {
      font-size: 1.4rem;
      font-weight: normal;
      display: inline-block; }
  .sec-portinfo a.c-portinfo-pk {
    display: inline-block;
    font-size: 1.4rem;
    line-height: 1.1;
    color: #d11380;
    text-decoration: underline;
    position: relative; }
    .sec-portinfo a.c-portinfo-pk::after {
      content: '>';
      display: block;
      width: 15px;
      height: 15px;
      font-weight: bold;
      position: absolute;
      top: 2px;
      right: -22px; }
    .sec-portinfo a.c-portinfo-pk:hover {
      text-decoration: none; }
  .sec-portinfo .c-portinfo-link {
    padding: 10px;
    display: flex;
    flex-wrap: wrap; }
    .sec-portinfo .c-portinfo-link li {
      width: 48%;
      flex-basis: 48%;
      font-size: 1.4rem;
      line-height: 1.1;
      margin-bottom: 8px;
      display: block; }
      .sec-portinfo .c-portinfo-link li:nth-child(2n) {
        padding-left: 4px; }
      .sec-portinfo .c-portinfo-link li:nth-child(2n+1) {
        padding-right: 4px; }
      .sec-portinfo .c-portinfo-link li a:link, .sec-portinfo .c-portinfo-link li a:visited {
        text-decoration: underline;
        color: #000; }
      .sec-portinfo .c-portinfo-link li a:hover {
        text-decoration: none; } }
    @media (min-width: 980px) and (max-width: 560px) {
      .sec-portinfo .c-portinfo-link li {
        float: none;
        width: 100%; } }

@media (min-width: 980px) {
  /* ------- アクセスルート案内 --------------------------*/
  .sec-accroot {
    margin-top: 24px;
    background-color: #d3f4fc; }
    .sec-accroot .c-secinner {
      padding: 22px 64px;
      text-align: center; }
    .sec-accroot .u-txt {
      text-align: left;
      font-size: 1.4rem;
      line-height: 1.4; }

  .c-accroot-cont {
    padding-top: 26px;
    font-size: 1.2rem;
    line-height: 1.3; }
    .c-accroot-cont .l-flex {
      margin-bottom: 20px; }
    .c-accroot-cont .l-flex__box:first-child {
      width: 58%;
      padding-right: 20px; }
    .c-accroot-cont .l-flex__box:last-child {
      width: 38%; }

  .c-accsearch-btn-wrap {
    position: relative;
    width: 80%;
    max-width: 350px;
    margin: 0 auto;
    display: block; }
    .c-accsearch-btn-wrap::after {
      content: '';
      display: block;
      padding-bottom: 20.45%; }

  .c-accsearch-btn {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    display: block;
    text-align: center;
    margin: 0 auto;
    background: url("../images/bt-search_off.jpg") 0 0 no-repeat;
    background-size: 100%;
    font-size: 3.0rem;
    line-height: 1;
    padding-top: 6%;
    font-weight: bold;
    color: #fff; }
    .c-accsearch-btn:hover {
      cursor: pointer;
      background-image: url("../images/bt-search_on.jpg"); }
    .c-accsearch-btn span {
      position: absolute;
      top: 36%;
      left: 0;
      right: 0;
      margin: auto; }

  /* ---- 運行情報詳細 -----------------------------*/
  .sec-transinfo-det {
    margin-top: 30px;
    padding-top: 30px;
    padding-bottom: 20px; }
    .sec-transinfo-det .c-secinner {
      padding: 0;
      text-align: center;
      margin: 0 68px; }
    .sec-transinfo-det .l-flex {
      flex-wrap: wrap;
      align-items: stretch; }
    .sec-transinfo-det .sec-tt {
      height: 100%; }
    .sec-transinfo-det .l-flex__box {
      flex: 0 0 50%;
      width: calc(50% - 20px);
      flex-basis: calc(50% - 20px);
      margin-bottom: 5px; }
      .sec-transinfo-det .l-flex__box:nth-child(2n+1) {
        margin-right: 20px; }
      .sec-transinfo-det .l-flex__box:nth-child(2n) {
        margin-left: 20px; }

  .c-transinfo-det-wrap .c-transinfo-det-wrap {
    padding: 9px 20px; }
  .c-transinfo-det-wrap .c-tt__cont {
    padding: 0 20px;
    display: block; }

  .c-transinfo-det-cont {
    text-align: left;
    font-size: 1.5rem;
    padding: 5px;
    background-color: #f4f3f8; }
    .c-transinfo-det-cont.is-alert {
      background-color: #fdf2fa; }
    .c-transinfo-det-cont .u-note {
      font-size: 1.3rem;
      text-align: right; }
    .c-transinfo-det-cont a:link, .c-transinfo-det-cont a:visited {
      color: #1facda;
      text-decoration: underline; }
    .c-transinfo-det-cont:hover {
      text-decoration: none; }
    .c-transinfo-det-cont p {
        overflow-wrap: break-word;
    }

  /* ---- おトクなチケット -----------------------------*/
  .sec-ticket {
    margin-top: 30px;
    padding-top: 30px;
    padding-bottom: 20px; }
    .sec-ticket .c-secinner {
      padding: 0 20px;
      text-align: center; }

  .c-ticket-wrap {
    display: flex;
    align-items: stretch;
    border-radius: 5px;
    margin-top: 30px;
    margin-bottom: 20px; }
    .c-ticket-wrap.u-bl {
      background-color: #d4f5fe; }
    .c-ticket-wrap.u-be {
      background-color: #feefd8; }
    .c-ticket-wrap .u-tit {
      font-size: 2rem;
      font-weight: bold;
      text-align: left;
      margin-bottom: 6px; }
    .c-ticket-wrap .u-price {
      color: #06175b;
      font-weight: bold;
      font-size: 1.8rem;
      text-align: left;
      margin-bottom: 6px; }
      .c-ticket-wrap .u-price .u-em {
        font-size: 128%; }
    .c-ticket-wrap .u-date {
      background-color: #06175b;
      color: #fff;
      padding: 3px 4px;
      border-radius: 4px;
      font-size: 1.2rem;
      line-height: 1.2;
      text-align: left;
      height: 20px; }
    .c-ticket-wrap .u-txt {
      font-size: 1.4rem;
      line-height: 1.3;
      text-align: left;
      margin-bottom: 5px; }
    .c-ticket-wrap .c-ticket-head {
      padding: 22px;
      width: 36%;
      flex-basis: 36%; }
      .c-ticket-wrap .c-ticket-head .l-flex__box {
        width: 50%;
        flex-basis: 50%; }
        .c-ticket-wrap .c-ticket-head .l-flex__box:first-child {
          padding-right: 2px; }
          .c-ticket-wrap .c-ticket-head .l-flex__box:first-child img {
            width: 100%;
            vertical-align: middle; }
        .c-ticket-wrap .c-ticket-head .l-flex__box:last-child {
          padding-left: 2px; }
    .c-ticket-wrap .c-ticket-body {
      width: 3%;
      flex-basis: 3%; }
      .c-ticket-wrap .c-ticket-body .ticket-line {
        height: 100%; }
    .c-ticket-wrap .c-ticket-bottom {
      width: 61%;
      flex-basis: 61%;
      padding: 22px;
      padding-left: 20px; }
      .c-ticket-wrap .c-ticket-bottom .l-flex {
        justify-content: flex-start; }
      .c-ticket-wrap .c-ticket-bottom .l-flex__box:first-child {
        width: 73%;
        flex-basis: 73%; }
      .c-ticket-wrap .c-ticket-bottom .l-flex__box:last-child {
        width: 25%;
        flex-basis: 25%;
        margin-left: 1.5%; }

  .c-ticket-btn-wrap {
    position: relative;
    height: 20px;
    margin: 0 auto;
    display: block; }
    .c-ticket-btn-wrap::after {
      content: '';
      display: block;
      padding-bottom: 20.45%; }

  .c-ticket-btn {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    display: block;
    text-align: center;
    margin: 0 auto;
    background: url("../images/ticket-btn_off.jpg") 0 0 no-repeat;
    background-size: 100% 20px;
    font-size: 1.3rem;
    line-height: 1;
    font-weight: bold;
    color: #fff; }
    .c-ticket-btn:hover {
      cursor: pointer;
      background-image: url("../images/ticket-btn_on.jpg"); }
    .c-ticket-btn span {
      position: absolute;
      top: 20%;
      left: 0;
      right: 0;
      margin: auto; }

  .c-ticket-line {
    font-size: 1.1rem;
    width: 100%;
    border: 0;
    background: url("../images/line-dot.jpg") center center repeat-x; }
    .c-ticket-line span {
      font-weight: bold;
      display: inline-block;
      background-color: #fff;
      padding: 8px; }

  /* ---- バナー -----------------------------*/
  .sec-bnr {
    margin-top: 24px;
    padding-top: 6px;
    padding-bottom: 50px; }
    .sec-bnr.sec-h2 {
      background-color: transparent;
      box-shadow: none; }
    .sec-bnr .c-secinner {
      padding: 0 20px;
      text-align: center; }

  .c-bnr-cont .l-flex {
    flex-wrap: wrap;
    justify-content: center; }
  .c-bnr-cont .l-flex__box {
    width: 32%;
    flex-basis: 32%;
    padding: 0.5%; }

  /* -------pagetop＆自動スクロール--------------------------*/
  .c-pagetop {
    z-index: 1001;
    right: 10px; }
    .c-pagetop a {
      width: 80px;
      text-align: center;
      display: block; }

  /* ----footer-----------------------------*/
  .l-footer {
    width: 100%;
    padding-top: 30px;
    padding-bottom: 30px;
    background-color: #06175b;
    text-align: center; }
    .l-footer .c-foot-link {
      font-size: 1.8rem;
      font-weight: bold;
      margin-bottom: 30px; }
      .l-footer .c-foot-link li {
        display: inline-block;
        margin: 0 20px; }
    .l-footer a:link, .l-footer a:visited {
      color: #fff; }
    .l-footer .c-footlogo {
      max-width: 360px;
      margin: 0 auto; } }
/* media end */
.l-allcontents {
  margin: 0 auto;
  position: relative; }

/*# sourceMappingURL=style.css.map */

@charset "UTF-8";

* {
    box-sizing: border-box;
}

.br-sp {
    display: block;
}

@media (min-width: 980px) {
    .br-sp {
        display: none;
    }
}

a:link {
    color: #06175b;
    text-decoration: none;
}

a:visited {
    color: #06175b;
    text-decoration: none;
}

a:hover {
    opacity: 0.8;
    text-decoration: none;
}

    a:hover * {
        filter: alpha(opacity=80);
        -moz-opacity: 0.8;
        opacity: 0.8;
    }

img {
    max-width: 100%;
    height: auto;
    width: auto;
}

input[type="text"] {
    -webkit-appearance: none;
    border-radius: 0;
    border: #ccc 1px solid;
    padding: 0 3px;
    font-size: 16px;
}

    input[type="text"]:focus {
        border: solid 1px #20b2aa;
    }

input[type="text"], select {
    outline: none;
}

input[type="submit"], input[type="button"] {
    -webkit-appearance: none;
    border-radius: 0;
    border: #ccc 1px solid;
    padding: 0 3px;
    font-size: 16px;
}

/* @layout  ------------------------------------------- */
/* @grid------------------------------------------- */
.l-grid {
    width: 100%;
}

    .l-grid:after {
        content: "";
        clear: both;
        display: block;
    }

.l-grid__box {
    box-sizing: border-box;
    float: left;
    border: 1px solid #000;
    width: 100%;
}

@media (min-width: 980px) {
    .l-grid__box.l-grid__box1 {
        width: 8.3%;
    }

    .l-grid__box.l-grid__box2 {
        width: 16.6%;
    }

    .l-grid__box.l-grid__box3 {
        width: 25%;
    }

    .l-grid__box.l-grid__box4 {
        width: 33.3%;
    }

    .l-grid__box.l-grid__box5 {
        width: 41.6%;
    }

    .l-grid__box.l-grid__box6 {
        width: 50%;
    }

    .l-grid__box.l-grid__box7 {
        width: 58.3%;
    }

    .l-grid__box.l-grid__box8 {
        width: 66.7%;
    }

    .l-grid__box.l-grid__box9 {
        width: 75%;
    }

    .l-grid__box.l-grid__box10 {
        width: 83.4%;
    }

    .l-grid__box.l-grid__box11 {
        width: 91.7%;
    }

    .l-grid__box.l-grid__box12 {
        width: 100%;
    }
}
/* flexbox------------------------------------------- */
.l-flex {
    display: -ms-flex;
    display: -webkit-flex;
    display: flex;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

.l-flex__box {
    flex: 1 1 auto;
}

/* layout------------------------------------------- */

/* header-fixed ------------------------------------------- */

.header-fixed {
    position: fixed;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 200px;
}







/* @mixin  ------------------------------------------- */
/*
@media screen and (max-width: xxxpx) {
}
@media screen and (min-width: xxxpx) {
}
*/
/* @mixin  ------------------------------------------- */
/*
@media screen and (max-width: xxxpx) {
}
@media screen and (min-width: xxxpx) {
}
*/
/* -------c-label--------------------------*/
.c-label {
    color: #000; /*add*/
    display: inline-block;
    background-color: #bbdef5;
    padding: 2px 6px;
    border-radius: 2px;
    margin: 1px 0;
}

/* -------bt--------------------------*/
.bt-tt-reload:hover {
    cursor: pointer;
}


/*----- hr -------*/
.c-line-dot {
    height: 8px;
    width: 100%;
    border: 0;
    background: url("../images/line-dot.jpg") 0 0 repeat-x;
}

@media only screen and (max-width: 979px) {
    .u-pc {
        display: none;
    }
}

@media screen and (min-width: 980px) {
    .u-sp {
        display: none;
    }
}
/* @mixin  ------------------------------------------- */
/*
@media screen and (max-width: xxxpx) {
}
@media screen and (min-width: xxxpx) {
}
*/
@media (max-width: 979px) {
    /* ----header-----------------------------*/
    .c-header-bg {
        background-image: url("../images/main-bg_sp.jpg");
        background-size: 100% auto;
        background-position: center bottom;
        background-position: center bottom;
        background-repeat: no-repeat;
        padding-bottom: 25%;
    }
}

/*@media (max-width: 959px) and (max-width: 480px) {
    .c-header-bg {
        padding-bottom: 45%;
    }
}*/

@media (max-width: 979px) {
    .l-header {
        width: 100%;
    }

        .l-header .head-container {
            z-index: 12;
            position: fixed;
            height: auto;
            width: 100%;
        }

        .l-header .head-bottom {
            padding-top: 67px;
        }

        .l-header .u-inner {
            background: #fbfffe url("../images/head-bg_sp.jpg") repeat-x;
            background-size: 100% 67px;
        }

        .l-header .c-logo {
            height: 33px;
        }

            .l-header .c-logo img {
                height: 100%;
            }

        .l-header .c-head-wrap {
            display: flex;
            justify-content: space-between;
            position: relative;
            width: 100%;
            height: 67px;
        }

            .l-header .c-head-wrap.is-on:before {
                content: "";
                position: absolute;
                width: 100%;
                height: 100%;
                display: block;
                background-color: #333;
                opacity: 0.5;
                z-index: 1;
            }

        .l-header .c-head-wrap__box {
            width: 13.56%;
            flex-basis: 13.56%;
            height: 67px;
            margin: 0 0.8325%;
        }

            .l-header .c-head-wrap__box:first-child {
                width: 50.89%;
                flex-basis: 50.89%;
                margin-right: auto;
                margin-left: 14px;
                padding: 16px 0;
            }

        .l-header .c-gnav-wrap {
            display: none;
        }

    .header-change {
        display: none;
    }

    .c-spmenu {
        width: 100%;
        height: 67px;
        background-color: #fff;
        display: inline-block;
        cursor: pointer;
        position: relative;
    }

        .c-spmenu.selected {
            z-index: 999;
            position: relative;
        }

        .c-spmenu img {
            position: absolute;
            top: 0;
            bottom: 0;
            left: 0;
            right: 0;
            margin: auto;
            max-height: 43px;
        }

    .c-spmenu__cont {
        display: none;
        position: absolute;
        top: 67px;
        left: 0;
        width: 100%;
        background: #fff;
        z-index: 998;
    }

        .c-spmenu__cont .cont_li {
            border-bottom: 1px solid #ccc;
            padding: 2px 16px;
        }

            .c-spmenu__cont .cont_li:last-child {
                border-bottom: 0;
            }

        .c-spmenu__cont .c-h2 {
            width: 100%;
        }

            .c-spmenu__cont .c-h2::before {
                top: 17%;
                left: 31%;
                left: calc(50% - 75px);
                background-position: 0 0px;
            }
}

/*@media (max-width: 959px) and (max-width: 480px) {
    .c-spmenu__cont .c-h2::before {
        left: calc(50% - 60px);
        background-position: 0 2px;
    }
}*/

@media (max-width: 979px) {
    .c-spmenu__close:hover {
        cursor: pointer;
    }

    .c-overlay {
        z-index: 10;
        display: none;
    }

        .c-overlay.is-on {
            position: absolute;
            top: 68px;
            left: 0;
            width: 100%;
            height: calc(100% - 68px);
            display: block;
            background-color: #333;
            opacity: 0.5;
        }

    /* ---- alert -----------------------------*/
    .c-head-alert {
        background-color: #06175b;
        text-align: center;
    }

        .c-head-alert .u-inner {
            background: none;
            padding: 0 10px;
            text-align: left;
        }

        .c-head-alert a:link, .c-head-alert a:visited {
            color: #fff;
        }

    .c-head-menu {
        background-color: #00abd9;
        text-align: center;
        line-height: 2.0rem;
        color: #fff;
        font-size: 1.3rem;
    }

        .c-head-menu .u-inner2 {
            background: none;
            padding: 5px;
        }

        .c-head-menu a:link, .c-head-menu a:visited {
            color: #fff;
            font-weight: bold;
        }

    .css-br::after {
        content: "\A";
        white-space: pre;
    }

    img.head_menu_icon {
        vertical-align: middle;
        /*margin: 0 5px 0 15px ;*/
        margin: 0 5px 0 0;
        width: 18px;
    }


    .ico_alert {
        display: inline-block;
        width: 22px;
        height: 22px;
        background: url(../images/ico_alert.png) 0 0 no-repeat;
        background-size: 22px;
        position: relative;
        top: 5px;
        margin-right: 5px;
    }

    .c-head-txt {
        width: 86%;
        max-width: 600px;
        padding: 10px 25px;
        margin: 0 auto;
        font-size: 1.2rem;
        line-height: 1.5;
    }
}

/*@media (max-width: 959px) and (max-width: 480px) {
    .c-header-bg {
        background-size: auto 100%;
    }

    .c-head-txt {
        width: 96%;
        padding: 10px;
    }


    /* ---- sp menu  -----------------------------*/

    .c-transinfo-menu {
        width: 90%;
    }
}*/


img .ico-img {
    width: 100px;
}

.u-menutit {
    vertical-align: middle;
    text-align: left;
    font-weight: bold;
    font-size: 1.7rem;
    text-align: left;
    padding: 30px 30px 30px 0;
    marigin: 50px;
    height: auto;
}

.u-sub {
    text-align: left;
    font-size: 1.4rem;
    line-height: 2.0rem;
    text-align: left;
    padding: 30px 30px 30px 0;
}


.c-switch-btn-img {
    margin-left: auto;
    width: 300px;
}


@media (max-width: 979px) {
    .c-transinfo-btn .u-status.u-ok img {
        top: 13%;
    }

    .c-spmenu__close {
        display: block;
        background-color: #566390;
        font-size: 1.4rem;
        font-weight: bold;
        color: #fff;
        padding: 7px 0;
        text-align: center;
        border-bottom: 1px solid #fff;
    }

        .c-spmenu__close:hover {
            cursor: pointer;
        }

    /* ---- lang menu -----------------------------*/
    .c-splang-wrap.c-spmenu__cont .cont_li {
        border-bottom: 0;
        padding-bottom: 5px;
    }

        .c-splang-wrap.c-spmenu__cont .cont_li a {
            display: block;
            padding: 8px 0;
            text-align: center;
            background-color: #dadce8;
        }

        .c-splang-wrap.c-spmenu__cont .cont_li:first-child {
            margin-top: 8px;
        }

        .c-splang-wrap.c-spmenu__cont .cont_li:nth-child(2n) a {
            background-color: #ecedf2;
        }

    .c-splang-wrap.c-spmenu__cont .c-spmenu__close {
        margin-top: 4px;
    }

    /* ---- sp menu -----------------------------*/
    .c-spmenulink-wrap.c-spmenu__cont li a {
        display: block;
        text-align: center;
        font-size: 1.6rem;
        padding: 5px 0;
        font-weight: bold;
    }

    .c-spmenulink-wrap.c-spmenu__cont .cont_li {
        border-bottom: 0;
        padding-bottom: 5px;
    }

        .c-spmenulink-wrap.c-spmenu__cont .cont_li a {
            padding: 8px 0;
            font-size: 1.8rem;
            background-color: #dadce8;
        }

        .c-spmenulink-wrap.c-spmenu__cont .cont_li:first-child {
            margin-top: 8px;
        }

        .c-spmenulink-wrap.c-spmenu__cont .cont_li:nth-child(2n) a {
            background-color: #ecedf2;
        }

    /* ----Helpful map-----------------------------*/
    .c-h2 {
        display: inline-block;
        text-align: center;
        margin: 0 auto;
        color: #06175b;
        font-weight: bold;
        /*font-size: 1.8rem;*/
        font-size: 1.6rem;
        line-height: 1;
        letter-spacing: 2px;
        padding: 14px 0 20px;
        padding-left: 15px;
        position: relative;
    }

        .c-h2::before {
            content: '';
            display: inline-block;
            position: absolute;
            width: 24px;
            height: 22px;
            top: 25%;
            left: -12px;
            background: url("../images/ico_h2.png") 40% 0px no-repeat;
            background-size: 100%;
        }
}



/*@media (max-width: 959px) and (max-width: 480px) {
    .c-h2 {
        font-size: 2.0rem;
    }

        .c-h2::before {
            width: 24px;
            height: 22px;
            top: 25%;
            left: -12px;
            margin: 0 0 0 0;
        }
}*/

@media (max-width: 979px) {
    .sec-h2 {
        background-color: #fff;
        box-shadow: 0px 6px rgba(6, 23, 91, 0.1);
    }

    .sec-helpmap .c-secinner {
        text-align: center;
        padding-top: 10px;
        padding-bottom: 10px;
        position: relative;
    }

    .c-map-ico {
        position: absolute;
        top: 15px;
        right: 12px;
        width: 25%;
    }

        .c-map-ico ul {
            display: flex;
            align-items: baseline;
            justify-content: flex-end;
        }

            .c-map-ico ul li {
                margin-left: 5px;
            }

    .c-map-cont-wrap img {
        width: 100%;
    }

    .c-map-cont {
        display: none;
    }

    .c-map-btn-wrap {
        padding: 0 22px;
        margin-top: 8px;
    }


    .c-h2-txt {
        padding: 0 0 5px 0;
        margin: -15px 0 0 0;
        font-size: 12px;
        line-height: 1.2;
    }

    .c-h2-txt2 {
        padding: 0 0 5px 0;
        font-size: 12px;
    }
}



.c-switch-btn-img {
    width: 300px;
    margin-left: auto;
}




/*@media (max-width: 959px) and (max-width: 420px) {
    .c-map-btn-wrap {
        padding: 0 10px;
    }
}*/

@media (max-width: 979px) {
    .c-map-btn-ul {
        display: flex;
        justify-content: center;
        align-items: stretch;
        width: 100%;
    }

        .c-map-btn-ul li {
            text-align: center;
            padding: 0 2px;
            width: 33.3%;
            flex-basis: 33.3%;
        }
}

/*@media (max-width: 959px) and (max-width: 420px) {
    .c-map-btn-ul {
        width: 100%;
        flex-basis: auto;
        justify-content: space-between;
    }

        .c-map-btn-ul li {
            width: 30%;
            flex-basis: 30%;
        }

            .c-map-btn-ul li:nth-child(2) {
                width: 40%;
                flex-basis: 40%;
            }
}*/

@media (max-width: 979px) {
    .c-map-btn {
        display: block;
        text-align: center;
        margin: 0 auto;
        width: 100%;
        height: 30px;
        background: url("../images/bt-map_off.jpg") 0 0 no-repeat;
        background-size: 100% 100%;
        font-size: 1.3rem;
        font-size: 14px;
        line-height: 1;
        padding: 9px 4px 14px 4px;
        color: #fff;
    }

        .c-map-btn::after {
            content: '';
            display: block;
            padding-bottom: 4%;
        }

        .c-map-btn:hover {
            cursor: pointer;
            background-image: url("../images/bt-map_on.jpg");
        }

        .c-map-btn.selected {
            background-image: url("../images/bt-map_on.jpg");
        }
}

/*@media (max-width: 959px) and (max-width: 420px) {
    .c-map-btn {
        font-size: 1.3rem;
        padding: 11px 2px 13px;
        height: 35px;
        background-size: 100% 100%;
    }

        .c-map-btn::after {
            padding-bottom: 0;
        }
}*/

@media (max-width: 979px) {
    .c-map-btnsub-wrap {
        padding: 0 22px;
        margin-top: 6px;
    }
}

/*@media (max-width: 959px) and (max-width: 420px) {
    .c-map-btnsub-wrap {
        padding: 0 10px;
    }
}*/

@media (max-width: 979px) {
    .c-map-btnsub {
        display: inline-block;
        padding: 4px 13px;
        font-size: 1.2rem;
        line-height: 1;
        font-weight: bold;
        background: url("../images/bt-port-dgy.jpg") 0 0 no-repeat;
        background-size: 100% 20px;
        border-radius: 4px;
    }

        .c-map-btnsub.u-lgy {
            background-image: url("../images/bt-port-lgy.jpg");
        }

    a.c-map-btnsub:link, a.c-map-btnsub:visited {
        color: #000;
    }

    .c-map-btnsub-ul {
        text-align: left;
        box-sizing: border-box;
    }

        .c-map-btnsub-ul li {
            display: block;
            line-height: 1;
            margin-top: 4px;
            margin-bottom: 6px;
        }


}

@media (max-width: 979px) {
    /* -------  --------------------------*/
    .sec-accroot {
        margin-top: 24px;
        background-color: #d3f4fc;
        padding-bottom: 20px;
    }

        .sec-accroot .c-secinner {
            padding: 0 22px;
            padding-top: 8px;
            text-align: center;
        }

        .sec-accroot .u-txt {
            text-align: left;
        }

    .c-accroot-cont {
        font-size: 1.2rem;
        line-height: 1.3;
    }

        .c-accroot-cont .l-flex {
            display: block;
        }

            .c-accroot-cont .l-flex img {
                width: 72%;
                margin: 10px auto;
            }

    .c-accsearch-btn-wrap {
        position: relative;
        width: 60%;
        max-width: 350px;
        margin: 0 auto;
        display: block;
    }

        .c-accsearch-btn-wrap::after {
            content: '';
            display: block;
            padding-bottom: 20.45%;
        }

    .c-accsearch-btn {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
        margin: auto;
        display: block;
        text-align: center;
        background: url("../images/bt-search_off.jpg") 0 0 no-repeat;
        background-size: 100%;
        font-size: 1.8rem;
        line-height: 0;
        padding-top: 10%;
        font-weight: bold;
        color: #fff;
    }

        .c-accsearch-btn:hover {
            cursor: pointer;
            background-image: url("../images/bt-search_on.jpg");
        }

    

    /* ----   -----------------------------*/
    .sec-ticket {
        margin-top: 24px;
        padding-top: 6px;
        padding-bottom: 20px;
    }

        .sec-ticket .c-secinner {
            padding: 0 20px;
            text-align: center;
        }

    .c-ticket-wrap {
        border-radius: 5px;
        margin-bottom: 20px;
    }

        .c-ticket-wrap.u-bl {
            background-color: #d4f5fe;
        }

        .c-ticket-wrap.u-be {
            background-color: #feefd8;
        }

        .c-ticket-wrap .ticket-line {
            width: 100%;
        }

        .c-ticket-wrap .u-tit {
            font-size: 16px;
            line-height: 1.4;
            font-weight: bold;
            text-align: left;
        }

        .c-ticket-wrap .u-price {
            color: #06175b;
            font-weight: bold;
            font-size: 3.3vw;
            line-height: 1.4;
            text-align: left;
        }

        .c-ticket-wrap .u-date {
            background-color: #06175b;
            color: #fff;
            padding: 2px;
            border-radius: 4px;
            font-size: 1.0rem;
            line-height: 1.2;
            text-align: left;
        }

        .c-ticket-wrap .u-txt {
            font-size: 1.3rem;
            line-height: 1.3;
            text-align: left;
            margin-bottom: 5px;
        }

        .c-ticket-wrap .c-ticket-head {
            padding: 8px;
            padding-bottom: 0;
        }

            .c-ticket-wrap .c-ticket-head .l-flex__box {
                width: 50%;
                flex-basis: 50%;
            }

                .c-ticket-wrap .c-ticket-head .l-flex__box:first-child {
                    padding-right: 2px;
                }

                .c-ticket-wrap .c-ticket-head .l-flex__box:last-child {
                    padding-left: 2px;
                }

            .c-ticket-wrap .c-ticket-head > .l-flex {
                align-items: stretch;
            }

        .c-ticket-wrap .c-ticket-bottom {
            padding: 8px;
            padding-top: 0;
        }

    .c-ticket-btn-wrap {
        position: relative;
        width: 60%;
        max-width: 250px;
        margin: 0 auto;
        display: block;
    }

        .c-ticket-btn-wrap::after {
            content: '';
            display: block;
            padding-bottom: 20.45%;
        }

    .c-ticket-btn {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
        display: block;
        text-align: center;
        margin: 0 auto;
        background: url("../images/ticket-btn_off.jpg") 0 0 no-repeat;
        background-size: 100%;
        font-size: 1.4rem;
        line-height: 1;
        font-weight: bold;
        color: #fff;
    }

        .c-ticket-btn:hover {
            cursor: pointer;
            background-image: url("../images/ticket-btn_on.jpg");
        }

        .c-ticket-btn span {
            position: absolute;
            top: 30%;
            left: 0;
            right: 0;
            margin: auto;
        }
}

/*@media (max-width: 959px) and (max-width: 380px) {
    .c-ticket-btn span {
        top: 24%;
    }
}*/

@media (max-width: 979px) {
    .c-ticket-line {
        font-size: 1.1rem;
        width: 100%;
        border: 0;
        background: url("../images/line-dot.jpg") center center repeat-x;
    }

        .c-ticket-line span {
            font-weight: bold;
            display: inline-block;
            background-color: #fff;
            padding: 8px;
        }

    /* ----   -----------------------------*/
    .sec-bnr {
        margin-top: 24px;
        padding-top: 6px;
        padding-bottom: 20px;
    }

        .sec-bnr.sec-h2 {
            background-color: transparent;
        }

        .sec-bnr .c-secinner {
            padding: 0 20px;
            text-align: center;
        }

    .c-bnr-cont .l-flex {
        flex-wrap: wrap;
        justify-content: center;
    }

    .c-bnr-cont .l-flex__box {
        width: calc(33.333% - 3px);
        flex-basis: calc(33.333% - 3px);
        padding: 3px;
    }

    .c-bnr-cont li, .c-bnr-cont a {
        line-height: 0;
    }

    /* -------   --------------------------*/
    .c-pagetop {
        z-index: 1001;
        right: 10px;
    }

        .c-pagetop a {
            width: 60px;
            text-align: center;
            display: block;
        }

    /* ---- footer -----------------------------*/
    .l-footer {
        width: 100%;
        padding-top: 14px;
        padding-bottom: 20px;
        background-color: #06175b;
        text-align: center;
    }

        .l-footer .c-foot-link {
            font-size: 1.2rem;
            font-weight: bold;
            margin-bottom: 22px;
        }

            .l-footer .c-foot-link li {
                display: inline-block;
                margin: 0 20px;
            }

        .l-footer a:link, .l-footer a:visited {
            color: #fff;
        }

        .l-footer .c-footlogo {
            max-width: 70%;
            margin: 0 auto;
        }
}
/* media end */
/* ---- min-width PC -------------------------------------*/
@media (min-width: 980px) {
    .l-allcontents {
        background-image: url("../images/main-bg_pc.jpg");
        background-size: 100%;
        background-position: center top;
        background-repeat: no-repeat;
    }
}

/*@media screen and (min-width: 960px) and (min-width: 1242px) {
    .l-allcontents {
        background-size: 100%;
        background-position: top bottom;
    }
}*/

@media (min-width: 980px) {
    /* ----header-----------------------------*/
    .c-header-bg {
        background: none;
        padding: 0;
    }

    .l-header {
        height: auto;
    }

        .l-header .u-inner {
            max-width: 960px;
            margin: 0 auto;
            /*padding-top: 80px;*/
        }

        .l-header .c-head-wrap {
            /*display: flex;*/
            height: auto;
            /*margin-bottom: 35px;*/
        }

        .l-header .c-head-wrap__box {
            height: auto;
            text-align: left;
        }

            .l-header .c-head-wrap__box img {
                max-height: 100%;
            }

            .l-header .c-head-wrap__box:first-child {
                padding: 0;
            }

            .l-header .c-head-wrap__box:first-child {
                /*width: 30%;
      flex-basis: 30%;*/
                padding: 26px 0;
            }

            .l-header .c-head-wrap__box:last-child {
                width: 70%;
                flex-basis: 70%;
            }

        .l-header .c-logo {
            margin-top: 0px;
            /*width: 174px;*/
            height: 68px;
        }

        .l-header .c-spmenu-wrap {
            display: none;
        }

        .l-header.is-fix {
            background: rgba(255, 255, 255, 0.9);
            position: fixed;
            top: 0px;
            transition: .9s;
            width: 100%;
            height: 60px;
            z-index: 990;
        }

            .l-header.is-fix .u-inner {
                padding-top: 0;
                position: relative;
            }

            .l-header.is-fix .c-head-wrap {
                display: block;
                position: absolute;
                top: 12px;
                left: 0px;
                margin-bottom: 0;
            }

            .l-header.is-fix .c-logo {
                width: 80px;
                height: 36px;
            }

            .l-header.is-fix .c-head-txt {
                visibility: hidden;
            }

            .l-header.is-fix .c-head-alert {
                display: none;
            }

    .c-gnav-wrap {
        display: block;
        position: absolute;
        right: 0;
        top: 35px;
        background-color: #fff;
        border-radius: 4px 0 0 4px;
    }

        .c-gnav-wrap .c-spmenu__cont {
            display: none;
            position: absolute;
            width: auto;
            top: 24px;
            left: auto;
            right: 10px;
            border: 1px solid #ccc;
            background: #fff;
            z-index: 998;
        }

            .c-gnav-wrap .c-spmenu__cont .cont_li {
                border-bottom: 1px solid #ccc;
                padding: 2px 16px;
            }

                .c-gnav-wrap .c-spmenu__cont .cont_li:last-child {
                    border-bottom: 0;
                }

    .c-gnav {
        font-size: 1.3rem;
        line-height: 1.4;
        font-weight: bold;
    }

    .c-gnav__menu {
        padding: 4px 20px;
        display: inline-block;
    }


    /* ---- kix menu  -----------------------------*/
    .header-change {
        top: -60px;
        background: rgba(255, 255, 255, 0.9);
        position: fixed;
        transition: .9s;
        width: 100%;
        height: 60px;
        z-index: 990;
    }

        .header-change .u-inner {
            max-width: 960px;
            margin: 0 auto;
            padding-top: 0;
            position: relative;
        }

        .header-change .c-head-wrap {
            display: block;
            position: absolute;
            top: 12px;
            left: 0px;
            margin-bottom: 0;
        }

        .header-change .c-logo {
            width: 238px;
            height: 38px;
        }

        .header-change .c-gnav-wrap {
            top: 16px;
            border-radius: 4px 0 0 4px;
        }

        .header-change.show {
            top: 0;
        }




    .c-head-txt {
        max-width: 100%;
        padding: 0;
        font-size: 1.2rem;
        line-height: 1.367;
        color: #fff; /*add*/
    }

    .c-lang {
        background: url("../../../cmn/img/ico_globe.png") 0 0 no-repeat;
        background-size: 18px;
        padding-left: 22px;
        display: inline-block;
    }

        .c-lang:hover {
            cursor: pointer;
        }

    /* ---- alert -----------------------------*/
    .c-head-alert {
        background-color: #06175b;
        text-align: center;
        color: #fff;
        font-size: 14px;
        font-weight: bold;
    }

        .c-head-alert .u-inner {
            padding: 3px;
            max-width: 960px;
            margin: 0 auto;
            text-align:left;
        }

        .c-head-alert a:link, .c-head-alert a:visited {
            color: #fff;
        }

    .c-head-menu {
        background-color: #00abd9;
        text-align: center;
        color: #fff;
        font-size: 1.4rem;
        padding: 3px;
    }

        .c-head-menu .u-inner2 {
            background: none;
            padding: 0 1px;
        }

        .c-head-menu a {
            margin: 0 20px;
        }

            .c-head-menu a:link, .c-head-menu a:visited {
                color: #fff;
                font-weight: bold;
            }

    img.head_menu_icon {
        vertical-align: middle;
        margin: 3px 5px 5px 10px;
        width: 22px;
    }



    .ico_alert {
        display: inline-block;
        width: 22px;
        height: 22px;
        background: url(../images/ico_alert.png) 0 0 no-repeat;
        background-size: 22px;
        position: relative;
        top: 5px;
        margin-right: 5px;
    }

    /* ---- Helpful map -----------------------------*/
    .l-main > .u-inner {
        max-width: 980px;
        margin: 0 auto;
    }

    .c-h2 {
        display: inline-block;
        text-align: center;
        margin: 0 auto;
        color: #06175b;
        font-weight: bold;
        font-size: 2.5rem;
        letter-spacing: 2px;
        padding-left: 60px;
        padding: 1px 0;
        position: relative;
    }

        .c-h2::before {
            content: '';
            display: inline-block;
            position: absolute;
            width: 45px;
            height: 38px;
            top: -7px;
            left: -60px;
            margin: 3px 0 0 10px;
            background: url("../images/ico_h2.png") 45% 0px no-repeat;
            background-size: 100%;
        }

    .c-h2-txt {
        font-size: 14px;
        line-height: 1.2;
        margin-top: 4px;
    }

    .c-h2-txt2 {
        font-size: 14px;
    }

    .sec-h2 {
        background-color: #fff;
        box-shadow: 6px 6px rgba(6, 23, 91, 0.1);
    }

    .c-maptransinfo-wrap {
        display: flex;
        justify-content: space-between;
        margin-top: 16px;
    }

    .sec-helpmap {
        width: 71.4%;
        flex-basis: 71.4%;
    }

        .sec-helpmap .c-h2 {
            font-size: 3.2rem;
            padding: 0 0 0 55px;
        }

            .sec-helpmap .c-h2::before {
                width: 40px;
                height: 36px;
                top: -4px;
                left: -5px;
            }

        .sec-helpmap .c-secinner {
            text-align: center;
            padding-top: 20px;
            padding-left: 36px;
            padding-right: 36px;
            padding-bottom: 29px;
            position: relative;
        }

    .c-map-ico {
        position: absolute;
        top: 2.9%;
        right: 3.3%;
    }

        .c-map-ico ul {
            display: flex;
            align-items: baseline;
        }

            .c-map-ico ul li {
                margin-left: 5px;
            }

    .c-map-cont-wrap {
        margin-top: 10px;
    }

        .c-map-cont-wrap img {
            width: 100%;
        }

    .c-map-cont {
        display: none;
        vertical-align: top;
    }

    .c-map-btn-wrap {
        margin-top: 5px;
        margin-bottom: 5px;
        padding: 0;
    }

    .c-map-btn-ul {
        text-align: left;
    }

        .c-map-btn-ul li {
            display: inline-block;
            width: 134px;
            padding-right: 5px;
        }

    .c-map-btn {
        display: block;
        text-align: center;
        width: 134px;
        height: 34px;
        background: url("../images/bt-map_off.jpg") 0 0 no-repeat;
        font-size: 1.2rem;
        line-height: 34px;
        font-weight: bold;
        color: #fff;
    }

        .c-map-btn:hover {
            cursor: pointer;
            background-image: url("../images/bt-map_on.jpg");
        }

        .c-map-btn.selected {
            background-image: url("../images/bt-map_on.jpg");
        }

    .c-map-btnsub-wrap {
        padding: 0;
    }

    .c-map-btnsub {
        display: inline-block;
        padding: 4px 13px;
        font-size: 1.2rem;
        line-height: 1;
        font-weight: bold;
        background: url("../images/bt-port-dgy.jpg") 0 0 no-repeat;
        background-size: 100% 20px;
        border-radius: 4px;
    }

        .c-map-btnsub.u-lgy {
            background-image: url("../images/bt-port-lgy.jpg");
        }

    a.c-map-btnsub:link, a.c-map-btnsub:visited {
        color: #000;
    }

    .c-map-btnsub-ul {
        text-align: left;
    }

        .c-map-btnsub-ul li {
            display: inline-block;
        }







    .c-transinfo-btn {
        background: url("../images/label-bl-bg.jpg") 0 0 no-repeat;
        background-size: 100% 100%;
        display: flex;
        align-items: center;
    }

        .c-transinfo-btn::before {
            content: "";
            display: block;
            padding-top: 36.7816%;
        }

        .c-transinfo-btn.is-alert {
            background-image: url("../images/label-pk-bg.jpg");
        }

        .c-transinfo-btn .u-tit {
            text-align: left;
            font-weight: bold;
            font-size: 16px;
            line-height: 1.1;
            display: table-cell;
            text-align: left;
            padding-left: 12px;
            width: 70px;
            height: auto;
            color: #fff;
        }

        .c-transinfo-btn .u-status {
            width: 80px;
            height: 100%;
            position: absolute;
            top: 0%;
            right: 0%;
        }

            .c-transinfo-btn .u-status img {
                width: auto;
                height: 50px;
                position: absolute;
                top: 0;
                right: 6%;
            }

            .c-transinfo-btn .u-status strong {
                position: absolute;
                bottom: 5px;
                left: 0;
                right: 0;
                margin: auto;
                font-weight: normal;
                font-size: 1.1rem;
                line-height: 1;
                display: inline-block;
            }

            .c-transinfo-btn .u-status.u-ok img {
                top: 12%;
            }

    /* ------- �o�H���@rootinfo --------------------------*/
    .sec-rootinfo {
        display: none;
        width: 26.93%;
        flex-basis: 26.93%;
    }

        .sec-rootinfo.is-on {
            display: block;
        }

        .sec-rootinfo .c-h2 {
            font-size: 2.4rem;
        }

            .sec-rootinfo .c-h2::before {
                width: 34px;
                height: 32px;
                top: -2px;
                left: -50px;
            }

        .sec-rootinfo:lang(en) .c-h2::before {
            left: 0px;
        }

        .sec-rootinfo .c-secinner {
            text-align: center;
            position: relative;
            padding-top: 18px;
            padding-left: 20px;
            padding-right: 20px;
        }

    .c-rootinfo-wrap {
        background-color: #f3f3f7;
        font-size: 1.4rem;
        text-align: left;
        padding: 10px;
        margin-top: 15px;
    }

        .c-rootinfo-wrap dt {
            /*background-color: #d6dae5;*/
            /*display: inline-block;*/
            font-weight: bold;
            padding: 0 2px;
        }

        .c-rootinfo-wrap dd {
            margin-bottom: 12px;
            margin-left: 1.4rem;
            line-height: 1.3;
            font-weight: bold;
        }

    .msgdd {
        padding: 8px;
        margin: 0 !important;
        font-size: 0.9em;
        color: red;
        font-weight: bold !important;
    }
    
}

/* media end */
.l-allcontents {
    margin: 0 auto;
    position: relative;
}

/*# sourceMappingURL=style.css.map */

@charset "UTF-8";

.txt-r {
    text-align: right !important;
}

.i-alrt {
    background-color: #c80074;
}

/***
    modal dialog
*/

.mdlg {
    max-width: 800px !important;
}

    .mdlg h2 {
        margin: 16px;
        display: block;
        font-size: 1.8rem;
        font-weight: bold;
        vertical-align: middle;
        color: #06175b;
        text-align: center;
    }

        .mdlg h2 span {
            vertical-align: middle;
            padding-left: 60px;
            padding-top: 4px;
            background: url(../images/ico_h2.png) 0 0px no-repeat;
            background-size: 45px 36px;
            height: 45px;
            display: inline-block;
        }


/***
    Helpful Map  
*/
iframe.hmapf {
    width: 627px;
    height: 324px;
    overflow: hidden;
}

.tinfo_close {
    text-align: center;
    display: block;
    background: #07185c;
    color: #ffffff;
    cursor: pointer;
    padding: 4px 0;
    margin: 8px;
    border-radius: 8px;
    font-size: 1.2rem;
    font-weight: bold;
}

/**
    Route Info
*/

.routettl {
    text-align: center;
    font-weight: bold;
    color: #06175b;
    font-size: 1.6rem;
    margin-bottom: 16px;
}

.ri_sttl {
    margin-right: 16px;
}

.routeart {
    font-weight: bold;
    color: #eb008b;
}

.ddrttl {
    background: #3049A7;
    margin: 8px 0 !important;
    padding: 4px 8px !important;
    color: #fff;
}

    .ddrttl span {
        color: #ffffff;
    }
dl dd.ddrttl:nth-child(n+2) {
    margin-top: 24px !important;
}

    .rdtldd {
        color: #3049A7;
    }
/**
    diagram
*/
.tb_bus_noriba {
    text-decoration: underline !important;
    color: #000 !important;
    font-size: 0.9em;
}

.c-table .u-tokkyu td {
    color: #00abd9;
    font-weight: bold;
}

.c-table .u-em td {
    color: #ea008a;
}

.txtr {
    text-align: right !important;
}

.keiyudiv {
    position: absolute;
    margin-top: 8px;
    display: inline;
    padding: 16px;
    display: none;
    background: #06175b;
    color: #fff;
    border-radius: 8px;
    box-shadow: 2px 2px 4px grey;
    text-align: left;
    margin-left: 8px;
    z-index: 300;
}

.rt {
    margin-left: -160px;
}

.keiyudiv ul li {
    width: 100%;
    margin-left: 8px;
    display: table-row;
}

    .keiyudiv ul li span {
        display: inline-block;
    }

        .keiyudiv ul li span:nth-child(2) {
            float: right;
        }

    .keiyudiv ul li::after {
        content: " ";
        clear: both;
    }

.keiyudiv .cls {
    cursor: pointer;
    font-weight: bold;
    float: right;
    position: absolute;
    right: 0;
    top: 0;
    padding: 3px;
    color: #fff;
}

.nwp {
    white-space: nowrap;
}

.c-table td a {
    color: #000;
}

.c-table .u-em td a {
    color: #ea008a;
}

.c-table .u-tokkyu td a {
    color: #00abd9;
    font-weight: bold;
}

@media only screen and (max-width: 979px) {
    .kul {
        right: 0;
        text-align: center;
        left: 0;
    }

        .kul li span:nth-child(2) {
            margin-left: 8px;
        }

        .kul span.khd {
            display: block;
            font-weight: bold;
            background: #07185c;
            padding: 8px 0;
            color: #fff;
            margin-bottom: 4px;
        }

        .kul li::after {
            content: " | ";
            clear: both;
            display: block;
            line-height: 0.4;
            padding: 0;
            margin: 0;
            font-weight: bold;
            color: #07185c;
        }

        .kul li:last-child::after {
            content: " ";
            clear: both;
            display: block;
        }

        .kul li span:first-child {
            padding: 4px;
            border: 2px solid #fff;
            border-radius: 8px 0 0 8px;
            background: #007291;
            color: #fff;
            font-size: 0.9rem;
        }

        .kul li span:last-child {
            padding: 4px;
            border: 2px solid #fff;
            border-radius: 0 8px 8px 0;
            background: #fff;
            margin-left: -2px;
            font-size: 0.9rem;
            font-weight: bold;
        }
}


/**
    ferry timetable 
    message 

*/

.fmsg {
    font-size: 0.9em;
    text-align: left;
    line-height: 1.8;
    padding: 10px;
}

.to_durl {
    text-decoration: underline !important;
}

@media only screen and (max-width: 959px) {
    /***
        modal dialog
    */
    .mdlg {
        max-width: none !important;
    }

        .mdlg h2 {
            font-size: 1.4rem;
        }

            .mdlg h2 span {
                padding-left: 30px;
                background-size: 24px 22px;
                height: 24px;
                padding-top: 0;
            }

    /***
    Helpful Map  
    */
    iframe.hmapf {
        width: 100%;
        height: 324px;
    }

    /*add*/
    .iframe-wrap {
        position: relative;
        width: 100%;
        height: 0;
        padding-top: 350px;
    }

        .iframe-wrap iframe {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
        }
    /**/
    /**
        route info
    */
    #routeinfo_sp {
        background-color: #f3f3f7;
        font-size: 1.4rem;
        text-align: left;
        padding: 10px;
        margin-top: 15px;
    }

        #routeinfo_sp dd {
            margin-bottom: 20px;
            margin-left: 1.4rem;
            line-height: 1.3;
            font-weight: bold;
        }

        #routeinfo_sp dt {
            /*background-color: #d6dae5;*/
            /*display: inline-block;*/
            font-weight: bold;
            padding: 0 2px;
        }


    /**
        noriba
    */

    .imgscrl {
        height: 300px;
        overflow-x: auto;
        overflow-y: hidden;
    }

        .imgscrl img {
            max-width: none;
            height: 100%;
            margin: 0 auto;
            display: block;
        }

    .imgscrl_howto {
        height: 400px;
        overflow-x: hidden;
        overflow-y: auto;
        text-align: center;
    }

        .imgscrl_howto img {
            width: 90%;
            height: auto;
            text-align: center;
        }

    .c-map-btn-ul:lang(en) li:nth-child(2) .c-map-btn {
        padding: 2px 2px;
    }

    .mdlg h2 span:lang(en) {
        line-height: 1;
    }

    #routeinfo_sp {
        max-height: 60%;
        overflow-y: auto;
    }

    .c-table--ship tr:nth-child(4n) td {
        background-color: #dadce8;
    }
}

/**
    PC
*/
@media (min-width: 980px) {

    /*.c-map3 {
        max-height: 306px;
        overflow: hidden;
    }*/

    .c-map-btn-ul:lang(en) li:nth-child(2) .c-map-btn {
        line-height: 1;
    }

    .c-table.c-table--nankai:lang(en) th:nth-child(2) {
        width: 55%;
    }

    .c-table.c-table--jr:lang(en) td:nth-child(2) {
        width: 55%;
    }

    .c-rootinfo-wrap {
        overflow-y: auto;
        max-height: 426px;
        overflow-x: hidden;
    }
}

.c-switch-btn img {
    width: 400px;
    overflow: auto;
}





/**
    search box 
*/

#id-searchbox {
    margin-top: 22px;
}

    #id-searchbox iframe {
        width: 920px;
        height: 480px;
    }

.sec-searchbox .c-secinner {
    text-align: center;
    padding-top: 10px;
    position: relative;
}

@media only screen and (max-width: 979px) {
    .sec-searchbox .c-secinner {
        padding-top: 2px;
    }

    #id-searchboxsp .sb_dtl {
        top: 70px;
    }
}

#id-searchboxsp iframe {
    width: 100%;
    height: 490px;
    margin-top: 0px;
}

#id-searchbox h2 {
    margin: 22px 0;
}

.sb_dtl {
    font-size: 10px;
    font-weight: bold;
    position: absolute;
    right: 16px;
    top: 46px;
    margin-top: 4px;
}

    .sb_dtl a {
        color: #eb008b;
        font-size: 14px;
        padding-left: 54px;
        display: block;
        background: url(../images/ico-link.png) 0 -4px no-repeat;
        background-size: auto 36px;
        padding-bottom: 4px;
    }

#id-searchbox h2.sb_dtl {
    top: 33px;
    right: 44px;
    margin: 0;
}

#id-searchboxsp .sb_dtl {
    top: 40px;
}

    #id-searchboxsp .sb_dtl a {
        font-size: 12px;
        background: url(../images/ico-link.png) 0 0 no-repeat;
        background-size: auto 26px;
        padding-left: 40px;
        height: 30px;
    }

@media only screen and (max-width: 979px) {
    .c-header-bg {
        padding-bottom: 0;
        margin-bottom: 15px;
    }
}

@media screen and (max-width: 979px) {
    #id-searchboxsp h2.c-h2 {
        padding-bottom: 35px !important;
    }

        #id-searchboxsp h2.c-h2::before {
            width: 24px;
            height: 22px;
            top: 20%;
            left: -12px;
            margin: 0 0 0 0;
        }
}

/**
    warning
*/

.i-alrt_w2 {
    background-color: #c80074 !important;
    color: #fff;
    font-size: 14px;
    font-weight: normal;
    line-height: 1.4;
    padding: 8px;
    text-decoration: none;
}

    .i-alrt_w2 a {
        text-decoration: none;
    }

.i-alrt_w .i-alrt_w {
    padding: 8px 0;
}

.u-inner2 {
    padding: 0;
    margin: 0 auto;
    margin-top: -2px;
}

.i-alrt-ic {
    background: url(../../Content/T../images/ico_alert.png) 0 0 no-repeat !important;
    background-size: 22px !important;
}




#loadmask {
    width: 100%;
    height: 0;
    position: absolute;
    left: 0;
    top: 0;
}

.loadmask {
    z-index: 1003;
    position: fixed;
    top: 0;
    left: 0;
    -moz-opacity: 0.5;
    opacity: .70;
    filter: alpha(opacity=50);
    background-color: #CCC;
    width: 100%;
    height: 100%;
    zoom: 1;
}

.loadmask-msg {
    z-index: 1004;
    position: absolute;
    top: 0;
    left: 0;
    border: 1px solid #5fcba9;
    background: #c3daf9;
    padding: 2px;
}

    .loadmask-msg div {
        padding: 10px;
        background: #fbfbfb url('../../cmn/img/loading.png') no-repeat center;
        line-height: 20px;
        /*border:1px solid #5fcba9;*/
        color: #222;
        font: normal 11px tahoma, arial, helvetica, sans-serif;
        cursor: wait;
        width: 120px;
        height: 120px;
    }

.masked {
    overflow: hidden !important;
}

.masked-relative {
    position: relative !important;
}

.masked-hidden {
    visibility: hidden !important;
}

/*--------add---------*/

.c-head-menu ul.pageAnchor {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    max-width: 315px;
    margin: 0 auto;
}

    .c-head-menu ul.pageAnchor li:nth-child(odd) {
        text-align: left;
        width: 44%;
        max-width: 155px;
    }

    .c-head-menu ul.pageAnchor li:nth-child(even) {
        text-align: left;
        width: 55%;
        max-width: 215px;
    }

    .c-head-menu ul.pageAnchor li a {
        margin: 0;
        white-space: nowrap;
    }

        .c-head-menu ul.pageAnchor li a:link,
        .c-head-menu ul.pageAnchor li a:visited {
            color: #fff;
            font-weight: bold;
        }

@media screen and (min-width: 980px) {
    .c-head-menu ul.pageAnchor {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-around;
        align-items: center;
        width: 100%;
        max-width: 860px;
        margin: 0 auto;
    }

        .c-head-menu ul.pageAnchor li:nth-child(odd) {
            text-align: left;
            width: auto;
            max-width: auto;
            padding: 5px 0;
        }

        .c-head-menu ul.pageAnchor li:nth-child(even) {
            text-align: left;
            width: auto;
            max-width: auto;
            padding: 5px 0;
        }
}

/**
    add
*/
.diagram_nooperation {
    padding: 12px 0;
    background: #eee;
    margin-bottom: 12px;
}

.modal {
    margin-top: 32px;
}





dt {
    position: relative;
    padding: 0 0 0 0;
    /*z-index: 900;*/
}



/* 
dt:after {
   content: "";
   position: absolute;
   border-right: 2px solid #000;
   border-bottom: 2px solid #000;
   width: 10px;
   right: 10px;
   height: 10px;
   transform: rotate(45deg);
   z-index: 888;
}

dt.ac:after {
padding: 0 0 0 0;
   content: "";
   position: absolute;
   border-left: 2px solid #000;
   border-top: 2px solid #000;
   border-right: 0;
   border-bottom: 0;
   width: 10px;
   right: 10px;
   height: 10px;
   transform: rotate(45deg);
   z-index: 888;
}
*/


.timetable-tit-num-t {
    box-sizing: border-box;
    text-align: center;
    display: inline-block;
    _display: inline;
    color: #fff;
    width: 15%;
    font-size: 14px;
    padding: 3px;
    background-color: #11125b;
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
    /* add */
    height: 64px;
    vertical-align: middle;
    font-weight: bold;
}

.timetable-tit-goto-t {
    box-sizing: border-box;
    display: inline-block;
    color: #fff;
    width: 40%;
    font-size: 14px;
    padding: 3px;
    background-color: #11125b;
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
}

.timetable-tit-detail-t {
    box-sizing: border-box;
    display: inline-block;
    color: #fff;
    /*width: 45%;*/
    width: 85%;
    font-size: 14px;
    padding: 3px;
    background-color: #11125b;
    border-bottom: 3px solid #fff;
    /* add */
    height: 64px;
    vertical-align: middle;
}

    .timetable-tit-detail-t span:first-child {
        display: block;
        font-weight: bold;
    }

.timetable-tit-num {
    box-sizing: border-box;
    display: flex;
    width: 15%;
    font-size: 14px;
    line-height: 18px;
    padding: 8px 3px;
    background-color: #dadce8;
    text-align: center;
    align-items: center;
    justify-content: center;
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
}

.timetable-tit-goto {
    box-sizing: border-box;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 40%;
    font-size: 14px;
    line-height: 18px;
    padding: 8px 3px;
    background-color: #dadce8;
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
    text-align: left;
}

.timetable-tit-detail {
    box-sizing: border-box;
    /*display: flex;*/
    justify-content: left;
    align-items: center;
    background: url("../images/pic-arrow.png") 0 0 no-repeat;
    background-position: right 2% top 50%;
    background-size: 15px auto;
    /*width: 45%;*/
    width: 85%;
    text-align: left;
    font-size: 14px;
    line-height: 18px;
    padding: 8px 15px 8px 3px;
    background-color: #dadce8;
    border-bottom: 3px solid #fff;
    -webkit-transition: all .2s ease 0s;
    transition: all .2s ease 0s;
}



    .timetable-tit-detail span:first-child {
        display: block;
        font-weight: bold;
    }

    .timetable-tit-detail span:last-child {
        display: block;
        padding-left: 16px;
    }

.timetable-tit-detail-active {
    background-image: url("../images/pic-arrow-u.png") !important;
}


.timetable-tit-num2 {
    box-sizing: border-box;
    display: flex;
    width: 15%;
    font-size: 14px;
    line-height: 18px;
    padding: 8px 3px;
    background-color: #ecedf2;
    text-align: center;
    align-items: center;
    justify-content: center;
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
}

.timetable-tit-goto2 {
    box-sizing: border-box;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 40%;
    font-size: 14px;
    line-height: 18px;
    padding: 8px 3px;
    background-color: #ecedf2;
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
    text-align: left;
}

.timetable-tit-detail2 {
    box-sizing: border-box;
    /*display: flex;*/
    justify-content: left;
    align-items: center;
    background: url("../images/pic-arrow.png") 0 0 no-repeat;
    background-position: right 2% top 50%;
    background-size: 15px auto;
    /*width: 45%;*/
    width: 85%;
    text-align: left;
    font-size: 14px;
    line-height: 18px;
    vertical-align: middle;
    padding: 8px 15px 8px 3px;
    background-color: #ecedf2;
    border-bottom: 3px solid #fff;
}



    .timetable-tit-detail2 span:first-child {
        display: block;
        font-weight: bold;
    }

    .timetable-tit-detail2 span:last-child {
        display: block;
        padding-left: 16px;
    }

.bus-subtit {
    font-weight: bold;
    font-size: 16px;
    padding: 0;
    margin: 15px 0 0 0;
}


.aorrowimg {
    width: 15px;
    text-align: right;
}





.detailtable_text {
    font-size: 14px;
    text-align: left;
    width: 85%;
    margin-left: auto;
    padding: 0 0 0 3px;
}


.detailtable_wrap {
    width: 85%;
    margin-left: auto;
    padding: 0;
}

@media screen and (max-width: 979px) {
    .detailtable_text {
        width: 100%;
        padding: 0;
        font-size: 12px;
    }

    .detailtable_wrap {
        width: 100%;
    }
}

.detailtable {
    box-sizing: border-box;
    width: 100%;
    background-color: #dadce8;
    border: none;
    margin: 0;
    padding: 0;
}

.hourtimetit {
    width: 20%;
    box-sizing: border-box;
    white-space: nowrap;
    background-color: #11125b;
    /*border: solid #fff 3px;*/
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
    vertical-align: middle;
    color: #fff;
    text-align: center;
    font-size: 14px;
    margin: 2px;
    padding: 5px;
}

@media screen and (max-width: 979px) {
    .detailtable {
        margin-bottom: 1em;
    }

    .hourtimetit {
        width: 15%;
    }
}

.mintimetit {
    background-color: #11125b;
    /*border: solid #fff 3px;*/
    border-bottom: 3px solid #fff;
    vertical-align: middle;
    color: #fff;
    text-align: center;
    font-size: 14px;
    margin: 2px;
    padding: 5px 3px;
}

.nospace {
    width: 15%;
    background-color: #fff;
    border: solid #FFFFFF 3px;
    vertical-align: middle;
    text-align: center;
    font-size: 14px;
    margin: 2px;
    padding: 3px;
}

.hourtime {
    width: 10%;
    /*border: solid #FFFFFF 3px;*/
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
    vertical-align: middle;
    text-align: center;
    font-size: 14px;
    font-weight: bold;
    margin: 2px;
    padding: 3px;
}

.mintime {
    width: 90%;
    /*border: solid #FFFFFF 3px;*/
    border-bottom: 3px solid #fff;
    vertical-align: middle;
    text-align: left;
    font-size: 14px;
    margin: 2px;
    padding: 5px 3px 5px 5px;
}


.minwrap {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 10px;
}

.mintxt {
    width: auto;
}

    .mintxt span {
        font-weight: bold;
    }

.minimg {
    width: auto;
}

@media screen and (max-width: 979px) {
    .mintxt {
        font-size: 14px;
    }
}





.btm_aritime {
    vertical-align: middle;
    padding: 5px;
    float: right;
    right: 0;
}

.timenumber {
    display: inline-block;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #11125b;
    text-align: center;
    line-height: 24px;
    color: #fff;
    font-size: 14px;
}



/*　modal setting ------------------------------------------- */

#scroll_box {
    position: relative;
    width: 245px;
    height: 470px;
    background-color: ebedf2;
    margin-bottom: 30px;
    overflow-y: scroll;
    border: 0px solid #fff;
}

#c-switch-btn {
    text-align: right;
    background-color: fff;
    width: 100%;
}

.modal-wrapper {
    z-index: 999;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    padding: 60px 10px;
    text-align: center
}

    .modal-wrapper:not(:target) {
        opacity: 0;
        visibility: hidden;
        transition: opacity .3s, visibility .3s;
    }

    .modal-wrapper:target {
        opacity: 1;
        visibility: visible;
        transition: opacity .4s, visibility .4s;
    }

    .modal-wrapper::after {
        display: inline-block;
        height: 100%;
        margin-left: -.05em;
        vertical-align: middle;
        content: ""
    }

    .modal-wrapper .modal-window {
        box-sizing: border-box;
        display: inline-block;
        z-index: 20;
        position: relative;
        width: 400px;
        max-width: 600px;
        padding: 30px 30px 15px;
        border-radius: 2px;
        background: #fff;
        box-shadow: 0 0 30px rgba(0, 0, 0, .6);
        vertical-align: middle
    }

        .modal-wrapper .modal-window .modal-content {
            max-height: 80vh;
            overflow-y: auto;
        }

.modal-overlay {
    z-index: 10;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: rgba(0, 0, 0, .8)
}

.modal-wrapper .modal-close {
    z-index: 20;
    position: absolute;
    top: 0;
    right: 0;
    width: 35px;
    color: #95979c !important;
    font-size: 20px;
    font-weight: 700;
    line-height: 35px;
    text-align: center;
    text-decoration: none;
    text-indent: 0
}

    .modal-wrapper .modal-close:hover {
        color: #2b2e38 !important
    }


@media screen and (max-width: 979px) {
    .modal-wrapper .modal-window {
        box-sizing: border-box;
        display: inline-block;
        z-index: 20;
        position: relative;
        width: 90%;
        max-width: 600px;
        padding: 30px 30px 15px;
        border-radius: 2px;
        background: #fff;
        box-shadow: 0 0 30px rgba(0, 0, 0, .6);
        vertical-align: middle
    }
}

/* set form ======================================================  */

/* display none */
@media screen and (max-width: 979px) {
    .fix-header {
        display: none
    }

    #pagegotop {
        display: none
    }
    /*.c-head-menu {display:none}*/


    .c_how_img {
        display: inline-block;
        vertical-align: top;
        width: 35px;
        margin: 0;
        margin: 0 0 0 5px;
        cursor: pointer;
    }
}
.c_how_img2 {
    display: none;
}
#btnHowtoCar {
    display: inline-block;
    width: 36px;
    margin-left: 8px;
}
@media screen and (min-width: 980px) {
    .c_how_img {
        display: inline-block;
        width: 100%;
    }

    

    #btnHowto {
        display: block;
        float: right;
        width: 35px;
        margin-top: -4px;
    }

    #btnHowtoCar {
        display: inline-block;
        width: 36px;
        margin-left: 8px;
    }
}
    /*�@layout(pc)  ------------------------------------------- */

    /*�@menu(pc)  ------------------------------------------- */

    .ic_earth {
        background: url("../images/ic_earth.png") 0 0 no-repeat;
        background-size: 18px auto;
        padding: 5px 0 0 -60;
        margin: 0 0 0 0;
    }



    /*�@table work(pc)  ------------------------------------------- */
    table {
        width: 100%;
        margin-bottom: 1em;
        /*border-top: 3px solid #fff;
    border-left: 3px solid #fff;*/
    }

    th {
        box-sizing: border-box;
        white-space: nowrap;
        padding: 8px 5px;
        font-weight: normal;
        text-align: center;
        color: #FFF;
        background-color: #11125b;
        vertical-align: middle;
        /*border-bottom: 3px solid #fff;
    border-right: 3px solid #fff;*/
    }

    td {
        box-sizing: border-box;
        padding: 8px 5px;
        /*border-bottom: 3px solid #fff;*/
        /*border-right: 3px solid #fff;*/
        text-align: center;
        vertical-align: middle;
        font-size: 14px;
        line-height: 1;
        color: #1f1f1f;
        font-weight: normal;
    }

    .odd {
        background-color: #dadce8;
    }

    .even {
        background-color: #ecedf2;
    }



    /*table styles for timetable*/
    .timetable_mono {
        border-left: none !important;
    }

        .timetable_mono thead tr th:nth-child(1) {
            width: 35%;
        }

        .timetable_mono thead tr th:nth-child(2) {
            width: 65%;
        }

    @media screen and (max-width: 979px) {
        .timetable_mono thead tr th:nth-child(1) {
            width: 16%;
        }

        .timetable_mono thead tr th:nth-child(2) {
            width: 84%;
        }
    }

    .timetable_mono tbody tr td.hourtime {
        font-weight: bold;
    }

    .timetable_txt_box {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-around;
        align-items: center;
    }

        .timetable_txt_box .timetable_txt {
            width: 50%;
            /*display: flex;*/
            flex-wrap: wrap;
            justify-content: center;
            align-items: center;
        }

            .timetable_txt_box .timetable_txt span {
                display: inline-block;
                padding: 0 20px;
                font-weight: bold;
            }

    @media screen and (max-width: 979px) {
        .timetable_txt_box .timetable_txt span {
            padding: 0 .8em;
        }
    }

    .timetable_btn_arv {
        display: inline-block;
        padding: 4px 8px;
        border-radius: 5px;
        background: #07185c;
        color: #fff !important;
        font-size: 11px;
        min-width: 65px;
        text-align: center;
    }

        .timetable_btn_arv::before {
            content: "＞";
            margin-right: 2px;
            font-size: 11px;
            color: #fff !important;
        }

    .timetable_btn_rld {
        box-sizing: border-box;
        display: inline-block;
        line-height: 1;
        padding: 6px 6px 6px 22px;
        border-radius: 3px;
        color: #fff !important;
        font-size: 10px;
        min-width: 50px;
        text-align: center;
        vertical-align: 1.8px;
        background: #00bff2 url("../images/ico-reload.png") 6px center no-repeat;
        background-size: 12px 12px;
        /*display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;*/
    }

        .timetable_btn_rld img {
            width: 12px;
            height: auto;
            margin-right: 5px;
        }

    /*�@js setting (pc)  ------------------------------------------- */







    .fix-header {
        background-color: #fff;
        line-height: 50px;
        top: -50px;
        left: 0;
        text-align: center;
        width: 100%;
        margin: 0 auto;
        color: #06175b;
        padding-top: 15px;
        position: fixed;
        opacity: 0;
        z-index: 1000;
    }

    .fix-header-contents {
        width: 960px;
        margin: 0 auto;
    }

    .fix-header ul {
        list-style-type: none;
    }

    .fix-header li {
        float: left;
        margin-right: 32px;
    }

        .fix-header li a, .fix-header li a:visited {
            color: #07185c;
            font-weight: bold;
            font-size: 14px;
            text-decoration: none;
        }

        .fix-header li:last-child {
            margin-right: 0;
        }

    #fix-header-logo {
        float: left;
    }

        #fix-header-logo img {
            width: 300px;
        }

    #fix-header-menus {
        float: right;
        text-align: right;
    }

    #scroll-fix-menu img {
        padding-bottom: 5px;
        border-bottom: 2px solid #fff;
    }

    #scroll-fix-menu .current-menu-item img {
        border-bottom: 2px solid #06175b;
    }

    #scroll-fix-menu a img:hover {
        border-bottom: 2px solid #06175b;
        transition: border-color 0.6s ease-out;
    }

    /* micro clearfx */
    .cf:before, .cf:after {
        content: "";
        display: table
    }

    .cf:after {
        clear: both
    }

    .cf {
        zoom: 1
    }
    /* For IE 6/7 */












    /* up to top bottom */
    /*
#pagegotop {
    position: fixed;
    bottom: 10px;
    right: 10px;
  z-index: 999;
}
 
#pagegotop a {
    display: block;
    color: #fff;
    width: 100px;
    padding: 0;
    text-align: center;
}
 
#pagegotop a:hover {
    text-decoration: none;
}
*/
    #pagegotop {
        position: fixed;
        bottom: 10px;
        right: 10px;
        z-index: 999;
    }

        #pagegotop a {
            display: block;
            color: #fff;
            width: 60px;
            padding: 0;
            text-align: center;
        }

            #pagegotop a:hover {
                text-decoration: none;
            }

    @media screen and (max-width: 979px) {
        #pagegotop {
            display: none
        }
    }

    img.gotoimg {
        width: 50px;
        height: 50px;
    }

    @media screen and (max-width: 979px) {
        #pagegotop {
            display: none
        }
    }






    .bustxtlink {
        border-bottom: solid #000 1px;
    }


    /*�@Helpfulmap (pc)  ------------------------------------------- */

    .step1size {
        text-align: left;
        width: 100%;
        height: 40px;
        margin: 0 0 0 0;
        padding: 0;
    }

    .step1size2 {
        text-align: left;
        width: 100%;
        margin: 0 0 0 0;
        padding: 0;
    }

    .step1size3 {
        text-align: center;
        width: 369px;
        margin: 0 0 0 0;
        padding: 0;
    }

    .step1size4 {
        text-align: left;
        width: 100%;
        margin: 0 0 0 0;
        padding: 0;
    }

    @media screen and (min-width: 980px) {
        .step1size4 {
            width: calc(100% - 40px);
        }
    }

    .inline-block_help1 {
        width: 365px;
        text-align: left;
        display: inline-block;
        vertical-align: top;
        padding: 0;
        margin: 0;
    }

    .inline-block_help2 {
        width: 255px;
        display: inline-block;
        vertical-align: top;
        padding: 0;
        margin: 0;
    }


    .step1switch_img {
        vertical-align: top;
        width: 210px;
        height: 35px;
        margin: 0;
        margin: 0 0 0 5px;
    }

    .c_loc_img {
        display: inline-block;
        vertical-align: top;
        width: 35px;
        margin: 0;
        margin: 0 0 0 5px;
        cursor: pointer;
    }


    .noriba_btm {
        display: inline-block;
        background-color: #c7c7c7;
        align-items: center;
        justify-content: center;
        vertical-align: center;
        text-align: center;
        border: solid #fff 1px;
        font-size: 10px;
        color: #000;
        height: 20px;
        border-radius: 20px;
        padding: 0 20px 10px 20px;
        margin: 0 0 0 0;
        line-height: 2.0;
    }

        .noriba_btm a {
            color: #000;
        }

            .noriba_btm a:hover {
                color: #000;
                opacity: 0.5;
            }





    .helpfulmap_btm {
        display: flex;
        justify-content: center;
    }

        .helpfulmap_btm li {
            display: block;
            background: url("../images/helpfulmap_btm_off.png");
            background-size: 120px;
            width: 120px;
            height: 35px;
            margin: 0 3px 0 0;
            overflow: hidden;
            text-align: center;
            color: #fff;
            font-size: 12px;
            line-height: 3;
        }

            .helpfulmap_btm li a {
                width: 120px;
                height: 35px;
                display: block;
                color: #fff;
                font-size: 12px;
            }

                .helpfulmap_btm li a:hover {
                    background: url("../images/helpfulmap_btm_on.png");
                    background-size: 120px;
                    height: 35px;
                    background-position: bottom;
                    color: #fff;
                    font-size: 12px;
                    opacity: 1;
                }

    .helpfulmap_btm_on {
        background: url("../images/helpfulmap_btm_on.png");
        background-size: 120px;
        height: 35px;
        background-position: bottom;
    }


    .switchimg {
        display: inline-block;
        width: 210px;
        height: 35px;
        margin: 0;
        padding: 0;
        cursor: pointer;
    }







    .img-area {
        widows: 265px;
        margin: 0;
        padding: 0;
    }

    .alarttxt {
        color: #fff;
        font-size: 20px;
        font-weight: bold;
        padding: 10px 5px;
    }

    .alarttxtlink {
        border-bottom: solid #FFFFFF 1px;
    }

    @media screen and (max-width: 979px) {
        .alarttxt {
            font-size: 16px;
            padding: 4px;
        }
    }


    /*�@table setting(sp)  ------------------------------------------------------------ */

    .all-table-wrap {
        padding: 0;
        text-align: left;
        width: 100%;
    }

    .timetable_tit_warp {
        text-align: center;
        width: 100%;
    }

    @media screen and (max-width: 979px) {

        .all-table-wrap {
            padding: 0 10px;
        }

        .timetable_tit_warp dl dt {
            position: static;
            z-index: 1;
        }
    }

    .bus_wrap {
        /*z-index: 10;*/
        display: -webkit-box; /*Android4.3*/
        display: -moz-box; /*Firefox21*/
        display: -ms-flexbox; /*IE10*/
        display: -webkit-flex; /*PC-Safari,iOS8.4*/
        display: flex;
        justify-content: center;
    }

        .bus_wrap:hover {
            cursor: pointer;
        }
















    @media screen and (max-width: 979px) {
        /*�@layout(sp)  ------------------------------------------------------------ */

        .step1size {
            text-align: center;
            width: 100%;
            height: auto; /*rev*/
            margin: 0 0 0 0;
            padding: 0;
            position: relative;
        }

        .step1size2 {
            text-align: left;
            width: 100%;
            margin: 0 0 0 0;
            padding: 0;
        }

        .step1size3 {
            text-align: center;
            width: 100%;
            /*margin: -30px 0 0 0;*/
            margin: 0;
            padding: 0;
            position: relative;
            background: #fff;
        }

        .step1size4 {
            text-align: left;
            width: 100%;
            /* margin: 0 0 50px 10px; */
            padding: 10px 0 10px 10px;
            /* padding: 0; */
            box-sizing: border-box;
        }


        .inline-block_help1 {
            width: 96%;
            text-align: center;
            display: inline-block;
            vertical-align: top;
            padding: 0;
            margin: 0;
            margin-top: 50px; /*add*/
        }

        .inline-block_help2 {
            width: 97%;
            /*display: flex;*/
            display: block;
            justify-content: flex-end;
            vertical-align: top;
            padding: 0 0 0 0;
            margin-right: auto 10px;
            /*margin-top: 40px;*/
            margin-top: 0;
            position: absolute;
            top: 0;
        }


        .step1switch_img {
            vertical-align: top;
            width: 210px;
            height: 35px;
            margin: 0;
            margin: 0 0 0 5px;
        }

        .c_loc_img {
            display: inline-block;
            vertical-align: top;
            width: 35px;
            margin: 0;
            margin: 0 0 0 5px;
        }


        .noriba_btm {
            display: inline-block;
            background-color: #c7c7c7;
            align-items: center;
            justify-content: center;
            vertical-align: center;
            text-align: center;
            border: solid #fff 1px;
            font-size: 10px;
            color: #000;
            height: 20px;
            border-radius: 20px;
            padding: 0 20px 10px 20px;
            margin: 0 0 0 0;
            line-height: 2.0;
        }

            .noriba_btm a {
                color: #000;
            }

                .noriba_btm a:hover {
                    color: #000;
                    opacity: 0.5;
                }





        .helpfulmap_btm {
            display: flex;
            justify-content: center;
        }

            .helpfulmap_btm li {
                display: block;
                background: url("../images/helpfulmap_btm_off.png");
                background-size: 100%;
                width: 100%;
                height: 35px;
                margin: 0 3px 0 0;
                overflow: hidden;
                text-align: center;
                color: #fff;
                font-size: 12px;
                line-height: 3;
            }

                .helpfulmap_btm li a {
                    width: 100%;
                    height: 35px;
                    display: block;
                    color: #fff;
                    font-size: 12px;
                }

                    .helpfulmap_btm li a:hover {
                        background: url("../images/helpfulmap_btm_on.png");
                        width: 100%;
                        background-size: 100%;
                        height: 35px;
                        background-position: bottom;
                        color: #fff;
                        font-size: 12px;
                        opacity: 1;
                    }

        .helpfulmap_btm_on {
            background: url("../images/helpfulmap_btm_on.png");
            background-size: 100%;
            width: 100%;
            height: 35px;
        }





        .switchimg {
            display: inline-block;
            width: 210px;
            height: 35px;
            margin: 0;
            padding: 0;
        }


        .img-area {
            widows: 100%;
            margin: 0;
            padding: 0;
        }
    }






    /*
    add
*/

    .rsnpth {
        vertical-align: middle;
        display: block !important;
    }

        .rsnpth span {
            display: table-cell;
            vertical-align: top;
            min-width: 20px;
        }

    .cmbinepath {
        margin-top: -9px;
    }

    .rsn_m {
        width: 20px;
        height: 20px;
        display: inline-block;
        border-radius: 50%;
        border: 4px solid #06175b;
        vertical-align: middle;
    }

    .rsn_frto {
        vertical-align: middle;
        display: inline-block;
        line-height: 1;
        padding-left: 4px;
    }

    .rsnpth_r {
        display: block;
        margin: 0 4px;
    }

    .rsn_nm {
        display: block;
        line-height: 1;
    }

    .rsn_ji {
        display: block;
    }

    .rsnpth_r .rsn_l {
        display: table-cell;
        width: 6px;
        height: 100%;
        background: #06175b;
        min-width: 6px;
    }

    .rsnpth_r .rsn_sps {
        display: table-cell;
        width: 3px;
        height: 100%;
    }

    .rsnpth_r .rsn_rsn {
        display: table-cell;
        padding: 8px;
    }

    .rsnpth_e {
        margin-bottom: 6px;
        display: block !important;
        margin-top: -10px;
    }

        .rsnpth_e span {
            display: table-cell;
            vertical-align: top;
            min-width: 20px;
        }

        .rsnpth_e .rsn_frto {
            vertical-align: bottom;
        }

    .tinfo_search {
        text-align: center;
        display: block;
        background: #eb008b;
        color: #ffffff !important;
        cursor: pointer;
        padding: 4px 0;
        margin: 8px 38px 8px 8px;
        border-radius: 8px;
        font-size: 1.2rem;
        font-weight: bold;
        width: 100%;
    }

    .alert-sml {
        color: red;
        font-weight: bold;
        font-size: 0.8em;
        text-align: left !important;
    }

    .c-map-cont-wrap {
        background: #fff;
    }

    .norikaedd {
        font-size: 0.9em;
        margin-top: -4px;
        display: block !important;
    }


    @media (max-width: 979px) {
        .c-table.c-table--ship tr:nth-child(2n) td:nth-child(1) {
            width: 22%;
            /*background-color: #ffcccc;*/
        }

        .c-table.c-table--ship .u-embg {
            background-color: #06175b !important;
            color: #fff;
            text-align: left;
            font-size: 0.9rem;
            padding: 4px;
        }

        .c-tt-tit {
            display: block;
            font-size: 2.0rem;
            font-weight: bold;
            letter-spacing: 2px;
            color: #06175b;
            text-align: left;
            line-height: 1;
            padding: 10px;
            padding-left: 50px;
            margin-bottom: 15px;
            background-color: #ecedf2;
            position: relative;
            background-position: 10px 5px;
            background-repeat: no-repeat;
            background-color: #ecedf2;
            cursor: pointer;
        }

        .c-tt-jr .c-tt-tit {
            background-image: url("../images/ico-train.png");
        }

        .c-tt-nankai .c-tt-tit {
            background-image: url("../images/ico-train.png");
        }

        .c-tt-bus .c-tt-tit {
            background-image: url("../images/ico-bus.png");
        }

        .c-tt-ship .c-tt-tit {
            background-image: url("../images/ico-ship.png");
        }

        .c-tt-bridge .c-tt-tit {
            background-image: url("../images/ico-bridge.png");
        }

        .c-tt-monorail .c-tt-tit {
            background-image: url("../images/ico-train.png");
        }

        .c-tt-limousinebus .c-tt-tit {
            background-image: url("../images/ico-bus.png");
        }

        .c-tt-longdistance .c-tt-tit {
            background-image: url("../images/ico-bus.png");
        }

        .c-tt-shortdistance .c-tt-tit {
            background-image: url("../images/ico-bus.png");
        }

        .c-tt-tit-transinfo {
            display: block;
            font-size: 2.0rem;
            font-weight: bold;
            letter-spacing: 2px;
            color: #06175b;
            text-align: left;
            line-height: 1;
            padding: 5px;
            padding-left: 30%;
            margin-bottom: 1px;
            position: relative;
            background-position: 10px 5px;
            background-repeat: no-repeat;
            cursor: pointer;
        }

        .c-tt-trans-monorail .c-tt-tit-transinfo {
            background-image: url("../images/ico-train.png");
            background-position: 20%;
        }

        .c-tt-trans-limousinebus .c-tt-tit-transinfo {
            background-image: url("../images/ico-bus.png");
            background-position: 20%;
        }

        .c-tt-trans-longdistance .c-tt-tit-transinfo {
            background-image: url("../images/ico-bus.png");
            background-position: 20%;
        }

        .c-tt-trans-shortdistance .c-tt-tit-transinfo {
            background-image: url("../images/ico-bus.png");
            background-position: 20%;
        }

        .c-tt__cont {
            display: none;
            margin: 15px auto;
        }

            .c-tt__cont .c-table {
                font-size: 1.2rem;
                line-height: 1.2;
            }

        .menu {
            display: table;
            width: 100%;
            background-color: #dadce8;
            border-bottom: 1px solid #ffffff;
            color: black;
            height: 25px;
            text-align: left;
        }

            .menu:hover {
                background-color: #dadce8;
                opacity: 0.7;
            }

            .menu div {
                display: table-cell;
                vertical-align: middle;
                cursor: pointer;
            }

            .menu:active {
                background-color: rgb(177, 248, 255);
            }

        .titlecircle {
            padding-left: 6px;
        }

        .titletxt {
            padding: 8px 0;
            padding-left: 16px;
            line-height: 18px;
            width: 86%;
            /*height:25px;*/
            text-align: left;
            font-size: 1.2rem;
        }

        .Arrow {
            height: 25px;
            width: 25px;
            right: 0;
        }

            .Arrow img {
                height: 25px;
                width: 25px;
            }

        .txtcircledigit {
            display: inline-block;
            width: 15px;
            height: 15px;
            text-align: center;
            line-height: 15px;
            font-size: 1.1rem;
            font-weight: bold;
            border-radius: 50%;
            background: #06175b;
            vertical-align: middle;
            color: #FFF;
        }
    }


    @media (max-width: 979px) {
        /* ---- 運行情報  -----------------------------*/
        .c-transinfo-wrap {
            padding: 4px 15px;
        }

            .c-transinfo-wrap .u-note {
                text-align: right;
                font-size: 1.1rem;
            }

            .c-transinfo-wrap .u-note-itami {
                text-align: center;
                font-size: 1.3rem;
                text-decoration: underline
            }

        .c-transinfo-ul {
            display: flex;
            justify-content: space-between;
            flex-wrap: wrap;
        }

            .c-transinfo-ul li {
                width: 49%;
                flex-basis: 49%;
                margin-bottom: 10px;
            }

                .c-transinfo-ul li:last-child {
                    margin-bottom: 0;
                }

        .c-transinfo-label {
            position: relative;
            width: 100%;
        }

            .c-transinfo-label a {
                display: block;
            }

        .c-transinfo-btn {
            background: url("../images/label-bl-bg.jpg") 0 0 no-repeat;
            background-size: 100%;
            display: flex;
            align-items: center;
        }

            .c-transinfo-btn::before {
                content: "";
                display: block;
                padding-top: 36.7816%;
            }

            .c-transinfo-btn.is-alert {
                background-image: url("../images/label-pk-bg.jpg");
            }

            .c-transinfo-btn .u-tit {
                font-weight: bold;
                font-size: 1.7rem;
                line-height: 1.1;
                display: table-cell;
                text-align: left;
                padding-left: 12px;
                width: 50%;
                height: auto;
                color: #fff;
            }
    }

    .n_comps {
        text-align: center;
    }

        .n_comps li {
            display: inline-block;
            margin-left: 6px;
        }

            .n_comps li a {
                text-decoration: underline !important;
                display: inline-block;
                font-size: 0.9em;
            }

    .n_bimg {
        text-align: center;
    }

        .n_bimg a {
            text-decoration: underline !important;
            font-size: 0.9em;
        }

    /**
    add
*/
    .bt-tt-reload {
        display: block;
        background: #00bff2;
        vertical-align: middle;
        padding: 0px 4px;
        border-radius: 4px;
    }

        .bt-tt-reload img {
            display: inline-block;
            vertical-align: middle;
            width: 24px;
            height: 24px;
        }

        .bt-tt-reload span {
            vertical-align: middle;
            display: inline-block;
            color: #fff;
            font-size: 12px;
        }

        .bt-tt-reload:hover {
            opacity: 0.8;
        }



    .sb_dtl a {
        width: 160px;
        line-height: 1.2;
        overflow-wrap: anywhere;
    }


@charset "UTF-8";

.txt-r{
    text-align:right !important;
}

.i-alrt{
    background-color:#c80074;
}
.alert-sml {
    color: red;
    font-weight: bold;
    font-size: 0.8em !important;
}
input[type="text"][disabled] {
    color: #000;
    cursor: default;
}

/***
    modal dialog
*/

.mdlg {
    max-width:800px !important;
}

.mdlg h2{
    margin: 16px;
    display: block;
    font-size: 1.8rem;
    font-weight: bold;
    vertical-align: middle;
    color: #06175b;
    text-align: center;
}
    .mdlg h2 span{
        line-height: 1.4;
        vertical-align: middle;
        padding-left: 60px;
        padding-top: 4px;
        background: url(../images/ico_h2.png) 0 0px no-repeat;
        background-size: 45px 36px;
        height: 45px;
        display: inline-block;
    }


/***
    Helpful Map  
*/
iframe.hmapf{
    width: 627px;
    height:324px;
    overflow:hidden;
}

.tinfo_close{
    text-align: center;
    display: block;
    background: #07185c;
    color: #ffffff;
    cursor: pointer;
    padding: 4px 0;
    margin: 8px;
    border-radius: 8px;
    font-size: 1.2rem;
    font-weight: bold;
    width:100%;
}

/**
    Route Info
*/

.routettl{
    text-align: center;
    font-weight: bold;
    color: #06175b;
    font-size: 1.6rem;
    margin-bottom: 16px;
}
.ri_sttl{
    margin-right: 16px;
}
.routeart{
    font-weight: bold;
    color: #eb008b;
}
.ddrttl{
    background: #3049A7;
    margin: 8px 0 !important;
    padding: 4px 8px !important;
    color: #fff;
}
.ddrttl span{
    color:#ffffff;
}
.rdtldd {
    color:#3049A7;
}
/**
    diagram
*/
.tb_bus_noriba{
    text-decoration: underline !important;
    color: #ea008a !important;
}

.c-table .u-tokkyu td{
    color:#00abd9;
    font-weight:bold;
}
.c-table .u-em td {
    color: #ea008a;
}
.txtr{
    text-align:right !important;
}
.keiyudiv{
    position: absolute;
    margin-top: 8px;
    display: inline;
    padding: 16px;
    display:none;
    background: #06175b;
    color: #fff;
    border-radius: 8px;
    box-shadow: 2px 2px 4px grey;
    text-align:left;
    margin-left: 8px;
    z-index: 300;
}
.rt {
    margin-left: -160px;
}
.keiyudiv ul li{
    width:100%;
    margin-left: 8px;
    display: table-row;
}
.keiyudiv ul li span{
    display:inline-block;
}
.keiyudiv ul li span:nth-child(2){
    float:right;

}
.keiyudiv ul li::after{
    content:" ";
    clear:both;
}
.keiyudiv .cls{
    cursor: pointer;
    font-weight: bold;
    float: right;
    position: absolute;
    right: 0;
    top: 0;
    padding: 3px;
    color: #fff;
}
.nwp{
    white-space: nowrap;
}
.c-table td a {
    color: #000;
    font-size: 14px;
}
.c-table .u-em td a {
    color: #ea008a;
}
.c-table .u-tokkyu td a{
    color: #00abd9;
    font-weight: bold;
}
@media only screen and (max-width: 979px) {
    .kul {
        right: 0;
        text-align: center;
        left: 0;
    }
    .kul li span:nth-child(2){
        margin-left:8px;
    }
    .kul span.khd {
        display: block;
        font-weight: bold;
        background: #07185c;
        padding: 8px 0;
        color: #fff;
        margin-bottom:4px;
    }
    .kul li::after {
        content: " | ";
    clear: both;
    display: block;
    line-height: 0.4;
    padding: 0;
    margin: 0;
    font-weight: bold;
    color: #07185c;
    }
        .kul li:last-child::after {
            content: " ";
            clear: both;
            display: block;
        }

        .kul li span:first-child {
            padding: 4px;
            border: 2px solid #fff;
            border-radius: 8px 0 0 8px;
            background: #007291;
            color: #fff;
            font-size:0.9rem;
        }
    .kul li span:last-child{
        padding: 4px;
        border: 2px solid #fff;
        border-radius: 0 8px 8px 0;
        background: #fff;
        margin-left: -2px;
        font-size:0.9rem;
        font-weight:bold;
    }
}


/**
    ferry timetable 
    message 

*/

.fmsg{
    font-size: 0.9em;
    text-align: left;
    line-height: 1.8;
    padding: 10px;
}

.to_durl{
    text-decoration:underline !important;
}

@media only screen and (max-width: 979px) {
    /***
        modal dialog
    */
    .mdlg {
        max-width: none !important;
    }
    .mdlg h2{
        font-size:1.4rem;
    }
    .mdlg h2 span{
        padding-left: 30px;
        background-size: 24px 22px;
        height: 24px;
        padding-top: 0;
    }

    /***
    Helpful Map  
    */
    iframe.hmapf {
        width: 100%;
        height:324px;
    }

    /**
        route info
    */
    #routeinfo_sp{
        background-color: #f3f3f7;
        font-size: 1.4rem;
        text-align: left;
        padding: 10px;
        margin-top: 15px;
    }
    #routeinfo_sp dd{
        margin-bottom: 20px;
        margin-left: 1.4rem;
        line-height: 1.3;
        font-weight: bold;
    }
    #routeinfo_sp dt{
        /*background-color: #d6dae5;*/
        display: inline-block;
        font-weight: bold;
        padding: 0 2px;
    }


    /**
        noriba
    */

    .imgscrl{
        height: 300px;
        overflow-x: auto;
        overflow-y: hidden;
    }
    .imgscrl img{
        max-width: none;
        height: 100%;
    }


    .c-map-btn-ul:lang(en) li:nth-child(2) .c-map-btn{
        padding: 2px 2px;
    }

    .mdlg h2 span:lang(en){
        line-height:1;
    }

    #routeinfo_sp{
        max-height: 60%;
        overflow-y: auto;
    }

    .c-table--ship tr:nth-child(4n) td{
        background-color: #dadce8;
    }
}

/**
    PC
*/
@media (min-width: 980px) {

    .c-map3 {
        /*max-height: 306px;*/
        /*overflow: auto;*/
    }
    .c-map-btn-ul:lang(en) li:nth-child(2) .c-map-btn{
        line-height:1;
    }

    .c-table.c-table--nankai:lang(en) th:nth-child(2){
        width: 55%;
    }
    .c-table.c-table--jr:lang(en) td:nth-child(2){
        width: 55%;
    }
    .c-rootinfo-wrap{
        overflow-y: auto;
        max-height: 376px;
    }
}


/**
    warning
*/

.i-alrt_w2 {
    background-color: #c80074 !important;
    color: #fff;
    font-size: 14px;
    font-weight: bold;
    line-height: 1.4;
    padding: 12px;
    text-decoration: none;
}

    .i-alrt_w2 a {
        text-decoration: underline;
    }

.i-alrt_w .i-alrt_w {
    padding: 8px 0;
}

.u-inner2 {
    padding: 0;
    margin: 0 auto;
    margin-top: -2px;
}

.i-alrt-ic {
    background: url(../../../cmn/img/check.svg) 0 0 no-repeat !important;
    background-size: 30px !important;
}
.alert-msg{
    font-size:1.8rem;
    vertical-align: middle;
    font-weight:bold;
}

@media only screen and (max-width: 979px) {
    .i-alrt-ic {
        background-size: 26px !important;
    }
    .alert-msg{
        font-size:1.6rem;
    }
}

/*
    出発時刻表部分
*/

.u-tit{
    margin: 16px 0;
}
.child{
    padding:16px;
}
.c-table--monorail  thead tr th{
    padding:8px;
}
.c-table--monorail  thead tr td{
    padding:12px;
}

.c-table-detail thead tr th{
    padding:8px;
}
.c-table-detail tbody tr td {
    padding:12px;
}
.c-table-detail .tb_time{
    display:inline-block;
    margin-top:8px;
    font-size:14px;

}
.diagram_nooperation {
    padding: 8px 0;
    background: #eee;
}
.u-titsub-msg {
    font-weight: normal !important;
    text-align: center !important;
    display:none;
}
.c-table.c-table--bustablehd th span {
    display: block;
    padding: 4px;
    font-weight: bold;
    
}
    .c-table.c-table--bustablehd th span:first-child {
        font-size: 1.2em;
    }
.titletxt span{
    display:block;
}
.titletxt span:last-child {
    padding-left:16px;
}
    /**

*/
    .FromToInput:disabled {
    color: rgb(7, 24, 92);
}




@media only screen and (max-width: 979px) {
    .sb_dtl {
        left: 24px;
    }

        .sb_dtl a {
            width: 100%;
            line-height: 1.2;
            text-align: left;
        }
}


/**
    timetable style
*/

.tmlnk {
    text-decoration: underline !important;
    position: relative;
    display: inline-block;
    margin: 0 6px;
}

    .tmlnk:after {
        content: " ";
        display: inline-block;
        background-image: url(../images/ic_timetable.svg);
        background-repeat: no-repeat;
        background-size: 10px;
        width: 10px;
        height: 10px;
        position: absolute;
        top: -3px;
    }

/**
    howto
*/

/* 使い方ガイド */
.navdiv {
    z-index: 1000;
    border: #ff39ae 3px solid;
    position: absolute !important;
    display: none;
    border-radius: 10px;
}

.navno {
    z-index: 1001;
    border: #ff39ae 1px solid;
    background-color: #eb008b;
    position: absolute !important;
    display: none;
    border-radius: 50%;
    width: 38px;
    height: 38px;
    color: white;
    font-size: 10px;
    padding: 6px;
    text-align: center;
    line-height: 1;
}

    .navno .navnono {
        font-size: 18px;
    }

.navmessage {
    z-index: 1001 !important;
    border: #ff39ae 3px solid !important;
    background-color: #eb008b !important;
    position: absolute !important;
    display: none;
    border-radius: 10px !important;
    width: 300px !important;
    color: white !important;
    padding: 10px !important;
    font-size: 1.4rem !important;
}

    .navmessage .navmessagetitle {
        font-size: 2rem !important;
        margin-bottom: 10px !important;
        text-align: center;
    }

    .navmessage * {
        color: white !important;
        line-height:1.2;
    }

/*
    メッセージ最後
*/
.navmessage_2 {
    width:auto !important;

}
.navdiv_2 {
    border: none;
    background-image: url(../images/yajirushi.png);
    background-size: 30px 30px;
    background-repeat: no-repeat;
    background-position: 40px 10px;
    width: 100px !important;
}


#loadmask {
    width: 100%;
    height: 0;
    position: absolute;
    left: 0;
    top: 0;
}
.loadmask {
    z-index: 1003;
    position: fixed;
    top:0;
    left:0;
    -moz-opacity: 0.5;
    opacity: .70;
    filter: alpha(opacity=50);
    background-color: #CCC;
    width: 100%;
    height: 100%;
    zoom: 1;
}
.loadmask-msg {
    z-index: 1004;
    position: absolute;
    top: 0;
    left: 0;
    border:1px solid #5fcba9;
    background: #c3daf9;
    padding:2px;
}
.loadmask-msg div {
    padding:10px;
    background: #fbfbfb url('../../cmn/img/loading.png') no-repeat center;
    line-height: 20px;
	/*border:1px solid #5fcba9;*/
    color:#222;
    font:normal 11px tahoma, arial, helvetica, sans-serif;
    cursor:wait;
    width:120px;
    height:120px;
}
.masked {
    overflow: hidden !important;
}
.masked-relative {
    position: relative !important;
}
.masked-hidden {
    visibility: hidden !important;
}
