/* --------------------------------------------------

  reserve

-------------------------------------------------- */

/* Common
-----------------------------------------------------------*/
.reserve {
  text-align: center;
  width: 1000px;
  margin: 0 auto;
  padding-top: 6rem;
  padding-bottom: 160px;
}
.reserve .reservationBlock {
  width: 700px;
  margin: 0 auto;
}
.reserve .reservationBlock .reservationBlock_inner {
  background: #fff;
  border-radius: 5px;
  padding-bottom: 45px;
}
/* headline*/
.reserve .reservationBlock h2 {
  margin-bottom: 30px;
}
.reserve .reservationBlock h3 {
  background: #0077c2;
  color: #fff;
  padding: 18.5px 0;
  border-radius: 5px 5px 0 0;
  margin-bottom: 0;
  font-size: 2rem;
}
/* paragraph*/
.reserve .reservationBlock p {
  margin-bottom: 0;
}
/* attentionList*/
.reserve .reservationBlock .attentionList {
  padding: 1rem 4.5rem 0;
}
.reserve .reservationBlock h3 + .attentionList,
.reserve .reservationBlock p + .attentionList {
  padding-top: 0;
}
.reserve .reservationBlock .attentionList ul {
  text-align: left;
  line-height: 2;
}
.reserve .reservationBlock .attentionList ul li {
  margin-left: 1rem;
  text-indent: -1rem;
  letter-spacing: 0.05em;
  font-size: .875rem;
}

@media screen and (max-width: 1120px) {
  .reserve {
    padding-bottom: 145px;
    width: 92%;
  }
  .reserve .reservationBlock {
    width: 74%;
  }
  .reserve .reservationBlock h2 {
    margin-bottom: 26px;
  }
}
@media screen and (max-width: 980px) {
  .reserve .reservationBlock .reservationBlock_inner {
    padding-bottom: 40px;
  }
  .reserve .reservationBlock h3 {
    padding: 16px 0;
    font-size: 1.85rem;
  }
  .reserve .reservationBlock p {
    font-size: 14px;
  }
}
@media screen and (max-width: 768px) {
  .reserve {
    width: 100%;
    padding: 0 20px 75px 20px;
    padding: 3rem 15px 75px 15px;
  }
  .reserve .reservationBlock {
    width: 100%;
    font-size: 1rem;
  }
  .reserve .reservationBlock h2 {
    margin-bottom: 22px;
  }
  .reserve .reservationBlock h3 {
    font-size: 1.9rem;
    padding: 11px 0;
    margin-bottom: 32px;
  }
  .reserve .reservationBlock p {
    line-height: 1.8;
    padding: 0 20px;
    padding: 0 15px;
    font-size: 1rem;
  }
  .reserve .reservationBlock .attentionList {
    padding-right:  15px;
    padding-left:  15px;
  }
  .reserve .reservationBlock .attentionList ul li {
    font-size: 1rem;
  }
}

/* Form
-----------------------------------------------------------*/
/* common
------------------------------*/
.reserve .reservationBlock .reservationForm {
  margin: 2rem auto 0;
  padding-top: 30px;
  /* border-top: 1px solid #DEDEDE; */
  width: 560px;
}
.reserve .reservationBlock .reservationForm ul{
  margin-bottom: 45px;
  text-align: left;
}
.reserve .reservationBlock .reservationForm ul li:not(:last-child){
  margin-bottom: 30px;
  padding-bottom: 30px;
  /* border-bottom: 1px solid #DEDEDE; */
}
.reserve * {
  -webkit-text-size-adjust: 100%;
}
.reserve input,
.reserve textarea,
.reserve select,
.reserve button {
  -webkit-appearance: none;
  appearance: none;
}
.reserve input {
  appearance: auto;
  accent-color: #0077c2;
}
.reserve input[type=radio], 
.reserve input[type=checkbox], 
.reserve option {
  display: inline;
}
.reserve .reservationBlock select,
.reserve .reservationBlock input {
  border-radius: 4px;
  border: 1px solid #B8B8B8;
  font-size: 1rem;
}
@media screen and (max-width: 980px) {
  .reserve .reservationBlock .reservationForm {
    margin-top: 25px;
    padding-top: 25px;
    width: 86%;
    font-size: 14px;
  }
  .reserve .reservationBlock .reservationForm ul li:not(:last-child) {
    margin-bottom: 25px;
    padding-bottom: 25px;
  }
  .reserve .reservationBlock .reservationForm .selectWrap {
    width: 64%;
  }
}
@media screen and (max-width: 768px) {
  .reserve .reservationBlock .reservationForm {
    margin-top: 28px;
    padding: 28px 15px 0;
    width: 100%;
    font-size: 1rem;
  }
  .reserve .reservationBlock .reservationForm .selectWrap{
    width: 72%;
  }
  .reserve .reservationBlock .reservationForm select,
  .reserve .reservationBlock .reservationForm input{
    font-size: 1rem;
  }
  .reserve .reservationBlock .reservationForm ul {
    margin-bottom: 35px;
  }
}

