@charset "utf-8";

/* reset
-------------------------------------------------- */
html, body, h1, h2, h3, h4, h5, h6,
div, p, ul, ol, li, dl, dt, dd,
span, em, strong, b, u, i, center, img, a,
table, tbody, thead, tfoot, tr, th, td, caption,
article, header, footer, nav, section, figure, figcaption,
form, input, label, button, select,
iframe, address{
	margin: 0;
	padding: 0;
	border: 0;
	outline: none;
	vertical-align: baseline;
	background: transparent;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}
article, header, footer, nav, section, figure, figcaption{
	display: block;
}
body{
	color: #333;
	font-size: 15px;
	font-family: Verdana,"游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, sans-serif;
	font-weight: normal;
	line-height: 1.6;
}
ul, ol{
	list-style: none;
}
table{
	border-collapse: collapse;
	border-spacing: 0;
}
img{
	vertical-align: bottom;
}
a{
	color: #333;
	text-decoration: none;
}
a:hover{
	text-decoration: none;
}

@media screen and (max-width:767px){
	body{
		font-size: 14px;
	}
}


/* wrapper
-------------------------------------------------- */
.wrapper{
	border-top: #ff0000 10px solid;
}

@media screen and (max-width:1024px){
	.wrapper{
		background: none;
		border-top: #ff0000 10px solid;
	}
}


/* main
-------------------------------------------------- */
/* main_visual */
.main_visual{
	background: url("../img/kv.png") no-repeat top center;
	background-size:inherit;
    padding-bottom: 20%;
}

.main_visual .logo_ttl h1{
	position: relative;
	/*width: 58%;*/
	width: 400px;
	margin: 0 auto;
	/*padding: 53.625% 0;*/
}

@media screen and (max-width:1024px){
	.main_visual{
		background: url("../img/kv_sp.png") no-repeat top center;
		background-size: cover;
        padding-bottom: 40%;
	}

	.main_visual .logo_jr{
		width: 9%;
	}
}

@media screen and (max-width:767px){
	.main_visual .logo_ttl h1{
		width: 80%;
		padding: 20% 0;
	}
	.main_visual .logo_jr{
		width: 13%;
		right: 3%;
	}
.main_visual{
	height: auto;
}
.logo_ttl{
	width: auto;
}
}


/*種田　改修 2021/8/31
-------------------------------------------------- */

/* cont_inner
-------------------------------------------------- */
.button03{
	margin-top: 30px;
	margin-bottom: 30px;
}
.button03 a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
  padding: 1em 2em;
  width: 256px;
  color: #111;
  font-size: 18px;
  border: 2px solid #2285b1;
	  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
}

.button03 a:hover {
  color: #fff;
  text-decoration: none;
  background-color: #073e53;
	opacity: 0.6;
	
}

.button03 a:hover::after {
  border-top: 3px solid #333333;
  border-right: 3px solid #333333;
}


