@charset "UTF-8";
/* CSS Document */



h2{width: 395px; margin: 60px auto 55px;}
h3 {
color : #891C32;
font-size: 3em;
font-weight: bold;
  position: relative;
  padding: 1.5rem;
  text-align: center;
  margin: 0 0 40px;
}

h3:before {
  position: absolute;
  bottom: -10px;
  left: calc(50% - 30px);
  width: 60px;
  height: 5px;
  content: '';
  border-radius: 3px;
  background: #891C32;

}

#box01,#box02{width: 850px; margin: 0 auto 80px;}
.map_img{margin: 0 0 40px; }

#box02 .box-lyt-bus .lyt-info{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	font-size: 16px;
	max-width: 420px;
	margin: 0 auto 2em;
}
#box02 .box-lyt-bus .lyt-info dt{
	border-radius: 6px;
	width: 90px;
	color: #fff;
	background-color: #891C32;
}
#box02 .box-lyt-bus .lyt-info dd{
	width:calc(100% - 100px);
	margin-left: 10px;
	line-height: 1.7;
	border-bottom: 1px dotted #891C32;
}
#box02 .box-lyt-bus .lyt-info dt,
#box02 .box-lyt-bus .lyt-info dd{
	box-sizing: border-box;
	margin-top: 1em;
	padding: .4em .4em .6em .6em;
}

#box02 .time_tbl{display: flex; justify-content: space-between; align-items: flex-start;}
#box02 .time_tbl li{width:calc((100% - 20px)/2);}

#box02 h4{color: #891c32; font-size: 2.9em; font-weight: bold; margin-bottom: 20px; display: flex; justify-content: center; align-items: center; flex-wrap: wrap;}
#box02 h4 span{font-size: 0.7em;}
#box02 h4 span.icon{width: 55px; margin-right: 8px;}


#news{padding: 50px 0 20px; background: #f2ebdf; margin: 0 0 60px;}
#news dl{width: 600px; font-size : 14px;  line-height : 24px; margin: 0 auto 30px;}
#news dt{color: #891c32; margin-right: 10px;}
#news .red{color: #f00;}

#guidmap{padding: 0;}
#guidmap .pict{width: 900px; margin: auto;}
#guidmap .note{width: 900px; font-size : 14px; margin:15px auto;}

#bus{padding: 0 0 85px; border-bottom: 1px solid #808080; width: 900px; margin: auto;}
#bus .tbl{display: flex; justify-content: space-between;  margin: 30px auto 0;}
#bus .tbl li{width: 440px;}

#bus .note{width: 900px; margin: 20px auto 0; font-size : 14px; line-height : 22px;}
#bus .note li{padding-left: 1.2em;}
#bus .note li::before{content: '※'; margin-left: -1.2em; padding-right: 5px;}

/*タブレット縦・スマホ横*/
@media screen and (max-width: 900px){

.map_img p{width: 100%;}
#box01,#box02{width: 95%;}
#box02 .time_tbl{display: block;}
#box02 .time_tbl li{width:90%; margin: 0 auto 20px;}
}

/*スマホ縦*/
@media screen and (max-width: 480px){

h2{width: 70%;}
h3{font-size: 22px;}
#box01,#box02{width: 90%;}
#box02 h4{font-size: 22px;}
.map_img,
.lin_img{overflow-x: scroll;  white-space: nowrap;  -webkit-overflow-scrolling: touch;}
.map_img p,
.lin_img p{width: 650px;}

#box02 .time_tbl th{font-size: 1.6rem}
#box02 .time_tbl td{font-size: 1.8rem;padding: .5em;}

#news dl{display: block; width: 90%; font-feature-settings: "palt";}

#guidmap .wrap{width: 100%; overflow: auto;}
#guidmap .note{width: 90%;}

#bus{width: 90%;}
#bus .tbl{flex-wrap: wrap;}
#bus .tbl li{width: 100%; margin-bottom: 15px;}
#bus .note{width: 90%;}

}

/*スマホ縦・小*/
@media screen and (max-width: 320px){}

/* 24.10.10　追記 */
*, *:before, *:after {
  box-sizing: border-box;
}

body {
  font-optical-sizing: auto;
}

picture {
  display: block;
}
picture > img {
  display: block;
  height: auto;
  width: 100%;
}

.sr-only {
  display: none;
}

@media screen and (min-width: 481px) {
  .xs-ssm {
    display: none;
  }
}

