.container {
  margin: 0 auto;
  padding: 20px;
  max-width: 950px;
}
.app-info__contents {
  border-bottom: thin solid #ccc;
  padding: 20px;
  text-align: center;
}
.app-info__contents .key {
  color: #999;
}
.app-info__contents .align-left {
  text-align: left;
}
.app-info__contents .space-evenly {
  display: flex;
  justify-content: space-evenly;
}
.app-info__contents .terminal {
  font-size: 12px;
}
.app-info__contents .license {
  font-size: 12px;
  color: #646464;
}

/* アンダーライン */
.bottom-line_hed {
  margin: 0;
  margin-bottom: 20px;
}

.bottom-line_txt {
  height: 0.5px;
  background: rgba(0, 0, 0, 0.2);
  margin: 10px 0px;
}

.bottom-line_txt_tel {
  height: 0.5px;
  background: rgba(0, 0, 0, 0.2);
  margin: 10px 16px;
}

/* よくある質問 */
.q-doc__body {
  background-color: #f6f6f6;
}
.q-doc__body .q-doc__container {
  margin-bottom: 20px;
  padding: 10px 30px;
}
.q-doc__body .q-doc__container:last-of-type {
  padding-bottom: 30px;
  margin-bottom: 0px;
}
.q-doc__body .q-doc__container h2 {
  user-select: none;
  margin: 5px 0px;
  font-size: 0.9rem;
  color: #00b4be;
}
.q-doc__body .q-doc__container .q-doc__contents {
  position: relative;
  border: thin solid #d8d8d8;
  background-color: #fff;
  padding: 10px;
}
.q-doc__body .q-doc__container .q-doc__contents.header {
  cursor: pointer;
}
.q-doc__body .q-doc__container .q-doc__contents.header:hover {
  opacity: 0.7;
}
.q-doc__body .q-doc__container .q-doc__contents + .q-doc__contents {
  border-top: none;
}
.q-doc__body .q-doc__container .q-doc__contents:first-of-type {
  border-radius: 10px 10px 0 0;
}
.q-doc__body .q-doc__container .q-doc__contents:last-of-type {
  border-radius: 0 0 10px 10px;
}
.q-doc__body .q-doc__container .q-doc__contents:only-of-type {
  border-radius: 10px;
}
.q-doc__body .q-doc__container .q-doc__contents h5 {
  user-select: none;
  color: #555;
  margin: 0;
  font-size: 0.8rem;
  margin-right: 22px;
  margin-left: 1.7rem;
  text-indent: -1.7rem;
}
.q-doc__body .q-doc__container .q-doc__contents h5::before {
  content: "Q";
  color: #00b4be;
  margin-right: 16px;
}
.q-doc__body .q-doc__container .q-doc__contents img {
  position: absolute;
  top: 50%;
  right: 18.5px;
  transform: translateY(-50%);
}
.q-doc__body h1.q-doc__category {
  background-color: #ececec;
  padding: 5px 20px;
  font-size: 0.7rem;
  margin-bottom: 5px;
  color: #00b4be;
}

.q-doc__body .q-doc__container .q-doc__contents .q-doc__contents_body {
  margin-bottom: 10px;
}
.q-doc__body .q-doc__container .q-doc__contents.open .q-doc__contents_body {
  display: block;
}
.q-doc__body .q-doc__container .q-doc__contents .q-doc__question_prefix {
  font-weight: bold;
  margin-right: 5px;
  color: #00b4be;
}

