/* ========================================================================================= ^^
  Key visual for access
============================================================================================ ^^ */
.c-key-visual {
  background: url(../images/access/kv.jpg) no-repeat 50% 100%/cover;
}

/* ========================================================================================= ^^
  Access station
============================================================================================ ^^ */
.p-access-station {
  max-width: 1090px;
  width: 100%;
  margin: 0 auto;
  grid-template-columns: 100%;
  row-gap: calc(20 * var(--min-ratio));
}
@media (min-width: 768px) {
  .p-access-station {
    grid-template-columns: repeat(2, 48.9908256881%);
    -moz-column-gap: 2.0183486239%;
    column-gap: 2.0183486239%;
    row-gap: calc(30 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  .p-access-station {
    row-gap: calc(30 * var(--rem-ratio));
  }
}

/* ========================================================================================= ^^
  Introduction for access
============================================================================================ ^^ */
#container .p-introduction {
  width: 100vw;
  padding: calc(70 * var(--min-ratio)) calc(10 * var(--min-ratio)) calc(85 * var(--min-ratio));
  margin: 0 calc(50% - 50vw);
  background: linear-gradient(to right, #d9d7cc 0%, #edebe7 53.6423%, #d9d2c8 100%);
  color: #333;
  text-align: center;
}
@media (min-width: 768px) {
  #container .p-introduction {
    padding: calc(70 * var(--max-ratio)) calc(10 * var(--max-ratio)) calc(85 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-introduction {
    padding: calc(70 * var(--rem-ratio)) calc(10 * var(--rem-ratio)) calc(85 * var(--rem-ratio));
  }
}
#container .p-introduction .c-title {
  margin-bottom: calc(48 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(1.25rem, 1.047rem + 0.86vw, 1.75rem);
  line-height: 1.7857142857;
  font-weight: 500;
  letter-spacing: 0.08em;
}
#container .p-introduction .c-title span {
  font-size: clamp(0.75rem, 0.623rem + 0.54vw, 1.063rem);
  line-height: 2.9411764706;
}
@media (min-width: 768px) {
  #container .p-introduction .c-title {
    margin-bottom: calc(48 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-introduction .c-title {
    margin-bottom: calc(48 * var(--rem-ratio));
  }
}
#container .c-text {
  font-size: clamp(0.875rem, 0.824rem + 0.22vw, 1rem);
  line-height: 2.5;
}

/* ========================================================================================= ^^
  Access lines
============================================================================================ ^^ */
#container .p-access-lines {
  width: 100vw;
  padding: calc(66 * var(--min-ratio)) calc(10 * var(--min-ratio)) calc(35 * var(--min-ratio));
  margin: 0 calc(50% - 50vw);
  background-color: #fff;
  color: #333;
  text-align: center;
}
@media (min-width: 768px) {
  #container .p-access-lines {
    padding: calc(66 * var(--max-ratio)) calc(10 * var(--max-ratio)) calc(70 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-lines {
    padding: calc(66 * var(--rem-ratio)) calc(10 * var(--rem-ratio)) calc(70 * var(--rem-ratio));
  }
}
#container .p-access-lines .c-title {
  margin-bottom: calc(30 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(1.25rem, 1.047rem + 0.86vw, 1.75rem);
  line-height: 1.7857142857;
  font-weight: 500;
  letter-spacing: 0.08em;
}
#container .p-access-lines .c-title span {
  font-size: clamp(0.75rem, 0.623rem + 0.54vw, 1.063rem);
  line-height: 2.9411764706;
}
@media (min-width: 768px) {
  #container .p-access-lines .c-title {
    margin-bottom: calc(30 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-lines .c-title {
    margin-bottom: calc(30 * var(--rem-ratio));
  }
}
#container .p-access-lines .c-text {
  font-size: clamp(0.875rem, 0.824rem + 0.22vw, 1rem);
  line-height: 2.5;
}
#container .p-access-lines .c-image {
  width: 100%;
}