.ac-content-width {
  margin-left: auto;
  margin-right: auto;
  width: 90vw;
}
@media screen and (min-width: 768px) {
  .ac-content-width {
    width: 740px;
  }
}
@media screen and (min-width: 992px) {
  .ac-content-width {
    width: 800px;
  }
}

.acces__sect {
  font-size: 13px;
  line-height: 1.7333333333;
}
@media screen and (min-width: 768px) {
  .acces__sect {
    font-size: 15px;
  }
}
.acces__sect h2, .acces__sect h3, .acces__sect h4, .acces__sect h5 {
  line-height: 1;
}
.acces__sect h3 {
  font-size: 2em;
  line-height: 1.1333333333;
}
.acces__sect h3::before {
  bottom: -0.4em;
}
.acces__sect h4 {
  font-size: 1.3333333333em;
  color: #891c32;
  font-weight: 600;
}

.acces__selector {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, 0.5fr);
  grid-template-rows: auto;
  margin-bottom: 2.5333333333em;
}
@media screen and (min-width: 768px) {
  .acces__selector {
    gap: 20px;
  }
}
.acces__selector .selector-tab {
  background: url(../img/access/ac-tab-arrow.svg) 50% calc(100% - 12px)/auto 12px no-repeat;
  padding-bottom: 11px;
  transition: all 0.15s ease-in-out;
}
.acces__selector .selector-tab > label {
  background-color: #ca99a3;
  color: #000;
  display: block;
  cursor: pointer;
  font-size: 1.2em;
  font-weight: 600;
  line-height: 1.25;
  padding: 1.3333333333em 0.5em;
  text-align: center;
  transition: inherit;
}
@media screen and (min-width: 768px) {
  .acces__selector .selector-tab > label {
    transition: background-color 0.15s ease, color 0.15s ease;
  }
  .acces__selector .selector-tab > label:hover {
    color: #fff;
    background-color: rgb(212.8981818182, 49.0018181818, 82.0818181818);
  }
}

.acces__detail {
  display: none;
}

.acces__sect input[value=motor]:checked ~ .acces__selector .selector-tab.motor {
  background-position: 50% 100%;
  pointer-events: none;
}
.acces__sect input[value=motor]:checked ~ .acces__selector .selector-tab.motor > label {
  background-color: #891c32;
  color: #fff;
}
.acces__sect input[value=motor]:checked ~ .acces__details > .acces__detail.motor {
  display: block;
}

.acces__sect input[value=train]:checked ~ .acces__selector .selector-tab.train {
  background-position: 50% 100%;
  pointer-events: none;
}
.acces__sect input[value=train]:checked ~ .acces__selector .selector-tab.train > label {
  background-color: #891c32;
  color: #fff;
}
.acces__sect input[value=train]:checked ~ .acces__details > .acces__detail.train {
  display: block;
}

.acces__details {
  margin-bottom: 6.6666666667em;
}

.acces__chart {
  margin-bottom: 2.2em;
}
.acces__chart img {
  display: block;
  height: auto;
  margin: 0 auto 3.2em;
  width: 100%;
}
.acces__chart .note-list {
  border: 2px solid #e6e6e6;
  line-height: 1.7333333333;
  padding: 1.1333333333em 2em;
}

.acces__detail.motor .acces__chart img {
  max-width: 606px;
}
.acces__detail.motor .acces__chart .note-list > li {
  margin-left: 1.15em;
  text-indent: -1.15em;
}

.acces__chart-and-notes {
  margin-bottom: 3em;
}

.acces__carnav {
  margin-bottom: 5.0666666667em;
  text-align: center;
}
.acces__carnav h4 {
  margin-bottom: 1.4em;
}
.acces__carnav h5 {
  display: flex;
  font-size: 1em;
  font-weight: 400;
  justify-content: center;
  margin-bottom: 0.5333333333em;
  margin-top: 1.4em;
}
.acces__carnav h5 span {
  border-bottom: 1px solid #891c32;
  padding-bottom: 0.4em;
}

.acces__wheelchair {
  background-color: #f2e5e8;
  text-align: center;
  padding: 1.8666666667em 1em;
}
.acces__wheelchair h4 {
  margin-bottom: 0.8em;
}

.acces__parking {
  text-align: center;
  margin-bottom: 1.7333333333em;
}