/* routing
------------------------------*/
.reserve .reservationBlock .reservationForm ul li.routing {
  display: block;
}
.reserve .reservationBlock .reservationForm ul li.routing article {
  display: inline-block;
  margin-right: 26px;
}
.reserve .reservationBlock .reservationForm ul li.routing article:last-child {
  margin-right: 0;
}
.reserve .reservationBlock .reservationForm ul li.routing article label {
  background: #0077c2;
  color: #fff;
  display: inline-block;
  width: 92px;
  margin-right: 5px;
  padding: 10px 0 10px 10px;
  line-height: 1;
  vertical-align: middle;
}
.reserve .reservationBlock .reservationForm ul li.routing article label img {
  margin: 0 3px -1px 0;
  width: 15px;
  vertical-align: text-top;
}
.reserve .reservationBlock .reservationForm .selectWrap {
  display: inline-block;
  position: relative;
  width: 160px;
}
.reserve .reservationBlock .reservationForm .selectWrap::before {
  position: absolute;
  content: "";
  bottom: 45%;
  right: 10px;
  border-bottom: solid 1px #143A49;
  border-right: solid 1px #143A49;
  width: 5px;
  height: 5px;
  transform: rotate(45deg);
}
.reserve .reservationBlock .reservationForm ul li.routing article select,
.reserve .reservationBlock .reservationForm ul li.routing article .routingSelect {
  position: relative;
  padding: 10px 0 10px 10px;
  border: 1px solid #B8B8B8;
  width: 100%;
  letter-spacing: -0.5px;
  cursor: pointer;
}
.reserve .reservationBlock .reservationForm ul li.routing article select::before {
  content: none;
  position: absolute;
  width: 100%;
  height: 10px;
  background: #ccc;
}
@media screen and (max-width: 980px) {

  .reserve .reservationBlock .reservationForm ul li.routing article {
    margin-right: 3%;
    width: 48%;
  }
  .reserve .reservationBlock .reservationForm ul li.routing article label {
    width: 32%;
    padding: 10px 0 10px 8px;
    margin-right: 2%;
  }
  .reserve .reservationBlock .reservationForm ul li.routing article label img {
    width: 14px;
  }
  .reserve .reservationBlock .reservationForm ul li.routing article select {
    padding: 6px 0 6px 5%;
  }
}
@media screen and (max-width: 768px) {
  .reserve .reservationBlock .reservationForm ul li.routing article {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    margin-right: 0;
    margin-bottom: 14px;
    width: 100%;
  }
  .reserve .reservationBlock .reservationForm ul li.routing article:last-child{
    margin-bottom: 0;;
  }
  .reserve .reservationBlock .reservationForm ul li.routing article label {
    width: 26%;
    padding: 10px 0 10px 3%;
    margin-right: 1.75%;
    font-size: 1rem;
  }
  .reserve .reservationBlock .reservationForm ul li.routing article label img {
    width: 14px;
    margin: 0 4px -1px 0;
  }
  .reserve .reservationBlock .reservationForm ul li.routing article .selectWrap {
    display: flex;
    flex: 1 1 auto;
    min-width: 0;
  }
  .reserve .reservationBlock .reservationForm ul li.routing article select {
    letter-spacing: 0;
    padding: 10px 0 10px 10px;
    font-size: 1.2rem;
  }
}

