@charset "UTF-8";
:root {
  --color-blue: #0066b3;
  --color-gray-1: #ccc;
  --color-gray-2: #f2f2f2;
  --color-orange: #ef7f20;
  --color-black: #1e1e1e;
  --color-darkgray: #444;
}

/* reset
/* ============================================ */
:where(.acrw-reset) button,
:where(.acrw-reset) input,
:where(.acrw-reset) optgroup,
:where(.acrw-reset) select,
:where(.acrw-reset) textarea {
  padding: 0;
  margin: 0;
  font: inherit;
  vertical-align: middle;
  color: inherit;
  text-align: inherit;
  text-transform: inherit; /* 2 */ /* 1 */
  appearance: none;
  outline: none;
  background: transparent;
  border: none;
  border-radius: 0;
}

/**
 * Correct cursors for clickable elements.
 */
:where(.acrw-reset) button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
}

:where(.acrw-reset) button:disabled,
[type=button]:disabled,
[type=reset]:disabled,
[type=submit]:disabled {
  cursor: default;
}

/**
 * Improve outlines for Firefox and unify style with input elements & buttons.
 */
:where(.acrw-reset) :-moz-focusring {
  outline: auto;
}

:where(.acrw-reset) select:disabled {
  opacity: inherit;
}

/**
 * Remove padding
 */
:where(.acrw-reset) option {
  padding: 0;
}

/**
 * Reset to invisible
 */
:where(.acrw-reset) fieldset {
  min-width: 0;
  padding: 0;
  margin: 0;
}

:where(.acrw-reset) legend {
  padding: 0;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
:where(.acrw-reset) progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
:where(.acrw-reset) textarea {
  overflow: auto;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
:where(.acrw-reset) [type=number]::-webkit-inner-spin-button,
:where(.acrw-reset) [type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * Correct the outline style in Safari.
 */
:where(.acrw-reset) [type=search] {
  outline-offset: -2px; /* 1 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
:where(.acrw-reset) [type=search]::-webkit-search-decoration {
  appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Fix font inheritance.
 */
:where(.acrw-reset) ::-webkit-file-upload-button {
  font: inherit; /* 2 */
  appearance: auto; /* 1 */
}

/**
 * Fix appearance for Firefox
 */
:where(.acrw-reset) [type=number] {
  appearance: textfield;
}

/**
 * Clickable labels
 */
label[for] {
  cursor: pointer;
}

/* base
/* ============================================ */
html {
  scroll-padding-top: 132px;
  scroll-behavior: smooth;
}

@media only screen and (width <= 768px) {
  html {
    scroll-padding-top: 19.2vw;
  }
}
@media only screen and (width > 768px) {
  #arc #contentInner > .inner {
    padding: 60px 0;
  }
}
@media only screen and (width <= 768px) {
  #arc #contentInner > .inner {
    padding-inline: 5vw;
  }
}
@media only screen and (width <= 768px) {
  #arc #contentInner p {
    font-size: 14px;
  }
}
@media only screen and (width <= 768px) {
  #arc #contentInner ul.btn_list_nowrapwh a {
    padding: 0.8em 2em 0.8em 2.4em;
    font-size: 14px;
    border-width: 1px;
  }
  #arc #contentInner ul.btn_list_nowrapwh li {
    position: relative;
  }
  #arc #contentInner ul.btn_list_nowrapwh a::after {
    position: absolute;
    top: 50%;
    left: 8%;
    display: block;
    width: 8px;
    height: 8px;
    content: "";
    border-right: 2px solid var(--color-blue);
    border-bottom: 2px solid var(--color-blue);
    rotate: 45deg;
    translate: 0 -60%;
  }
}
/* item
---------- */
#arc :has(> .arcw-p-item) {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
}

#arc .arcw-p-item {
  position: relative;
  box-sizing: border-box;
  display: grid;
  grid-template-columns: 1fr 180px;
  width: 100%;
  padding: 35px 35px 50px;
  border: 2px solid var(--color-gray-1);
  border-top: none;
}

#arc .arcw-p-item::before {
  position: absolute;
  inset: 0 -2px auto;
  display: block;
  height: 5px;
  content: "";
  background: var(--color-blue);
}

#arc .arcw-p-item_title {
  margin-bottom: 1em;
  font-size: 22px;
  line-height: 160%;
  color: var(--color-blue);
}

#arc .arcw-p-item_tag {
  display: flex;
  flex-flow: row wrap;
  gap: 10px;
  align-items: center;
  margin: 0 0 10px;
  font-size: 14px;
  line-height: 160%;
  color: var(--color-blue);
}

