@charset "UTF-8";

/* ----------------------------------------
	base
---------------------------------------- */
body {
  background-color: #fff;
  display: flex;
  flex-direction: column;
}

.wrapper {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  height: 100%;
}

#container-wrap {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
}

#container-wrap #container {
  display: block;
  flex: none;
  padding: 0 12px;
  margin: 0 auto;
  width: 100%;
  max-width: 1260px;
}

@media screen and (max-width: 767px) {
  #container-wrap_top {
    background-size: 71px 365px;
  }

  #container-wrap_top #container {
    padding: 0 !important;
  }
}

/* ---------------------------------------- 
　　　　見出し
---------------------------------------- */
h1 {
  display: inline-flex;
  margin-bottom: 15px;
  padding: 5px;
  width: 100%;
  background: #dff1fd;
  font-size: 1.2rem;
}

h2 {
  padding: 0 10px 3px;
  color: #006abd;
  font-size: 18px;
  border-left: 8px solid #006abd;
  margin-top: 1rem;
}

h2.h2-mypage {
  padding: 0.3rem 0.5rem;
  border-left: none;
  border-bottom: 2px solid #006abd;
  margin-bottom: 1rem;
}

h3 {
  margin: 10px 0;
  padding: 1px 10px 3px;
  color: #006abd;
  font-size: 18px;
  line-height: 1.2;
  border-left: 8px solid #dd0b0b;
}

.h_ttl {
  display: inline-block;
  width: 1260px;
  text-align: left;
  padding: 7px 0 7px 10px;
  margin: 0 auto;
  color: #46b2e7;
}

.form-txt {
  padding: 10px 0;
  line-height: 1.5;
}

.form-notice {
  line-height: 1.5;
}

@media screen and (max-width: 767px) {
  h2 {
    font-size: 18px;
  }

  h3 {
    font-size: 16px;
  }

  .form-txt,
  p.attention,
  .form-notice,
  li {
    font-size: 0.9rem;
  }
}

/* ----------------------------------------
	layout
---------------------------------------- */
ul.ul-disc {
  list-style: disc;
  margin-left: 2em;
  line-height: 1.3;
}

p.attention {
  margin-top: 10px;
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.2;
}

p.attention>span {
  color: #006abd;
  margin-left: 1rem;
}


/*
	header
---------------------------------------- */
#header {
  display: flex;
  justify-content: center;
  height: 52px;
}

#header .header-inner {
  display: flex;
  justify-content: space-between;
  max-width: 1260px;
  width: 100%;
  padding: 0 12px;
}

#header .header-inner .logo a {
  display: inline-flex;
  height: 100%;
  align-items: center;
  text-decoration: none;
}

#header .header-inner .logo a span {
  margin-left: 15px;
  font-size: 1.3rem;
  font-weight: bold;
  color: #46b2e7;
}

#header .header-inner .logo a img {
  height: 40px;
}

#header .header-inner .link-contents {
  display: flex;
}

#header .header-inner .link-area {
  position: relative;
}

#header .header-inner .link-area a {
  display: inline-flex;
  align-items: center;
  height: 100%;
  padding: 0 12px;
  position: relative;
  text-decoration: none;
}

#header .header-inner .link-info {
  width: 8rem;
}

#header .header-inner .link-area a img {
  position: absolute;
  top: 50%;
  left: -10%;
  transform: translate(-50%, -50%);
  width: 40px;
  display: block;
}

#header .header-inner .link-area:hover img:nth-of-type(2) {
  opacity: 0;
}

#header .header-inner .link-area .login:hover+.hdinout {
  color: #80B5DE;
}

#header .header-inner .link-area .mypage:hover+.hdinout {
  color: #80B5DE;
}

#header .header-inner .link-area a span {
  color: #006abd;
  font-size: 18px;
  font-weight: bold;
  padding: 1rem 0;
}

#header .header-inner .sp-link-area {
  display: none;
}

#header .header-inner .link-area :hover {
  color: #80B5DE;
}

@media screen and (max-width: 767px) {
  #header .header-inner .logo {
    display: inline-flex;
    align-items: center;
  }

  #header .header-inner .logo a span {
    font-size: 0.8rem;
    margin-left: 5px;
    white-space: nowrap;
  }

  #header .header-inner .link-area {
    display: none;
  }

  #header .header-inner .sp-link-area {
    display: flex;
    align-items: center;
  }

  #header .header-inner .sp-link-area a {
    padding: 0 10px;
  }

  #header .header-inner .sp-link-area a img {
    width: 35px;
  }

  #header .header-inner .logo span {
    line-height: 1.25;
    margin: 0 0 0 0.3em;
    font-size: 0.9rem;
  }
}

/* ----------------------------------------
	navigation
---------------------------------------- */
.navi {
  display: flex;
  justify-content: center;
}

.navi .navi-inner {
  display: flex;
  max-width: 1280px;
  width: 100%;
  height: 50px;
  text-align: center;
  background: #dff1fd;
  line-height: 2.2;
}

.navi .navi-inner .navi-contents {
  width: 100%;
  height: 100%;
}

.navi .navi-inner .navi-contents span {
  margin-left: 5px;
  color: #006abd;
  font-size: 20px;
  font-weight: bold;
  vertical-align: super;
}

.navi-contents-select {
  pointer-events: none;
  border-bottom: 5px solid #006abd;
}

.navi-contents-select span {
  color: #006abd;
}

.navi-contents-no-select {
  border-bottom: none;
}

.navi-contents-no-select span {
  color: #808080 !important;
}

@media screen and (max-width: 767px) {
  .navi .navi-inner .navi-contents {
    flex-direction: column;
  }

  .navi .navi-inner .navi-contents img {
    display: block;
    margin: 6px auto 4px;
  }
}

@media screen and (max-width: 389px) {
  .navi .navi-inner {
    line-height: 2.6;
  }

  .navi .navi-inner .navi-contents span {
    font-size: 17px;
  }
}

/* ----------------------------------------
	footer
---------------------------------------- */
#footer {
  display: flex;
  justify-content: center;
  height: 62px;
}

#footer .footer-inner {
  width: 100%;
}

#footer .footer-inner div {
  display: flex;
  background-color: #dff1fd;
  height: 2.5rem;
  justify-content: center;
  align-items: center;
  font-size: 13px;
}

#footer .footer-inner div a {
  padding: 0 20px;
  text-decoration: underline;
}

#footer .footer-inner div.copyright {
  background-color: #006abd;
  text-align: center;
  height: auto;
  line-height: 1.7;
}

#footer .footer-inner div.copyright span {
  color: #fff;
}

.pseudo #footer .footer-inner .footer-link a:hover,
.pseudo #footer .footer-inner .footer-link a:focus {
  text-decoration: none;
}

@media screen and (max-width: 767px) {
  #footer {
    height: 116px;
  }

  #footer .footer-inner div {
    display: block;
    height: auto;
    padding: 0.5em;
    text-align: center;
  }

  #footer .footer-inner .footer-link a {
    display: block;
    margin-bottom: 4px;
    font-size: 13px;
  }
}

/* ----------------------------------------
  new table
---------------------------------------- */
.tableCtn {
  border-top: 1px solid #006abd;
  border-right: 1px solid #006abd;
  border-left: 1px solid #006abd;
  margin-bottom: 20px;
}

.tableCtn th,
.tableCtn td {
  padding: 10px;
  border-bottom: 1px solid #006abd;
}

.tableCtn .tableLine {
  display: flex;
  align-items: center;
  border-bottom: 1px solid #006abd;
  background: #dff1fd;
}

.tableCtn th {
  width: 33%;
  border-right: 1px solid #006abd;
  text-align: left;
  vertical-align: middle;
  font-weight: normal;
}

.tableCtn th .require {
  float: right;
  padding: 4px 3px;
  color: #ffffff;
  background: #D60000;
  font-size: 0.8rem;
  font-weight: bold;
  letter-spacing: 0.5px;
  vertical-align: middle;
  border-radius: 3px;
}

.tableCtn .tableCell_l {
  padding: 10px;
  width: 33%;
}