/* calendar
------------------------------*/
.reserve .reservationBlock .reservationForm .flatpickr {
  display: flex;
  align-items: center;
}
.reserve .reservationBlock .reservationForm .flatpickr label {
  background: #0077c2;
  color: #fff;
  display: inline-block;
  width: 76px;
  padding: 10px 0 10px 10px;
  margin-right: 10px;
}
.reserve .reservationBlock .reservationForm .flatpickr label img {
  width: 17px;
  margin-right: 3px;
}
.reserve .reservationBlock .reservationForm .flatpickr .selectWrap {
  width: 230px;
  margin-right: 12px;
}
.reserve .reservationBlock .reservationForm .flatpickr .selectWrap::before {
  z-index: 1;
}
.reserve .reservationBlock .reservationForm .flatpickr .selectWrap::after {
  content: "";
  position: absolute;
  background: #fff;
  width: 18px;
  height: 70%;
  bottom: 20%;
  right: 4px;
}
.reserve .reservationBlock .reservationForm .flatpickr input {
  padding: 10px 0 10px 14px;
  width: 100%;
}
.reserve .reservationBlock .reservationForm .flatpickr .numInput{
  cursor: pointer;
}
.reserve .reservationBlock .reservationForm .flatpickr a,
.reserve .reservationBlock .reservationForm .flatpickr .input-button{
  display: inline-block;
  width: 26px;
  cursor: pointer;
}
@media screen and (max-width: 980px) {

  .reserve .reservationBlock .reservationForm .flatpickr label {
    width: 13%;
    padding: 10px 0 10px 8px;
    margin-right: 2%;
  }
  .reserve .reservationBlock .reservationForm .flatpickr .selectWrap {
    width: 35%;
    margin-right: 2%;
  }
  .reserve .reservationBlock .reservationForm .flatpickr input {
    padding: 10px 0 10px 5%;
  }
}
@media screen and (max-width: 768px) {
  .reserve .reservationBlock .reservationForm .flatpickr {
    display: flex;
    align-items: center;
    max-width: 100%;
  }
  .reserve .reservationBlock .reservationForm .flatpickr label {
    margin-right: 1.75%;
    padding: 10px 0 10px 2.5%;
    width: 26%;
    font-size: 1rem;
  }
  .reserve .reservationBlock .reservationForm .flatpickr label img {
    width: 14px;
  }
  .reserve .reservationBlock .reservationForm .flatpickr .selectWrap {
    display: flex;
    flex: 1 1 auto;
    min-width: 0;
    text-align: left;
  }
  .reserve .reservationBlock .reservationForm .flatpickr input {
    align-self: center; 
    display: flex;
    justify-content: flex-start;
    box-sizing: border-box;
    padding: 10px 0 10px 10px;
    width: 100%;
    height: 40px;
    font-size: 16px;
    text-align: left !important;
    text-indent: 0; 
    -webkit-appearance: none;
    appearance: none;
  }
  .reserve .reservationBlock .reservationForm .flatpickr a {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    text-decoration: none;
    line-height: 1;
    cursor: pointer;
  }
  .reserve .reservationBlock .reservationForm .flatpickr a i {
    display: block;
    width: 26px;
  }
}