/* よくある質問詳細 */
.q-dtl__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  justify-content: space-between;
  height: 90vh;
  padding: 10px 20px;
}
.q-dtl__body .q-dtl__contents {
  margin-bottom: 30px;
}
.q-dtl__body .q-dtl__contents h3 {
  margin-left: 18px;
  margin-top: 13px;
  font-style: normal;
  font-weight: 600;
  font-size: 15px;
  line-height: 22px;
}
.q-dtl__body .q-dtl__contents h3::before {
  content: "Q";
  color: #00b4be;
  position: absolute;
  top: 22px;
  left: 16px;
  font-weight: 600;
  font-size: 18px;
}
.q-dtl__body .q-dtl__contents h3.not_found::before {
  content: "";
}
.q-dtl__body .q-dtl__contents .q-dtl__answer {
  margin-left: 18px;
  margin-top: 20px;
  font-weight: 400;
  font-size: 15px;
  line-height: 22px;
}
.q-dtl__body .q-dtl__contents .q-dtl__answer::before {
  content: "A";
  color: #00b4be;
  position: absolute;
  left: 16px;
  font-weight: 600;
  font-size: 18px;
}
.q-dtl__body .q-dtl__contents .q-dtl__answer span {
  display: block;
  padding-left: 1em;
  text-indent: -1em;
}
.q-dtl__body .q-dtl__contents .q-dtl__answer table {
  margin-left: 0;
}
.q-dtl__body .q-dtl__contents .q-dtl__answer table tr td {
  vertical-align: top;
}
.q-dtl__body .q-dtl__contents button.q-dtl__tel {
  padding: 8px;
  border: none;
  background-color: #00b4be;
  color: #fff;
  border-radius: 10px;
  cursor: pointer;
  font-weight: bold;
  letter-spacing: 0.25rem;
  margin-left: auto;
  margin-right: auto;
  display: none;
}
.q-dtl__body .q-dtl__contents button.q-dtl__tel:hover {
  opacity: 0.75;
}

.q-dtl__body .q-dtl__footer {
  text-align: center;
  /* font-size: 0.8rem; */
}
.q-dtl__body .q-dtl__footer .q-dtl__table {
  display: inline-table;
  border-collapse: separate;
  border-spacing: 20px;
}
.q-dtl__body .q-dtl__footer .q-dtl__table .q-dtl__table-cell {
  display: table-cell;
  background-color: #f3f3f3;
  height: 120px;
  width: 94px;
  cursor: pointer;
  padding: 5px;
  border-radius: 4px;
  vertical-align: middle;
}
.q-dtl__body .q-dtl__footer .q-dtl__table .q-dtl__table-cell:hover {
  opacity: 0.8;
}
.q-dtl__body .q-dtl__footer h4 {
  margin: 0;
  font-weight: 400;
  font-size: 15px;
  line-height: 22px;
}
.q-dtl__body .q-dtl__footer .q-dtl__symbol {
  font-size: 30px;
  padding-bottom: 5px;
}
.q-dtl__body .q-dtl__footer .q-dtl__result {
  font-weight: 400;
  font-size: 12px;
  line-height: 17px;
  display: flex;
}
.q-dtl__body .q-dtl__footer .q-dtl__result.circle {
  height: 34px;
  margin-top: 12px;
  margin-bottom: 5px;
  align-items: center;
  justify-content: center;
}
.q-dtl__body .q-dtl__footer .q-dtl__result.cross {
  height: 34px;
  margin-top: 12px;
  margin-bottom: 5px;
  align-items: center;
  justify-content: center;
}
.q-dtl__body .q-dtl__footer .q-dtl__result.triangle {
  height: 34px;
  margin-top: 12px;
  margin-bottom: 5px;
  align-items: center;
  justify-content: center;
}

/* お問い合せ（電話） */
.q-tel__body {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 90vh;
}
.q-tel__body .q-tel__container {
  margin: 20px;
}
.q-tel__body .q-tel__container h2 {
  font-size: 24px;
  font-weight: 400;
  color: #544a47;
  text-align: center;
}
.q-tel__body .q-tel__container .q-tel__discript {
  display: none;
  color: #544a47;
  font-size: 15px;
  font-weight: 300;
  line-height: 22px;
}
.q-tel__body .q-tel__container .q-tel__delete-able-privacy {
  color: #544a47;
  font-size: 15px;
  font-weight: 300;
  line-height: 22px;
}
.q-tel__body .q-tel__container .q-tel__member-no {
  margin-top: 20px;
  margin-bottom: 36px;
  display: none;
}
.q-tel__body .q-tel__container .q-tel__member-no h3 {
  margin: 0 0 5px 0;
  font-weight: 600;
  font-size: 15px;
  line-height: 22px;
  color: #544a47;
}
.q-tel__body .q-tel__container .q-tel__member-no .member_no {
  font-weight: 300;
  font-size: 24px;
  line-height: 32px;
  text-align: center;
  border-top: 0.5px solid;
  border-bottom: 0.5px solid;
  border-color: rgba(0, 0, 0, 0.2);
  padding: 5px;
  color: #544a47;
}
.q-tel__body .q-tel__container .q-tel__contents {
  height: 110px;
  margin-top: 36px;
  background-color: #f3f3f3;
  text-align: center;
  padding: 20px 0px;
  border-radius: 4px;
}
.q-tel__body .q-tel__container .q-tel__contents .telno {
  font-weight: 300;
  font-size: 35px;
  line-height: 32px;
  margin-bottom: 36px;
}
.q-tel__body .q-tel__container .q-tel__contents .reception-time {
  margin-top: 10px;
  margin-left: 16px;
  margin-right: 16px;
  /* border-top: 0.5px solid;
  border-color: rgba(0, 0, 0, 0.2); */
  font-weight: 300;
  font-size: 15px;
  line-height: 22px;
  color: #544a47;
}
.q-tel__body .q-tel__footer {
  display: none;
  text-align: center;
  color: #544a47;
}