.tableCtn .tableCell_l .require {
  float: right;
  padding: 4px 3px;
  color: #ffffff;
  background: #D60000;
  font-size: 0.8rem;
  font-weight: bold;
  letter-spacing: 0.5px;
  vertical-align: middle;
  border-radius: 3px;
}

.tableCtn .tableCell_r {
  padding: 10px;
  width: 67%;
  border-left: 1px solid #006abd;
  background: #fff;
}

.tableCtn .tableCell_r .nameBox .nameBox-left,
.tableCtn .tableCell_r .nameBox .nameBox-right {
  display: inline-block;
  width: 49%;
}

.tableCtn .tableCell_r .nameBox .nameBox-right input {
  margin-left: 10px;
}

.tableCtn .tableCell_r .cellBorder {
  padding: 0 10px;
  border-bottom: 1px solid #006abd;
}

.tableCtn .tableCell_r .cellBorder:last-child {
  border-bottom: none;
}

.tableCtn .tableCell_r .cellBorder .cellFlex {
  display: flex;
  padding: 10px 0;
}

.tableCtn .tableCell_r .cellBorder .cellFlex p {
  margin-right: 20px;
  padding-top: 10px;
  width: 70px;
}

.tableCtn .tableCell_r select {
  width: 100%;
}

.tableCtn .confirmText {
  padding: 10px 0;
}

.tableCtn .p-reset {
  padding: 0;
}

.tableCtn-confirm th {
  width: 50%;
}

.tableCtn-confirm .tableLine .tableCell_l {
  width: 50%;
}

.tableCtn-confirm .tableLine .tableCell_r {
  width: 50%;
}

.tableCtn-confirm .confirmText {
  padding: 10px 0;
}

.tableCell_r .confirmName {
  display: inline-block;
  width: 50%;
}

.td_area {
  background: #fff;
}

.kana-change {
  display: flex;
}

/*ETCカード編集・削除画面*/
.tableCell_etc {
  width: 67%;
  border-left: 1px solid #006abd;
}

.tableCell_etc .etcInfoBox {
  display: flex;
  background: #fff;
  align-items: center;
  border-bottom: 1px solid #006abd;
}

.tableCell_etc .etcInfoBox:last-child {
  border-bottom: none;
}

.tableCell_etc .etcInfoBox .etcCardNo {
  width: 40%;
  text-indent: 1em;
}

.tableCell_etc .etcInfoBox .etcCardBtn {
  display: flex;
  width: 60%;
  justify-content: end;
}

.tableCell_etc .etcInfoBox button {
  box-sizing: border-box;
  height: 2.5em;
  width: 170px;
  border: #9d9ead solid 1px;
  border-radius: 10px;
  color: #333;
  background: #f0f0f0;
  margin: 10px;
}

.etcCardAddBox {
  display: flex;
  justify-content: space-between;
  line-height: 1.2;
}

.etcCardAddBox p {
  text-indent: -1em;
  padding-left: 1em;
}

.etcCardAddBox button {
  box-sizing: border-box;
  height: 2.5em;
  width: 170px;
  border: #9d9ead solid 1px;
  border-radius: 10px;
  color: #333;
  background: #f0f0f0;
  margin-right: 10px;
}


@media screen and (max-width: 910px) {

  .tableCell_etc .etcInfoBox button {
    font-size: 0.8rem;
  }
}

@media screen and (max-width: 767px) {
  .tableCtn {
    border: none;
  }

  .tableCtn th,
  .tableCtn td {
    display: block;
    width: 100%;
  }

  .tableCtn .tableLine {
    display: block;
    border: none;
  }

  .tableCtn .tableCell_l,
  .tableCtn .tableCell_r {
    display: block;
    width: 100%;
  }

  .tableCtn th {
    border-right: none;
  }

  .tableCtn .tableCell_l {
    padding: 10px;
  }

  .tableCtn .tableCell_r {
    border-left: none;
  }

  .tableCtn-confirm .tableLine .tableCell_l {
    width: 100%;
  }

  .tableCtn-confirm .tableLine .tableCell_r {
    width: 100%;
  }

  .kana-change {
    display: flex !important;
  }

  .tableCell_etc {
    width: 100%;
    border: none;
  }

  .tableCell_etc .etcInfoBox:last-child {
    border-bottom: 1px solid #006abd;
  }

  .tableCell_etc .etcInfoBox {
    display: block;
    border-bottom: 1px solid #006abd;
  }

  .tableCell_etc .etcInfoBox .etcCardNo {
    width: 100%;
    height: 3em;
    line-height: 3;
  }

  .tableCell_etc .etcInfoBox .etcCardBtn {
    display: flex;
    justify-content: center;
    width: 100%;
  }

  .etcCardAddBox {
    display: block;
  }

  .etcCardAddBox button {
    margin: 10px;
  }
}

.tdMypageEntry {
  background: #fff;
}

.tdMypageEntry_chng input,
.tdMypageEntry_chng select {
  border: 2px #D60000 solid;
}

.tableCell_r .error_border_r {
  border: 2px solid #D60000;
}

input[type="text"].error_border_r {
  border: solid 2px #D60000;
}

input[type="tel"].error_border_r {
  border: solid 2px #D60000;
}

.tableCell_r .selectBox .error_border_r {
  border: 2px solid #D60000;
}

.tdCtn {
  position: relative;
  display: block;
  padding: 10px 0;
  word-break: break-all;
}

.tdCtn .mypageEntry {
  display: inline-block;
  width: 58%;
  vertical-align: middle;
}

.tdCtn .etcDisp {
  display: flex;
  flex-wrap: wrap;
  width: auto;
  padding-right: 2em;
}

.tdCtn .etcDisp div {
  margin-right: 20px;
  line-height: 1.5;
  white-space: nowrap;
}

.tdCtn ul {
  display: inline-block;
  width: 58%;
}

.tdCtn ul li {
  padding: 5px 0;
}

.tdCtn ul .number {
  margin-bottom: 10px;
}

.tdCtn .btnBox-mypage {
  position: absolute;
  display: inline-block;
  width: 40%;
  top: 0;
}

.tdCtn .btnBox-mypage-etc {
  width: 50%;
}

.tdCtn .btnBox-mypage .mypage-btn {
  box-sizing: border-box;
  height: 3em;
  width: 100%;
  border: #9d9ead solid 1px;
  border-radius: 10px;
  color: #333;
  background: #f0f0f0;
}

.tdCtn .btnBox-mypage .etc-info {
  width: 10em;
}

.tdCtn .btnBox-mypage .etc-info:first-child {
  margin-right: 10px;
}

.pseudo .tdCtn .btnBox-mypage .mypage-btn:hover {
  background-color: #d3d3d3;
}

@media screen and (min-width: 768px) {
  .tdCtn {
    padding: 18px 0;
  }

  .tdCtn-notify {
    padding: 10px 0;
  }
}

@media screen and (max-width: 767px) {
  .tdCtn .mypageEntry {
    margin-bottom: 10px;
    width: 100%;
  }

  .tdCtn ul {
    padding-bottom: 10px;
  }

  .tdCtn .btnBox-mypage {
    position: relative;
    width: 100%;
  }

  .tdCtn .etcDisp {
    padding-right: 0;
    width: 328px;
  }
}

.tdCtn .btnBox-etcpage {
  position: absolute;
  display: inline;
  width: 30%;
  top: 0;
}

.tdCtn .btnBox-etcpage {
  position: relative;
  width: 100%;
}

/* ----------------------------------------
	input
---------------------------------------- */
input {
  padding: 5px;
  width: 100%;
  height: 42px;
  text-indent: 0.4rem;
  color: #666666;
  border: 1px solid #9d9ea0;
}

input::placeholder {
  color: #ddd;
}

@media screen and (max-width: 767px) {
  input {
    height: 37px;
  }
}

/* ----------------------------------------
	select
---------------------------------------- */
select {
  height: 42px;
  padding: 5px 5px 5px 10px;
  color: #666666;
  border: 1px solid #9d9ea0;
  cursor: pointer;
  appearance: none;
}