/* people
------------------------------*/
.reserve .reservationBlock .reservationForm .people{
  display: flex;
}
.reserve .reservationBlock .reservationForm .people article{
  margin-right: 30px;
}
.reserve .reservationBlock .reservationForm .people article:last-child{
  margin-right: 0;
}
.reserve .reservationBlock .reservationForm .people article label{
  background: #0077c2;
  color: #fff;
  display: inline-block;
  width: 76px;
  margin-right: 5px;
  padding: 10px 0 10px 10px;
  line-height: 1;
  vertical-align: middle;
}
.reserve .reservationBlock .reservationForm .people article label img{
  width: 15px;
  margin-right: 4px;
  vertical-align: text-top;
}
.reserve .reservationBlock .reservationForm .people .selectWrap{
  display: inline-block;
  width: 90px;
}
.reserve .reservationBlock .reservationForm .people .selectWrap::before {
  bottom: 45%;
}
.reserve .reservationBlock .reservationForm .people article select{
  padding: 10px 0 10px 10px;
  width: 100%;
  cursor: pointer;
  /*矢印消去*/
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.reserve .reservationBlock .reservationForm .people article span{
  display: inline-block;
  margin-left: 10px;
}
@media screen and (max-width: 980px) {

  .reserve .reservationBlock .reservationForm .people article {
    margin-right: 2%;
    width: 42%;
  }
  .reserve .reservationBlock .reservationForm .people article label {
    width: 32%;
    padding: 10px 0 10px 8px;
    margin-right: 3%;
  }
  .reserve .reservationBlock .reservationForm .people article select {
    padding: 6px 0 6px 5%;
  }
  .reserve .reservationBlock .reservationForm .people article span {
    margin-left: 2%;
  }
}
@media screen and (max-width: 768px) {
  .reserve .reservationBlock .reservationForm .people {
    display: inline-block;
    width: 100%;
  }
  .reserve .reservationBlock .reservationForm .people article{
    display: inline-block;
    display: flex;
    margin-right: 0;
    margin-bottom: 14px;
    width: 100%;
  }
  .reserve .reservationBlock .reservationForm .people article:last-child{
    margin-bottom: 0;
  }
  .reserve .reservationBlock .reservationForm .people article label {
    width: 26%;
    font-size: 1rem;
  }
  .reserve .reservationBlock .reservationForm .people article label img {
    width: 14px;
    margin-right: 4px;
  }
  .reserve .reservationBlock .reservationForm .people .selectWrap {
    display: flex;
    flex: 1 1 auto;
  }
  .reserve .reservationBlock .reservationForm .people article select {
    padding: 8px 0 8px 5%;
    font-size: 16px;
  }
  .reserve .reservationBlock .reservationForm .people article span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    font-size: 16px;
  }
}

/* train select
------------------------------*/
.reserve .reservationBlock .reservationForm ul li.trainSelectorWrap article {
  display: inline-block;
  width: 100%;
}
.reserve .reservationBlock .reservationForm ul li.trainSelectorWrap article label {
  background: #000;
  color: #fff;
  display: inline-block;
  width: 92px;
  margin-right: 5px;
  padding: 10px 0 10px 10px;
  line-height: 1;
  vertical-align: middle;
}
.reserve .reservationBlock .reservationForm ul li.trainSelectorWrap article label img {
  margin: 0 3px -1px 0;
  width: 15px;
  vertical-align: text-top;
}
.reserve .reservationBlock .reservationForm ul li.trainSelectorWrap article .selectWrap {
  width: calc(100% - 105px);
}
.reserve .reservationBlock .reservationForm ul li.trainSelectorWrap article .selectWrap::before {
  position: absolute;
  content: "";
  bottom: 45%;
  right: 10px;
  border-bottom: solid 1px #143A49;
  border-right: solid 1px #143A49;
  width: 5px;
  height: 5px;
  transform: rotate(45deg);
}
.reserve .reservationBlock .reservationForm ul li.trainSelectorWrap article select {
  position: relative;
  padding: 10px 0 10px 10px;
  border: 1px solid #B8B8B8;
  width: 100%;
  letter-spacing: -0.5px;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .reserve .reservationBlock .reservationForm ul li.trainSelectorWrap article {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    margin-right: 0;
    margin-bottom: 14px;
    width: 100%;
  }
  .reserve .reservationBlock .reservationForm ul li.trainSelectorWrap article label {
    width: 26%;
    padding: 10px 0 10px 3%;
    margin-right: 1.75%;
    font-size: 1rem;
  }
  .reserve .reservationBlock .reservationForm ul li.trainSelectorWrap article label img {
    width: 14px;
    margin: 0 4px -1px 0;
  }
  .reserve .reservationBlock .reservationForm ul li.trainSelectorWrap article .selectWrap {
    display: flex;
    flex: 1 1 auto;
    width: auto;
    min-width: 0;
  }
  .reserve .reservationBlock .reservationForm ul li.trainSelectorWrap article select {
    letter-spacing: 0;
    padding: 10px 0 10px 10px;
    font-size: min(1.2rem, );
  }
}

