@charset "UTF-8";
.main {
  color: #1a1a1b;
  font-size: 1.4rem;
  line-height: 1.8;
  font-family: "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo UI", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  -webkit-text-size-adjust: none; }
  @media screen and (max-width: 767px) {
    .main {
      font-size: 1.4rem; } }
  @media screen and (max-width: 767px) {
    .main {
      font-size: 1.4rem; } }

.rwd-topic-path {
  font-family: "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "Meiryo UI", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: 1.6; }

.rwd-emergencyArea-wrap {
  font-family: "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "Meiryo UI", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; }

/* HEADING
/*+---------------------------------*/
/* --- heading-level2 --- */
.heading-level2 {
  margin-bottom: 40px;
  padding: 0 0 10px 8px;
  border-bottom: 1px solid #ccc;
  font-size: 2.8rem;
  color: #3d3f8a; }
  @media screen and (max-width: 767px) {
    .heading-level2 {
      margin-bottom: 25px;
      font-size: 2.0rem;
      line-height: 1.4;
      padding-bottom: 5px; } }

/* --- heading-level3 --- */
.heading-level3 {
  margin-bottom: 30px;
  padding: 0 0 15px 10px;
  font-size: 2.2rem;
  background-image: url(/railroad/train/assets/img/heading_level2_line.png);
  background-size: 5px auto;
  background-position: bottom left;
  background-repeat: repeat-x; }
  @media screen and (max-width: 767px) {
    .heading-level3 {
      margin-bottom: 20px;
      font-size: 1.8rem;
      line-height: 1.4; } }

/* --- heading-level4 --- */
.heading-level4 {
  margin-bottom: 20px;
  padding: 0 0 5px 10px;
  border-bottom: 1px solid #ccc;
  font-size: 2.0rem;
  color: #3d3f8a; }
  @media screen and (max-width: 767px) {
    .heading-level4 {
      font-size: 1.6rem;
      line-height: 1.4; } }

/* --- heading-level5 --- */
.heading-level5 {
  margin-bottom: 10px;
  font-size: 1.6rem;
  font-weight: bold; }
  .heading-level5 .heading-level5__sub-text {
    font-size: 1.4rem;
    font-weight: normal; }
  @media screen and (max-width: 767px) {
    .heading-level5 {
      font-size: 1.5rem;
      line-height: 1.5; } }

/* --- yellow-mark-heading --- */
.yellow-mark-heading-wrap {
  margin-bottom: 40px;
  text-align: center; }
  @media screen and (max-width: 767px) {
    .yellow-mark-heading-wrap {
      margin-bottom: 30px; } }

.yellow-mark-heading {
  display: inline-block;
  padding: 0 35px;
  background-image: url(/railroad/train/assets/img/yellow_heading_mark_left.png), url(/railroad/train/assets/img/yellow_heading_mark_right.png);
  background-repeat: no-repeat;
  background-position: left center, right center;
  background-size: 25px 40px, 25px 40px;
  color: #3d3f8a;
  font-weight: bold;
  font-size: 2.6rem; }
  .yellow-mark-heading br {
    display: none; }
  @media screen and (max-width: 767px) {
    .yellow-mark-heading {
      font-size: 2.0rem;
      line-height: 1.6; }
      .yellow-mark-heading br {
        display: inline; } }

/* BOX
/*+---------------------------------*/
/* --- content-wrap --- */
.content-wrap {
  box-sizing: border-box;
  margin: 0 auto 80px;
  padding: 0 10px;
  max-width: 1044px; }
  @media screen and (max-width: 767px) {
    .content-wrap {
      margin-bottom: 50px; } }

/* --- content-box --- */
.content-box {
  margin-bottom: 50px; }
  .content-box:last-child {
    margin-bottom: 0; }
  .content-box p + .attention-list {
    margin-top: 10px; }
  @media screen and (max-width: 767px) {
    .content-box {
      margin-bottom: 35px; } }

/* --- content-box-2 --- */
.content-box-2 {
  margin-top: 30px;
  margin-bottom: 30px; }

/* --- content-inner --- */
.content-inner {
  margin: 0 10px; }
  .content-inner p + p {
    margin-top: 10px; }

/* --- text-box --- */
.text-box {
  margin-bottom: 20px; }
  .text-box p {
    margin-bottom: 5px; }

/* --- two-column --- */
.two-column {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  margin-bottom: -30px; }
  .two-column > li {
    margin-right: 40px;
    margin-bottom: 30px;
    width: calc(50% - 20px); }
    .two-column > li:nth-child(2n) {
      margin-right: 0; }
  @media screen and (max-width: 767px) {
    .two-column {
      display: block;
      margin-bottom: 0; }
      .two-column > li {
        margin-right: 0;
        margin-bottom: 20px;
        width: 100%; }
      .two-column.is-no-change {
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        display: -webkit-box;
        margin-bottom: -20px; }
        .two-column.is-no-change > li {
          margin-right: 20px;
          width: calc(50% - 10px); }
          .two-column.is-no-change > li:nth-child(2n) {
            margin-right: 0; } }

/* --- three-column --- */
.three-column {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  margin-bottom: -30px; }
  .three-column > li {
    margin-right: 3.3864%;
    margin-bottom: 30px;
    width: 31.075%; }
    .three-column > li:nth-child(3n) {
      margin-right: 0; }
  .three-column + .three-column {
    margin-top: 30px; }
  @media screen and (max-width: 767px) {
    .three-column {
      margin-bottom: 0; }
      .three-column > li {
        margin-right: 8%;
        margin-bottom: 20px;
        width: 45.714%; }
        .three-column > li:nth-child(3n) {
          margin-right: 8%; }
        .three-column > li:nth-child(2n) {
          margin-right: 0; }
      .three-column + .three-column {
        margin-top: 20px; } }

/* --- thumbnail --- */
.thumbnail a .thumbnail__name {
  text-decoration: underline; }

.thumbnail a:hover .thumbnail__name {
  text-decoration: none; }

.thumbnail__image {
  margin-bottom: 15px; }
  .thumbnail__image img {
    max-width: 100%;
    height: auto; }
  @media screen and (max-width: 767px) {
    .thumbnail__image {
      margin-bottom: 10px; } }

.thumbnail__name {
  font-size: 1.6rem;
  font-weight: bold; }
  @media screen and (max-width: 767px) {
    .thumbnail__name {
      font-size: 1.4rem; } }

.thumbnail__section {
  margin-top: 15px; }
  @media screen and (max-width: 767px) {
    .thumbnail__section {
      margin-top: 10px; } }

.thumbnail__section {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  overflow: hidden; }
  .thumbnail__section dt {
    margin-right: 7px;
    width: 74px;
    height: 23px;
    background-image: url(/railroad/train/assets/img/icon_bg_section.png);
    background-repeat: no-repeat;
    background-size: 74px 23px;
    color: #fff;
    font-size: 1.3rem;
    text-indent: 5px; }
  .thumbnail__section dd {
    width: calc(100% - 81px);
    font-size: 1.3rem; }
  @media screen and (max-width: 767px) {
    .thumbnail__section {
      display: block; }
      .thumbnail__section dd {
        width: auto; } }

/* --- relational-info --- */
.relational-info {
  margin-top: 20px;
  padding: 15px;
  background-color: #f0f0f0; }

.relational-info__label {
  float: left; }

.relational-info__text a {
  margin-right: 10px;
  text-decoration: underline; }
  .relational-info__text a:hover {
    text-decoration: none; }
  .relational-info__text a + .rwd-icon-blank {
    margin-left: -5px; }

/* --- top-visual --- */
.top-visual {
  overflow: hidden; }
  .top-visual .top-visual__image {
    height: 600px;
    position: relative;
    pointer-events: none; }
    .top-visual .top-visual__image:before {
      box-sizing: border-box;
      display: block;
      content: '';
      width: 100%;
      height: 100%;
      position: absolute;
      top: 0;
      left: 0;
      background-image: url(/railroad/train/assets/img/top_visual.jpg);
      background-position: left top;
      background-repeat: repeat-x;
      background-size: auto 600px; }
  @media screen and (max-width: 767px) {
    .top-visual .top-visual__image {
      height: 260px; }
      .top-visual .top-visual__image .top-visual__image-inner li {
        background-image: url(/railroad/train/assets/img/top_visual.jpg); }
        .top-visual .top-visual__image .top-visual__image-inner li img {
          width: auto;
          height: 260px; }
      .top-visual .top-visual__image .top-visual__image-inner.is-legacy-ios {
        background-image: url(/railroad/train/assets/img/top_visual.jpg);
        background-size: auto 260px;
        background-repeat: repeat-x; }
      .top-visual .top-visual__image:before {
        background-repeat: repeat-x;
        background-size: auto 260px; } }

.top-visual__heading-wrap {
  border-top: 1px solid #fff;
  padding: 0 10px;
  position: relative; }

.top-visual__heading {
  margin: -50px auto 0;
  padding: 30px 0 20px;
  max-width: 1024px;
  border-top: 5px solid #3d3f8a;
  background-color: rgba(255, 255, 255, 0.97);
  font-size: 4.2rem;
  text-align: center; }
  @media screen and (max-width: 767px) {
    .top-visual__heading {
      margin-top: -20px;
      padding: 20px 0 10px;
      font-size: 2.8rem; } }

.top-visual__shinkansen {
  text-align: right;
  margin-left: 20px; }
  .top-visual__shinkansen img {
    max-width: 100%;
    height: auto;
    vertical-align: bottom; }

/* --- top-category-search --- */
.top-category-search {
  margin-bottom: 50px; }
  @media screen and (max-width: 767px) {
    .top-category-search {
      margin-bottom: 30px;
      background: linear-gradient(#313370 0%, #5458bf 50%, #5458bf 100%); } }

.top-category-search__inner {
  box-sizing: border-box;
  padding: 60px 10px 70px;
  height: 534px;
  background-image: url(/railroad/train/assets/img/top_shinkansen_bg.jpg);
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: cover; }
  @media screen and (max-width: 767px) {
    .top-category-search__inner {
      padding: 35px 20px 40px;
      height: auto;
      background-image: url(/railroad/train/assets/img/top_shinkansen_sp_bg.jpg);
      background-size: 100% auto; } }

.top-category-search__heading {
  margin-bottom: 35px;
  text-align: center;
  font-size: 2.6rem;
  color: #f5d018; }
  .top-category-search__heading:before {
    content: '';
    display: inline-block;
    margin-right: 10px;
    position: relative;
    top: 5px;
    width: 34px;
    height: 34px;
    background-image: url(/railroad/train/assets/img/icon_search.png);
    background-repeat: no-repeat;
    background-size: 34px 34px; }
  @media screen and (max-width: 767px) {
    .top-category-search__heading {
      margin-bottom: 25px;
      font-size: 2.0rem; }
      .top-category-search__heading:before {
        width: 24px;
        height: 24px;
        background-size: 24px 24px; } }

.top-category-search__button {
  display: block;
  margin: 40px auto 0;
  position: relative;
  padding: 15px 0;
  background-color: #3d3f8a;
  border: 1px solid #fff;
  width: 400px;
  text-align: center;
  font-size: 1.6rem;
  color: #fff; }
  .top-category-search__button:visited {
    color: #fff; }
  .top-category-search__button:hover {
    background: linear-gradient(150deg, #cde6fa 0%, #cde6fa 30%, #fff 70%, #fff 100%);
    color: #0067b8; }
  .top-category-search__button:after {
    display: block;
    position: absolute;
    bottom: 5px;
    right: 5px;
    content: '';
    width: 8px;
    height: 8px;
    background-image: url(/railroad/train/assets/img/arrow_orange_right_bottom.png);
    background-repeat: no-repeat;
    background-size: 100% auto; }
  @media screen and (max-width: 767px) {
    .top-category-search__button {
      box-sizing: border-box;
      margin: 30px 0 0;
      padding: 12px 0;
      width: 100%;
      font-size: 1.4rem; } }

/* --- top-category-button-list --- */
.top-category-button-list {
  margin: -20px auto 0;
  max-width: 820px;
  overflow: hidden; }
  .top-category-button-list li {
    float: left;
    margin-top: 20px;
    width: calc(50% - 10px); }
    .top-category-button-list li:nth-child(2n) {
      float: right; }
    .top-category-button-list li a {
      display: block;
      position: relative;
      box-sizing: border-box;
      padding-top: 35px;
      padding-left: 45px;
      width: 100%;
      height: 100px;
      background: linear-gradient(150deg, #fff 0%, #fff 40%, #e6e9f0 70%, #e6e9f0 100%);
      text-align: center;
      font-size: 1.8rem;
      font-weight: bold;
      color: #1a1a1b; }
      .top-category-button-list li a:hover {
        background: linear-gradient(150deg, #cde6fa 0%, #cde6fa 30%, #fff 70%, #fff 100%);
        color: #0067b8; }
      .top-category-button-list li a:after {
        display: block;
        content: '';
        position: absolute;
        bottom: 6px;
        right: 6px;
        width: 13px;
        height: 13px;
        background-image: url(/railroad/train/assets/img/arrow_orange_right_bottom.png);
        background-repeat: no-repeat; }
      .top-category-button-list li a:before {
        display: block;
        content: '';
        position: absolute;
        top: 20px;
        left: 30px;
        width: 56px;
        height: 60px;
        background-repeat: no-repeat; }
      .top-category-button-list li a.shinkansen:before {
        background-image: url(/railroad/train/assets/img/illust_shinkansen.png); }
      .top-category-button-list li a.express-train:before {
        background-image: url(/railroad/train/assets/img/illust_express_train.png); }
      .top-category-button-list li a.normal-train:before {
        background-image: url(/railroad/train/assets/img/illust_normal_train.png); }
      .top-category-button-list li a.sleeper-train:before {
        background-image: url(/railroad/train/assets/img/illust_sleeper_train.png); }
  @media screen and (max-width: 767px) {
    .top-category-button-list li {
      float: none;
      margin-top: 10px;
      width: auto; }
      .top-category-button-list li:nth-child(2n) {
        float: none; }
      .top-category-button-list li a {
        padding-top: 20px;
        padding-left: 0;
        height: 70px;
        font-size: 1.6rem; }
        .top-category-button-list li a:before {
          top: 15px;
          left: 15px;
          width: 40px;
          height: 43px;
          background-size: 40px auto; } }

/* --- button-list --- */
.button-list {
  margin-top: -10px;
  overflow: hidden; }
  .button-list li {
    float: left;
    margin-right: 1.01%;
    margin-top: 10px;
    width: 24.2424%; }
    .button-list li:nth-child(4n) {
      margin-right: 0; }
    .button-list li a {
      display: table;
      box-sizing: border-box;
      position: relative;
      width: 100%;
      height: 100px;
      border: 1px solid #ccc;
      background: linear-gradient(150deg, #fff 0%, #fff 40%, #e6e9f0 70%, #e6e9f0 100%);
      text-align: center;
      font-size: 1.6rem;
      font-weight: bold;
      color: #1a1a1b; }
      .button-list li a span {
        display: table-cell;
        vertical-align: middle; }
      .button-list li a:visited {
        color: #1a1a1b; }
      .button-list li a:hover {
        background: linear-gradient(150deg, #cde6fa 0%, #cde6fa 30%, #fff 70%, #fff 100%);
        color: #0067b8; }
      .button-list li a:after {
        display: block;
        content: '';
        position: absolute;
        bottom: 6px;
        right: 6px;
        width: 13px;
        height: 13px;
        background-image: url(/railroad/train/assets/img/arrow_orange_right_bottom.png);
        background-repeat: no-repeat; }
  @media screen and (max-width: 767px) {
    .button-list li {
      margin-right: 10px;
      width: calc(50% - 5px); }
      .button-list li:nth-child(2n) {
        margin-right: 0; } }
  @media screen and (max-width: 767px) {
    .button-list li {
      margin-right: 0;
      width: 100%; }
      .button-list li a {
        padding: 10px 0;
        height: auto;
        font-size: 1.4rem; }
        .button-list li a br {
          display: none; }
        .button-list li a:after {
          bottom: 5px;
          right: 5px;
          width: 8px;
          height: 8px;
          background-size: 100% auto; } }

/* --- train-visual --- */
.train-visual {
  margin-bottom: 60px;
  padding: 54px 0 60px;
  background: linear-gradient(to bottom, #313370 30%, #5458bf 100%); }
  @media screen and (max-width: 767px) {
    .train-visual {
      margin-bottom: 35px;
      padding: 35px 0 40px; }
      .train-visual .relational-info {
        margin-right: 20px;
        margin-left: 20px; } }

.train-visual__inner {
  margin: 0 auto;
  padding: 0 10px;
  max-width: 1024px; }
  @media screen and (max-width: 767px) {
    .train-visual__inner {
      padding: 0; } }

.train-visual__heading {
  margin-bottom: 35px;
  color: #fff;
  font-size: 3.2rem; }
  @media screen and (max-width: 767px) {
    .train-visual__heading {
      padding: 0 20px;
      font-size: 2.0rem; } }

.train-visual__slider {
  margin-bottom: 25px; }
  @media screen and (max-width: 767px) {
    .train-visual__slider + .train-visual__data {
      margin-top: 50px; } }

.train-visual__data {
  width: 100%;
  overflow: hidden; }
  .train-visual__data .text {
    float: left;
    width: 65%;
    color: #fff; }
  .train-visual__data .data {
    float: right;
    width: 30%; }
    .train-visual__data .data p {
      margin-top: 10px;
      color: #fff; }
  .train-visual__data .basic-table {
    width: 100%; }
    .train-visual__data .basic-table th {
      width: 75px; }
  @media screen and (max-width: 767px) {
    .train-visual__data {
      box-sizing: border-box;
      padding: 0 20px; }
      .train-visual__data .text {
        float: none;
        margin-bottom: 20px;
        width: auto; }
      .train-visual__data .data {
        float: none;
        width: 100%; } }

/* --- image-set --- */
.image-set {
  margin-bottom: 30px;
  overflow: hidden; }
  @media screen and (max-width: 767px) {
    .image-set {
      margin-bottom: 20px; } }

.image-set__image {
  float: left;
  width: 49.80%; }
  .image-set__image img {
    max-width: 100%;
    height: auto; }
  @media screen and (max-width: 767px) {
    .image-set__image {
      float: none;
      margin-bottom: 20px;
      width: auto;
      text-align: center; } }

.image-set__content {
  float: right;
  width: 44.921%; }
  @media screen and (max-width: 767px) {
    .image-set__content {
      float: none;
      width: auto; } }

/* --- image-banner-set --- */
.image-banner-set {
  margin-bottom: 30px;
  padding-bottom: 30px;
  border-bottom: 1px dotted #ccc;
  overflow: hidden; }
  .image-banner-set:last-child {
    padding-bottom: 0;
    border-bottom: none; }
  @media screen and (max-width: 767px) {
    .image-banner-set {
      margin-bottom: 20px;
      padding-bottom: 20px; } }

.image-banner-set__image {
  float: left;
  width: 59.76%; }
  .image-banner-set__image img {
    max-width: 100%;
    height: auto; }
  @media screen and (max-width: 767px) {
    .image-banner-set__image {
      float: none;
      margin-bottom: 20px;
      width: auto;
      text-align: center; } }

.image-banner-set__content {
  float: right;
  width: 36.852%;
  padding-top: 35px; }
  .image-banner-set__content .yellow-mark-heading-wrap {
    margin-bottom: 20px; }
  .image-banner-set__content .yellow-mark-heading {
    font-size: 1.8rem; }
    .image-banner-set__content .yellow-mark-heading br {
      display: inline; }
  .image-banner-set__content .text p {
    margin-bottom: 10px; }
    .image-banner-set__content .text p:last-child {
      margin-bottom: 0; }
  @media screen and (max-width: 767px) {
    .image-banner-set__content {
      float: none;
      width: auto;
      padding-top: 0; }
      .image-banner-set__content .yellow-mark-heading-wrap {
        margin-bottom: 10px; }
      .image-banner-set__content .yellow-mark-heading {
        font-size: 1.6rem; } }

/* --- image-mini-set --- */
.image-mini-set {
  overflow: hidden; }
  @media screen and (max-width: 767px) {
    .image-mini-set {
      margin-bottom: 0; } }

.image-mini-set__image {
  float: left;
  width: 41.6666%; }
  .image-mini-set__image img {
    max-width: 100%;
    height: auto; }
  @media screen and (max-width: 767px) {
    .image-mini-set__image {
      float: none;
      margin-bottom: 20px;
      width: auto;
      text-align: center; } }

.image-mini-set__content {
  float: right;
  width: 53.125%; }
  @media screen and (max-width: 767px) {
    .image-mini-set__content {
      float: none;
      width: auto; } }

/* --- image-box --- */
.image-box {
  margin-bottom: 30px; }
  .image-box img {
    max-width: 100%;
    height: auto; }
  @media screen and (max-width: 767px) {
    .image-box {
      margin-bottom: 15px; } }

.image-box__caption {
  margin-bottom: 10px;
  font-weight: bold; }
  .image-box__caption.is-right {
    margin-bottom: 0;
    margin-top: 10px;
    text-align: right; }

/* --- symbol-list --- */
.symbol-list {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; }
  .symbol-list li {
    display: table;
    margin-bottom: 20px;
    width: 25%;
    line-height: 1.2; }
    .symbol-list li img {
      margin: 0 10px 0 8px;
      width: 30px; }
    .symbol-list li p {
      display: table-cell;
      width: 190px;
      vertical-align: middle; }
    .symbol-list li span {
      font-size: 1.2rem; }
  @media screen and (max-width: 767px) {
    .symbol-list li {
      width: 33%; } }
  @media screen and (max-width: 767px) {
    .symbol-list li {
      width: 50%; } }

/* --- photo-with-caption --- */
.photo-with-caption .photo img {
  max-width: 100%;
  height: auto; }

.photo-with-caption .caption {
  margin-top: 15px; }

@media screen and (max-width: 767px) {
  .photo-with-caption .caption {
    margin-top: 5px; } }

/* --- train-seat --- */
.train-seat {
  margin-bottom: 60px; }

.train-seat__heading {
  margin-bottom: 30px;
  padding-bottom: 10px;
  border-bottom: 2px solid #ccc; }
  .train-seat__heading .icon-image {
    position: relative;
    top: 2px;
    margin-right: 3px; }

.train-number {
  margin-right: 10px;
  display: inline-block; }
  .train-number.is-long {
    display: block;
    margin-top: 5px; }
  .train-number th,
  .train-number td {
    padding: 0;
    vertical-align: top;
    font-size: 1.6rem;
    line-height: 1.2;
    font-weight: bold; }
    .train-number th span,
    .train-number td span {
      font-weight: normal;
      font-size: 1.3rem; }
      .train-number th span .icon-image-kurumaisu,
      .train-number td span .icon-image-kurumaisu {
        top: -1px; }
  .train-number th {
    padding-right: 10px;
    white-space: nowrap; }

/* --- icon-image-green --- */
.icon-image-green {
  position: relative;
  top: -1px;
  margin: 0 3px; }

/* --- icon-image-kurumaisu --- */
.icon-image-kurumaisu {
  position: relative;
  top: 2px;
  margin-left: 5px; }

/* --- train-multiple-box --- */
.train-multiple-box {
  margin-bottom: 30px;
  padding-bottom: 20px;
  border-bottom: dotted 1px #ccc; }
  .train-multiple-box:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none; }
  .train-multiple-box .text-box {
    margin-bottom: 0; }

/* NAVIGATION
/*+---------------------------------*/
/* --- page-navigation --- */
.page-navigation {
  overflow: hidden;
  width: 80%;
  margin: -15px auto 45px;
  text-align: center; }
  .page-navigation li {
    float: left;
    margin-top: 15px;
    width: 49%; }
    .page-navigation li:nth-child(2n) {
      float: right; }
    .page-navigation li a {
      display: block;
      position: relative;
      padding: 15px 0;
      background: linear-gradient(150deg, #4f52b2 0%, #4f52b2 40%, #313370 70%, #313370 100%);
      text-align: center;
      color: #fff;
      font-size: 1.6rem; }
      .page-navigation li a:before {
        display: block;
        content: '';
        position: absolute;
        top: 25px;
        left: 20px;
        width: 18px;
        height: 10px;
        background-image: url(/railroad/train/assets/img/arrow_orange_bottom.png);
        background-repeat: no-repeat; }
      .page-navigation li a:hover {
        background: linear-gradient(150deg, #313370 0%, #313370 30%, #4f52b2 70%, #4f52b2 100%); }
  @media screen and (max-width: 767px) {
    .page-navigation li {
      float: none;
      width: 100%; }
      .page-navigation li:nth-child(2n) {
        float: none; }
      .page-navigation li:last-child {
        margin-bottom: 0; } }
  @media screen and (max-width: 767px) {
    .page-navigation {
      margin-bottom: 30px;
      width: 100%; }
      .page-navigation li a {
        font-size: 1.4rem; }
        .page-navigation li a:before {
          width: 15px;
          height: 7px;
          background-size: 100% auto; } }

/* TABLE
/*+---------------------------------*/
/* --- basic-table --- */
.basic-table {
  border-collapse: collapse; }
  .basic-table caption {
    padding: 5px 10px;
    border-bottom: 1px solid #ccc;
    text-align: center;
    background-color: #ebebeb; }
  .basic-table th {
    padding: 10px;
    border-right: 1px solid #ccc;
    border-bottom: 1px solid #ccc;
    background-color: #ebebeb;
    vertical-align: middle;
    text-align: center;
    font-weight: normal;
    line-height: 1.4; }
  .basic-table td {
    padding: 8px 10px;
    border-bottom: 1px solid #ccc;
    background-color: #fff; }
  .basic-table tr:last-child th, .basic-table tr:last-child td {
    border-bottom: none; }
  @media screen and (max-width: 767px) {
    .basic-table th {
      padding: 8px 5px; }
    .basic-table td {
      padding: 5px; } }

/* LIST
/*+---------------------------------*/
/* --- list --- */
.list {
  margin-bottom: 10px; }
  .list:last-child {
    margin-bottom: 0; }
  .list > li {
    margin-bottom: 5px;
    padding-left: 11px;
    text-indent: -11px; }
    .list > li:before {
      display: inline-block;
      position: relative;
      top: -3px;
      margin-right: 7px;
      content: '';
      width: 4px;
      height: 4px;
      border-radius: 2px;
      background-color: #000; }
    .list > li ul {
      margin-top: 5px; }
    .list > li > ul > li:before {
      top: -3px;
      box-sizing: border-box;
      background-color: #fff;
      border: 1px solid #333; }
    .list > li > ul > li > ul > li:before {
      display: inline-block;
      content: '';
      font-weight: bold;
      border: none;
      width: 5px;
      height: 2px;
      background-color: #000; }
    .list > li:last-child {
      margin-bottom: 0; }

/* --- attention-list --- */
.attention-list {
  margin-bottom: 10px; }
  .attention-list:last-child {
    margin-bottom: 0; }
  .attention-list > li {
    padding-left: 1em;
    text-indent: -1em; }
  .attention-list + section {
    margin-top: 20px; }
  .attention-list ul {
    margin-top: 5px; }

/* OTHER
/*+---------------------------------*/
/* --- text-link --- */
.text-link {
  text-decoration: underline; }
  .text-link:hover {
    text-decoration: none; }

/* --- text-icon --- */
.text-icon {
  margin-right: 2px;
  padding: 3px;
  display: inline-block;
  border: 1px solid #ccc;
  line-height: 1.2;
  font-size: 1.3rem;
  vertical-align: top; }

/* --- page-link --- */
.page-link {
  margin-top: -120px;
  padding-top: 120px; }
  @media screen and (max-width: 767px) {
    .page-link {
      margin-top: -80px;
      padding-top: 80px; } }

/* --- disabled --- */
@media screen and (min-width: 768px),print {
  .disabled {
    margin-bottom: 0; } }

/* --- trainslider --- */
.trainslider {
  margin: 0;
  padding: 0; }

.trainslider .slides > li {
  display: none;
  -webkit-backface-visibility: hidden; }

.trainslider .slides img {
  width: 100%;
  display: block; }

.trainslider .slides:after {
  content: "\0020";
  display: block;
  clear: both;
  visibility: hidden;
  line-height: 0;
  height: 0; }

html[xmlns] .trainslider .slides {
  display: block; }

* html .trainslider .slides {
  height: 1%; }

.no-js .trainslider .slides > li:first-child {
  display: block; }

.trainslider {
  background: #fff;
  position: relative;
  zoom: 1; }

/* SP時関連情報が2行以上だとスライダーとかぶる不具合 */
@media screen and (max-width: 767px) {
  .trainslider.heightAdd {
    padding-bottom: 50px;
  }
  .trainslider.heightAdd .train-visual-button {
    bottom: 0;
  }
}
.trainslider .slides {
  zoom: 1; }

.trainslider .slides img {
  height: auto;
  -moz-user-select: none; }

.train-slider-direction-nav {
  *height: 0; }

.train-slider-direction-nav a {
  text-decoration: none;
  display: block;
  width: 40px;
  height: 40px;
  margin: -20px 0 0;
  position: absolute;
  top: 50%;
  z-index: 10;
  overflow: hidden;
  opacity: 0;
  cursor: pointer;
  color: rgba(0, 0, 0, 0.8);
  text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.3);
  transition: all 0.3s ease-in-out; }

.train-slider-direction-nav a:before {
  font-family: "trainslider-icon";
  font-size: 40px;
  display: inline-block;
  content: '\f001';
  color: rgba(0, 0, 0, 0.8);
  text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.3); }

.train-slider-direction-nav a.train-slider-next:before {
  content: '\f002'; }

.train-slider-direction-nav .train-slider-prev {
  left: -50px; }

.train-slider-direction-nav .train-slider-next {
  right: -50px;
  text-align: right; }

.trainslider:hover .train-slider-direction-nav .train-slider-prev {
  opacity: 0.7;
  left: 10px; }

.trainslider:hover .train-slider-direction-nav .train-slider-prev:hover {
  opacity: 1; }

.trainslider:hover .train-slider-direction-nav .train-slider-next {
  opacity: 0.7;
  right: 10px; }

.trainslider:hover .train-slider-direction-nav .train-slider-next:hover {
  opacity: 1; }

.train-slider-direction-nav .train-slider-disabled {
  opacity: 0 !important;
  filter: alpha(opacity=0);
  cursor: default;
  z-index: -1; }

@media screen and (max-width: 767px) {
  .train-visual-button {
    position: absolute;
    bottom: -50px;
    width: 100%;
    height: 50px;
    background-color: #3d3f8a;
    text-align: center; } }

.train-slider-pause,
.train-slider-play {
  display: block;
  width: 60px;
  height: 30px;
  background-color: #3d3f8a;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 60px 30px;
  border: none;
  position: absolute;
  bottom: 10px;
  right: 10px;
  z-index: 10;
  overflow: hidden;
  cursor: pointer;
  text-indent: -9999px; }
  @media screen and (max-width: 767px) {
    .train-slider-pause,
    .train-slider-play {
      position: static;
      display: inline-block; } }

.train-slider-pause {
  right: 80px;
  background-image: url(/railroad/train/assets/img/button_pause.png); }

.train-slider-play {
  background-image: url(/railroad/train/assets/img/button_play.png); }

.train-slider-pause.on,
.train-slider-pause:hover {
  background-image: url(/railroad/train/assets/img/button_pause_hover.png); }

.train-slider-play.on,
.train-slider-play:hover {
  background-image: url(/railroad/train/assets/img/button_play_hover.png); }

.train-slider-control-nav {
  padding-top: 18px;
  width: 100%;
  height: 50px;
  box-sizing: border-box;
  background-color: #3d3f8a;
  text-align: center; }

.train-slider-control-nav li {
  margin: 0 6px;
  display: inline-block;
  zoom: 1;
  *display: inline; }

.train-slider-control-paging li a {
  width: 10px;
  height: 10px;
  display: block;
  background: #fff;
  cursor: pointer;
  text-indent: -9999px;
  border-radius: 5px; }

.train-slider-control-paging li a:hover {
  background: #f5d018; }

.train-slider-control-paging li a.train-slider-active {
  background: #f5d018;
  cursor: default; }

/* 特急列車ページのリンク追加 */
.buttonRight {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 15px;
}

.expressButton-wrap {
  text-align: center;
  margin-top: 48px;
}

@media screen and (min-width: 768px),print {
  .expressButton-wrap {
    margin-top: 48px;
  }
}

@media screen and (max-width: 767px) {
  .expressButton-wrap {
    margin-top: 16px;
  }
}

.expressButton {
  position: relative;
  background: #004fb2;
  color: #fff;
  border-radius: 8px;
  text-align: left;
}

.expressButton:visited {
  color: #fff;
}

@media screen and (min-width: 768px),print {
  .expressButton {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    padding: 24px 60px 28px 32px;
  }
}

@media screen and (max-width: 767px) {
  .expressButton {
    display: block;
    margin-left:auto;
    margin-right: auto;
    padding: 2.4rem 4.2rem 2.4rem 3.2rem;
    max-width: 35.5rem;
    width: 100%
  }
}

@media (hover: hover),screen and (-ms-high-contrast:active),screen and (-ms-high-contrast:none) {
  .expressButton {
    -webkit-transition-property:background,color,-webkit-box-shadow;
    transition-property: background,color,-webkit-box-shadow;
    transition-property: background,color,box-shadow;
    transition-property: background,color,box-shadow,-webkit-box-shadow;
    -webkit-transition-duration: .25s;
    transition-duration: .25s
  }

  .expressButton:hover {
    background: #f4f9ff;
    color: #004fb2;
    -webkit-box-shadow: inset 0 0 0 2px #004fb2;
    box-shadow: inset 0 0 0 2px #004fb2
  }

  .expressButton:hover[target='_blank']::before {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%228%22%20height%3D%228%22%20viewBox%3D%220%200%208%208%22%3E%20%3Cpath%20id%3D%22%E5%90%88%E4%BD%93_94%22%20data-name%3D%22%E5%90%88%E4%BD%93%2094%22%20d%3D%22M1%2C8A1%2C1%2C0%2C0%2C1%2C0%2C7V1.624a1%2C1%2C0%2C0%2C1%2C1-1H3.69a.439.439%2C0%2C0%2C1%2C0%2C.877H1a.127.127%2C0%2C0%2C0-.127.127V7A.127.127%2C0%2C0%2C0%2C1%2C7.123H6.376A.127.127%2C0%2C0%2C0%2C6.5%2C7V4.31a.439.439%2C0%2C1%2C1%2C.877%2C0V7a1%2C1%2C0%2C0%2C1-1%2C1ZM3.845%2C4.156a.438.438%2C0%2C0%2C1%2C0-.62L6.5.878H5.7A.439.439%2C0%2C0%2C1%2C5.7%2C0H7.551a.441.441%2C0%2C0%2C1%2C.11.011h0l.01%2C0h0l.009%2C0h0l.008%2C0h0l.008%2C0h0l.009%2C0h0l.009%2C0h0l.009%2C0h0l.009%2C0h0l.009%2C0h0l.009%2C0h0l.009%2C0h0l.009%2C0h0l.008%2C0h0l.007%2C0h0l.006%2C0%2C0%2C0%2C0%2C0%2C0%2C0%2C0%2C0%2C.007.005h0A.438.438%2C0%2C0%2C1%2C8%2C.439C8%2C.446%2C8%2C.453%2C8%2C.46V2.3a.439.439%2C0%2C1%2C1-.877%2C0V1.5L4.465%2C4.156a.439.439%2C0%2C0%2C1-.62%2C0Z%22%20transform%3D%22translate(0%20-0.001)%22%20fill%3D%22%23004fb2%22%2F%3E%3C%2Fsvg%3E");
    background-repeat: no-repeat;
    background-size: contain
  }

  .expressButton:hover::before {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20id%3D%22navigation-down-circle%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2220%22%20height%3D%2220%22%20viewBox%3D%220%200%2020%2020%22%3E%20%3Cpath%20id%3D%22Shape%22%20d%3D%22M10%2C20A10%2C10%2C0%2C0%2C1%2C2.929%2C2.929%2C10%2C10%2C0%2C1%2C1%2C17.071%2C17.071%2C9.935%2C9.935%2C0%2C0%2C1%2C10%2C20ZM6.26%2C10.01a.829.829%2C0%2C0%2C0-.589.244.838.838%2C0%2C0%2C0-.01%2C1.168l3.75%2C3.75a.833.833%2C0%2C0%2C0%2C1.178%2C0l3.75-3.75a.84.84%2C0%2C0%2C0-.01-1.17.833.833%2C0%2C0%2C0-1.168-.01l-1.972%2C1.972a.209.209%2C0%2C0%2C1-.356-.148V5A.833.833%2C0%2C1%2C0%2C9.166%2C5v7.066a.208.208%2C0%2C0%2C1-.355.149L6.839%2C10.244A.83.83%2C0%2C0%2C0%2C6.26%2C10.01Z%22%20transform%3D%22translate(0%200)%22%20fill%3D%22%23004fb2%22%2F%3E%3C%2Fsvg%3E");
    background-repeat: no-repeat;
    background-size: contain
  }
}

.expressButton .-main {
    display: block;
    font-weight: 700
}

@media screen and (min-width: 768px),print {
  .expressButton .-main {
    font-size: 1.6rem;
    line-height: 1.38
  }
}

@media screen and (max-width: 767px) {
  .expressButton .-main {
    font-size: 1.6rem;
    line-height: 1.71
  }
}

.expressButton::before {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  content: '';
  display: inline-block;
  rotate: -90deg;
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20id%3D%22navigation-down-circle%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2220%22%20height%3D%2220%22%20viewBox%3D%220%200%2020%2020%22%3E%20%3Cpath%20id%3D%22Shape%22%20d%3D%22M10%2C20A10%2C10%2C0%2C0%2C1%2C2.929%2C2.929%2C10%2C10%2C0%2C1%2C1%2C17.071%2C17.071%2C9.935%2C9.935%2C0%2C0%2C1%2C10%2C20ZM6.26%2C10.01a.829.829%2C0%2C0%2C0-.589.244.838.838%2C0%2C0%2C0-.01%2C1.168l3.75%2C3.75a.833.833%2C0%2C0%2C0%2C1.178%2C0l3.75-3.75a.84.84%2C0%2C0%2C0-.01-1.17.833.833%2C0%2C0%2C0-1.168-.01l-1.972%2C1.972a.209.209%2C0%2C0%2C1-.356-.148V5A.833.833%2C0%2C1%2C0%2C9.166%2C5v7.066a.208.208%2C0%2C0%2C1-.355.149L6.839%2C10.244A.83.83%2C0%2C0%2C0%2C6.26%2C10.01Z%22%20transform%3D%22translate(0%200)%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E");
  background-repeat: no-repeat;
  background-size: contain
}

@media screen and (min-width: 768px),print {
  .expressButton::before {
    right:clamp(25.173px,2.133vw,32px);
    width: 24px;
    height: 24px
  }
}

@media screen and (max-width: 767px) {
  .expressButton::before {
    right:1.8rem;
    width: 2.4rem;
    height: 2.4rem
  }
}