@media screen and (max-width: 767px) {
  select {
    height: 37px;
  }
}

/* ----------------------------------------
	button
---------------------------------------- */
.btn-box {
  position: relative;
  display: block;
  text-align: center;
  justify-content: center;
}

.btn-box i {
  margin-right: 10px;
  color: #fff;
}

.btn-box-chck {
  display: flex;
  flex-wrap: wrap;
}

.c-btn {
  box-sizing: border-box;
  margin: 20px 10px;
  height: 3em;
  border-radius: 10px;
}

/* ----- 進むボタン ----- */
.btn_c_b {
  color: #ffffff;
  background: #46b2e7;
}

.pseudo .btn_c_b：hover {
  border: 4px solid #6bb2ec;
}

.pseudo .btn_c_b:hover,
.pseudo .btn_c_b:focus {
  background: #6bb2ec;
}

.btn_c_b:disabled {
  cursor: default;
  background: #999;
}

.pseudo .btn_c_b:disabled {
  background: #999;
}

/* ----- その他ボタン ----- */
.btn_c_e {
  color: #46b2e7;
  background: #fff;
  border: 3px solid #46b2e7;
}

.pseudo .btn_c_e：hover {
  border: 4px solid #6bb2ec;
}

.pseudo .btn_c_e:hover,
.pseudo .btn_c_e:focus {
  background: #6bb2ec;
  color: #fff;
}

.btn_c_e:disabled {
  cursor: default;
  background: #999;
}

.pseudo .btn_c_e:disabled {
  background: #999;
}

/* ----- 戻るボタン ----- */
.btn_c_g {
  background: #fff;
  border: 3px solid #d9d9d9;
  color: #999;
}

.btn_c_g:active {
  box-shadow: none;
}

.pseudo .btn_c_g:hover,
.pseudo .btn_c_g:focus {
  background: #ededed;
}

.btn-box .btn-b {
  background: #46b2e7;
  margin: 10px;
}

.pseudo .btn-box .btn-b:hover {
  background: #bce3f6;
}

/* ----- 登録情報・利用明細ボタン ----- */
.btn_c_g_dark {
  margin: 5px 0 5px;
  width: 100%;
  min-width: 10em;
  color: #333;
  background-color: #f0f0f0;
  border: #9d9ead solid 1px;
}

.btn_c_g_dark:active {
  box-shadow: none;
}

.pseudo .btn_c_g_dark:hover,
.pseudo .btn_c_g_dark:focus {
  background: #d3d3d3;
}

/* ----- ボタンサイズ調整用 ----- */
.btn_w_25 {
  width: 300px;
}

.btn_w_100 {
  width: 26%;
}

.btn_w_long {
  width: 100%;
  max-width: 24em;
}

@media screen and (max-width: 767px) {
  .c-btn {
    margin: 10px 0;
    font-size: 14px;
  }

  .btn_w_25 {
    width: 47%;
  }

  .btn_w_100 {
    width: 100%;
    margin-left: 0;
    font-size: 16px;
  }
}

/* ----------------------------------------
	ページネーション
---------------------------------------- */
.pagination {
  padding: 10px 0;
}

.pagination .pagination-btn {
  display: flex;
  justify-content: center;
  margin: 0 auto;
}

.pagination .pagination-btn .lead,
.pagination .pagination-btn .prev,
.pagination .pagination-btn .current,
.pagination .pagination-btn .next,
.pagination .pagination-btn .rear {
  margin: 0 4px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  user-select: none;
}

.pagination .pagination-btn .lead,
.pagination .pagination-btn .prev,
.pagination .pagination-btn .next,
.pagination .pagination-btn .rear {
  position: relative;
  background-color: #fff;
  border: #006abd solid 2px;
}

.pagination .pagination-btn .prev-icon {
  position: absolute;
  top: 11px;
  left: 13px;
  height: 15px;
  transform: rotate(180deg);
}

.pagination .pagination-btn .lead-icon {
  position: absolute;
  top: 11px;
  left: 8px;
  height: 15px;
  transform: rotate(180deg);
}

.pagination .pagination-btn .next-icon {
  position: absolute;
  top: 11px;
  left: 14px;
  height: 15px;
}

.pagination .pagination-btn .rear-icon {
  position: absolute;
  top: 11px;
  left: 11px;
  height: 15px;
}

.pagination .pagination-btn .current {
  padding: 11px 5px 5px 5px;
  color: #fff;
  background: #006abd;
  text-align: center;
  font-weight: bold;
  font-size: 16px;
}

.pagination .pagination-btn .page-number {
  width: 40px;
  height: 40px;
  margin: 0 4px;
  padding: 9px 5px 5px 5px;
  color: #006abd;
  border: 2px solid #006abd;
  border-radius: 50%;
  text-align: center;
  font-weight: bold;
  font-size: 16px;
  cursor: pointer;
  user-select: none;
}

.pagination .pageCount {
  padding: 10px 0 5px;
  text-align: center;
  color: #006abd;
  font-size: 15px;
  font-weight: bold;
}

.pagination .pageCount span {
  padding: 0 3px;
  font-size: 18px;
  font-weight: bold;
  color: #006abd;
  display: inline-block;
  vertical-align: text-top;
}

.pagination .pageCount span.num-splt {
  font-size: 16px;
}

.pseudo .pagination .prev:hover,
.pseudo .pagination .lead:hover,
.pseudo .pagination .next:hover,
.pseudo .pagination .rear:hover {
  background: #80b5de;
  border: 2px solid #80b5de;
  color: #fff;
  cursor: pointer;
}

.pseudo .pagination .lead:hover .lead-icon,
.pseudo .pagination .prev:hover .prev-icon,
.pseudo .pagination .next:hover .next-icon,
.pseudo .pagination .rear:hover .rear-icon {
  opacity: 0.7;
}

.pseudo .pagination .page-number:hover {
  background: #80b5de;
  color: #fff;
  border: 2px solid #80b5de;
}

@media screen and (max-width: 767px) {
  .pagination .pagination-btn {
    width: 228px;
  }

  .pagination .pagination-btn .page-number {
    display: none;
  }
}

/* ----------------------------------------
	Modal Dialog
---------------------------------------- */
/* モーダルダイアログ */
.modal-dialog {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0.3;
  z-index: 100;
}

/* モーダルダイアログ メッセージエリア */
.dialog-message {
  position: fixed;
  top: 50%;
  left: 50%;
  min-width: 300px;
  min-height: 270px;
  background: #ffffff;
  border-radius: 15px;
  z-index: 101;
  transform: translate(-50%, -50%);
}

/* モーダルダイアログ メッセージ */
.dialog-message .message-area {
  margin: 10% 20px;
  text-align: left;
  font-size: 16px;
}

/* モーダルダイアログ OKボタン表示 */
.dialog-message .dialog-button {
  display: flex;
  justify-content: center;
}

.dialog-message .dialog-button div {
  width: 7rem;
  text-align: center;
  color: #fff;
  padding: 0.8rem;
  background: #46B2E7;
  margin: 0.3em;
  border-radius: 10px;
  cursor: pointer;
}

/* ----------------------------------------
	stepbar
---------------------------------------- */
.stepBar {
  margin-bottom: 20px;
  display: flex;
  justify-content: space-around;
  /* 式に使用している為アンダーバー区切り（ハイフンがマイナスになる） */
}

.stepBar li {
  position: relative;
  width: 34%;
  padding: 15px;
  text-align: center;
  background: #e6e6e6;
}

.stepBar li:before {
  content: "";
  height: 50%;
  width: 15px;
  top: 50%;
  left: -7px;
  position: absolute;
  display: inline-block;
  background: #e6e6e6;
  transform: skew(-25deg);
  border-left: 3px solid #fff;
  z-index: 1;
}

.stepBar li:after {
  content: "";
  height: 50%;
  width: 15px;
  top: 0;
  left: -7px;
  position: absolute;
  display: inline-block;
  background: #e6e6e6;
  transform: skew(25deg);
  border-left: 3px solid #fff;
  z-index: 1;
}

.stepBar li .br-sp {
  display: none;
}