/* #submit
------------------------------*/
.reserve .reservationBlock .reservationForm a#submit{
  box-sizing: border-box;
  display: block;
  margin: 0 auto;
  border-radius: 2rem;
  border: #000033 solid 1px;
  padding: 0.8rem 1rem 0.8rem 2rem;
  background-color: #fff;
  width: 16rem;
  text-align: center;
  text-decoration: none;
  /*
  font-family: "Avenir", "Helvetica Neue", "Helvetica", "Arial",
  "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo",
  "游ゴシック", "Yu Gothic", "ＭＳ Ｐゴシック", sans-serif;
  */
  color: #000033;
  transition: 0.5s;
  cursor: pointer;
}
.reserve .reservationBlock .reservationForm a#submit:hover{
  background-color: #000033;
  color: #fff;
}
.reserve .reservationBlock .reservationForm a#submit::after{
  content: "→";
  margin-left: 1.5rem;
}
@media screen and (max-width: 767px) {
  .reserve .reservationBlock .reservationForm a#submit {
  padding: 0.8rem 1rem 0.8rem 2rem;
  width: 15rem;
  text-align: center;
  box-sizing: border-box;
  font-weight: bold;
  font-size: 1.25rem;
  }
  .reserve .reservationBlock .reservationForm a#submit {
  width: 80%;
  margin: 0 auto;
  }
}


/* Adjust
-----------------------------------------------------------*/

/* option：hidden＋disabled
------------------------------*/
/* 選択不可項目の配色 */
/*
.reserve .reservationBlock .reservationForm option[hidden]:disabled {
  background-color: #e4e4e4;
}
*/
/* 禁止ペア項目非表示 */
/*
option[data-blocked="1"] {
    display: none;
}
*/

/* 追従バナー
------------------------------*/
.btn_reserve {
  position: fixed;
  display: inline-block;
  margin: auto;
  transition: 0.5s;
  z-index: 5;
}
@media screen and (min-width: 769px) {
  .btn_reserve {
    top: 40%;
    right: 0;
    border-radius: 10px 0 0 10px;
    padding: 20px 12px;
    width: 46px;
    height: 202px;
  }
  .btn_reserve img {
    width: 22px;
    height: 162px;
  }
  .btn_reserve:hover {background-color: #B29233;}
}
@media screen and (max-width: 768px) {
  .btn_reserve {
    bottom: 0;
    left: 0;
    right: 0;
    border-radius: 10px 10px 0 0 ;
    width: 206px;
    height: 37px;
  }
}


/* Trains Custom
-----------------------------------------------------------*/
/* common
------------------------------*/
/* カレンダーアイコン */
.reserve .reservationBlock .reservationForm .flatpickr a i.material-icons {
  display: block;
  width: 26px;
  height: 27px;
  mask-image: url(/trains/common/reserve_form/img/icon_calendar.svg);
  mask-repeat: no-repeat;
}

/* atrain
------------------------------*/
/* headline, label*/
#atrain .reserve .reservationBlock h3, 
#atrain .reserve .reservationBlock .reservationForm ul li.routing article label, 
#atrain .reserve .reservationBlock .reservationForm .flatpickr label, 
#atrain .reserve .reservationBlock .reservationForm .people article label,
#atrain .reserve .reservationBlock .reservationForm ul li.trainSelectorWrap label {
  background-color: #db7308;
  color: #fff;
}
/* ico calendar */
#atrain .reserve .reservationBlock .reservationForm .flatpickr a i.material-icons {
  background-color: #db7308;
}
/* foroating Anchor */
#atrain #bnr_reserve .trainname {
  background-color: #db7308;
  color: #fff;
}
#atrain .btn_reserve {
  background: #db7308;
}