/* footer
-------------------------------------------------- */
.footer{
	margin-top: 100px;
	padding: 25px;
	color: #fff;
	font-size: 13px;
	text-align: center;
	/*background: #03508b;*/
	background: rgb(36,0,0);
background: -moz-linear-gradient(180deg, rgba(36,0,0,0) 0%, rgba(255,0,0,1) 35%, rgba(121,9,9,1) 100%);
background: -webkit-linear-gradient(180deg, rgba(36,0,0,0) 0%, rgba(255,0,0,1) 35%, rgba(121,9,9,1) 100%);
background: linear-gradient(180deg, rgba(36,0,0,0) 0%, rgba(255,0,0,1) 35%, rgba(121,9,9,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#240000",endColorstr="#790909",GradientType=1);
	/*background-size:cover; */
}

@media screen and (max-width:767px){
	.footer{
		margin-top: 30px;
		padding: 15px 10px;
	}
	
	.footer{
	background: url("../img/fooetr_bg_color_sp.jpg") top center no-repeat;
	background-size:cover; 
}

}


/* module

-------------------------------------------------- */
/* infomation area */

.block{
	display: block;
	width: 100%;
}

.block_inner.w_900{
	max-width: 900px;
	width: 100%;
	margin: 0 auto;
	padding: 0 10px;
}

.inner_info_flex{
	/*border: 1px solid #110;*/
	margin-top: 69px;
}

.info_Area{
	width: 100%;
	padding: 20px 50px;
}

.info_Area_title{
	font-size: 20px;
	text-align: center;
}


.info_Area_title span{
	border-bottom: 1px solid #000;
}

.item{
	display: flex;
	align-items: center;
	-webkit-align-items: center;
}

.column{
	display: flex;
	align-items: center;
}

.column time{
	font-size: 14px;
	margin-right: 1.4rem;
	white-space: nowrap;
	text-align: left;
}

.column .info_Area_text{
	font-size: 16px;
	text-align: left;
}

.info_Area_textArea{
	margin-top: 20px;
}

.info_Area_textArea .item:not(:first-child){
	margin-top: 20px;
}

.mb_set{
	margin-bottom: 70px;
}

.pc_only{
	display: block;
}

.sp_only{
	display: none;
}

/* -------------------------------------------------- */
/* form area */

.inner_form{
	/*border: 1px solid #110;*/
	margin-top: 70px;
}

.form_Area{
	text-align: center;
}


.form_Area_title{
	font-size: 18px;
	text-align: center;
	font-weight: bold;
	margin-top: 20px;
	margin-bottom: 20px;
}


.link_form{
	margin-top: 1.4rem;
	margin-bottom: 1.1rem;
}
.info_Area_text a,
.link_form a{
	transition-timing-function:ease;
	transition-duration:.4s;
}

.info_Area_text a:hover,
.link_form a:hover{
	color: #bf9b00;
}


.button1,
a.button1,
button.button1 {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 1rem 4rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #212529;
  border-radius: 0.5rem;
}
.button1-c-wrap {
  margin: 30px 0;
  text-align: center;
}
a.button1-c {
  font-size: 1.15rem;
  width: 100%;
  position: relative;
  padding: 0.25rem 2rem 0.5rem 1.8rem;
  color: #333;
  background: #fff100;
  -webkit-box-shadow: 0 5px 0 #2c9d60;
  box-shadow: 0 5px 0 #ccc100;
}
a.button1-c span {
  font-size: 0.8rem;
  position: absolute;
  top: -0.75rem;
  left: calc(50% - 180px);
  display: block;
  width: 360px;
  padding: 0.25rem 0;
  color: #333;
  border: 2px solid #ccc100;
  border-radius: 100vh;
  background: #fff;
  -webkit-box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
}
a.button1-c span:before,
a.button1-c span:after {
  position: absolute;
  left: calc(50% - 10px);
  content: "";
}
a.button1-c span:before {
  bottom: -10px;

  border-width: 10px 10px 0 10px;
  border-style: solid;
  border-color: #ccc100 transparent transparent transparent;
}

a.button1-c span:after {
  bottom: -7px;

  border-width: 10px 10px 0 10px;
  border-style: solid;
  border-color: #fff transparent transparent transparent;
}

a.button1-c i {
  margin-right: 0.75rem;
}

a.button1-c:hover {
  -webkit-transform: translate(0, 3px);
  transform: translate(0, 3px);

  color: #333;
  background: #fff100;
  -webkit-box-shadow: 0 2px 0 #ccc100;
  box-shadow: 0 2px 0 #ccc100;
}



/*--------------------------------------
年末年始期間の臨時列車運転のお知らせ
--------------------------------------*/
.button2,
a.button2,
button.button2 {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 1rem 4rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #212529;
  border-radius: 0.5rem;
}
.button2-c-wrap {
  margin: 30px 0;
  text-align: center;
}
a.button2-c {
  font-size: 1.15rem;
  width: 100%;
  position: relative;
  padding: 0.25rem 2rem 0.5rem 1.8rem;
  color: #fff;
  background: #e94919;
  -webkit-box-shadow: 0 5px 0 #d44114;
  box-shadow: 0 5px 0 #d44114;
}
a.button2-c span {
  font-size: 0.8rem;
  position: absolute;
  top: -0.75rem;
  left: calc(50% - 180px);
  display: block;
  width: 360px;
  padding: 0.25rem 0;
  color: #d44114;
  border: 2px solid #d44114;
  border-radius: 100vh;
  background: #fff;
  -webkit-box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
}
a.button2-c span:before,
a.button2-c span:after {
  position: absolute;
  left: calc(50% - 10px);
  content: "";
}
a.button2-c span:before {
  bottom: -10px;

  border-width: 10px 10px 0 10px;
  border-style: solid;
  border-color: #d44114 transparent transparent transparent;
}

a.button2-c span:after {
  bottom: -7px;

  border-width: 10px 10px 0 10px;
  border-style: solid;
  border-color: #fff transparent transparent transparent;
}

a.button2-c i {
  margin-right: 0.75rem;
}

a.button2-c:hover {
  -webkit-transform: translate(0, 3px);
  transform: translate(0, 3px);

  color: #fff;
  background: #eb5b30;
  -webkit-box-shadow: 0 2px 0 #d44114;
  box-shadow: 0 2px 0 #d44114;
}

/*--------------------------------------
12 月分 臨時列車運転のお知らせ
--------------------------------------*/

.button3,
a.button3,
button.button3 {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 1rem 4rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #212529;
  border-radius: 0.5rem;
}

.button3-wrap {
  margin: 30px 0;
  text-align: center; 
}

a.button3-c {
    font-size: 1.15rem;
    width: 100%;
    position: relative;
    padding: 0.25rem 2rem 0.5rem 2.1rem;
    color: #333;
    background: #fff100;
    -webkit-box-shadow: 0 5px 0 #2c9d60;
    box-shadow: 0 5px 0 #ccc100;
}

a.button3-c span {
    font-size: 0.8rem;
    position: absolute;
    top: -10px;
    left: calc(50% - 150px);
    display: block;
    width: 300px;
    padding: 0.2rem 0;
    color: #333;
    border: 2px solid #333;
    border-radius: 0.5rem;
    background: #fff;
  -webkit-box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
}

a.button3-c:hover {
  -webkit-transform: translate(0, 3px);
  transform: translate(0, 3px);
  color: #333;
  background: #fff100;
  -webkit-box-shadow: 0 2px 0 #ccc100;
  box-shadow: 0 2px 0 #ccc100;
}

a.button3-c:hover:before {
  left: 2rem;
}





.block.bg_c{
	background-color: #fffef9;
}

.block img{
	height: auto;
	width: 100%;
}

.block .block_inner.m_set1{
	margin-top: 69px;
	margin-bottom: 64px;
}

.block .block_inner.p_set2{
	padding-top: 70px;
	padding-bottom: 65px;
}


@media screen and (max-width:767px){
	.sp_only{
		display: block;
	}
	.pc_only{
		display: none;
	}
	
	.block .block_inner.m_set1{
	margin-top: 8.93%;
	margin-bottom: 2.8%;
}
	
	.block .block_inner.p_set2{
	padding-top: 7.3%;
	padding-bottom: 6.93%;
	}
	
	.block_inner.w_900{
	margin: 0 auto;
	padding: 0 2.93% 0;
	}
	.mb_set{
	margin-bottom: 8.13%;
	}
	
	.column{
	display: flex;
	align-items: flex-start;
		flex-direction: column;
	}
	
	.form_Area_title{
	font-size: 14px;
	margin-top: 20px;
	margin-bottom: 20px;
	}
	.column{
		display: block;
	}
	
	
}

/*-------------------------------------------------- */


/* clearFix */
.clearFix::after{
	display: block;
	clear: both;
	content: "";
}

/* universal class */
.fL{ float: left; }
.fR{ float: right; }
.clear{ clear: both; }

.taL{ text-align: left; }
.taR{ text-align: right; }
.taC{ text-align: center; }

.vaT{ vertical-align: top; }
.vaM{ vertical-align: middle; }
.vaB{ vertical-align: bottom; }

.indent{ padding-left: 1em; text-indent: -1em; }
.indent_list li{ padding-left: 1em; text-indent: -1em; }

.fwN{ font-weight: normal; }
.fwB{ font-weight: bold; }

.fs70{ font-size: 70% !important; }
.fs75{ font-size: 75% !important; }
.fs80{ font-size: 80% !important; }
.fs85{ font-size: 85% !important; }
.fs90{ font-size: 90% !important; }
.fs95{ font-size: 95% !important; }
.fs100{ font-size: 100% !important; }
.fs105{ font-size: 105% !important; }
.fs110{ font-size: 110% !important; }
.fs115{ font-size: 115% !important; }
.fs120{ font-size: 120% !important; }
.fs125{ font-size: 125% !important; }

.mT0{ margin-top: 0 !important; }
.mT5{ margin-top: 5px !important; }
.mT10{ margin-top: 10px !important; }
.mT15{ margin-top: 15px !important; }
.mT20{ margin-top: 20px !important; }
.mT25{ margin-top: 25px !important; }
.mT30{ margin-top: 30px !important; }
.mT35{ margin-top: 35px !important; }
.mT40{ margin-top: 40px !important; }
.mT45{ margin-top: 45px !important; }
.mT50{ margin-top: 50px !important; }
.mT55{ margin-top: 55px !important; }
.mT60{ margin-top: 60px !important; }

.mR0{ margin-right: 0 !important; }
.mR5{ margin-right: 5px !important; }
.mR10{ margin-right: 10px !important; }
.mR15{ margin-right: 15px !important; }
.mR20{ margin-right: 20px !important; }
.mR25{ margin-right: 25px !important; }
.mR30{ margin-right: 30px !important; }
.mR35{ margin-right: 35px !important; }
.mR40{ margin-right: 40px !important; }
.mR45{ margin-right: 45px !important; }
.mR50{ margin-right: 50px !important; }
.mR55{ margin-right: 55px !important; }
.mR60{ margin-right: 60px !important; }

.mB0{ margin-bottom: 0 !important; }
.mB5{ margin-bottom: 5px !important; }
.mB10{ margin-bottom: 10px !important; }
.mB15{ margin-bottom: 15px !important; }
.mB20{ margin-bottom: 20px !important; }
.mB25{ margin-bottom: 25px !important; }
.mB30{ margin-bottom: 30px !important; }
.mB35{ margin-bottom: 35px !important; }
.mB40{ margin-bottom: 40px !important; }
.mB45{ margin-bottom: 45px !important; }
.mB50{ margin-bottom: 50px !important; }
.mB55{ margin-bottom: 55px !important; }
.mB60{ margin-bottom: 60px !important; }

.mL0{ margin-left: 0 !important; }
.mL5{ margin-left: 5px !important; }
.mL10{ margin-left: 10px !important; }
.mL15{ margin-left: 15px !important; }
.mL20{ margin-left: 20px !important; }
.mL25{ margin-left: 25px !important; }
.mL30{ margin-left: 30px !important; }
.mL35{ margin-left: 35px !important; }
.mL40{ margin-left: 40px !important; }
.mL45{ margin-left: 45px !important; }
.mL50{ margin-left: 50px !important; }
.mL55{ margin-left: 55px !important; }
.mL60{ margin-left: 60px !important; }

.pT0{ padding-top: 0 !important; }
.pT5{ padding-top: 5px !important; }
.pT10{ padding-top: 10px !important; }
.pT15{ padding-top: 15px !important; }
.pT20{ padding-top: 20px !important; }
.pT25{ padding-top: 25px !important; }
.pT30{ padding-top: 30px !important; }
.pT35{ padding-top: 35px !important; }
.pT40{ padding-top: 40px !important; }
.pT45{ padding-top: 45px !important; }
.pT50{ padding-top: 50px !important; }
.pT55{ padding-top: 55px !important; }
.pT60{ padding-top: 60px !important; }

.pR0{ padding-right: 0 !important; }
.pR5{ padding-right: 5px !important; }
.pR10{ padding-right: 10px !important; }
.pR15{ padding-right: 15px !important; }
.pR20{ padding-right: 20px !important; }
.pR25{ padding-right: 25px !important; }
.pR30{ padding-right: 30px !important; }
.pR35{ padding-right: 35px !important; }
.pR40{ padding-right: 40px !important; }
.pR45{ padding-right: 45px !important; }
.pR50{ padding-right: 50px !important; }
.pR55{ padding-right: 55px !important; }
.pR60{ padding-right: 60px !important; }

.pB0{ padding-bottom: 0 !important; }
.pB5{ padding-bottom: 5px !important; }
.pB10{ padding-bottom: 10px !important; }
.pB15{ padding-bottom: 15px !important; }
.pB20{ padding-bottom: 20px !important; }
.pB25{ padding-bottom: 25px !important; }
.pB30{ padding-bottom: 30px !important; }
.pB35{ padding-bottom: 35px !important; }
.pB40{ padding-bottom: 40px !important; }
.pB45{ padding-bottom: 45px !important; }
.pB50{ padding-bottom: 50px !important; }
.pB55{ padding-bottom: 55px !important; }
.pB60{ padding-bottom: 60px !important; }

.pL0{ padding-left: 0 !important; }
.pL5{ padding-left: 5px !important; }
.pL10{ padding-left: 10px !important; }
.pL15{ padding-left: 15px !important; }
.pL20{ padding-left: 20px !important; }
.pL25{ padding-left: 25px !important; }
.pL30{ padding-left: 30px !important; }
.pL35{ padding-left: 35px !important; }
.pL40{ padding-left: 40px !important; }
.pL45{ padding-left: 45px !important; }
.pL50{ padding-left: 50px !important; }
.pL55{ padding-left: 55px !important; }
.pL60{ padding-left: 60px !important; }