/* お問い合せ（フォーム） */
.q-mail__body {
  padding: 0 20px;
}
.q-mail__body .q-mail__container {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 90vh;
}
.q-mail__body .q-mail__container .q-mail__head h2 {
  font-size: 24px;
  font-weight: 400;
  color: #544a47;
  text-align: center;
  margin-bottom: 30px;
}
.q-mail__body .q-mail__container .q-mail__head .q-mail__discript {
  margin-bottom: 30px;
  color: #555;
}
.q-mail__body .q-mail__container .q-mail__form {
  flex-grow: 1;
}
.q-mail__body .q-mail__container .q-mail__form .q-mail__contents {
  margin-bottom: 20px;
}
.q-mail__body .q-mail__container .q-mail__form .q-mail__contents .head {
  position: relative;
  font-size: 1.5rem;
  font-weight: bold;
}
.q-mail__body .q-mail__container .q-mail__form .q-mail__contents .head .key {
  color: #544a47;
}
.q-mail__body
  .q-mail__container
  .q-mail__form
  .q-mail__contents
  .head
  .key.require::after {
  content: "必須";
  font-size: 15px;
  position: absolute;
  top: 0;
  right: 5px;
  color: #cb0c0c;
  font-weight: normal;
}
.q-mail__body .q-mail__container .q-mail__form .q-mail__contents .body {
  margin-bottom: 30px;
}
.q-mail__body
  .q-mail__container
  .q-mail__form
  .q-mail__contents
  .body
  input[type="text"],
.q-mail__body
  .q-mail__container
  .q-mail__form
  .q-mail__contents
  .body
  textarea {
  margin: 10px 0;
  padding: 10px;
  width: 100%;
  width: -moz-available; /* WebKit-based browsers will ignore this. */
  width: -webkit-fill-available; /* Mozilla-based browsers will ignore this. */
  width: fill-available;
  border: 1px solid rgba(0, 0, 0, 0.15);
  border-radius: 5px;
  background-color: #fcfcfc;
}
.q-mail__body
  .q-mail__container
  .q-mail__form
  .q-mail__contents
  .body
  textarea {
  resize: none;
}
.q-mail__body .q-mail__container .q-mail__foot {
}
.q-mail__body .q-mail__container .q-mail__foot input[type="button"] {
  width: 100%;
  width: -moz-available; /* WebKit-based browsers will ignore this. */
  width: -webkit-fill-available; /* Mozilla-based browsers will ignore this. */
  width: fill-available;
  height: 50px;
  border: none;
  background-color: #00b4be;
  color: #fff;
  border-radius: 10px;
  cursor: pointer;
  font-size: 17px;
  font-weight: bold;
  letter-spacing: 0.25rem;
  margin-bottom: 10px;
}
.q-mail__body .q-mail__container .q-mail__foot input[type="button"]:hover {
  opacity: 0.75;
}

.q-mail__body .q-mail__container .q-mail__foot_text input[type="button"] {
  width: 100%;
  width: -moz-available; /* WebKit-based browsers will ignore this. */
  width: -webkit-fill-available; /* Mozilla-based browsers will ignore this. */
  width: fill-available;
  height: 40px;
  border: none;
  background-color: #fff;
  color: #00b4be;
  border-radius: 5px;
  cursor: pointer;
  font-size: 17px;
  letter-spacing: 0.25rem;
  margin-bottom: 20px;
}

.q-mail__body .q-mail__container .q-mail__foot_text input[type="button"]:hover {
  opacity: 0.75;
}

