@charset "utf-8";

.irregular-setting2 {
  height: 23em;
  line-height: 23em;
}

.lineup-flex {
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding-left: 30px;
}

.lineup-flex a {
  text-decoration: none;
}

.lineup-flex li {
  width: 80%;
  line-height: 2rem;
}

.mgm-set1 {
  height: auto;
  width: 4.5em;
  display: flex;
  justify-content: center;
  align-items: center;
}

.mgm-set2 {
  height: auto;
  display: flex;
  justify-content: center;
  align-items: center;
}

.mgm-set3 {
  height: auto;
  display: flex;
  justify-content: center;
  align-items: center;
}

.mgm-ul {
  margin-left: -20px;
  margin-top: 0;
}

.mgm-calc {
  display: flex;
  list-style: none;
  flex-wrap: wrap;
  width: 100%;
  margin-left: -35px;
}

.mgm-calc li {
  width: calc(33.33% - 20px);
  border-right: dashed 1px #cccccc;
  margin-right: 7px;
}

.mgm-calc li:not(:first-child) {
  margin-left: 7px;
}

.line-img-1 {
  display: flex;
  gap: 70px;
  width: 100%;
  justify-content: center;
}

.line-img-1 div {
  width: 30%;
}

.line-img-2 {
  width: 30%;
  margin: 0 auto;
}

.f-bold {
  font-weight: bold;
}

.linearea-btn {
  width: 100%;
  margin-top: 80px;
  margin-bottom: 80px;
  text-align: center;
}

.linearea-btn a {
  width: 40%;
  background-color: #b99a48;
  color: #ffffff;
  text-decoration: none;
  padding: 20px;
  display: inline-block;
}

.info-wid {
  width: 100%;
}

.info-midashi {
  background-color: #eee;
  padding: 10px;
}

.box_18 {
  position: relative;
  padding: 30px;
  padding-top: 50px;
  border: 2px solid #000;
  margin-top: 50px;
  margin-bottom: 50px;
}

.box_18_ttl {
  position: absolute;
  padding: 10px;
  left: 30px;
  top: -25px;
  background: #000;
  font-weight: bold;
  color: #f0f0f0;
}

.img-set {
  width: 50%;
}

.img-set2 {
  width: 25%;
}

.sp-only {
  display: none;
}

.wid-res {
  width: 60% !important;
}

.table-h {
  border-collapse: revert !important;
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
  margin-top: 20px !important;
}

.table-h th {
  background-color: #000 !important;
  color: #ffffff !important;
  height: 50px !important;
  width: 90px;
}

.table-h td {
  border: none !important;
  text-align: left !important;
}

.table-graph {
  border: 1px solid #000000;
  border-collapse: collapse;
  width: 50%;
}

.table-graph tr {
  border-collapse: collapse;
  border-bottom: solid 1px #000000;
}

.table-graph th:first-child {
  border-right: solid 1px #000000;
  width: 50%;
  padding: 10px;
  background-color: #eee;
}

.table-graph th:nth-child(2) {
  width: 50%;
  padding: 10px;
  background-color: #eee;
}

.table-graph td:first-child {
  width: 50%;
  padding: 10px;
  border-right: solid 1px #000000;
}

.table-graph td:nth-child(2) {
  width: 50%;
  padding: 10px;
}

.table-width {
  width: 80%;
}

.table td {
  padding: 5px;
}

.sp-plan {
  list-style: none;
  margin-left: -40px;
  line-height: 3.5;
}

.sp-plan li::before {
  content: "■";
  padding-right: 5px;
}

.lucua-imgset {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 30px;
  width: 70%;
  margin-top: 30px;
}

/* 2025.07.03 追記 */
.text-center {
  text-align: left;
  line-height: 2;
}

.p-tdSp {
  text-align: left;
  padding: 0;
}

.pcNone {
  display: none;
}

.sp-textSmall {
  text-align: left;
}

/* 2025.08.06 追記 */
.img_resize {
  width: 100%;
  max-width: 600px;
}
.img_resize img {
  width: 100%;
}
.img_resizeHalf {
  width: 100%;
  max-width: 300px;
}
.img_resizeHalf img {
  width: 100%;
}

/* 2025.08.22 追記 */
.header_borderL {
  border-left: solid 5px #000;
  padding-left: 10px;
  margin-top: 2rem;
  background-color: #f0f0f0;
  padding: 15px;
}

.info_dl {
  margin-left: 2em;
}