.acces__routemap {
  border: 2px solid #e6e6e6;
  margin-bottom: 2.8666666667em;
  position: relative;
}
.acces__routemap picture {
  position: relative;
}
.acces__routemap .routemap-point-list {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
.acces__routemap .routemap-point-list > li {
  animation: routemap_point_move 1.5s ease-in-out 0s infinite both;
  animation-delay: calc(var(--dly) * 0.1s);
  animation-play-state: paused;
  background-position: 50% 100%;
  background-repeat: no-repeat;
  background-size: contain;
  cursor: pointer;
  height: 7.3%;
  position: absolute;
  transform-origin: 50% 100%;
  width: 3.8%;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .acces__routemap .routemap-point-list > li {
    transition: filter 0.15s ease;
  }
  .acces__routemap .routemap-point-list > li:hover {
    filter: contrast(150%) brightness(110%) drop-shadow(0px 1px 3px rgba(0, 0, 0, 0.35));
  }
}
.acces__routemap .routemap-point-list > li.point-1n, .acces__routemap .routemap-point-list > li.point-1g {
  background-image: url(../img/access/ac-mot-mk1.svg);
}
.acces__routemap .routemap-point-list > li.point-1n {
  left: 32.1608040201%;
  top: 76.7716535433%;
}
.acces__routemap .routemap-point-list > li.point-1g {
  left: 24.7487437186%;
  top: 74.4094488189%;
}
.acces__routemap .routemap-point-list > li.point-2 {
  background-image: url(../img/access/ac-mot-mk2.svg);
  left: 28.1407035176%;
  top: 71.4566929134%;
}
.acces__routemap .routemap-point-list > li.point-3 {
  background-image: url(../img/access/ac-mot-mk3.svg);
  left: 42.7135678392%;
  top: 62.7952755906%;
}

@media screen and (max-width: 640px) {
  .acces__routemap.scroll {
    overflow-x: scroll;
    overflow-y: hidden;
  }
  .acces__routemap.scroll > .container {
    height: 409px;
    width: 640px;
    position: relative;
  }
  .acces__routemap.scroll > .container picture {
    height: 100%;
  }
  .acces__routemap.scroll > .container picture > img {
    height: 100%;
    width: auto;
  }
}
@keyframes routemap_point_move {
  0% {
    rotate: 0deg;
  }
  25% {
    rotate: 15deg;
  }
  50% {
    rotate: 0deg;
  }
  75% {
    rotate: -15deg;
  }
  100% {
    rotate: 0deg;
  }
}
.acces__sect input[value=motor]:checked ~ .acces__details .routemap-point-list > li {
  animation-play-state: running;
}

@media screen and (min-width: 576px) {
  .acces__routepic-list {
    display: grid;
    grid-template-columns: repeat(2, 0.5fr);
    grid-template-rows: repeat(5, auto);
    gap: 0 2.6666666667em;
  }
}
.acces__routepic-list .caption {
  display: grid;
  gap: 0.6666666667em;
  grid-template-columns: 1.5333333333em 1fr;
  grid-template-rows: auto;
  margin: 0.6666666667em 0 2em;
}
.acces__routepic-list .icon {
  background-size: contain;
  background-repeat: no-repeat;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
.acces__routepic-list .point-1n .icon,
.acces__routepic-list .point-1g .icon {
  background-image: url(../img/access/ac-mot-mk1.svg);
}
.acces__routepic-list .point-2 .icon {
  background-image: url(../img/access/ac-mot-mk2.svg);
}
.acces__routepic-list .point-3 .icon {
  background-image: url(../img/access/ac-mot-mk3.svg);
}
.acces__routepic-list .desc .strong {
  font-weight: 600;
}
.acces__routepic-list .desc .strong ~ p {
  margin-top: -0.2em;
}

.acces__timetable .timetable-head {
  margin: 5.3333333333em auto 2.3333333333em;
  text-align: center;
}
.acces__timetable .timetable-data {
  display: grid;
  gap: 1.2em 1.0666666667em;
  grid-template-columns: 9.3em 1fr;
  grid-template-rows: auto;
  margin: 0 auto 2.3333333333em;
  max-width: 500px;
}
.acces__timetable .timetable-data dt {
  background-color: #891c32;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.3333333333em;
  text-align: center;
}
.acces__timetable .timetable-data dt.widen {
  letter-spacing: 0.3333333333em;
  padding-right: 0;
}
.acces__timetable .timetable-data dd {
  align-items: center;
  border-bottom: 1px solid #891c32;
  display: flex;
  padding: 0.3333333333em;
}
.acces__timetable .table-group-single table + table {
  margin-top: 2em;
}
.acces__timetable .table-group-single {
  margin: 0 auto;
  max-width: 500px;
}
.acces__timetable table {
  border-collapse: collapse;
  line-height: 1.3333333333;
}
.acces__timetable table th, .acces__timetable table td {
  border: 1px solid #891c32;
  font-size: 1em;
  padding: 0.6333333333em 0;
  text-align: center;
}
.acces__timetable table th .gridcell, .acces__timetable table td .gridcell {
  align-items: center;
  display: grid;
  grid-template-columns: 0.25fr 1.1em 0.25fr 1.1em 0.25fr 1.1em 0.25fr;
}
.acces__timetable table th {
  background-color: #891c32;
  color: #fff;
  font-weight: 400;
}
.acces__timetable table td {
  letter-spacing: 0.5px;
}
.acces__timetable table td.red {
  color: #f00;
}
.acces__timetable .table-group-caption {
  color: #f00;
  font-size: 0.8666666667em;
  margin: 1em auto 0;
  max-width: 500px;
}

#routePicCard {
  align-items: center;
  animation: rpc_fadein 0.3s ease 0s 1 both;
  background-color: rgba(0, 0, 0, 0.75);
  cursor: pointer;
  height: 100%;
  display: flex;
  font-size: 16px;
  justify-content: center;
  left: 0;
  opacity: 0;
  padding: 1em;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 1000;
}
@media screen and (min-width: 576px) {
  #routePicCard {
    font-size: 18px;
  }
}
#routePicCard.fadeout {
  animation: rpc_fadeout 0.3s ease 0s 1 both;
}
#routePicCard .routepiccard__base {
  background-color: #fff;
  border-radius: 4px;
  box-shadow: 0px 8px 24px rgba(0, 0, 0, 0.5);
  cursor: auto;
  padding: 0.6666666667em;
}
@media screen and (min-width: 768px) {
  #routePicCard .routepiccard__base {
    max-width: 800px;
    width: 73%;
  }
}
#routePicCard .routepiccard__content {
  pointer-events: none;
}
#routePicCard .routepiccard__content .caption {
  display: grid;
  gap: 0.6666666667em;
  grid-template-columns: 1.5333333333em 1fr;
  grid-template-rows: auto;
  margin: 0.6666666667em 0 0;
}
#routePicCard .routepiccard__content .icon {
  background-size: contain;
  background-repeat: no-repeat;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