/* ========================================================================================= ^^
  Access stations
============================================================================================ ^^ */
#container .p-access-stations {
  padding: calc(86 * var(--min-ratio)) calc(10 * var(--min-ratio)) calc(58 * var(--min-ratio));
  color: #333;
  text-align: center;
}
@media (min-width: 768px) {
  #container .p-access-stations {
    padding: calc(86 * var(--max-ratio)) calc(10 * var(--max-ratio)) calc(58 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-stations {
    padding: calc(86 * var(--rem-ratio)) calc(10 * var(--rem-ratio)) calc(58 * var(--rem-ratio));
  }
}
#container .p-access-stations .c-title {
  margin-bottom: calc(49 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(1.25rem, 1.047rem + 0.86vw, 1.75rem);
  line-height: 1.7857142857;
  font-weight: 500;
  letter-spacing: 0.08em;
}
@media (min-width: 768px) {
  #container .p-access-stations .c-title {
    margin-bottom: calc(49 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-stations .c-title {
    margin-bottom: calc(49 * var(--rem-ratio));
  }
}
#container .p-access-stations .c-title span {
  font-size: clamp(0.75rem, 0.623rem + 0.54vw, 1.063rem);
  line-height: 2.9411764706;
}
#container .p-access-stations .c-text {
  margin-bottom: calc(65 * var(--min-ratio));
  font-size: clamp(0.875rem, 0.824rem + 0.22vw, 1rem);
  line-height: 2.5;
  letter-spacing: 0.08em;
}
@media (min-width: 768px) {
  #container .p-access-stations .c-text {
    margin-bottom: calc(132 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-stations .c-text {
    margin-bottom: calc(132 * var(--rem-ratio));
  }
}
#container .p-access-stations .c-image-text {
  margin-bottom: calc(70 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-access-stations .c-image-text {
    margin-bottom: calc(138 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-stations .c-image-text {
    margin-bottom: calc(138 * var(--rem-ratio));
  }
}
#container .p-access-stations .c-image-text + .c-image-text {
  margin-bottom: calc(55 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-access-stations .c-image-text + .c-image-text {
    margin-bottom: calc(110 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-stations .c-image-text + .c-image-text {
    margin-bottom: calc(110 * var(--rem-ratio));
  }
}
#container .p-access-stations .c-image-text .c-image {
  padding: 0;
  margin: 0;
  background: none;
}
#container .p-access-stations .c-image-text .c-image img {
  width: 100%;
}
#container .p-access-stations .c-image {
  max-width: 1112px;
  width: 100%;
  padding: calc(65 * var(--min-ratio)) calc(20 * var(--min-ratio));
  margin: 0 auto calc(30 * var(--min-ratio));
  background-color: rgba(255, 255, 255, 0.6);
}
@media (min-width: 768px) {
  #container .p-access-stations .c-image {
    padding: calc(65 * var(--max-ratio)) calc(20 * var(--max-ratio));
    margin-bottom: calc(75 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-stations .c-image {
    padding: calc(65 * var(--rem-ratio)) calc(20 * var(--rem-ratio));
    margin-bottom: calc(75 * var(--rem-ratio));
  }
}
@media (min-width: 768px) {
  #container .p-access-stations .c-image img {
    width: calc(750 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-stations .c-image img {
    width: calc(750 * var(--rem-ratio));
  }
}

/* ========================================================================================= ^^
  Access car
============================================================================================ ^^ */
#container .p-access-car {
  max-width: 1110px;
  width: 100%;
  padding: calc(38 * var(--min-ratio)) calc(10 * var(--min-ratio)) calc(94 * var(--min-ratio));
  margin: 0 auto;
  color: #333;
  text-align: center;
}
@media (min-width: 768px) {
  #container .p-access-car {
    padding: calc(75 * var(--max-ratio)) calc(10 * var(--max-ratio)) calc(94 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-car {
    padding: calc(75 * var(--rem-ratio)) calc(10 * var(--rem-ratio)) calc(94 * var(--rem-ratio));
  }
}
#container .p-access-car .c-title {
  margin-bottom: calc(32 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(1.25rem, 1.047rem + 0.86vw, 1.75rem);
  line-height: 1.7857142857;
  font-weight: 500;
  letter-spacing: 0.08em;
}
#container .p-access-car .c-title span {
  font-size: clamp(0.75rem, 0.623rem + 0.54vw, 1.063rem);
  line-height: 2.9411764706;
}
@media (min-width: 768px) {
  #container .p-access-car .c-title {
    margin-bottom: calc(32 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-car .c-title {
    margin-bottom: calc(32 * var(--rem-ratio));
  }
}
#container .p-access-car .c-text {
  margin-bottom: calc(68 * var(--min-ratio));
  font-size: clamp(0.875rem, 0.824rem + 0.22vw, 1rem);
  line-height: 2.5;
}
@media (min-width: 768px) {
  #container .p-access-car .c-text {
    margin-bottom: calc(68 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-car .c-text {
    margin-bottom: calc(68 * var(--rem-ratio));
  }
}
#container .p-access-car .c-image {
  margin-bottom: calc(20 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-access-car .c-image {
    margin-bottom: calc(20 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-car .c-image {
    margin-bottom: calc(20 * var(--rem-ratio));
  }
}
#container .p-access-car .c-grid {
  grid-template-columns: repeat(2, 49%);
  -moz-column-gap: 2%;
  column-gap: 2%;
  row-gap: calc(20 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-access-car .c-grid {
    grid-template-columns: repeat(6, 15.665%);
    -moz-column-gap: 1.202%;
    column-gap: 1.202%;
  }
}
#container .p-access-car .c-grid + p {
  margin: calc(10 * var(--min-ratio)) 0 0;
  text-align: right;
}
@media (min-width: 768px) {
  #container .p-access-car .c-grid + p {
    margin-top: calc(10 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-car .c-grid + p {
    margin-top: calc(10 * var(--rem-ratio));
  }
}

/* ========================================================================================= ^^
  Access bus
============================================================================================ ^^ */
#container .p-access-bus {
  padding: 0 calc(10 * var(--min-ratio)) calc(44 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-access-bus {
    padding: 0 calc(10 * var(--max-ratio)) calc(88 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-bus {
    padding: 0 calc(10 * var(--rem-ratio)) calc(88 * var(--rem-ratio));
  }
}
#container .p-access-bus .p-section-block {
  margin-bottom: calc(106 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-access-bus .p-section-block {
    margin-bottom: calc(106 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-bus .p-section-block {
    margin-bottom: calc(106 * var(--rem-ratio));
  }
}

/* ========================================================================================= ^^
  Access train
============================================================================================ ^^ */
#container .p-access-train {
  padding: calc(30 * var(--min-ratio)) calc(10 * var(--min-ratio)) calc(45 * var(--min-ratio));
  color: #333;
  text-align: center;
}
@media (min-width: 768px) {
  #container .p-access-train {
    padding: calc(44 * var(--max-ratio)) calc(10 * var(--max-ratio)) calc(94 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-train {
    padding: calc(44 * var(--rem-ratio)) calc(10 * var(--rem-ratio)) calc(94 * var(--rem-ratio));
  }
}
#container .p-access-train .c-title {
  margin-bottom: calc(20 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(1.25rem, 1.047rem + 0.86vw, 1.75rem);
  line-height: 1.7857142857;
  font-weight: 500;
  letter-spacing: 0.08em;
}
@media (min-width: 768px) {
  #container .p-access-train .c-title {
    margin-bottom: calc(40 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-train .c-title {
    margin-bottom: calc(40 * var(--rem-ratio));
  }
}
#container .p-access-train .c-title span {
  font-size: clamp(0.75rem, 0.623rem + 0.54vw, 1.063rem);
  line-height: 2.9411764706;
}
#container .p-access-train .c-text {
  font-size: clamp(0.875rem, 0.824rem + 0.22vw, 1rem);
  line-height: 2.5;
}
#container .p-access-train .c-grid {
  row-gap: calc(35 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-access-train .c-grid {
    row-gap: calc(70 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-train .c-grid {
    row-gap: calc(70 * var(--rem-ratio));
  }
}
@media (min-width: 768px) {
  #container .p-access-train .c-image-text__content--no-color {
    padding-left: calc(70 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-train .c-image-text__content--no-color {
    padding-left: calc(70 * var(--rem-ratio));
  }
}
@media (min-width: 768px) {
  #container .p-access-train .c-image-text--reverse .c-image-text__content--no-color {
    padding-right: calc(70 * var(--max-ratio));
    padding-left: calc(20 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-train .c-image-text--reverse .c-image-text__content--no-color {
    padding-right: calc(70 * var(--rem-ratio));
    padding-left: calc(20 * var(--rem-ratio));
  }
}
#container .p-access-train .c-image-text .note {
  margin-bottom: 0;
  font-size: clamp(0.75rem, 0.699rem + 0.22vw, 0.875rem);
  line-height: 1.2;
}
@media (min-width: 768px) {
  #container .p-access-train .c-image-text .note {
    font-size: clamp(0.75rem, 0.57rem + 0.38vw, 0.875rem);
  }
}

/* ========================================================================================= ^^
  Section block
============================================================================================ ^^ */
#container .p-section-block {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  background-color: #fff;
  filter: drop-shadow(0 3px 15px rgba(133, 124, 118, 0.48));
}
#container .p-section-block .c-grid {
  max-width: 1300px;
  width: 100%;
  margin: 0 auto;
}
@media (min-width: 768px) {
  #container .p-section-block .c-grid {
    grid-template-columns: 35.3846153846% 64.6153846154%;
    align-items: center;
  }
}
#container .p-section-block .c-grid--pa {
  padding-top: calc(34 * var(--min-ratio));
  padding-bottom: 0;
}
@media (min-width: 768px) {
  #container .p-section-block .c-grid--pa {
    padding-top: calc(34 * var(--max-ratio));
    padding-bottom: calc(34 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-section-block .c-grid--pa {
    padding-top: calc(34 * var(--rem-ratio));
    padding-bottom: calc(34 * var(--rem-ratio));
  }
}
#container .p-section-block .c-grid .c-contents {
  padding: calc(40 * var(--min-ratio)) calc(10 * var(--min-ratio));
}
@media not all and (min-width: 768px) {
  #container .p-section-block .c-grid .c-contents {
    grid-row: 2/3;
  }
}
@media (min-width: 768px) {
  #container .p-section-block .c-grid .c-contents {
    padding: 0 calc(20 * var(--max-ratio)) 0 calc(38 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-section-block .c-grid .c-contents {
    padding: 0 calc(20 * var(--rem-ratio)) 0 calc(38 * var(--rem-ratio));
  }
}
#container .p-section-block .c-grid .c-title {
  margin-bottom: calc(20 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(0.938rem, 0.76rem + 0.76vw, 1.375rem);
  color: #333;
  line-height: 1.5454545455;
  font-weight: 500;
  letter-spacing: 0.08em;
}
@media (min-width: 768px) {
  #container .p-section-block .c-grid .c-title {
    margin-bottom: calc(20 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-section-block .c-grid .c-title {
    margin-bottom: calc(20 * var(--rem-ratio));
  }
}
#container .p-section-block .c-grid .c-text {
  font-family: var(--font-noto-serif);
  font-size: clamp(0.75rem, 0.699rem + 0.22vw, 0.875rem);
  color: #333;
  line-height: 2.4285714286;
  font-weight: 400;
  letter-spacing: 0.08em;
}
@media not all and (min-width: 768px) {
  #container .p-section-block .c-grid .c-image {
    grid-row: 1/2;
  }
}
@media (min-width: 768px) {
  #container .p-section-block--reverse .c-grid {
    grid-template-columns: 56.1538461538% 37.9230769231%;
    -moz-column-gap: 5.9230769231%;
    column-gap: 5.9230769231%;
  }
}
#container .p-section-block--reverse .c-grid .c-title {
  margin-bottom: calc(20 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-section-block--reverse .c-grid .c-title {
    padding: 0 calc(20 * var(--max-ratio));
    margin-bottom: calc(12 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-section-block--reverse .c-grid .c-title {
    padding: 0 calc(20 * var(--rem-ratio));
    margin-bottom: calc(12 * var(--rem-ratio));
  }
}
#container .p-section-block--reverse .c-grid .c-text {
  margin-bottom: calc(10 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-section-block--reverse .c-grid .c-text {
    padding: 0 calc(20 * var(--max-ratio));
    margin-bottom: calc(20 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-section-block--reverse .c-grid .c-text {
    padding: 0 calc(20 * var(--rem-ratio));
    margin-bottom: calc(20 * var(--rem-ratio));
  }
}
@media (min-width: 768px) {
  #container .p-section-block--reverse .c-grid .c-contents {
    padding: 0;
    grid-column: 2/3;
  }
}
#container .p-section-block--reverse .c-grid .c-contents ul {
  padding: calc(20 * var(--min-ratio)) calc(10 * var(--min-ratio));
  border: 1px solid #333;
  font-family: var(--font-shippori);
  font-size: clamp(0.688rem, 0.611rem + 0.32vw, 0.875rem);
  line-height: 1.2142857143;
  font-weight: 500;
  letter-spacing: 0.08em;
  display: grid;
  grid-template-columns: 100%;
  align-items: center;
  row-gap: calc(24 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-section-block--reverse .c-grid .c-contents ul {
    padding: calc(20 * var(--max-ratio)) calc(18 * var(--max-ratio));
    row-gap: calc(24 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-section-block--reverse .c-grid .c-contents ul {
    padding: calc(20 * var(--rem-ratio)) calc(18 * var(--rem-ratio));
    row-gap: calc(24 * var(--rem-ratio));
  }
}
#container .p-section-block--reverse .c-grid .c-contents ul::after {
  display: none;
}
#container .p-section-block--reverse .c-grid .c-contents ul li {
  display: grid;
  grid-template-columns: 1fr calc(50 * var(--min-ratio));
  align-items: center;
}
#container .p-section-block--reverse .c-grid .c-contents ul li:first-of-type {
  font-size: clamp(0.938rem, 0.811rem + 0.54vw, 1.25rem);
}
@media (min-width: 768px) {
  #container .p-section-block--reverse .c-grid .c-contents ul li {
    grid-template-columns: 1fr calc(62 * var(--max-ratio));
  }
  #container .p-section-block--reverse .c-grid .c-contents ul li:first-of-type {
    margin-bottom: calc(-17 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-section-block--reverse .c-grid .c-contents ul li {
    grid-template-columns: 1fr calc(62 * var(--rem-ratio));
  }
  #container .p-section-block--reverse .c-grid .c-contents ul li:first-of-type {
    margin-bottom: calc(-17 * var(--rem-ratio));
  }
}
#container .p-section-block--reverse .c-grid .c-contents ul li .time {
  /* font-size: clamp(1rem, 0.924rem + 0.32vw, 1.188rem); */
  font-size: clamp(1.938rem, 1.735rem + 0.86vw, 2.438rem);
}
#container .p-section-block--reverse .c-grid .c-contents ul li .time span {
  font-size: clamp(0.75rem, 0.699rem + 0.22vw, 0.875rem);
}
@media (min-width: 768px) {
  #container .p-section-block--reverse .c-grid .c-image {
    grid-column: 1/2;
    grid-row: 1/2;
  }
}

/* ========================================================================================= ^^
  Access note
============================================================================================ ^^ */
#container .p-access-note {
  width: 100vw;
  padding: calc(40 * var(--min-ratio)) calc(10 * var(--min-ratio)) calc(27 * var(--min-ratio));
  margin: 0 calc(50% - 50vw);
  background-color: #fff;
}
@media (min-width: 768px) {
  #container .p-access-note {
    padding: calc(40 * var(--max-ratio)) calc(10 * var(--max-ratio)) calc(27 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-access-note {
    padding: calc(40 * var(--rem-ratio)) calc(10 * var(--rem-ratio)) calc(27 * var(--rem-ratio));
  }
}
#container .p-access-note .c-inner {
  max-width: 1120px;
  width: 100%;
  margin: 0 auto;
}
#container .p-access-note .c-text {
  font-size: clamp(0.75rem, 0.75rem + 0vw, 0.75rem);
  color: #333;
  line-height: 2;
  letter-spacing: 0.06em;
}

/* ========================================================================================= ^^
  Access
============================================================================================ ^^ */