/* ランク説明 */
.rank-info__body {
  margin: 28px 15px 24px;
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN",
    "Hiragino Sans", Meiryo, sans-serif;
  color: #544a47;
}
.rank-info__contents {
  margin: auto;
  min-width: 310px;
}
.rank-info__contents_head {
  color: #fff;
  background-color: #00b4be;
  text-align: center;
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
  font-size: 15px;
  line-height: 15px;
  padding-top: 9px;
  padding-bottom: 8px;
  font-weight: bold;
}
.rank-info__contents_body {
  margin-bottom: 32px;
  border: thin solid #d8d8d8;
  border-radius: 0 0 8px 8px;
}
.rank-info__contents_body .rank-info__contents_row,
.rank-info__contents_body .rank-info__contents_tab {
  position: relative;
  padding: 12px 15px;
}
.rank-info__contents_body .rank-info__contents_row + .rank-info__contents_row {
  border-top: thin solid #d8d8d8;
}
.rank-info__contents_row_head {
  font-size: 12px;
  line-height: 17px;
  font-weight: bold;
}
.rank-info__contents_row_body {
  font-size: 12px;
  line-height: 17px;
}
.rank-info__table {
  margin-left: 0;
}
.rank-info__table tr td {
  vertical-align: top;
}

.rank-info__contents_tab table {
  border-collapse: collapse;
  font-size: 10px;
  width: 100%;
}
.rank-info__contents_tab table thead tr th {
  text-align: center;
}
.rank-info__contents_tab table thead tr th div {
  background-color: #dff5f3;
  height: 42px;
  border-radius: 6px;
  display: inline-table;
}
.rank-info__contents_tab table thead tr th div span {
  line-height: 17px;
  display: table-cell;
  vertical-align: middle;
}
.rank-info__contents_tab table tbody tr {
  border-bottom: thin solid #d8d8d8;
}
.rank-info__contents_tab table tbody tr td {
  text-align: center;
  padding: 10px 0;
}
.rank-info__contents_tab table tbody tr td.td-rank {
  display: flex;
  justify-content: center;
  align-items: center;
}
.rank-info__contents_tab table tbody tr td.td-rank div {
  font-weight: bold;
  width: 80px;
  margin-left: 8px;
  text-align: left;
}
.rank-info__contents_tab table tbody tr td.td-rank img {
  width: 32px;
  height: 28px;
}
.rank-info__contents_tab table tbody tr td.td-cond {
  letter-spacing: -0.05em;
  font-size: 14px;
}

.rank-info__contents_tab table tbody tr td.td-cond span.tax {
  font-size: 10px;
}

.rank-info__contents_tab table tbody tr td.td-rate {
  font-size: 12px;
  font-weight: 600;
}

.rank-info__contents_tab table tbody tr td span.important {
  letter-spacing: -0.05em;
  font-weight: bold;
}

.rank-info__footer {
  margin: 0 10px 70px 0;
  color: #544a47;
}
.rank-info__footer .rank-info__table {
  font-size: 13px;
  padding-left: 13px;
}
.rank-info__footer ul {
  padding-inline-start: 26px;
}
.rank-info__footer ul li {
  font-size: 13px;
  line-height: 19px;
  list-style-type: none;
  text-indent: -0.6rem;
  margin-bottom: 7px;
}
.rank-info__footer ul li::before {
  display: inline;
  content: "※";
}
.rank-info__footer span {
  display: inline-block;
  text-indent: 0rem;
}

/* 大手門カード */
.ootemon__body {
  padding-left: 20px;
  padding-right: 20px;
}
.ootemon__body img {
  display: block;
  margin: auto;
  margin-bottom: 24px;
}
.ootemon__body h1 {
  font-size: 15px;
  color: #544a47;
}
.ootemon__body p {
  font-size: 15px;
  color: #544a47;
}
.ootemon__body ul {
  padding-left: 20px;
}
.ootemon__body ul.ootemon__info li {
  position: relative;
  font-size: 13px;
  line-height: 19px;
  color: #544a47;
  list-style-type: none;
  margin-bottom: 7px;
}
.ootemon__body ul.ootemon__info li::before {
  display: inline-block;
  content: "※";
  position: absolute;
  top: 0;
  left: -15px;
}
.ootemon__body ul.ootemon__guide li {
  font-size: 13px;
  line-height: 19px;
  color: #544a47;
}

/* 利用規約 */
.p-doc__body {
  color: #544a47;
}
.p-doc__container h2 {
  color: #00b4be;
  text-align: center;
  font-size: 26px;
  font-weight: 400;
}
.p-doc__container .p-doc__sub-header {
  font-weight: 600;
}