.info_dt {
  font-weight: bold;
  margin-left: 1em;
  position: relative;
}

.info_dt::before {
  content: "";
  position: absolute;
  width: 0.5em;
  height: 0.5em;
  background-color: #333;
  transform: translate(-100%, -50%);
  top: 50%;
  left: -0.25em;
}

.info_dd {
  margin: 0 0 1.5em 1em;
}

.info_dd ul {
  padding: 0 0 0 2em;
}

.sansou_dl {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  line-height: 1.5;
  padding-left: 1.5em;
}

.sansou_dt {
  white-space: nowrap;
  width: 8.5em;
  font-weight: bold;
  text-align: left;
  position: relative;
}

.sansou_dt::after {
  position: absolute;
  content: "：";
  width: 1em;
  height: 1em;
  top: 0;
  right: 0;
  transform: translateX(100%);
}

.sansou_dd {
  width: calc(100% - 12em);
  word-break: break-all;
  hyphens: manual;
  margin-bottom: 1.5em;
  margin-left: 1.5em;
}

.pc_2column {
  display: flex;
  gap: 1rem;
  width: 80%;
}

.pc_2column div {
  width: calc((100% - 1rem) / 2);
}

.pl_1rem {
  padding-left: 1rem;
}

.info_h4 {
  margin: 2em 0 0.5em;
}

.flex-set {
  display: flex;
  justify-content: space-between;
  padding: 0 40px;
}

.flex-img-1 {
  width: 45%;
  align-content: center;
}

.flex-img-2 {
  width: 45%;
}

.t-beside-line {
  width: 100%;
  border: solid 1px #000000;
}

.box-line {
  display: flex;
  border-bottom: solid 1px #000000;
}

.box-line:last-child {
  border-bottom: none;
}

.t-line-1 {
  display: flex;
  border: solid 1px #000000;
}

.t-line-left {
  width: 50%;
  border-right: solid 1px #000000;
}

.t-line-right {
  width: 50%;
}

.t-line-h2 {
  border-bottom: solid 1px #000000;
  text-align: center;
  padding: 10px;
  background-color: #eee;
  font-weight: bold;
}

.t-line-txt {
  padding: 10px;
}

.t-c {
  text-align: center;
}

.heading-h5 {
  padding: 0.5em 0.7em;
  border-left: 5px solid #2589d0;
  color: #333333;
}

.scrollbar {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.scrollbar::-webkit-scrollbar {
  display: none;
}

.table-wrap {
  margin-top: 10px;
  margin-bottom: 50px;
  overflow: scroll;
  width: 100%;
  scrollbar-width: none;
  /* Firefox用 */
  -ms-overflow-style: none;
  /* IE10+用 */
}
/* 2025年12月4日 追記 */
.p-info__h2 {
  font-size: 1.15em;
  font-weight: bold;
  margin: 1em 0;
  padding: 0;
  box-shadow: none;
}
.img__note {
  margin: 0;
  text-align: center;
}
/* 2025年12月9日 */
.waku {
  margin-bottom: 20px;
}

.waku .p-note {
  position: relative;
  text-align: left;
  margin-top: 0.5em;
  margin-bottom: 0;
  padding-left: 1.25em;
  color: var(--noteColor);
  line-height: 1.5;
}
.waku .p-note:first-of-type {
  margin-top: 1em;
}
.waku .p-note::before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
  width: 1em;
  height: 1em;
}
#news251212 th {
  padding: 5px 8px;
}
#news251212 td {
  padding: 5px 5px;
}
#news251212 ol {
  padding-left: 2.5em;
}
#news251212 li {
  position: relative;
}
#news251212 li + li {
  margin-top: 0.5em;
}
#news251212 li::before {
  position: absolute;
  content: "※";
  top: 0;
  left: -2.5em;
  width: 1em;
  height: 1em;
}

/* 2026年1月16日 追記 */
/* 戻るボタン */
.p-backBtn {
  color: #666;
  line-height: 1;
  display: block;
  padding: 0.75em 1.5em;
  border: solid 1px #666;
  border-radius: 2px;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 30px;
  text-decoration: none;
  box-shadow: 0px 0px 2px 2px rgba(0, 0, 0, 0.1);
  transition: all 0.2s ease;
}
.p-backBtn:hover {
  background-color: #666;
  color: #fff;
}

/* お問い合わせ */
/* .p-contactBtn {
  margin-right: 20px;
  margin-bottom: 30px;
  text-align: right;
} */