#routePicCard .routepiccard__content.point-1n .icon, #routePicCard .routepiccard__content.point-1g .icon {
  background-image: url(../img/access/ac-mot-mk1.svg);
}
#routePicCard .routepiccard__content.point-2 .icon {
  background-image: url(../img/access/ac-mot-mk2.svg);
}
#routePicCard .routepiccard__content.point-3 .icon {
  background-image: url(../img/access/ac-mot-mk3.svg);
}
#routePicCard .routepiccard__content .desc .strong {
  font-weight: 600;
}
#routePicCard .routepiccard__content .desc .strong ~ p {
  margin-top: -0.2em;
}

@keyframes rpc_fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes rpc_fadeout {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
#bus {
  max-width: 900px;
  width: 90%;
}
@media screen and (min-width: 768px) {
  #bus {
    width: 95%;
  }
}
@media screen and (min-width: 900px) {
  #bus {
    width: 100%;
  }
}
#bus .tbl {
  flex-wrap: wrap;
  justify-content: center;
}
@media screen and (min-width: 768px) {
  #bus .tbl {
    flex-wrap: nowrap;
    justify-content: space-between;
  }
}
#bus .tbl li {
  margin-bottom: 15px;
  max-width: 440px;
  width: 100%;
}
@media screen and (min-width: 768px) {
  #bus .tbl li {
    flex-basis: 48.9%;
    margin-bottom: 0;
    width: auto;
  }
}
#bus .tbl li > img {
  display: block;
  height: auto;
  width: 100%;
}
#bus .note {
  max-width: 900px;
  width: auto;
}

#guidmap .note {
  max-width: 900px;
  width: 90%;
}
@media screen and (min-width: 768px) {
  #guidmap .note {
    width: 95%;
  }
}
@media screen and (min-width: 900px) {
  #guidmap .note {
    width: 100%;
  }
}

#news dl {
  max-width: 600px;
  width: 90%;
}
@media screen and (min-width: 768px) {
  #news dl {
    width: 95%;
  }
}
@media screen and (min-width: 600px) {
  #news dl {
    width: 100%;
  }
}