.stepBar li:first-child:before,
.stepBar li:first-child:after {
  content: none;
}

.stepBar .stepbar_c {
  color: #ffffff;
  background: #46b2e7;
  font-weight: bold;
}

.stepBar .stepbar_c:before,
.stepBar .stepbar_c:after {
  background: #46b2e7;
}

@media screen and (max-width: 910px) {
  .stepBar li {
    padding: 8px 5px 9px 1px;
    font-size: 12px;
    line-height: 1.2;
  }

  .stepBar li:before {
    width: 10px;
  }

  .stepBar li:after {
    width: 10px;
  }

  .stepRegist li {
    font-size: 12px;
  }

  .stepRegist li .br-sp {
    display: block;
  }

  .stepRegist2 li {
    font-size: 12px;
  }

  .stepRegist2 li .br-sp {
    display: block;
  }

  .stepBar .stepber_long {
    width: 57%;
  }

}

@media screen and (max-width: 768px) {

  .stepRegist li:nth-child(1),
  .stepRegist li:nth-child(2),
  .stepRegist li:nth-child(4),
  .stepRegist li:nth-child(5) {
    padding: 16px 12px 0px 1px;
  }

  .stepRegist2 li:nth-child(3),
  .stepRegist2 li:nth-child(4) {
    padding: 16px 12px 0px 1px;
  }
}

@media screen and (max-width: 374px) {
  .stepBar li {
    font-size: 10px;
  }
}

/* ----------------------------------------
	error
---------------------------------------- */
.error_text {
  margin: 10px 5px;
  color: #D60000;
  font-weight: bold;
}

.error-textbox {
  margin: 6.25rem 0;
  text-align: center;
}

.error-textbox2 {
  margin: 0 auto;
  text-align: center;
  max-width: 720px;
  padding: 0 30px 0 40px;
}

.error-textbox .err-txt-box {
  text-align: center;
  font-weight: bold;
  color: #D60000;
}

.error-textbox .err-txt {
  /* padding-top: 1rem; */
  line-height: normal;
  text-align: left;
  color: #D60000;
}

.error-textbox-link {
  justify-content: center;
  align-items: center;
  height: 100vh; /* ビューポートの高さを100%に設定 */
  margin: 10rem 0px; /* マージンをリセット */
  text-align: center;
}

.error-textbox-link .err-txt-box-link {
  font-weight: bold;
  color: #000;
}

.error-textbox-link .err-txt-link {
  line-height: normal;
  text-align: center; /* 左揃えから中央揃えに変更 */
  color: #000;
}

.error-textbox-link .err-return {
  display: block;
  text-align: center;
  text-decoration: underline;
  margin: 4rem auto 0;
}
.error-textbox-link .err-return a {
  display: block;
}

.error-textbox .err-return {
  display: block;
  text-align: center;
  text-decoration: underline;
  margin: 4rem auto 0;
}

.error-textbox .err-return a {
  display: block;
}

.error-step {
  display: inline;
}

@media screen and (max-width: 767px) {
  .error_msg {
    padding: 15px;
    font-size: 0.9rem;
  }
}

/* ----------------------------------------
	【共通】checkbox
---------------------------------------- */

label .check-form {
  /*label .notification*/
  display: none;
}

label .check-box {
  /*label .notice-checkbox*/
  padding-left: 25px;
  position: relative;
  display: inline-block;
  line-height: 1.4;
  cursor: pointer;
  color: #999;
}

label .check-box:before {
  /*label .notice-checkbox:before*/
  content: "";
  display: block;
  position: absolute;
  top: 3px;
  left: 0;
  width: 15px;
  height: 15px;
  border: 1px solid #9d9ea0;
  border-radius: 4px;
}

label .check-form:checked+.check-box {
  color: #46b2e7;
}

label .check-form:checked+.check-box:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 5px;
  width: 7px;
  height: 14px;
  transform: rotate(40deg);
  border-right: 3px solid #46b2e7;
  border-bottom: 3px solid #46b2e7;
}

.pseudo label+.check-box,
label .check-form:focus+.check-box {
  color: #46b2e7;
}

label .check-hover {
  color: #333;
}

label .check-hover:hover {
  color: #46b2e7;
}

/* ----------------------------------------
	contents
---------------------------------------- */

/* 履歴の日付表示調整 */
.ml-date {
  margin-left: 7px;
}

/*PC幅の時のみ表示する*/
@media screen and (max-width: 767px) {
  .pc-hide {
    display: none;
  }

  .ml-date {
    margin-left: 0;
  }
}

/*スマホ幅の時のみ表示する*/
@media screen and (min-width: 768px) {
  .sp-hide {
    display: none;
  }
}

/*タブレット横幅くらい幅の時のみ表示する*/
@media screen and (min-width: 1240px) {
  .tp-hide {
    display: none;
  }
}

/* ----------------------------------------
	ヒーローエリア
---------------------------------------- */
.hero {
  display: block;
  justify-content: center;
}

.hero .hero-inner {
  max-width: 1235px;
  width: 100%;
  height: 310px;
  padding: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: url("../img/top.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  margin-top: 0.5rem;
}

.hero-title-area {
  display: flex;
  justify-content: space-between;
  margin-top: 30px;
  margin-bottom: 74px;
}

.hero-title-area .hero-title {
  font-weight: bold;
  color: #000;
  font-size: 42px;
  font-family: sans-serif;
  line-height: 1.2em;
  text-shadow: #fff 1px 0px 5px, #fff -1px 0px 5px, #fff 0px -1px 5px, #fff -1px 0px 5px, #fff 1px 1px 5px, #fff -1px 1px 5px, #fff 1px -1px 5px, #fff -1px -1px 5px, #fff 1px 1px 5px, #fff -1px 1px 5px, #fff 1px -1px 5px, #fff -1px -1px 5px, #fff 1px 1px 5px, #fff -1px 1px 5px, #fff 1px -1px 5px, #fff -1px -1px 5px, #fff 3px 1px 5px, #fff -1px 1px 5px, #fff 1px -1px 5px, #fff -1px -1px 5px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
}

.hero-login-area {
  text-align: center;
}

.hero-login-area button {
  margin: 38px;
}

.hero-login-area p {
  text-align: start;
  font-size: 1.3em;
  margin: 0.5em 0;
  color: #46b2e7;
  font-weight: bold;
}

.hero-login-area button p {
  color: #fff;
  font-size: 15px;
}

.pseudo .hero-login-area .btn_login:hover,
.pseudo .hero-login-area .btn_login:focus {
  background: #bce3f6;
}

.hero-login-area .btn_login:disabled {
  opacity: 0.7;
  cursor: default;
}

.pseudo .hero-login-area .btn_login:disabled {
  border: 4px solid #fff;
}

.hero-login-area .new-member {
  padding-top: 0.5em;
  border-top: 1px solid #aaa;
}

div.login-area {
  display: flex;
}

div.login-area .login-item {
  min-width: 15rem;
  font-size: 1.2rem;
  text-align: center;
  line-height: 2;
  background: #006ABD;
  color: #FFF;
  margin: 1rem 0.8rem 0.5rem 1rem;
  border-radius: 7px;
  height: 2.6rem;
}

div.login-area div:last-child {
  margin: 1rem 0.8rem 0.5rem 1rem;
  width: 100%;
}

div.login-area .login-err{
  text-align: left;
}

@media screen and (max-width: 767px) {
  .hero {
    height: 155px;
  }

  .hero-title-area {
    margin-top: 14px;
    margin-bottom: 1px;
  }

  .hero-title-area .hero-title {
    font-size: 28px;
  }

  .hero .hero-inner {
    height: 100%;
  }

  .hero .hero-inner .hero-login-area .btn_login {
    display: block;
    width: 50%;
    height: 48px;
    margin: 20px auto;
    font-size: 18px;
    padding: 0;
  }

  .hero-login-area {
    padding: 0 10px;
  }

  .hero-login-area p {
    font-size: 1.1em;
  }

  .hero-login-area button {
    margin: 23px;
  }

  div.login-area {
    display: block;
  }

  div.login-area div:first-child {
    margin: 1.5rem 0.5rem 0.5rem 0.5rem;
  }

  div.login-area div:last-child {
    width: auto;
    margin: 0rem 0.5rem 1rem 0.5rem;
  }
}

/* ----------------------------------------
	企業情報
---------------------------------------- */
.company {
  width: 70%;
  margin: 40px auto;
  padding: 40px;
  text-align: center;
  border: 1px solid #aaa;
  background: #f0f0f0;
}

.company div {
  display: inline-block;
  color: #333;
  text-align: left;
  line-height: 1.5;
}

/* ----------------------------------------
	login
---------------------------------------- */
.hd-login {
  position: relative;
  margin: 0 auto;
  display: block;
  border-radius: 12px;
  overflow: hidden;
  cursor: pointer;
}

.hd-login img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  display: block;
  transition: .4s ease-in-out;
}