@media screen and (max-width: 767px) {
  .waku p {
    margin-top: 1.5em;
  }
  .border-set {
    width: 5.3em;
  }

  .border-anther {
    width: 6.5em;
  }

  .lineup-flex {
    display: block;
    padding-left: 20px;
  }

  .lineup-flex li {
    width: 100%;
  }

  .mgm-set1 {
    height: auto;
  }

  .mgm-ul {
    margin-left: -22px;
    margin-top: 0;
  }

  .mgm-set3 {
    height: auto;
  }

  .mgm-calc {
    display: block;
    list-style: disc;
    flex-wrap: wrap;
    width: 100%;
  }

  .mgm-calc li {
    width: 100%;
    border-right: none;
    margin-right: none;
  }

  .mgm-calc li:not(:first-child) {
    margin-left: none;
  }

  .line-img-1 {
    display: block !important;
  }

  .line-img-1 div {
    margin: 0 auto !important;
    width: 70% !important;
  }

  .line-img-2 {
    width: 70% !important;
  }

  .linearea-btn a {
    width: 90%;
  }

  .hans-limt {
    margin-top: 15px;
  }

  .info-wid {
    width: 85%;
  }

  .info-midashi {
    background-color: #eee;
    padding: 10px;
  }

  .box_18 {
    padding-top: 20px;
  }

  .box_18_ttl {
    left: 35px;
  }

  .img-set {
    width: 100%;
  }

  .afa-set {
    width: 5.5em !important;
  }

  .sp-only {
    display: block;
  }

  .pc-only {
    display: none;
  }

  .wid-res {
    width: 100% !important;
  }

  .table-graph {
    width: 100%;
  }

  .table-h th {
    width: 90px;
  }

  .img-set2 {
    width: 100%;
  }

  .afa-set {
    width: 5.5em !important;
  }

  .sp-only {
    display: block;
  }

  .pc-only {
    display: none;
  }

  .table-width {
    width: 100%;
  }

  .ul-le {
    padding-left: 20px;
  }

  .ul-le li:not(:first-child) {
    margin-top: 10px;
  }

  .lucua-imgset {
    display: block;
    width: 100%;
  }

  /* 2025.07.03 追記 */
  .pcNone {
    display: block;
  }

  .p-tdSp {
    text-align: right;
    /* padding-right: 2rem; */
    display: inline-block;
    width: auto;
  }

  .text-center {
    text-align: center;
    line-height: 2;
  }

  .sp-textSmall {
    line-height: 1.25;
  }
  .img_resizeHalf {
    max-width: none;
  }

  /* 2025.08.22 追記 */
  .info_dl {
    margin-left: 0.5em;
  }

  .info_dd {
    margin: 0 0 1.5em 0.25em;
  }

  .info_dd ul {
    padding: 0;
  }

  .sansou_dl {
    flex-direction: column;
    padding-left: 0.5em;
  }

  .sansou_dt {
    width: fit-content;
    text-align: start;
    text-align-last: initial;
    margin-bottom: 0.25em;
  }

  .sansou_dd {
    width: 100%;
    word-break: break-all;
    hyphens: manual;
    margin-bottom: 1.5em;
    margin-left: 0;
    padding-bottom: 1.5em;
    padding-left: 1em;
    border-bottom: 1px solid #ccc;
  }

  .pc_2column {
    flex-direction: column;
    width: 100%;
  }

  .pc_2column div {
    width: 100%;
  }

  .pl_1rem {
    padding-left: 0;
  }

  .info_h4 {
    margin: 3em 0 0.5em;
  }

  .element__container > .info_h4:first-of-type {
    margin: 1em 0 0.5em;
  }

  .flex-set {
    display: block;
    padding: 0;
  }

  .flex-img-1 {
    width: 100%;
    height: 135px;
  }

  .flex-img-2 {
    width: 100%;
    margin-top: 30px;
  }

  .t-line-1 {
    display: block;
    border: none;
  }

  .t-line-left {
    width: 100%;
    border: solid 1px #000000;
  }

  .t-line-right {
    width: 100%;
    border: solid 1px #000000;
    margin-top: 50px;
  }

  .table-wrap {
    margin-bottom: 30px;
  }
  /* 2025年12月4日 追記 */
  .table-wrap {
    margin-bottom: 30px;
  }
  .img__note {
    text-align: center;
  }
}