#arc .arcw-p-item_tag > li {
  padding: 0 15px;
  border: 1px solid var(--color-blue);
}

#arc .arcw-p-item_entry {
  width: 160px;
  margin: 0 0 0 auto;
}

#arc .arcw-p-item_entry a {
  box-sizing: border-box;
  padding: 12px 0;
  font-size: 16px;
}

#arc .arcw-p-item_detail {
  box-sizing: border-box;
  display: grid;
  grid-template-columns: 140px 1fr;
  grid-column: 1/3;
  border: 1px solid var(--color-gray-1);
}

#arc .arcw-p-item_detail > dt {
  padding: 10px 15px;
  font-size: 16px;
  font-weight: bold;
  background: var(--color-gray-2);
  border-right: 1px solid var(--color-gray-1);
  border-bottom: 1px solid var(--color-gray-1);
}

#arc .arcw-p-item_detail > dd {
  padding: 10px 25px;
  border-bottom: 1px solid var(--color-gray-1);
}

#arc .arcw-p-item_detail > dt:last-of-type,
#arc .arcw-p-item_detail > dd:last-of-type {
  border-bottom: none;
}

@media only screen and (width <= 768px) {
  #arc .arcw-p-item {
    display: flex;
    flex-flow: row wrap;
    align-items: start;
    justify-content: center;
    padding: 6.6666666667% 0 10%;
    border-width: 1px;
  }
  #arc .arcw-p-item::before {
    inset: 0 -1px auto;
    height: 3px;
  }
  #arc .arcw-p-item_header {
    width: 100%;
    padding-inline: 5%;
  }
  #arc .arcw-p-item_title {
    margin-bottom: 1em;
    font-size: 18px;
  }
  #arc .arcw-p-item_tag {
    gap: 10px;
    margin: 0 0 10px;
    font-size: 14px;
  }
  #arc .arcw-p-item_tag > li {
    padding: 0 12px;
    font-size: 14px;
  }
  #arc .arcw-p-item_entry {
    order: 3;
    width: 200px;
    margin: 10% auto 0;
  }
  #arc .arcw-p-item_entry a {
    box-sizing: border-box;
    padding: 12px 0;
  }
  #arc .arcw-p-item_detail {
    display: block;
    border: 1px solid var(--color-gray-1);
    border-right: none;
    border-left: none;
  }
  #arc .arcw-p-item_detail > dt {
    padding: 3% 6%;
    font-weight: bold;
    border-right: none;
    border-bottom: 1px solid var(--color-gray-1);
  }
  #arc .arcw-p-item_detail > dd {
    padding: 3% 6%;
    border-bottom: 1px solid var(--color-gray-1);
  }
  #arc .arcw-p-item_detail > dt:last-of-type,
  #arc .arcw-p-item_detail > dd:last-of-type {
    border-bottom: none;
  }
}
/* filter
---------- */
#arc .arcw-p-filter_container-items {
  padding: 35px 10.5363984674%;
  border: 2px solid var(--color-gray-1);
}

@media only screen and (width <= 768px) {
  #arc .arcw-p-filter_container-items {
    padding: 6.6666666667% 0 10%;
  }
}
#arc .arcw-p-filter_row {
  display: grid;
  grid-template-columns: 17.5609756098% 1fr;
  gap: 15px;
}

#arc .arcw-p-filter_row:not(:first-of-type) {
  padding-top: 20px;
  margin-top: 20px;
  border-top: 1px solid var(--color-gray-1);
}

@media only screen and (width <= 768px) {
  #arc .arcw-p-filter_row {
    display: grid;
    grid-template-columns: 1fr;
    padding: 15px;
  }
}
#arc .arcw-p-filter_label {
  position: relative;
  font-size: 16px;
  font-weight: bold;
}

#arc .arcw-p-filter_label::after {
  position: absolute;
  top: 0;
  right: 0;
  content: "：";
}

@media only screen and (width <= 768px) {
  #arc .arcw-p-filter_label::after {
    position: relative;
    right: auto;
  }
}
#arc .arcw-p-filter_items {
  display: flex;
  flex-flow: row wrap;
  gap: 1em 2em;
}

@media only screen and (width <= 768px) {
  #arc .arcw-p-filter_items {
    gap: 1em 1.5em;
  }
}
#arc .arcw-p-filter_item {
  font-size: 16px;
}

#arc .arcw-p-filter_actions {
  margin: 20px 0 0;
}

#arc .arcw-p-filter .arcw-p-filter_submit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 160px;
  height: 50px;
  margin: 0 auto;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  background: var(--color-blue);
}

/* result
---------- */
#arc .arcw-p-filter_result {
  width: fit-content;
  margin: 30px auto 40px;
  font-size: 16px;
  line-height: 160%;
  text-align: center;
  border-bottom: 2px solid var(--color-orange);
}