.btn:hover img:nth-of-type(2) {
  opacity: 0;
}

.autologin {
  margin: 0 auto;
  width: auto;
  text-align: center;
}

.login-option ul {
  text-align: right;
  margin-bottom: 3em;
}

.login-option ul li {
  line-height: 1.5;
}

.login-option ul li a {
  color: #028dd2;
  text-decoration: underline;
}

.pseudo .login-option a:hover,
.pseudo .login-option a:focus {
  text-decoration: none;
}

@media screen and (max-width: 767px) {
  .autologin-txt {
    font-size: 0.9rem;
  }

  .company {
    width: 100%;
    font-size: 0.9rem;
  }
}

.consent {
  display: flex;
}

.consent ul {
  display: block;
  margin: 0 auto;
  padding-top: 15px;
}

.consent ul li {
  margin: 15px 0;
}

.consent ul li .consent-input {
  display: none;
}

.consent ul li .consent-input+label {
  display: inline-block;
  padding-left: 25px;
  position: relative;
}

.consent ul li label:before {
  content: "";
  display: block;
  position: absolute;
  top: -1px;
  left: 0;
  width: 15px;
  height: 15px;
  border: 1px solid #9d9ea0;
  border-radius: 50%;
}

.consent ul li .consent-input:checked+label {
  color: #009a9a;
}

.consent ul li .consent-input:checked+label:after {
  content: "";
  display: block;
  position: absolute;
  top: 2px;
  left: 3px;
  width: 11px;
  height: 11px;
  background: #009a9a;
  border-radius: 50%;
}

.pseudo .consent ul li label:hover,
.pseudo .consent ul li label:focus {
  color: #009a9a;
}

.credit-number,
.security {
  display: inline-block;
  width: 72px;
}

/* ----------------------------------------
	Information=お知らせ=
---------------------------------------- */
.information {
  margin-bottom: 2em;
}

.info-wrap {
  line-height: 1.25em;
  font-size: 0.9em;
}

.info-wrap dl {
  clear: both;
  overflow: hidden;
}

.info-wrap dl dt {
  padding: 5px 0 5px 15px;
  width: 85px;
  float: left;
  clear: both;
}

.info-wrap dl dd {
  padding: 5px 0 5px 120px;
}

@media screen and (max-width: 767px) {
  .info-wrap dl dt {
    padding: 5px 0 5px 0px;
  }

  .info-wrap dl dd {
    padding: 5px 0 5px 100px;
  }
}

.info-wrap .new {
  animation: new-flash 3s ease-in infinite;
  background: #f9c21e;
  margin-right: 1px;
  padding: 0 8px;
  border-radius: 15px;
  font-size: 0.3rem;
  color: #fff;
}

@keyframes new-flash {

  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: 0.3;
  }
}

.detail-topic {
  line-height: 1.5em;
}

.detail-topic>.title {
  display: flex;
  padding: 0.25em 0;
  border-bottom: 2px solid #006abd;
}

.detail-topic>.title span:first-child {
  padding: 0 3rem 0 1rem;
}

.detail-topic .detail {
  padding: 1rem;
}

.more-info {
  margin: 10px;
}

.more-info a {
  font-size: 0.8rem;
  text-decoration: underline;
}

/* ----------------------------------------
	mypage
---------------------------------------- */
.btn-box-quit {
  display: block;
  text-align: right;
  padding-right: 30px;
}

.tbl_mypage {
  margin-bottom: 20px;
}

.tbl_mypage .notify {
  font-size: 12px;
}

.tbl_mypage td {
  height: 50px;
  vertical-align: middle;
}

.tbl_mypage td .td_ctn {
  display: block;
  position: relative;
}

.tbl_mypage td .td_ctn p {
  display: inline-block;
  width: 55%;
}

.tbl_mypage td .td_ctn ul {
  display: inline-block;
  width: 55%;
  vertical-align: middle;
}

.tbl_mypage td .td_ctn ul li {
  line-height: 1.5;
}

.tbl_mypage td .td_ctn ul li:nth-child(even) {
  padding-bottom: 10px;
}

.tbl_mypage td .td_ctn .btn-box {
  position: static;
  display: inline-block;
  width: 42%;
  text-align: start;
}

.tbl_mypage td .td_ctn .btn-box .car_btn {
  position: absolute;
  top: 0;
  width: 42%;
}

.tbl_mypage td .td_ctn .pay-btn {
  vertical-align: top;
}

.pseudo .tbl_mypage .td_ctn .change_btn:hover,
.pseudo .tbl_mypage .td_ctn .change_btn:focus {
  border: 4px solid #84878c;
}

.tbl_mypage .td_ctn .change_btn:disabled {
  opacity: 0.7;
  cursor: default;
}

.pseudo .tbl_mypage .td_ctn .change_btn:disabled {
  border: 4px solid #fff;
}

.btn-box_mypage {
  display: block;
  text-align: left;
}

.complete-text {
  margin: 100px 0 60px;
  text-align: center;
  font-weight: bold;
}

@media screen and (max-width: 767px) {

  .btn-box_mypage .m20-0,
  .btn-box-quit .m20-0 {
    padding: 11px 12px;
    margin-bottom: 20px;
  }

  .btn-box-quit {
    padding-right: 0px;
  }

  .tbl_mypage td {
    height: auto;
  }

  .tbl_mypage td .td_ctn p {
    display: block;
    width: 100%;
  }

  .tbl_mypage td .td_ctn ul {
    width: 100%;
  }

  .tbl_mypage td .td_ctn .btn-box {
    display: block;
    width: 100%;
    text-align: center;
  }

  .tbl_mypage td .td_ctn .btn-box .car_btn {
    position: static;
    width: 100%;
  }
}

/* ----------------------------------------
	history
---------------------------------------- */
.backnumber-box {
  display: flex;
}

.backnumber-box .backnumber {
  margin: 10px 0 15px;
  width: 100%;
  text-align: center;
}

.backnumber-box .backnumber span {
  padding: 0 3px;
  color: #006abd;
  font-size: 18px;
  font-weight: bold;
}

.btn-box .search-img {
  width: 27px;
  padding: 0 5px 2px;
  vertical-align: middle;
}

.number {
  margin-top: 15px;
}

/* ----------------------------------------
	mail-notify
---------------------------------------- */
.mail-send {
  margin: 10px 0;
}

.send-info-box {
  max-width: 650px;
  display: block;
  margin: 0 auto 2rem auto;
  text-align: left;
  padding: 0 1rem;
}

.w-change {
  max-width: 750px;
}

/* ----------------------------------------
	unsubscribe
---------------------------------------- */
.unsubscribe {
  padding: 2rem 3rem;
  line-height: 1.5;
}

.check_confirm {
  margin: 0 auto 3rem auto;
  width: 250px;
}

@media screen and (max-width: 767px) {
  .unsubscribe {
    padding: 2rem 1rem;
  }

  .unsubscribe .unsubscribe-txt {
    font-size: 0.9rem;
  }

  .check_confirm .confirm-txt {
    font-size: 0.9rem;
  }
}

.notice_comment {
  display: inline-block;
  margin: 5px 0 20px 0;
  padding-left: 25px;
  cursor: pointer;
  font-size: 0.8rem;
}