/* yufuinnomori
------------------------------*/
/* headline, label*/
#yufuinnomori .reserve .reservationBlock h3, 
#yufuinnomori .reserve .reservationBlock .reservationForm ul li.routing article label, 
#yufuinnomori .reserve .reservationBlock .reservationForm .flatpickr label, 
#yufuinnomori .reserve .reservationBlock .reservationForm .people article label,
#yufuinnomori .reserve .reservationBlock .reservationForm ul li.trainSelectorWrap label {
	background-color: #00751a;
	color: #fff;
}
/* ico calendar */
#yufuinnomori .reserve .reservationBlock .reservationForm .flatpickr a i.material-icons {
	background-color: #00751a;
}
/* foroating Anchor */
#yufuinnomori #bnr_reserve .trainname {
  background-color: #00751a;
  color: #fff;
}
#yufuinnomori .btn_reserve {
  background: #00751a;
}

/* asoboy
------------------------------*/
/* headline, label*/
#asoboy .reserve .reservationBlock h3, 
#asoboy .reserve .reservationBlock .reservationForm ul li.routing article label, 
#asoboy .reserve .reservationBlock .reservationForm .flatpickr label, 
#asoboy .reserve .reservationBlock .reservationForm .people article label,
#asoboy .reserve .reservationBlock .reservationForm ul li.trainSelectorWrap label {
  background-color: #000000;
	color: #fff;
}
/* ico calendar */
#asoboy .reserve .reservationBlock .reservationForm .flatpickr a i.material-icons {
  background-color: #000000;
}
/* foroating Anchor */
#asoboy #bnr_reserve .trainname {
  background-color: #000000;
  color: #fff;
}
#asoboy .btn_reserve {
  background: #000000;
}

/* ibusukinotamatebako
------------------------------*/
/* headline, label*/
#ibusukinotamatebako .reserve .reservationBlock h3, 
#ibusukinotamatebako .reserve .reservationBlock .reservationForm ul li.routing article label, 
#ibusukinotamatebako .reserve .reservationBlock .reservationForm .flatpickr label, 
#ibusukinotamatebako .reserve .reservationBlock .reservationForm .people article label,
#ibusukinotamatebako .reserve .reservationBlock .reservationForm ul li.trainSelectorWrap label {
  background-color: #000000;
	color: #fff;
}
/* ico calendar */
#ibusukinotamatebako .reserve .reservationBlock .reservationForm .flatpickr a i.material-icons {
  background-color: #000000;
}
/* foroating Anchor */
#ibusukinotamatebako #bnr_reserve .trainname {
  background-color: #000000;
  color: #fff;
}
#ibusukinotamatebako .btn_reserve {
  background: #000000;
}

/* umisachiyamasachi
------------------------------*/
/* headline, label*/
#umisachiyamasachi .reserve .reservationBlock h3, 
#umisachiyamasachi .reserve .reservationBlock .reservationForm ul li.routing article label, 
#umisachiyamasachi .reserve .reservationBlock .reservationForm .flatpickr label, 
#umisachiyamasachi .reserve .reservationBlock .reservationForm .people article label,
#umisachiyamasachi .reserve .reservationBlock .reservationForm ul li.trainSelectorWrap label {
  background-color: #c38649;
  color: #fff;
}
/* ico calendar */
#umisachiyamasachi .reserve .reservationBlock .reservationForm .flatpickr a i.material-icons {
  background-color: #c38649;
}
/* foroating Anchor */
#umisachiyamasachi #bnr_reserve .trainname {
  background-color: #c38649;
  color: #fff;
}
#umisachiyamasachi .btn_reserve {
  background: #c38649;
}

/* umisachiyamasachi
------------------------------*/
/* headline, label*/
#kawasemiyamasemi .reserve .reservationBlock h3, 
#kawasemiyamasemi .reserve .reservationBlock .reservationForm ul li.routing article label, 
#kawasemiyamasemi .reserve .reservationBlock .reservationForm .flatpickr label, 
#kawasemiyamasemi .reserve .reservationBlock .reservationForm .people article label,
#kawasemiyamasemi .reserve .reservationBlock .reservationForm ul li.trainSelectorWrap label {
  background-color: #163c72;
  color: #fff;
}
/* ico calendar */
#kawasemiyamasemi .reserve .reservationBlock .reservationForm .flatpickr a i.material-icons {
  background-color: #163c72;
}
/* foroating Anchor */
#kawasemiyamasemi #bnr_reserve .trainname {
  background-color: #163c72;
  color: #fff;
}
#kawasemiyamasemi .btn_reserve {
  background: #163c72;
}