#arc .arcw-p-filter_result .total {
  padding-right: 0.2em;
  font-size: 18px;
  font-weight: bold;
  color: var(--color-orange);
}

/* none */
#arc .acrw-p-filter_none {
  height: 50px;
}

/* pagination
---------- */
#arc .arcw-p-pagination {
  margin: 20px 0;
}

#arc .arcw-p-pagination:has(> .arcw-p-pagination-info) {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

@media only screen and (width <= 768px) {
  #arc .arcw-p-pagination:has(> .arcw-p-pagination-info) {
    display: block;
  }
}
/* info
---------- */
#arc .arcw-p-pagination-info {
  font-size: 16px;
  line-height: 160%;
  text-align: left;
}

#arc .arcw-p-pagination-info .total {
  padding-right: 0.2em;
  font-size: 18px;
  font-weight: bold;
  color: var(--color-orange);
}

@media only screen and (width <= 768px) {
  #arc .arcw-p-pagination-info {
    margin: 0 0 10px;
    text-align: center;
  }
}
/* numeric
---------- */
#arc .arcw-p-pagination-numeric ul {
  position: relative;
  display: flex;
  justify-content: end;
  padding: 0 45px;
  margin: 0;
}

#arc .arcw-p-pagination-numeric li {
  margin: 0 1px;
}

#arc .arcw-p-pagination-numeric li > a,
#arc .arcw-p-pagination-numeric li > span {
  position: relative;
  box-sizing: border-box;
  display: block;
  width: 30px;
  height: 30px;
  font-size: 16px;
  color: #0066b3;
}

#arc .arcw-p-pagination-numeric li > a:not(.next, .prev),
#arc .arcw-p-pagination-numeric li > span {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #e0e0e0;
}

#arc .arcw-p-pagination-numeric li > span.dots {
  border: none;
}

#arc .arcw-p-pagination-numeric li > span.current {
  color: #fff;
  text-decoration: none;
  background: #0066b3;
  border: 1px solid #0066b3;
}

@media (any-hover: hover) {
  #arc .arcw-p-pagination-numeric li > a:not(.next, .prev):hover {
    color: #fff;
    text-decoration: none;
    background: #0066b3;
    border: 1px solid #0066b3;
  }
}
#arc .arcw-p-pagination-numeric li:has(.next),
#arc .arcw-p-pagination-numeric li:has(.prev) {
  position: absolute;
  margin: 0;
}

#arc .arcw-p-pagination-numeric li:has(.prev) {
  position: absolute;
  left: 0;
}

#arc .arcw-p-pagination-numeric li:has(.next) {
  right: 0;
}

#arc .arcw-p-pagination-numeric li > a.next::before,
#arc .arcw-p-pagination-numeric li > a.prev::before {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 5px;
  height: 5px;
  margin-top: -3px;
  content: "";
  border-top: 2px solid #0066b3;
  border-right: 2px solid #0066b3;
}

#arc .arcw-p-pagination-numeric li > a.prev::before {
  margin-left: -2px;
  transform: rotate(-135deg);
}

#arc .arcw-p-pagination-numeric li > a.next::before {
  margin-left: -4px;
  transform: rotate(45deg);
}

@media (any-hover: hover) {
  #arc .arcw-p-pagination-numeric li > a.next:hover,
  #arc .arcw-p-pagination-numeric li > a.prev:hover {
    opacity: 0.6;
  }
}
@media only screen and (width <= 768px) {
  #arc .arcw-p-pagination-numeric ul {
    justify-content: center;
    padding: 0 7.6vw;
  }
  #arc .arcw-p-pagination-numeric li > a,
  #arc .arcw-p-pagination-numeric li > span {
    width: 7.6vw;
    height: 7.6vw;
    font-size: 3.6vw;
  }
  #arc .arcw-p-pagination-numeric li > a.next::before,
  #arc .arcw-p-pagination-numeric li > a.prev::before {
    width: 1.5vw;
    height: 1.5vw;
    margin-top: -0.9vw;
  }
  #arc .arcw-p-pagination-numeric li > a.prev::before {
    margin-left: -0.4vw;
  }
  #arc .arcw-p-pagination-numeric li > a.next::before {
    margin-left: -1.3vw;
  }
  #arc .arcw-p-pagination-numeric li {
    margin: 0 3vw;
  }
}
@media only screen and (width <= 768px) {
  #arc .arcw-p-form p {
    margin: 0;
  }
}
/* form
---------- */
#arc .arcw-p-form input[type=text],
#arc .arcw-p-form input[type=email],
#arc .arcw-p-form textarea {
  box-sizing: border-box;
  width: 100%;
  padding: 10px 15px;
  font-size: 16px;
  font-weight: normal;
  line-height: 22px;
  background-color: #f5f8fa;
  border: 1px solid #cbd6e2;
  border-radius: 3px;
}