/* ----------------------------------------
  明細書
---------------------------------------- */
.receipt-wrap {
  width: 100%;
  margin: 60px 0 0;
}

.receipt-area {
  background: #fff;
  width: 100%;
  max-width: 400px;
  margin: 0 auto;
  padding: 2em 0;
  border: solid #505050 1px;
}

.receipt-bg {
  background: #eee;
}

.receipt-area .receipt-ttl h4 {
  padding: 0 0 0.5em;
  text-align: center;
  font-size: 1.5em;
}

.receipt-area .receipt-ttl p {
  text-align: center;
  font-size: 1.75em;
  margin: 2px 1em 0 1em;
}

.receipt-area .receipt-logo {
  text-align: center;
}

.receipt-area img {
  height: 82px;
  padding-bottom: 20px;
}

.receipt-dtl ul {
  margin: 0 1em 0;
  text-align: right;
}

.receipt-dtl ul li {
  margin-bottom: 0.5em;
}

.receipt-dtl ul li.fee-ttl {
  top: 0;
  left: 0;
}

.receipt-dtl ul li.fee-dscnt {
  position: relative;
}

.receipt-dtl ul li.fee-dscnt span {
  position: absolute;
  top: 0;
  left: 0;
}

.receipt-dtl ul li.fee-dscnt:nth-child(2) {
  padding: 1.5em 0 0;
}

.receipt-dtl ul li.fee-dscnt:nth-child(2) span {
  margin: 1.5em 0 0;
}

.receipt-rslt {
  margin: 0 1em;
}

.receipt-rslt ul {
  padding: 2em 0 0;
}

.receipt-rslt ul.dis-lst {
  padding: 0 0 0.5em;
}

.receipt-rslt ul li {
  width: 50%;
  display: inline-block;
  line-height: 1.25em;
}

.receipt-rslt ul li.fee-ttl {
  text-align: right;
  vertical-align: top;
}

.receipt-rslt ul li.dis-dtl {
  vertical-align: top;
  width: 60%;
}

.receipt-rslt ul li.dis-cnt {
  width: 15%;
  text-align: left;
  vertical-align: top;
  padding-left: 1em;
}

.receipt-rslt ul li.dis-amnt {
  width: 25%;
  text-align: right;
  vertical-align: top;
}

div.caution-note {
  margin: 2em 1em 0;
}

div.caution-note p {
  line-height: 1.25em;
}

div.invoice {
  text-align: center;
}

div.invoice span {
  margin-left: 10px;
}

.fee-bfr {
  width: 50%;
  display: inline-block;
  text-align: left;
}

.fee-prc {
  width: 50%;
  display: inline-block;
  text-align: right;
}

.total-fee {
  margin: 0.5em 1em 0;
  padding-top: 0.5em;
}

.total-fee ul {
  padding: 0 0 0.2em;
}

.total-fee ul li {
  display: inline-block;
  vertical-align: top;
  text-align: right;
}

.total-fee ul li:first-child {
  width: 30%;
  text-align: left;
}

.receipt-details {
  width: 70%;
}

.receipt-details1 {
  width: 40% !important;
}

.receipt-details2 {
  width: 37%;
}

.receipt-details3 {
  width: 23%;
}

.receipt-dtl {
  text-align: center;
}

.receipt-dtl-pay {
  width: 22% !important;
}

.receipt-dtl-pay-name {
  width: 55%;
}

.receipt-dtl-pay-fee {
  width: 23%;
}



/* ----------------------------------------
	調整用
---------------------------------------- */
.mt15 {
  margin-top: 15px;
}

.mt10 {
  margin-top: 10px;
}

.mb5 {
  margin-bottom: 5px;
}

.mb15 {
  margin-bottom: 15px;
}

.mr15 {
  margin-right: 15px;
}

.ml15 {
  margin-left: 15px;
}

.m5-0 {
  margin: 5px 0;
}

.m20-0 {
  margin: 20px 0;
}

.indent-1 {
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.2;
}

.mt70 {
  margin-top: 70px;
}

@media screen and (max-width: 767px) {
  .m5-0 {
    margin: 5px 0 15px;
  }

  .btn_c_g.mr15 {
    margin-right: 0;
  }
}

p.txt_change {
  padding: 10px 0;
}

/* 印刷 */
@media print {
  body {
    background: #ffffff !important;
  }

  .not-print {
    display: none;
  }
}

/* ロード中 */
.button_box_loading {
  padding: 9px 12px 3px;
  background: #999 !important;
  color: #fff !important;
  cursor: default;
  vertical-align: bottom;
}

.ballsWaveG-wrap {
  display: flex;
  justify-content: space-between;
  width: 120px;
  height: 8px;
  margin: 0 auto 2px;
}

.ballsWaveG {
  background-color: lightgray;
  width: 8px;
  height: 8px;
  animation-name: ballsWaveG;
  animation-duration: 0.8s;
  animation-iteration-count: infinite;
  animation-direction: normal;
  border-radius: 8px;
}

.ballsWaveG_1 {
  left: 0;
  animation-delay: 0.08s;
}

.ballsWaveG_2 {
  left: 14px;
  animation-delay: 0.16s;
}

.ballsWaveG_3 {
  left: 28px;
  animation-delay: 0.24s;
}

.ballsWaveG_4 {
  left: 42px;
  animation-delay: 0.32s;
}

.ballsWaveG_5 {
  left: 56px;
  animation-delay: 0.4s;
}

.ballsWaveG_6 {
  left: 70px;
  animation-delay: 0.48s;
}

.ballsWaveG_7 {
  left: 84px;
  animation-delay: 0.56s;
}

.ballsWaveG_8 {
  left: 98px;
  animation-delay: 0.64s;
}

.ballsWaveG_9 {
  left: 112px;
  animation-delay: 0.72s;
}

.ballsWaveG_10 {
  left: 126px;
  animation-delay: 0.8s;
}

@keyframes ballsWaveG {
  0% {
    background-color: rgba(255, 255, 255, 0.97);
  }

  to {
    background-color: lightgray;
  }
}

/* --- パスワード再発行 --- */

.notice-sentence {
  padding: 100px 0 60px;
  text-align: center;
  font-weight: bold;
  line-height: 1.5;
}

.notice-text {
  margin-bottom: 50px;
  font-size: 30px;
  color: #D60000;
}

.notice-red {
  color: #D60000;
}

@media screen and (max-width: 767px) {
  .notice-sentence {
    padding: 60px 0;
  }

  .notice-sentence .notice-text {
    font-size: 24px;
  }
}

/*--- マイページ ---*/
.nochng-ntc {
  margin: 2em 0 0.5em;
  line-height: 1.2;
}

.attention-ntc {
  margin: 1em 0;
}

div.etc-coution {
  margin: 2rem 0 0 1rem;
}

@media screen and (max-width: 767px) {
  .nochng-ntc {
    font-size: 0.9rem;
  }
}

.notice-blue,
.notice-blue span {
  color: #46b2e7
}

/* エラー */
.errorTextBox {
  margin-top: 8em;
  text-align: center;
}

.errorTextBox p.errorText_b {
  margin-bottom: 1em;
  font-weight: bold;
}

.errorTextBox p.errorText {
  margin-bottom: 4em;
}

.errorTextBox a {
  text-decoration: underline;
}

/*-- t-error --*/
div.errorBox {
  border: 2px solid #D60000;
  margin: 10px auto;
  padding: 10px;
  width: 90%;
}

div.etc-rimit {
  border: 0;
  margin-top: 10em;
}

div.errorBox p {
  color: #D60000;
  font-weight: bold;
  text-align: center;
  line-height: 1.2;
}

div.errorBox p.errorText {
  padding: 5px;
}

div.errorBox p.errorTextLarge {
  padding: 18px;
  font-size: 1.3rem;
}

div.errorBox p.errorTextLeft {
  margin-top: 1em;
  text-align: left;
}

div.errorBox span {
  color: #D60000;
  font-size: 14px;
}

/*-- history btn --*/
.company p.cmpny-info {
  width: 100%;
  margin-bottom: 1em;
  line-height: 1.25em;
}

