@charset "UTF-8";
.mb4 {
  margin-bottom: 4px !important;
}

.mt4 {
  margin-top: 4px !important;
}

.mtb4 {
  margin-top: 4px !important;
  margin-bottom: 4px !important;
}

.mb8 {
  margin-bottom: 8px !important;
}

.mt8 {
  margin-top: 8px !important;
}

.mtb8 {
  margin-top: 8px !important;
  margin-bottom: 8px !important;
}

.mb12 {
  margin-bottom: 12px !important;
}

.mt12 {
  margin-top: 12px !important;
}

.mtb12 {
  margin-top: 12px !important;
  margin-bottom: 12px !important;
}

.mb16 {
  margin-bottom: 16px !important;
}

.mt16 {
  margin-top: 16px !important;
}

.mtb16 {
  margin-top: 16px !important;
  margin-bottom: 16px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mtb20 {
  margin-top: 20px !important;
  margin-bottom: 20px !important;
}

.mb24 {
  margin-bottom: 24px !important;
}

.mt24 {
  margin-top: 24px !important;
}

.mtb24 {
  margin-top: 24px !important;
  margin-bottom: 24px !important;
}

.mb28 {
  margin-bottom: 28px !important;
}

.mt28 {
  margin-top: 28px !important;
}

.mtb28 {
  margin-top: 28px !important;
  margin-bottom: 28px !important;
}

.mb32 {
  margin-bottom: 32px !important;
}

.mt32 {
  margin-top: 32px !important;
}

.mtb32 {
  margin-top: 32px !important;
  margin-bottom: 32px !important;
}

.mb36 {
  margin-bottom: 36px !important;
}

.mt36 {
  margin-top: 36px !important;
}

.mtb36 {
  margin-top: 36px !important;
  margin-bottom: 36px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mtb40 {
  margin-top: 40px !important;
  margin-bottom: 40px !important;
}

.mb44 {
  margin-bottom: 44px !important;
}

.mt44 {
  margin-top: 44px !important;
}

.mtb44 {
  margin-top: 44px !important;
  margin-bottom: 44px !important;
}

.mb48 {
  margin-bottom: 48px !important;
}

.mt48 {
  margin-top: 48px !important;
}

.mtb48 {
  margin-top: 48px !important;
  margin-bottom: 48px !important;
}

.mb52 {
  margin-bottom: 52px !important;
}

.mt52 {
  margin-top: 52px !important;
}

.mtb52 {
  margin-top: 52px !important;
  margin-bottom: 52px !important;
}

.mb56 {
  margin-bottom: 56px !important;
}

.mt56 {
  margin-top: 56px !important;
}

.mtb56 {
  margin-top: 56px !important;
  margin-bottom: 56px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mt60 {
  margin-top: 60px !important;
}

.mtb60 {
  margin-top: 60px !important;
  margin-bottom: 60px !important;
}

.mb64 {
  margin-bottom: 64px !important;
}

.mt64 {
  margin-top: 64px !important;
}

.mtb64 {
  margin-top: 64px !important;
  margin-bottom: 64px !important;
}

.mb68 {
  margin-bottom: 68px !important;
}

.mt68 {
  margin-top: 68px !important;
}

.mtb68 {
  margin-top: 68px !important;
  margin-bottom: 68px !important;
}

.mb72 {
  margin-bottom: 72px !important;
}

.mt72 {
  margin-top: 72px !important;
}

.mtb72 {
  margin-top: 72px !important;
  margin-bottom: 72px !important;
}

.mb76 {
  margin-bottom: 76px !important;
}

.mt76 {
  margin-top: 76px !important;
}

.mtb76 {
  margin-top: 76px !important;
  margin-bottom: 76px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.mt80 {
  margin-top: 80px !important;
}

.mtb80 {
  margin-top: 80px !important;
  margin-bottom: 80px !important;
}

.mb84 {
  margin-bottom: 84px !important;
}

.mt84 {
  margin-top: 84px !important;
}

.mtb84 {
  margin-top: 84px !important;
  margin-bottom: 84px !important;
}

.mb88 {
  margin-bottom: 88px !important;
}

.mt88 {
  margin-top: 88px !important;
}

.mtb88 {
  margin-top: 88px !important;
  margin-bottom: 88px !important;
}

.mb92 {
  margin-bottom: 92px !important;
}

.mt92 {
  margin-top: 92px !important;
}

.mtb92 {
  margin-top: 92px !important;
  margin-bottom: 92px !important;
}

.mb96 {
  margin-bottom: 96px !important;
}

.mt96 {
  margin-top: 96px !important;
}

.mtb96 {
  margin-top: 96px !important;
  margin-bottom: 96px !important;
}

.mb100 {
  margin-bottom: 100px !important;
}

.mt100 {
  margin-top: 100px !important;
}

.mtb100 {
  margin-top: 100px !important;
  margin-bottom: 100px !important;
}

@media screen and (min-width: 769px) {
  .pc_mb4 {
    margin-bottom: 4px !important;
  }
  .pc_mt4 {
    margin-top: 4px !important;
  }
  .pc_mtb4 {
    margin-top: 4px !important;
    margin-bottom: 4px !important;
  }
  .pc_mb8 {
    margin-bottom: 8px !important;
  }
  .pc_mt8 {
    margin-top: 8px !important;
  }
  .pc_mtb8 {
    margin-top: 8px !important;
    margin-bottom: 8px !important;
  }
  .pc_mb12 {
    margin-bottom: 12px !important;
  }
  .pc_mt12 {
    margin-top: 12px !important;
  }
  .pc_mtb12 {
    margin-top: 12px !important;
    margin-bottom: 12px !important;
  }
  .pc_mb16 {
    margin-bottom: 16px !important;
  }
  .pc_mt16 {
    margin-top: 16px !important;
  }
  .pc_mtb16 {
    margin-top: 16px !important;
    margin-bottom: 16px !important;
  }
  .pc_mb20 {
    margin-bottom: 20px !important;
  }
  .pc_mt20 {
    margin-top: 20px !important;
  }
  .pc_mtb20 {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
  }
  .pc_mb24 {
    margin-bottom: 24px !important;
  }
  .pc_mt24 {
    margin-top: 24px !important;
  }
  .pc_mtb24 {
    margin-top: 24px !important;
    margin-bottom: 24px !important;
  }
  .pc_mb28 {
    margin-bottom: 28px !important;
  }
  .pc_mt28 {
    margin-top: 28px !important;
  }
  .pc_mtb28 {
    margin-top: 28px !important;
    margin-bottom: 28px !important;
  }
  .pc_mb32 {
    margin-bottom: 32px !important;
  }
  .pc_mt32 {
    margin-top: 32px !important;
  }
  .pc_mtb32 {
    margin-top: 32px !important;
    margin-bottom: 32px !important;
  }
  .pc_mb36 {
    margin-bottom: 36px !important;
  }
  .pc_mt36 {
    margin-top: 36px !important;
  }
  .pc_mtb36 {
    margin-top: 36px !important;
    margin-bottom: 36px !important;
  }
  .pc_mb40 {
    margin-bottom: 40px !important;
  }
  .pc_mt40 {
    margin-top: 40px !important;
  }
  .pc_mtb40 {
    margin-top: 40px !important;
    margin-bottom: 40px !important;
  }
  .pc_mb44 {
    margin-bottom: 44px !important;
  }
  .pc_mt44 {
    margin-top: 44px !important;
  }
  .pc_mtb44 {
    margin-top: 44px !important;
    margin-bottom: 44px !important;
  }
  .pc_mb48 {
    margin-bottom: 48px !important;
  }
  .pc_mt48 {
    margin-top: 48px !important;
  }
  .pc_mtb48 {
    margin-top: 48px !important;
    margin-bottom: 48px !important;
  }
  .pc_mb52 {
    margin-bottom: 52px !important;
  }
  .pc_mt52 {
    margin-top: 52px !important;
  }
  .pc_mtb52 {
    margin-top: 52px !important;
    margin-bottom: 52px !important;
  }
  .pc_mb56 {
    margin-bottom: 56px !important;
  }
  .pc_mt56 {
    margin-top: 56px !important;
  }
  .pc_mtb56 {
    margin-top: 56px !important;
    margin-bottom: 56px !important;
  }
  .pc_mb60 {
    margin-bottom: 60px !important;
  }
  .pc_mt60 {
    margin-top: 60px !important;
  }
  .pc_mtb60 {
    margin-top: 60px !important;
    margin-bottom: 60px !important;
  }
  .pc_mb64 {
    margin-bottom: 64px !important;
  }
  .pc_mt64 {
    margin-top: 64px !important;
  }
  .pc_mtb64 {
    margin-top: 64px !important;
    margin-bottom: 64px !important;
  }
  .pc_mb68 {
    margin-bottom: 68px !important;
  }
  .pc_mt68 {
    margin-top: 68px !important;
  }
  .pc_mtb68 {
    margin-top: 68px !important;
    margin-bottom: 68px !important;
  }
  .pc_mb72 {
    margin-bottom: 72px !important;
  }
  .pc_mt72 {
    margin-top: 72px !important;
  }
  .pc_mtb72 {
    margin-top: 72px !important;
    margin-bottom: 72px !important;
  }
  .pc_mb76 {
    margin-bottom: 76px !important;
  }
  .pc_mt76 {
    margin-top: 76px !important;
  }
  .pc_mtb76 {
    margin-top: 76px !important;
    margin-bottom: 76px !important;
  }
  .pc_mb80 {
    margin-bottom: 80px !important;
  }
  .pc_mt80 {
    margin-top: 80px !important;
  }
  .pc_mtb80 {
    margin-top: 80px !important;
    margin-bottom: 80px !important;
  }
  .pc_mb84 {
    margin-bottom: 84px !important;
  }
  .pc_mt84 {
    margin-top: 84px !important;
  }
  .pc_mtb84 {
    margin-top: 84px !important;
    margin-bottom: 84px !important;
  }
  .pc_mb88 {
    margin-bottom: 88px !important;
  }
  .pc_mt88 {
    margin-top: 88px !important;
  }
  .pc_mtb88 {
    margin-top: 88px !important;
    margin-bottom: 88px !important;
  }
  .pc_mb92 {
    margin-bottom: 92px !important;
  }
  .pc_mt92 {
    margin-top: 92px !important;
  }
  .pc_mtb92 {
    margin-top: 92px !important;
    margin-bottom: 92px !important;
  }
  .pc_mb96 {
    margin-bottom: 96px !important;
  }
  .pc_mt96 {
    margin-top: 96px !important;
  }
  .pc_mtb96 {
    margin-top: 96px !important;
    margin-bottom: 96px !important;
  }
  .pc_mb100 {
    margin-bottom: 100px !important;
  }
  .pc_mt100 {
    margin-top: 100px !important;
  }
  .pc_mtb100 {
    margin-top: 100px !important;
    margin-bottom: 100px !important;
  }
}
.asterisk_list,
.asterisk_list_number,
.notes_list,
.notes_list_number {
  list-style: none;
  padding-left: 0 !important;
}
.asterisk_list li,
.asterisk_list_number li,
.notes_list li,
.notes_list_number li {
  display: flex;
  font-size: 0.7rem;
}
.asterisk_list + .note_after,
.asterisk_list_number + .note_after,
.notes_list + .note_after,
.notes_list_number + .note_after {
  margin-top: 15px;
  font-size: 0.75rem;
}

.notes_list li:before {
  content: "※";
  display: inline-block;
}
.notes_list li:is(.notes_numbering01,
.notes_numbering02,
.notes_numbering03,
.notes_numbering04)::before {
  margin-right: 10px;
}
.notes_list li.notes_numbering01:before {
  content: "※1";
}
.notes_list li.notes_numbering02:before {
  content: "※2";
}
.notes_list li.notes_numbering03:before {
  content: "※3";
}
.notes_list li.notes_numbering04:before {
  content: "※4";
}

.asterisk_list li:before {
  content: "*";
  display: inline-block;
}

.asterisk_list_number,
.notes_list_number {
  counter-reset: notes;
}
.asterisk_list_number li:before,
.notes_list_number li:before {
  display: inline-block;
  content: "※" counter(notes, decimal);
  counter-increment: notes;
  margin-right: 3px;
}

.notes_list_number li:before {
  content: "※" counter(notes, decimal);
}

.asterisk_list_number li:before {
  content: "*" counter(notes, decimal);
}

:is(.num_list_paren,
.num_list,
.alphabet_list,
.num_list_dot,
.asterisk_list,
.asterisk_list_number,
.notes_list,
.notes_list_number) {
  display: flex;
  flex-direction: column;
}
:is(.num_list_paren,
.num_list,
.alphabet_list,
.num_list_dot,
.asterisk_list,
.asterisk_list_number,
.notes_list,
.notes_list_number):is(.type_right, .right) {
  align-items: flex-end;
}
:is(.num_list_paren,
.num_list,
.alphabet_list,
.num_list_dot,
.asterisk_list,
.asterisk_list_number,
.notes_list,
.notes_list_number):is(.type_center, center) {
  align-items: center;
}
:is(.num_list_paren,
.num_list,
.alphabet_list,
.num_list_dot,
.asterisk_list,
.asterisk_list_number,
.notes_list,
.notes_list_number):is(.type_row, .type_direction_row) {
  flex-direction: row;
}
:is(.num_list_paren,
.num_list,
.alphabet_list,
.num_list_dot,
.asterisk_list,
.asterisk_list_number,
.notes_list,
.notes_list_number):is(.type_row, .type_direction_row):is(.type_center, center) {
  justify-content: center;
}
:is(.num_list_paren,
.num_list,
.alphabet_list,
.num_list_dot,
.asterisk_list,
.asterisk_list_number,
.notes_list,
.notes_list_number).type_direction_row {
  gap: 5px;
}
:is(.num_list_paren,
.num_list,
.alphabet_list,
.num_list_dot,
.asterisk_list,
.asterisk_list_number,
.notes_list,
.notes_list_number).type_row {
  flex-wrap: wrap;
  -moz-column-gap: 8px;
       column-gap: 8px;
}
@media screen and (min-width: 769px) {
  :is(.num_list_paren,
  .num_list,
  .alphabet_list,
  .num_list_dot,
  .asterisk_list,
  .asterisk_list_number,
  .notes_list,
  .notes_list_number):is(.pc_type_row, .pc_type_direction_row) {
    flex-direction: row;
  }
  :is(.num_list_paren,
  .num_list,
  .alphabet_list,
  .num_list_dot,
  .asterisk_list,
  .asterisk_list_number,
  .notes_list,
  .notes_list_number):is(.pc_type_row, .pc_type_direction_row):is(.type_center, center) {
    justify-content: center;
  }
  :is(.num_list_paren,
  .num_list,
  .alphabet_list,
  .num_list_dot,
  .asterisk_list,
  .asterisk_list_number,
  .notes_list,
  .notes_list_number).pc_type_direction_row {
    gap: 5px;
  }
  :is(.num_list_paren,
  .num_list,
  .alphabet_list,
  .num_list_dot,
  .asterisk_list,
  .asterisk_list_number,
  .notes_list,
  .notes_list_number).pc_type_row {
    flex-wrap: wrap;
    -moz-column-gap: 8px;
         column-gap: 8px;
  }
}

:is(.num_list_dot) {
  gap: 5px;
}

:is(.num_list_paren, .num_list_dot) {
  list-style: none;
  padding-left: 0;
}

.num_list_paren {
  counter-reset: num;
}
.num_list_paren li {
  counter-increment: num;
  position: relative;
  padding-left: 2em;
}
.num_list_paren li::before {
  content: "(" counter(num) ")";
  position: absolute;
  left: 0;
}

.num_list_dot {
  list-style: none;
  counter-reset: num_dot;
}
.num_list_dot li {
  margin-bottom: 5px;
  counter-increment: num_dot;
  position: relative;
  padding-left: 2.2em;
}
.num_list_dot li::before {
  content: counter(num_dot) ".";
  position: absolute;
  left: 0;
}

.num_list {
  list-style-type: decimal;
}

.num_zero_list {
  list-style-type: decimal-leading-zero;
}

.alphabet_list {
  list-style-type: upper-alpha;
}

.fs10 {
  font-size: 10px;
}

.fs11 {
  font-size: 11px;
}

.fs12 {
  font-size: 12px;
}

.fs13 {
  font-size: 13px;
}

.fs14 {
  font-size: 14px;
}

.fs15 {
  font-size: 15px;
}

.fs16 {
  font-size: 16px;
}

.fs17 {
  font-size: 17px;
}

.fs18 {
  font-size: 18px;
}

.fs19 {
  font-size: 19px;
}

.fs20 {
  font-size: 20px;
}

.fs21 {
  font-size: 21px;
}

.fs22 {
  font-size: 22px;
}

.fs23 {
  font-size: 23px;
}

.fs24 {
  font-size: 24px;
}

.fs25 {
  font-size: 25px;
}

.fs26 {
  font-size: 26px;
}

.fs27 {
  font-size: 27px;
}

.fs28 {
  font-size: 28px;
}

.fs29 {
  font-size: 29px;
}

.fs30 {
  font-size: 30px;
}

.fw_bold {
  font-weight: bold;
}

.fw_normal {
  font-weight: normal;
}

.type_text_center,
.text_center {
  text-align: center;
}

.type_text_right,
.text_right {
  text-align: right;
}

.text_left,
.type_text_left {
  text-align: left;
}

@media screen and (min-width: 769px) {
  .pc_type_text_left,
  .pc_text_left {
    text-align: left;
  }
  .pc_type_text_center,
  .pc_text_center {
    text-align: center;
  }
  .pc_type_text_right,
  .pc_text_right {
    text-align: right;
  }
}
.text_left {
  text-align: left;
}

.underline {
  text-decoration: underline;
}

mark {
  color: #231815;
  background: linear-gradient(transparent 0%, #0B4848 0%);
  display: inline;
}
mark.white {
  background: linear-gradient(transparent 10%, #FFF 0%);
  display: inline;
}

.marker {
  background: linear-gradient(transparent 65%, #FFF946 0%);
  display: inline;
  font-weight: bold;
}
.marker.thick {
  background: linear-gradient(transparent 60%, #0B4848 0%);
  display: inline;
}
.marker.thin {
  background: linear-gradient(transparent 80%, #0B4848 0%);
  display: inline;
}
.marker.gradation {
  background: linear-gradient(transparent 0, #0B4848 60%);
}

sup {
  vertical-align: top;
}

.flex_box {
  display: flex;
}
.flex_box > .order_0 {
  order: 0;
}
.flex_box > .order_1 {
  order: 1;
}
.flex_box > .order_2 {
  order: 2;
}
.flex_box > .order_3 {
  order: 3;
}
.flex_box > .order_4 {
  order: 4;
}
.flex_box > .order_5 {
  order: 5;
}
.flex_box > .order_first {
  order: -1;
}
.flex_box > .order_last {
  order: 999;
}
.flex_box.flex_row {
  flex-direction: row;
}
.flex_box.flex_row_reverse {
  flex-direction: row-reverse;
}
.flex_box.flex_column {
  flex-direction: column;
}
.flex_box.flex_column_reverse {
  flex-direction: column-reverse;
}
.flex_box.flex_nowrap {
  flex-wrap: nowrap;
}
.flex_box.flex_wrap {
  flex-wrap: wrap;
}
.flex_box.flex_wrap_reverse {
  flex-wrap: wrap-reverse;
}
.flex_box.align_start {
  align-items: flex-start;
}
.flex_box.align_center {
  align-items: center;
}
.flex_box.align_end {
  align-items: flex-end;
}
.flex_box.justify_start {
  justify-content: flex-start;
}
.flex_box.justify_center {
  justify-content: center;
}
.flex_box.justify_end {
  justify-content: flex-end;
}
.flex_box.justify_between {
  justify-content: space-between;
}
.flex_box.justify_around {
  justify-content: space-around;
}
.flex_box.gap_sm {
  gap: 0.5rem;
}
.flex_box.gap_md {
  gap: 1rem;
}
.flex_box.gap_lg {
  gap: 2rem;
}
.flex_box.w_full {
  width: 100%;
}
.flex_box.w_auto {
  width: auto;
}
@media screen and (min-width: 769px) {
  .flex_box.pc_flex_row {
    flex-direction: row;
  }
  .flex_box.pc_flex_row_reverse {
    flex-direction: row-reverse;
  }
  .flex_box.pc_flex_column {
    flex-direction: column;
  }
  .flex_box.pc_flex_column_reverse {
    flex-direction: column-reverse;
  }
  .flex_box.pc_justify_start {
    justify-content: flex-start;
  }
  .flex_box.pc_justify_center {
    justify-content: center;
  }
  .flex_box.pc_justify_end {
    justify-content: flex-end;
  }
  .flex_box.pc_justify_between {
    justify-content: space-between;
  }
  .flex_box.pc_justify_around {
    justify-content: space-around;
  }
  .flex_box.pc_align_start {
    align-items: flex-start;
  }
  .flex_box.pc_align_center {
    align-items: center;
  }
  .flex_box.pc_align_end {
    align-items: flex-end;
  }
  .flex_box.pc_gap_sm {
    gap: 0.5rem;
  }
  .flex_box.pc_gap_md {
    gap: 1rem;
  }
  .flex_box.pc_gap_lg {
    gap: 2rem;
  }
  .flex_box.pc_w_full {
    width: 100%;
  }
  .flex_box.pc_w_auto {
    width: auto;
  }
  .flex_box > .pc_order_0 {
    order: 0;
  }
  .flex_box > .pc_order_1 {
    order: 1;
  }
  .flex_box > .pc_order_2 {
    order: 2;
  }
  .flex_box > .pc_order_3 {
    order: 3;
  }
  .flex_box > .pc_order_4 {
    order: 4;
  }
  .flex_box > .pc_order_5 {
    order: 5;
  }
  .flex_box > .pc_order_first {
    order: -1;
  }
  .flex_box > .pc_order_last {
    order: 999;
  }
}
.flex_box > .img_box {
  flex: 0 0 auto;
}
.flex_box > .img_box img {
  width: 100%;
}
.flex_box > .text_box {
  flex: 1 1 0;
  min-width: 0;
}

.footer {
  background-color: #006C6E;
  position: relative;
}
.footer a {
  text-decoration: none;
}

.footer_nav {
  background-color: #006C6E;
}
.footer_nav .outline {
  padding-top: 30px;
  padding-bottom: 30px;
}
.footer_nav nav {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px 10px;
}
@media screen and (min-width: 769px) {
  .footer_nav nav {
    flex-wrap: nowrap;
    justify-content: center;
  }
}
.footer_nav nav a {
  display: block;
  color: #FFF;
  width: 48%;
  text-align: center;
  font-size: 0.75rem;
  padding: 4px 0;
}
.footer_nav nav a:not(:last-child):nth-child(odd) {
  border-right: 1px solid #FFF;
}
@media screen and (min-width: 769px) {
  .footer_nav nav a {
    font-size: 0.875rem;
    padding: 0;
    width: 100%;
  }
  .footer_nav nav a:not(:last-child) {
    border-right: 1px solid #FFF;
  }
}

.footer_info {
  display: grid;
  place-items: center;
  place-content: center;
  gap: 8px;
  background-color: #006C6E;
  color: #FFF;
  min-height: 60px;
}

.footer_page_top {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 56px;
}

.page_top_box {
  max-width: 1340px;
  margin: auto;
  position: relative;
}

.page_top {
  position: fixed;
  right: 12px;
  bottom: 100px;
  width: 40px;
  z-index: 2;
  display: none;
  opacity: 0;
  transition: opacity 0.3s ease;
  filter: drop-shadow(0px 3px 6px rgba(0, 0, 0, 0.16));
}
.page_top.active {
  display: block;
  opacity: 1;
  transition: opacity 0.3s ease;
}
@media (hover: hover) {
  .page_top:hover::before {
    opacity: 0.8;
  }
}

.footer_common {
  padding: 30px 0;
}
.footer_common .outline {
  position: relative;
}
.footer_common .logo_box {
  display: flex;
  flex-direction: column;
  gap: 6px 8px;
  flex-wrap: nowrap;
  align-items: flex-start;
  white-space: nowrap;
}
@media screen and (min-width: 769px) {
  .footer_common .logo_box {
    flex-direction: row;
    align-items: center;
  }
}
.footer_common .logo_box .logo {
  max-width: 130px;
}
@media screen and (min-width: 769px) {
  .footer_common .logo_box .logo {
    max-width: 160px;
  }
}
.footer_common .logo_box .logo img {
  width: 100%;
}
.footer_common .logo_box .logo_text {
  font-size: 0.5rem;
}
@media screen and (min-width: 769px) {
  .footer_common .logo_box .logo_text {
    font-size: 0.625rem;
  }
}

.floating_cta_block {
  background-color: #e5f5fd;
  position: fixed;
  left: 0;
  bottom: 0;
  padding: 0;
  width: 100%;
  transform: translateY(100%);
  z-index: 1000;
}
@media screen and (min-width: 769px) {
  .floating_cta_block {
    display: none;
    padding: 10px;
  }
}
.floating_cta_block.active {
  animation: floatingMove 0.8s ease forwards;
}

.floating_cta_box {
  max-width: 1200px;
  margin: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 15px 5%;
  place-content: center;
  place-items: center;
}

.floating_cta_pc {
  display: none;
}
@media screen and (min-width: 769px) {
  .floating_cta_pc {
    display: flex;
    justify-content: center;
    align-items: center;
  }
}
.floating_cta_pc .btn_box {
  max-width: 320px;
  width: 100%;
}
.floating_cta_pc .btn_box a {
  max-width: 320px;
  min-width: 0;
  width: 100%;
  font-size: 1.125rem;
  font-size: clamp(0.8125rem, 1.3235294118vw, 1.125rem);
}

.floating_cta_sp {
  display: grid;
  gap: 0;
}
@media screen and (min-width: 769px) {
  .floating_cta_sp {
    display: none;
  }
}
.floating_cta_sp a {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: row;
  text-align: center;
  gap: 4px 8px;
  color: #FFF;
  text-decoration: none;
  font-weight: bold;
  font-size: 0.875rem;
  padding: 8px 0;
  min-height: 52px;
}
.floating_cta_sp a::after {
  display: block;
  content: "";
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  aspect-ratio: 1;
  width: 27px;
  order: -1;
}
.floating_cta_sp a.type_tel {
  background-color: #FF942B;
}
.floating_cta_sp a.type_tel::after {
  filter: brightness(0) invert(1);
  background-image: url(../img/common/icon_tel.svg);
}
.floating_cta_sp a.type_mail {
  background-color: #0B4848;
}
.floating_cta_sp a.type_mail::after {
  filter: brightness(0) invert(1);
  background-image: url(../img/common/icon_mail.svg);
}
.floating_cta_sp a .supp {
  font-size: 10px;
}

@keyframes floatingMove {
  0% {
    opacity: 0;
    transform: translateY(100%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.faq_list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.faq_list .notes_list li {
  font-size: 0.78em;
}
.faq_list a:not(.btn_default) {
  color: #0366d6;
}
.faq_list table {
  border: none;
}
.faq_list table th {
  text-align: left;
  white-space: nowrap;
}
.faq_list table td {
  padding: 2px 8px;
}

.faq_box {
  background: #FFF;
  border-radius: 6px;
  width: 100%;
  margin: auto;
  filter: drop-shadow(0px 3px 6px rgba(0, 0, 0, 0.16));
}
.faq_box:last-child {
  border-bottom: none;
}
.faq_box [data-accordion=btn] {
  display: flex;
  align-items: center;
  padding: 16px;
  min-height: 61px;
}
@media screen and (min-width: 769px) {
  .faq_box [data-accordion=btn] {
    padding: 36px;
    gap: 3%;
  }
}
.faq_box .faq_inner {
  width: 100%;
  margin: auto;
}
.faq_box .title,
.faq_box .text {
  display: flex;
  gap: 15px;
  position: relative;
  color: #231815;
}
.faq_box .text > div > * + * {
  margin-top: 10px;
}

.faq_title .title {
  align-items: center;
  font-weight: bold;
  letter-spacing: 0.1em;
  font-size: 0.9375rem;
}
@media screen and (min-width: 769px) {
  .faq_title .title {
    font-size: 1.5rem;
    font-size: clamp(1.125rem, 1.7647058824vw, 1.5rem);
  }
}

.faq_content .faq_inner {
  padding: 0 20px 20px;
}
@media screen and (min-width: 769px) {
  .faq_content .faq_inner {
    padding: 0 20px 30px calc(3% + 65px);
  }
}
.faq_content .text {
  align-items: baseline;
  font-size: 0.875rem;
}
@media screen and (min-width: 769px) {
  .faq_content .text {
    font-size: 1.25rem;
    font-size: clamp(1rem, 1.4705882353vw, 1.25rem);
  }
}

.color_primary {
  color: #FF942B;
}

.color_yellow {
  color: #FFF946;
}

.color_accent {
  color: #0B4848;
}

.sec_title_wrap {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #0B4848;
  gap: 8px;
}
.sec_title_wrap :is(.title, .title02, .title03, .title04, .title05) {
  text-align: center;
  line-height: 1.5;
  font-weight: bold;
  letter-spacing: 0.075em;
}
.sec_title_wrap :is(.title, .title02, .title03, .title04, .title05) .sub_title {
  display: block;
  font-weight: 500;
  order: -1;
  font-size: 1.125rem;
}
@media screen and (min-width: 769px) {
  .sec_title_wrap :is(.title, .title02, .title03, .title04, .title05) .sub_title {
    font-size: 1.75rem;
  }
}
.sec_title_wrap > .sub_title {
  order: -1;
}
.sec_title_wrap .title {
  font-size: 1.5rem;
}
@media screen and (min-width: 769px) {
  .sec_title_wrap .title {
    font-size: 3rem;
  }
}
.sec_title_wrap .title + .sub_title {
  font-size: 1.125rem;
}
@media screen and (min-width: 769px) {
  .sec_title_wrap .title + .sub_title {
    font-size: 1.75rem;
  }
}
.sec_title_wrap .title02 {
  font-size: 1.625rem;
}
@media screen and (min-width: 769px) {
  .sec_title_wrap .title02 {
    font-size: 2.5rem;
  }
}
.sec_title_wrap .title03 {
  font-size: 1.5rem;
}
@media screen and (min-width: 769px) {
  .sec_title_wrap .title03 {
    font-size: 1.625rem;
  }
}
.sec_title_wrap.type_bottom_border :is(.title, .title02, .title03, .title04, .title05) {
  position: relative;
  padding-bottom: 16px;
}
.sec_title_wrap.type_bottom_border :is(.title, .title02, .title03, .title04, .title05)::after {
  content: "";
  width: 61px;
  height: 2px;
  background-color: #0B4848;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
.sec_title_wrap.type_white {
  color: #FFF;
}
.sec_title_wrap.type_white :is(.title, .title02, .title03, .title04, .title05)::after {
  background-color: #FFF;
}
.sec_title_wrap .lead_text {
  margin-top: 24px;
  text-align: center;
  font-size: 1rem;
}

[data-js=accordion] [data-traget] {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.4s ease;
}

[data-accordion=btn] {
  display: flex;
  gap: 16px;
  position: relative;
  cursor: pointer;
}
[data-accordion=btn] .icon {
  width: 24px;
  position: relative;
}
@media screen and (min-width: 769px) {
  [data-accordion=btn] .icon {
    width: 32px;
  }
}
[data-accordion=btn] .icon::before, [data-accordion=btn] .icon::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 4px;
  background-color: #0B4848;
  border-radius: 2px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
[data-accordion=btn] .icon::after {
  transition: all 0.3s ease;
  transform: translate(-50%, -50%) rotate(90deg);
}
[data-accordion=btn].active .icon::after {
  background-color: #52bd95;
  transform: translate(-50%, -50%);
}

.cta_section {
  display: grid;
  grid-template-columns: 100%;
  place-items: center;
  background-color: #006C6E;
}
@media screen and (min-width: 1001px) {
  .cta_section {
    grid-template-columns: 48vw auto;
  }
}
.cta_section .cta_content {
  display: grid;
  place-content: center;
  align-items: center;
  padding: 30px 10px;
  color: #FFF;
}
@media screen and (min-width: 1001px) {
  .cta_section .cta_content {
    min-height: 360px;
  }
}
.cta_section .cta_img {
  height: 100%;
}
.cta_section .cta_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.cta_section .title {
  text-align: center;
  margin-bottom: 24px;
  color: #FFF;
  font-weight: bold;
  font-size: 1.125rem;
}
@media screen and (min-width: 769px) {
  .cta_section .title {
    font-size: 2.125rem;
    font-size: clamp(0.8125rem, 2.5vw, 2.125rem);
  }
}

.form_tel_box {
  background-color: #F4F7F9;
  border-radius: 12px;
  padding: 30px 16px;
  max-width: 600px;
  margin-inline: auto;
}
.form_tel_box .title {
  text-align: center;
  color: #0B4848;
  font-weight: bold;
  margin-bottom: 8px;
  font-size: 1.125rem;
}
@media screen and (min-width: 769px) {
  .form_tel_box .title {
    font-size: 1.25rem;
  }
}
.form_tel_box .tel_box {
  color: #0B4848;
}
.form_tel_box .tel_box .tel {
  color: inherit;
}
.form_tel_box .tel_box .tel::before {
  filter: none;
}