#arc .arcw-p-form select {
  box-sizing: border-box;
  padding: 10px 15px;
  font-size: 16px;
  font-weight: normal;
  line-height: 22px;
  background-color: #f5f8fa;
  border: 1px solid #cbd6e2;
  border-radius: 3px;
}

#arc .arcw-p-form input[type=file] {
  box-sizing: border-box;
  padding: 10px 15px;
  font-size: 16px;
  font-weight: normal;
  line-height: 22px;
  background-color: #f5f8fa;
  border: 1px solid #cbd6e2;
  border-radius: 3px;
}

#arc .arcw-p-form button,
#arc .arcw-p-form input[type=submit],
#arc .arcw-p-form input[type=button],
#arc .arcw-p-form .form_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 160px;
  height: 50px;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  text-decoration: none;
  background: var(--color-blue);
}

#arc .arcw-p-form button.is-disabled {
  opacity: 0.5;
}

/* label
---------- */
#arc .arcw-p-form .form_label {
  display: inline-block;
  margin-bottom: 5px !important;
  font-size: 13px;
  color: #33475b;
}

#arc .arcw-p-form .form_required {
  color: red;
}

/* error
---------- */
#arc .arcw-p-form .wpcf7-not-valid-tip,
#arc .arcw-p-form .form_error {
  display: block;
  font-size: 13px;
  font-weight: normal;
  color: #dc3232;
}

/* layout
---------- */
#arc .arcw-p-form .form_row {
  margin-bottom: 15px;
}

/* name */
#arc .arcw-p-form .form_row-name {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
}

@media only screen and (width <= 768px) {
  #arc .arcw-p-form .form_row-name {
    gap: 15px;
  }
}
/* birth */
/* memo */
/* file */
#arc .arcw-p-form .form_row-file > div:has(input[type=file]) {
  position: relative;
  display: flex;
}

#arc .arcw-p-form .form_row-file > div:has(input[type=file]) .form_row_note {
  padding: 11px 3px 0;
}

@media only screen and (width <= 768px) {
  #arc .arcw-p-form .form_row-file > div:has(input[type=file]) {
    display: block;
  }
  #arc .arcw-p-form .form_row-file > div:has(input[type=file]) .form_row_note {
    padding: 0;
  }
  #arc .arcw-p-form .form_row-file p:has(+ .form_row_note) {
    margin-bottom: 0 !important;
  }
}
/* legal_check */
#arc .arcw-p-form .form_legal_check {
  position: relative;
}

#arc .arcw-p-form .form_legal_check .wpcf7-checkbox {
  position: relative;
  box-sizing: border-box;
  display: block;
  width: 100%;
  padding: 10px 15px;
  font-size: 16px;
  font-weight: normal;
  line-height: 22px;
  background-color: #f5f8fa;
  border: 1px solid #cbd6e2;
  border-radius: 3px;
}

#arc .arcw-p-form .form_legal_check .wpcf7-list-item::after {
  color: red;
  content: "*";
}

#arc .arcw-p-form .form_legal_check .wpcf7-list-item {
  margin: 0;
}

/* text,regal
---------- */
#arc .arcw-p-form .form_text {
  margin: 50px 0 0;
  font-weight: bold;
}

#arc .arcw-p-form .form_legal {
  margin: 50px 0 0;
}

/* submit
---------- */
#arc .arcw-p-form .form_submit {
  display: flex;
  gap: 30px;
  justify-content: center;
  margin: 50px 0 0;
}

@media only screen and (width <= 768px) {
  #arc .arcw-p-form .form_submit {
    gap: 15px;
  }
}
#arc :has(> .form_btn) {
  display: flex;
  gap: 30px;
  justify-content: center;
}

@media only screen and (width <= 768px) {
  #arc :has(> .form_btn) {
    gap: 15px;
  }
}
/* hidden
---------- */
#arc .arcw-p-form :has(> input[type=hidden]:nth-of-type(5)) {
  height: 0;
}

#arc .wpcf7-response-output {
  display: none;
}

/* confirm
---------- */
#arc .wpcf7 form.is-confirm .form_stepContainer-edit {
  display: none;
}

#arc .wpcf7 form.is-confirm .form_stepContainer-confirm {
  display: block;
}

/* page top
---------- */
#arc .arcw-top_section-descriptions_container {
  margin: 20px 0 0;
}