@media screen and (max-width: 767px) {
  div.etc-rimit {
    margin-top: 0em;
  }
}

.company p.cmpny-info:last-child {
  margin-bottom: 0;
}

@media screen and (max-width: 767px) {
  .company {
    padding: 2em 0.75rem;
  }
}

/* 期間検索 */
.search-rireki {
  display: flex;
  margin-top: 25px;
}

.search-rireki div {
  display: flex;
  max-width: 100%;
}

.search-rireki select {
  height: 28px;
  max-width: 100%;
  appearance: none;
  padding: 2px 30px 2px 10px;
  line-height: 1.1em;
  border-radius: 5px;
  background-image: url(../img/select_down.svg);
  background-repeat: no-repeat;
  background-size: 11px 9px;
  background-position: right 10px center;
}

.search-rireki .search-period {
  width: 42%;
}

.search-rireki .search-period select {
  width: 130px;
}

.search-rireki .search-period p {
  margin: 7px;
  width: 80px;
  white-space: nowrap;
}

.search-rireki .search-period .select-month-w {
  width: 65px;
}

.search-rireki .search-parking {
  width: 42%;
}

.search-rireki .search-parking select {
  width: 300px;
  overflow-x: hidden;
}

.search-rireki .search-parking p {
  margin: 7px;
  white-space: nowrap;
}

/* 検索ボタン */
.search-period .search-btn select {
  margin-left: 10px;
  color: #ffffff;
  background: #006abd;
  border-radius: 15px;
  font-size: 0.9em;
  user-select: none;
  width: 50px;
  text-align: center;
  line-height: 1.9;
}

/* 検索結果表示テーブル */
.use_detail_table {
  width: 100%;
  margin-top: 10px;
}

.use_detail_table table {
  border-collapse: collapse;
}

.use_detail_table table tr:hover {
  background-color: #ffff99;
}

.use_detail_table table tr.cancel,
.use_detail_table table tr.cancel:hover {
  background-color: lightgray;
  text-decoration: line-through;
}

.use_detail_table th {
  height: 40px;
  background: #e6e6e6;
  border: solid 1px #999;
  vertical-align: middle;
}

.use_detail_table td {
  height: 40px;
  border: solid 1px #999;
  vertical-align: middle;
  text-align: center;
  line-height: 1.2;
}

.use_detail_table .check {
  width: 5%;
}

.use_detail_table .in-date {
  width: 15%;
}

.use_detail_table .out-date {
  width: 15%;
}

.use_detail_table .car-time {
  width: 15%;
}

.use_detail_table .parking-fee {
  width: 20%;
}

.use_detail_table .car {
  width: 10%;
}

.use_detail_table .card {
  width: 30%;
}

.use_detail_table .check input {
  height: 15px;
}

@media screen and (max-width: 960px) {
  .use_detail_table {
    font-size: 0.8rem;
  }
}

@media screen and (max-width: 767px) {
  .search-rireki {
    display: block;
  }

  .search-rireki .search-period {
    margin-bottom: 10px;
    width: 100%;
  }

  .search-rireki .search-parking p {
    width: 80px;
  }

  .search-rireki .search-parking select,
  .search-rireki .search-period select {
    width: 250px;
    max-width: 66%;
    overflow-x: hidden;
  }

  .use_detail_table .in-date {
    width: 20%;
  }

  .use_detail_table .out-date {
    width: 20%;
  }

  .use_detail_table .car-time {
    width: 20%;
  }

  .use_detail_table .parking-fee {
    width: 20%;
  }

  .use_detail_table .car {
    width: 20%;
  }
}

/* ----------------------------------------
	numberplate
---------------------------------------- */
.info-numberplate {
  display: flex;
}

.numberplate {
  display: inline-block;
  width: 60%;
}

.numberplate .carBox {
  margin: 10px 0;
  width: 175px;
  height: 93px;
  border: 4px double #aaaaaa;
  border-radius: 5px;
}

.numberplate .carBox .carTop {
  display: flex;
}

.numberplate .carBox .carTop .topLeft {
  margin: 11px 5px 5px 0;
  width: 60%;
  color: #004d04;
  text-align: right;
  font-size: 20px;
}

.numberplate .carBox .carTop .topRight {
  margin: 11px 0 5px 5px;
  width: 40%;
  color: #004d04;
  font-size: 20px;
}

.numberplate .carBox .carBottom {
  display: flex;
}

.numberplate .carBox .carBottom .bottomLeft {
  margin: 10px 5px;
  padding: 5px 0 0 5px;
  width: 16%;
  color: #004d04;
  font-size: 20px;
}

.numberplate .carBox .carBottom .bottomRight {
  width: 80%;
  color: #004d04;
  font-size: 45px;
}

.carEntry .numberplate .carBox {
  width: 193px;
  height: 112px;
}

.carEntry .numberplate .carBox .carTop .carArea {
  margin: 5px 0 5px 10px;
  padding: 5px 10px;
  width: 100px;
  font-size: 18px;
}

.carEntry .numberplate .carBox .carTop .carNumber01 {
  margin: 5px 10px 5px 5px;
  padding: 5px 10px;
  width: 60px;
  font-size: 18px;
}

.carEntry .numberplate .carBox .carBottom .carFont {
  position: relative;
  margin: 5px 10px 5px 10px;
  width: 60px;
  font-size: 18px;
}

.carEntry .numberplate .carBox .carBottom .carFont:before {
  position: absolute;
  top: 1.1em;
  right: 0.5em;
  width: 0;
  height: 0;
  padding: 0;
  content: "";
  border-top: 5px solid #aaaaaa;
  border-right: 5px solid transparent;
  border-left: 5px solid transparent;
  pointer-events: none;
}

.carEntry .numberplate .carBox .carBottom input {
  margin: 5px 10px 5px 10px;
  padding: 5px 10px;
  font-size: 18px;
}

.carEntry .numberplate .carBox .carBottom .carFont {
  width: 60px;
}

.carEntry .numberplate .carBox .carBottom .carNumber02 {
  width: 85px;
}

.ex-numberplate {
  display: flex;
  width: 60%;
}

.ex-numberplate img {
  width: auto;
  height: 100px;
  margin-left: 1em;
}

.numberplate .carNumber {
  width: 10em;
}

@media screen and (max-width: 1160px) {

  /*@media screen and (max-width: 767px) {*/
  .numberplate {
    display: block;
    width: 100%;
  }

  .numberplate .carBox {
    margin-bottom: 10px;
  }

  .numberplate .carBox input,
  select {
    height: 42px;
  }

  .info-numberplate {
    display: block;
  }

  .ex-numberplate {
    display: block;
    width: 100%;
    margin-top: 1em;
  }

  .ex-numberplate img {
    margin-left: 0;
    height: 93px;
    margin-top: 0.5em;
  }
}

@media screen and (max-width: 374px) {
  .ex-numberplate img {
    height: 78px;
  }
}

/* ETCカード登録 */

.consent-check {
  display: flex;
}

.consent-check label {
  margin: 1rem auto;
}

.cardNumber {
  display: flex;
}

.cardNumber span {
  padding: 20px 5px 0;
}

.etc-period-message {
  margin-top: 10px;
}

/* selectBox 全般 */
.selectBox {
  position: relative;
  display: inline-block;
  width: 85px;
  text-align: center;
  font-size: 18px;
}

.select-w100 {
  /* 秘密の質問 */
  width: 100%;
}

.select-font16 {
  /* 秘密の質問 */
  font-size: 16px;
}

.selectBox:before {
  content: "";
  position: absolute;
  top: 1.1em;
  right: 0.5em;
  width: 0;
  height: 0;
  padding: 0;
  border-top: 5px solid #aaa;
  border-right: 5px solid transparent;
  border-left: 5px solid transparent;
  pointer-events: none;
}

.selectBox select {
  width: 100%;
  cursor: pointer;
  text-indent: 0.01px;
  text-overflow: ellipsis;
  background: transparent;
  background-image: none;
  box-shadow: none;
  appearance: none;
  padding: 6px 24px 6px 10px;
  color: #666666;
}

/* ----------------------------------------
	registration 新規登録
---------------------------------------- */

.reserveTerm {
  text-align: center;
  margin: 3rem 0;
}

.reserveTerm a {
  color: #46b2e7;
  text-decoration: underline;
}

.reserveTerm a:hover {
  text-decoration: none;
}

.reserveTerm div {
  margin-bottom: 3rem;
  line-height: 1.2;
}

.term {
  margin: 10px 0;
  border: 1px solid #aaa;
}

.term .scrollBox {
  height: 100px;
  min-height: 200px;
  margin: 10px;
  padding: 15px;
  border: 1px solid #aaa;
  overflow: scroll;
  overflow-x: hidden;
  font-size: 0.8rem;
  background: #fffaf0;
}

.term .scrollBox .rules-ttl-b {
  margin-bottom: 10px;
  font-size: 1rem;
  font-weight: bold;
}

.term .scrollBox .rules-ttl-top {
  margin: 10px 0;
  font-weight: bold;
}

.term .scrollBox .rules-day {
  text-align: right;
}

.term .scrollBox .term-box li {
  display: flex;
  margin: 0 10px 30px 10px;
  line-height: 1.5;
}

.term .scrollBox .term-box li .number {
  display: inline-block;
  padding-right: 20px;
  width: 78px;
  text-align: right;
}

.term .scrollBox .term-box li .sub-ttl {
  display: block;
  padding-bottom: 5px;
}

.term .scrollBox .term-box li div {
  display: inline-block;
  width: 100%;
}

.term .scrollBox .term-box li div .brakets-box {
  padding-top: 15px;
}

.term .scrollBox .term-box li div .brakets-box .brakets-list {
  margin: 0 10px 15px 0;
}

.term .scrollBox .supplementary {
  margin-left: 10px;
  line-height: 1.5;
}

/* ----------------------------------------
	contact　* お問い合わせ *
---------------------------------------- */
div.contact-box {
  margin: 1em auto;
}

div.contact-table {
  display: table;
  max-width: 25em;
  word-break: break-all;
  border-top: 1px solid #aaa;
  border-left: 1px solid #aaa;
}

div.contact-table-raw {
  display: table-row;
  min-height: 3em;
}

div.contact-table-cell {
  display: table-cell;
  vertical-align: middle;
  height: 2em;
  padding: 0.3em;
  border-right: 1px solid #aaa;
  border-bottom: 1px solid #aaa;
  line-height: 1.2;
}

div.contact-table-cell:first-child {
  width: 7em;
  background-color: #f0f0f0;
}

@media screen and (max-width: 767px) {
  div.contact-table {
    display: block;
    width: 100%;
    margin: 0 auto;
  }

  div.contact-table-raw {
    display: block;
  }

  div.contact-table-cell {
    display: block;
    height: auto;
  }

  div.contact-table-cell:first-child {
    width: 100%;
    background-color: #f0f0f0;
  }
}

/* ----------------------------------------
	support　* よくある質問 *
---------------------------------------- */
.support-top {
  line-height: 1.25;
  font-size: 0.9em;
  border-bottom:  2px solid #dff1fd;
}

.support-top div {
  border-top:  2px solid #dff1fd;
}

.support-top dl {
  clear: both;
  overflow: hidden;
  overflow-wrap: break-word;
  display: flex;
}

.support-top .dl-question {
  cursor: pointer;
  margin: 3px 0px;
}

.support-top .dl-answer {
  pointer-events: none;
  margin: 3px 0px ;
}

.support-top dl dt {
  padding: 5px 0 5px 0px;
  width: 38px;
  float: left;
  clear: both;
}

.support-top dl dt .question-marker{
  float: left;
  border-left: 8px solid #6bb2ec;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  margin-top: 6px;
}

.support-top dl dt .answer-marker{
  float: left;
  border-right: 5px solid transparent;
  border-left: 5px solid transparent;
  border-top: 8px solid #6bb2ec;
  margin-top: 8px;
}

.support-top dl dt .question-icon{
  float: right;
  background: #ffffff;
  border: solid 2px #6bb2ec;
  border-radius: 50% ;
  height: 24px;
  width: 24px;
  color: #6bb2ec;
  font-size: 0.9rem;
  text-align: center;
  line-height: 1.25;
}

.support-top dl dt .answer-icon{
  float: right;
  background: #6bb2ec;
  border-radius: 50% ;
  height: 24px;
  width: 24px;
  color: #ffffff;
  font-size: 0.9rem;
  text-align: center;
  line-height: 1.6;
}

.support-top dl dd {
  width: calc(100% - 38px);
  padding: 8px 30px 8px 5px;
}

.support-top-btn {
  width: 300px;
}

@media screen and (max-width: 767px) {
  .support-top-btn {
    width: 55%;
  }
}

.nochng-ntc a {
  color: #028dd2;
}

.tdCtn .repeatDiscountInfo {
  display: inline-block;
  width: 58%;
  vertical-align: middle;
}

/* 割引情報 */
.tableDiscount {
  border-top: 1px solid #006abd;
  border-right: 1px solid #006abd;
  border-left: 1px solid #006abd;
  margin-bottom: 20px;
}

.tableDiscount .tableTitle {
  display: flex;
  align-items: normal;
  text-align: center;
  border-bottom: 1px solid #006abd;
  background: #dff1fd;
}

.tableDiscount .tableContents {
  display: flex;
  align-items: normal;
  border-bottom: 1px solid #006abd;
  background: #fff;
  text-align: left;
  height: 115px;
}

.tableDiscount .tableLine {
  display: flex;
  align-items: center;
}

.tableDiscount .tableCell_l {
  align-content: center;
  padding: 10px;
  width: 16%;
  word-wrap: break-word;
}

.tableDiscount .tableCell_cl {
  align-content: center;
  padding: 10px;
  width: 31%;
  border-left: 1px solid #006abd;
  word-wrap: break-word;
}

.tableDiscount .tableCell_c {
  align-content: center;
  padding: 10px;
  width: 19%;
  border-left: 1px solid #006abd;
  word-wrap: break-word;
}

.tableDiscount .tableCell_cr {
  align-content: center;
  padding: 10px;
  width: 24%;
  border-left: 1px solid #006abd;
  word-wrap: break-word;
}

.tableDiscount .tableCell_r {
  align-content: center;
  padding: 10px;
  width: 10%;
  border-left: 1px solid #006abd;
}

.nochng-tableDiscount {
  margin: 1em 0 0.5em;
  line-height: 1.2;
}

.tableDiscount .tableCell_r p{
  text-align: right;
}

.tdCtn_v {
  background: #fff;
  padding: 3% 0 3% 0;
}
.breadcrumb {
  background: none;
  padding:10px;
}

.breadcrumbZero {
  color: #6bb2ec;
}

.breadcrumbZero-link {
  pointer-events: none;
}

.breadcrumbZero-link:hover {
  cursor: help;
}
.breadcrumbNonZero {
  pointer-events: none;
  color: #000;
}

.breadcrumb-top {
  padding-top: 1rem;
}



@media screen and (min-width:768px){
  .tableDiscount .tableContents .tdCtn{
    padding: 10px 0;
  }
}

@media screen and (max-width: 767px) {
  
  .tableDiscount  {
    border: none;
    width: 100%;
  }
  .tableDiscount .tableTitle {
    display: block;
    text-align: left;
  }

  .tableDiscount .tableContents {
    display: block;
    border: none;
  }

  .tdCtn_v {
    background: #fff;
    padding: 3% 0 3% 0;
  }
  
  .tableDiscount .tableCell_l,
  .tableDiscount .tableCell_cl,
  .tableDiscount .tableCell_c,
  .tableDiscount .tableCell_cr,
  .tableDiscount .tableCell_r {
    padding: 0px;
    width: 100%;
    border-left: none;
  }

  .tableCell_r .tdCtn .tdCtn_v p{
    text-align: right;
  }

  .tableDiscount .tableCell_l {
    background: #dff1fd;
  }
  
.tableDiscount .tableCell_r div p{
  text-align: left;
}
}